forked from noxious/server
Added logics for saving zone updates
This commit is contained in:
@ -9,13 +9,13 @@ interface IZoneLoad {
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle character zone request event
|
||||
* Handle game master zone request event
|
||||
* @param socket
|
||||
* @param io
|
||||
*/
|
||||
export default function (socket: TSocket, io: Server) {
|
||||
socket.on('gm:zone_editor:zone:request', async (data: IZoneLoad) => {
|
||||
console.log(`---GM ${socket.character?.id} has requested zone in zone editor.`);
|
||||
console.log(`---GM ${socket.character?.id} has requested zone via zone editor.`);
|
||||
|
||||
if (!data.zoneId) {
|
||||
console.log(`---Zone id not provided.`);
|
||||
@ -29,11 +29,7 @@ export default function (socket: TSocket, io: Server) {
|
||||
return;
|
||||
}
|
||||
|
||||
socket.join(zone.id.toString());
|
||||
|
||||
// send over zone and characters to socket
|
||||
socket.emit('gm:zone_editor:zone:load', {
|
||||
zone: zone
|
||||
});
|
||||
// send over zone to game master
|
||||
socket.emit('gm:zone_editor:zone:load', zone);
|
||||
});
|
||||
}
|
49
src/app/events/GmZoneEditorZoneSave.ts
Normal file
49
src/app/events/GmZoneEditorZoneSave.ts
Normal file
@ -0,0 +1,49 @@
|
||||
import { Server } from "socket.io";
|
||||
import {TSocket} from "../utilities/Types";
|
||||
import ZoneRepository from "../repositories/ZoneRepository";
|
||||
import ZoneManager from "../ZoneManager";
|
||||
import {Character, Zone} from "@prisma/client";
|
||||
|
||||
interface IZoneLoad {
|
||||
zoneId: number;
|
||||
name: string;
|
||||
width: number;
|
||||
height: number;
|
||||
tiles: number[][];
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle game master zone save event
|
||||
* @param socket
|
||||
* @param io
|
||||
*/
|
||||
export default function (socket: TSocket, io: Server) {
|
||||
socket.on('gm:zone_editor:zone:save', async (data: IZoneLoad) => {
|
||||
console.log(`---GM ${socket.character?.id} has saved zone via zone editor.`);
|
||||
|
||||
if (!data.zoneId) {
|
||||
console.log(`---Zone id not provided.`);
|
||||
return;
|
||||
}
|
||||
|
||||
let zone = await ZoneRepository.getById(data.zoneId);
|
||||
|
||||
if (!zone) {
|
||||
console.log(`---Zone not found.`);
|
||||
return;
|
||||
}
|
||||
|
||||
await ZoneRepository.update(
|
||||
data.zoneId,
|
||||
data.name,
|
||||
data.width,
|
||||
data.height,
|
||||
data.tiles
|
||||
);
|
||||
|
||||
zone = await ZoneRepository.getById(data.zoneId);
|
||||
|
||||
// send over zone and characters to socket
|
||||
socket.emit('gm:zone_editor:zone:load', zone);
|
||||
});
|
||||
}
|
Reference in New Issue
Block a user