forked from noxious/server
zone editor stuff
This commit is contained in:
parent
ea10ef5230
commit
aef82affc5
@ -57,15 +57,13 @@ class ZoneManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public removeCharacterFromZone(zoneId: number, characterId: number) {
|
public removeCharacterFromZone(zoneId: number, character: Character) {
|
||||||
const loadedZone = this.loadedZones.find((loadedZone) => {
|
const loadedZone = this.loadedZones.find((loadedZone) => {
|
||||||
console.log('Checking zone', loadedZone.zone.id, zoneId);
|
|
||||||
return loadedZone.zone.id === zoneId;
|
return loadedZone.zone.id === zoneId;
|
||||||
});
|
});
|
||||||
if (loadedZone) {
|
if (loadedZone) {
|
||||||
console.log('Removing character from zone', characterId);
|
loadedZone.characters = loadedZone.characters.filter((loadedCharacter) => {
|
||||||
loadedZone.characters = loadedZone.characters.filter((character) => {
|
return loadedCharacter.id !== character.id;
|
||||||
return character.id !== characterId;
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
48
src/app/events/CharacterZoneLeave.ts
Normal file
48
src/app/events/CharacterZoneLeave.ts
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
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";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle character zone leave event
|
||||||
|
* @param socket
|
||||||
|
* @param io
|
||||||
|
*/
|
||||||
|
export default function (socket: TSocket, io: Server) {
|
||||||
|
socket.on('character:zone:leave', async () => {
|
||||||
|
console.log(`---Socket ${socket.character?.id} has leaved zone.`);
|
||||||
|
|
||||||
|
if (!socket.character) {
|
||||||
|
console.log('Socket leaved zone but had no character set');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!socket.character.zoneId) {
|
||||||
|
console.log(`---Zone id not provided.`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const zone = await ZoneRepository.getById(socket.character.zoneId);
|
||||||
|
|
||||||
|
if (!zone) {
|
||||||
|
console.log(`---Zone not found.`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
socket.leave(zone.id.toString());
|
||||||
|
|
||||||
|
socket.emit('character:zone:unload');
|
||||||
|
|
||||||
|
// let other clients know of new character
|
||||||
|
io.to(zone.id.toString()).emit('zone:character:leave', socket.character);
|
||||||
|
|
||||||
|
// add character to zone manager
|
||||||
|
ZoneManager.removeCharacterFromZone(zone.id, socket.character as Character);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resources:
|
||||||
|
* https://stackoverflow.com/questions/6873607/socket-io-rooms-difference-between-broadcast-to-and-sockets-in
|
||||||
|
*/
|
@ -9,14 +9,12 @@ interface IZoneLoad {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @TODO: Implement zone loading, check if zone id is given or else load current character zone
|
* Handle character zone request event
|
||||||
*
|
|
||||||
* Handle character zone load event
|
|
||||||
* @param socket
|
* @param socket
|
||||||
* @param io
|
* @param io
|
||||||
*/
|
*/
|
||||||
export default function (socket: TSocket, io: Server) {
|
export default function (socket: TSocket, io: Server) {
|
||||||
socket.on('character:zone:load', async (data: IZoneLoad) => {
|
socket.on('character:zone:request', async (data: IZoneLoad) => {
|
||||||
console.log(`---User ${socket.character?.id} has requested zone.`);
|
console.log(`---User ${socket.character?.id} has requested zone.`);
|
||||||
|
|
||||||
if (!data.zoneId) {
|
if (!data.zoneId) {
|
@ -4,15 +4,20 @@ import ZoneManager from "../ZoneManager";
|
|||||||
|
|
||||||
export default function (socket: TSocket, io: Server) {
|
export default function (socket: TSocket, io: Server) {
|
||||||
socket.on('disconnect', (data: any) => {
|
socket.on('disconnect', (data: any) => {
|
||||||
|
if (!socket.user) {
|
||||||
|
console.log('User disconnected but had no user set');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
io.emit('user:disconnect', socket.user.id);
|
||||||
|
|
||||||
if (!socket.character) {
|
if (!socket.character) {
|
||||||
console.log('User disconnected but had no character set');
|
console.log('User disconnected but had no character set');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ZoneManager.removeCharacterFromZone(socket.character.zoneId, socket.character.id);
|
ZoneManager.removeCharacterFromZone(socket.character.zoneId, socket.character);
|
||||||
|
|
||||||
io.emit('user:disconnect', socket.character);
|
io.emit('character:disconnect', socket.character.id);
|
||||||
});
|
});
|
||||||
}
|
}
|
39
src/app/events/GmZoneEditorZoneRequest.ts
Normal file
39
src/app/events/GmZoneEditorZoneRequest.ts
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle character 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.`);
|
||||||
|
|
||||||
|
if (!data.zoneId) {
|
||||||
|
console.log(`---Zone id not provided.`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const zone = await ZoneRepository.getById(data.zoneId);
|
||||||
|
|
||||||
|
if (!zone) {
|
||||||
|
console.log(`---Zone not found.`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
socket.join(zone.id.toString());
|
||||||
|
|
||||||
|
// send over zone and characters to socket
|
||||||
|
socket.emit('gm:zone_editor:zone:load', {
|
||||||
|
zone: zone
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user