forked from noxious/server
Fixed char move
This commit is contained in:
parent
839fec1c06
commit
293b2be919
@ -3,6 +3,7 @@ import { TSocket } from '../../utilities/types'
|
||||
import ZoneRepository from '../../repositories/zoneRepository'
|
||||
import ZoneManager from '../../managers/zoneManager'
|
||||
import { Character, Zone } from '@prisma/client'
|
||||
import CharacterManager from '../../managers/characterManager'
|
||||
|
||||
/**
|
||||
* Handle character zone leave event
|
||||
@ -11,22 +12,17 @@ import { Character, Zone } from '@prisma/client'
|
||||
*/
|
||||
export default function (socket: TSocket, io: Server) {
|
||||
socket.on('zone:character: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
|
||||
}
|
||||
|
||||
@ -36,7 +32,7 @@ export default function (socket: TSocket, io: Server) {
|
||||
io.to(zone.id.toString()).emit('zone:character:leave', socket.character)
|
||||
|
||||
// add character to zone manager
|
||||
ZoneManager.removeCharacterFromZone(zone.id, socket.character as Character)
|
||||
CharacterManager.removeCharacter(socket.character)
|
||||
})
|
||||
}
|
||||
|
||||
|
@ -1,10 +1,10 @@
|
||||
import { Character, Zone } from '@prisma/client'
|
||||
import ZoneCharacter from './zoneCharacter'
|
||||
import { Zone } from '@prisma/client'
|
||||
import zoneRepository from '../../repositories/zoneRepository'
|
||||
import characterManager from '../../managers/characterManager'
|
||||
import { ExtendedCharacter } from '../../utilities/types'
|
||||
|
||||
class LoadedZone {
|
||||
private readonly zone: Zone
|
||||
private characters: ZoneCharacter[] = []
|
||||
// private readonly npcs: ZoneNPC[] = []
|
||||
private readonly grid: number[][] = []
|
||||
|
||||
@ -16,17 +16,8 @@ class LoadedZone {
|
||||
return this.zone
|
||||
}
|
||||
|
||||
public getCharacters(): ZoneCharacter[] {
|
||||
return this.characters
|
||||
}
|
||||
|
||||
public addCharacter(character: Character): void {
|
||||
const zoneCharacter = new ZoneCharacter(character)
|
||||
this.characters.push(zoneCharacter)
|
||||
}
|
||||
|
||||
public removeCharacter(character: Character): void {
|
||||
this.characters = this.characters.filter((zoneCharacter) => zoneCharacter.getCharacter().id !== character.id)
|
||||
public getCharacters(): ExtendedCharacter[] {
|
||||
return characterManager.getCharactersInZone(this.zone);
|
||||
}
|
||||
|
||||
public async getGrid(): Promise<number[][]> {
|
||||
|
@ -1,14 +0,0 @@
|
||||
import { Character } from '@prisma/client'
|
||||
|
||||
export default class ZoneCharacter {
|
||||
private readonly character: Character
|
||||
private isMoving: boolean = false
|
||||
|
||||
constructor(character: Character) {
|
||||
this.character = character
|
||||
}
|
||||
|
||||
public getCharacter(): Character {
|
||||
return this.character
|
||||
}
|
||||
}
|
@ -26,7 +26,7 @@ export class CharacterMoveService {
|
||||
}
|
||||
|
||||
public async calculatePath(character: ExtendedCharacter, targetX: number, targetY: number): Promise<Array<{ x: number; y: number }> | null> {
|
||||
const grid = await ZoneManager.getGrid(character.zoneId)
|
||||
const grid = await ZoneManager.getZoneById(character.zoneId)?.getGrid()
|
||||
if (!grid?.length) {
|
||||
logger.error('character:move error', 'Grid not found or empty')
|
||||
return null
|
||||
|
@ -4,6 +4,7 @@ import ZoneRepository from '../repositories/zoneRepository'
|
||||
import ZoneManager from '../managers/zoneManager'
|
||||
import { Character, ZoneEventTile, ZoneEventTileTeleport } from '@prisma/client'
|
||||
import { Server } from 'socket.io'
|
||||
import CharacterManager from '../managers/characterManager'
|
||||
|
||||
export class ZoneEventTileService {
|
||||
public async handleTeleport(io: Server, socket: TSocket, character: ExtendedCharacter, teleport: ZoneEventTileTeleport): Promise<void> {
|
||||
@ -12,6 +13,8 @@ export class ZoneEventTileService {
|
||||
const zone = await ZoneRepository.getById(teleport.toZoneId)
|
||||
if (!zone) return
|
||||
|
||||
// CharacterManager.moveCharacterBetweenZones(character, zone)
|
||||
|
||||
const oldZoneId = character.zoneId
|
||||
const newZoneId = teleport.toZoneId
|
||||
|
||||
@ -30,9 +33,6 @@ export class ZoneEventTileService {
|
||||
character.positionX = teleport.toPositionX
|
||||
character.positionY = teleport.toPositionY
|
||||
|
||||
// Atomic operation in ZoneManager
|
||||
await ZoneManager.moveCharacterBetweenZones(oldZoneId, newZoneId, character as Character)
|
||||
|
||||
// Emit events
|
||||
io.to(oldZoneId.toString()).emit('zone:character:leave', character.id)
|
||||
io.to(newZoneId.toString()).emit('zone:character:join', character)
|
||||
@ -44,7 +44,7 @@ export class ZoneEventTileService {
|
||||
// Send teleport information to the client
|
||||
socket.emit('zone:teleport', {
|
||||
zone,
|
||||
characters: ZoneManager.getCharactersInZone(zone.id)
|
||||
characters: CharacterManager.getCharactersInZone(zone)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user