forked from noxious/server
Continues asset loading
This commit is contained in:
@ -1,9 +1,11 @@
|
||||
import { Zone } from '@prisma/client'
|
||||
import { Zone, ZoneEventTileTeleport, ZoneEventTileType } from '@prisma/client'
|
||||
import ZoneRepository from '../repositories/zoneRepository'
|
||||
import ZoneService from '../services/zoneService'
|
||||
import logger from '../utilities/logger'
|
||||
import LoadedZone from '../models/loadedZone'
|
||||
import zoneRepository from '../repositories/zoneRepository'
|
||||
import { beforeEach } from 'node:test'
|
||||
import prisma from '../utilities/prisma'
|
||||
|
||||
class ZoneManager {
|
||||
private loadedZones: LoadedZone[] = []
|
||||
@ -25,15 +27,36 @@ class ZoneManager {
|
||||
}
|
||||
|
||||
// For now only current zone.
|
||||
public async getNeededAssets(zone: Zone) {
|
||||
const tiles = this.getUnique((JSON.parse(JSON.stringify(zone.tiles)) as string[][]).reduce((acc, val) => [...acc, ...val]));
|
||||
public async getNeededAssets(zone: Zone, getMore = true): Promise<ZoneAssets> {
|
||||
const tiles: string[] = this.getUnique((JSON.parse(JSON.stringify(zone.tiles)) as string[][]).reduce((acc, val) => [...acc, ...val]));
|
||||
const objects = await zoneRepository.getObjects(zone.id);
|
||||
const eventTeleportTiles = await zoneRepository.getEventTeleportTiles(zone.id);
|
||||
let toZoneAssets = null;
|
||||
if(getMore) {
|
||||
for (const eventTeleportTile of eventTeleportTiles) {
|
||||
console.log(eventTeleportTile);
|
||||
console.log(eventTeleportTile.teleport.toZoneId);
|
||||
const toZone = await zoneRepository.getById(eventTeleportTile.teleport.toZoneId);
|
||||
console.log(toZone);
|
||||
if(toZone) {
|
||||
if(!toZoneAssets) {
|
||||
toZoneAssets = await this.getNeededAssets(toZone, false);
|
||||
} else {
|
||||
const newToZoneAssets = await this.getNeededAssets(toZone, false);
|
||||
toZoneAssets = {
|
||||
tiles: this.getUnique([...toZoneAssets.tiles, ...(newToZoneAssets ? newToZoneAssets.tiles : [])]),
|
||||
objects: this.getUnique([...toZoneAssets.objects, ...(newToZoneAssets ? newToZoneAssets.objects : [])]),
|
||||
} as ZoneAssets
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
let mappedObjects = this.getUnique(objects.map(x => x.objectId));
|
||||
|
||||
return {
|
||||
tiles,
|
||||
objects: mappedObjects
|
||||
};
|
||||
tiles: this.getUnique([...tiles, ...(toZoneAssets ? toZoneAssets.tiles : [])]),
|
||||
objects: this.getUnique([...mappedObjects, ...(toZoneAssets ? toZoneAssets.objects : [])]),
|
||||
} as ZoneAssets;
|
||||
}
|
||||
|
||||
private getUnique<T>(array: T[]) {
|
||||
@ -65,4 +88,9 @@ class ZoneManager {
|
||||
}
|
||||
}
|
||||
|
||||
export interface ZoneAssets {
|
||||
tiles: string[]
|
||||
objects: string[]
|
||||
}
|
||||
|
||||
export default new ZoneManager()
|
||||
|
Reference in New Issue
Block a user