burguillos.info/js-src/conquer/map-node.ts

142 lines
4.3 KiB
TypeScript
Raw Normal View History

2023-12-31 20:43:53 +01:00
import { JsonObject, JsonProperty } from 'typescript-json-serializer';
2023-11-28 21:10:12 +01:00
import Style from 'ol/style/Style'
import Feature from 'ol/Feature'
2023-12-31 20:43:53 +01:00
import CircleStyle from 'ol/style/Circle'
import Point from 'ol/geom/Point'
import Fill from 'ol/style/Fill'
import Stroke from 'ol/style/Stroke'
import InterfaceManager from '@burguillosinfo/conquer/interface-manager'
import NodeView from '@burguillosinfo/conquer/interface/node-view'
2024-01-13 01:17:57 +01:00
import JsonSerializer from '@burguillosinfo/conquer/serializer';
2024-01-13 23:14:14 +01:00
import SelectTeamUI from '@burguillosinfo/conquer/interface/select-team';
2023-11-28 21:10:12 +01:00
2023-12-31 20:43:53 +01:00
@JsonObject()
2023-11-28 21:10:12 +01:00
export default class MapNode {
2023-12-31 20:43:53 +01:00
private feature: Feature | null = null;
private callbacks: Record<string, Array<() => void>> = {}
2023-12-31 20:43:53 +01:00
constructor(
@JsonProperty() private uuid: string,
@JsonProperty() private coordinate_1: number,
@JsonProperty() private coordinate_2: number,
@JsonProperty() private type: string,
@JsonProperty() private name: string,
@JsonProperty() private description: string,
@JsonProperty() private kind: string,
2024-01-13 01:17:57 +01:00
@JsonProperty() private is_near: boolean,
2023-12-31 20:43:53 +01:00
) {
}
2024-01-13 01:17:57 +01:00
public async fetch(): Promise<MapNode> {
const urlNode = new URL('/conquer/node/' + this.uuid, window.location.protocol + '//' + window.location.hostname + ':' + window.location.port)
const response = await fetch(urlNode);
let responseBody;
const errorThrow = new Error('Unable to fetch node updated.');
try {
responseBody = await response.json();
} catch (error) {
console.error('Error parseando json: ' + responseBody);
console.error(error);
throw errorThrow;
}
if (response.status !== 200) {
console.error(responseBody.error);
throw errorThrow;
}
const node = JsonSerializer.deserialize(responseBody, MapNode);
if (!(node instanceof MapNode)) {
console.error('Unexpected JSON value for MapNode.');
throw errorThrow;
}
return node;
}
public click(interfaceManager: InterfaceManager): void {
const viewNodeInterface = new NodeView(this);
viewNodeInterface.on('close', () => {
interfaceManager.remove(viewNodeInterface);
});
2024-01-13 01:17:57 +01:00
viewNodeInterface.on('update-nodes', () => {
this.runCallbacks('update-nodes');
});
2024-01-13 23:14:14 +01:00
viewNodeInterface.on('open-select-team', () => {
this.openSelectTeam(interfaceManager);
});
interfaceManager.push(viewNodeInterface);
this.runCallbacks('click');
}
2024-01-13 23:14:14 +01:00
public openSelectTeam(interfaceManager: InterfaceManager): void {
const selectTeamUI = new SelectTeamUI(this);
selectTeamUI.on('close', () => {
interfaceManager.remove(selectTeamUI);
});
interfaceManager.push(selectTeamUI);
}
public on(eventName: string, callback: () => void): void {
if (this.callbacks[eventName] === undefined) {
this.callbacks[eventName] = []
}
this.callbacks[eventName].push(callback)
}
protected runCallbacks(eventName: string) {
const callbacks = this.callbacks[eventName];
if (callbacks === undefined) {
return
}
for (const callback of callbacks) {
callback()
}
}
2023-12-31 20:43:53 +01:00
public getType(): string {
return this.type;
}
2024-01-13 01:17:57 +01:00
public isNear(): boolean {
return this.is_near;
}
2023-12-31 20:43:53 +01:00
public getName(): string {
return this.name;
}
public getDescription(): string {
return this.description;
2023-11-28 21:10:12 +01:00
}
public getId(): string {
2023-12-31 20:43:53 +01:00
return 'node-' + this.uuid;
2023-11-28 21:10:12 +01:00
}
public getUUID(): string {
return this.uuid;
}
2023-12-31 20:43:53 +01:00
public getFeature(): Feature {
if (this.feature === null) {
this.feature = new Feature({
geometry: new Point([this.coordinate_1, this.coordinate_2]),
type: 'node-' + this.uuid,
})
}
return this.feature;
2023-11-28 21:10:12 +01:00
}
public getStyle(): Style {
2023-12-31 20:43:53 +01:00
return new Style({
image: new CircleStyle({
radius: 14,
fill: new Fill({color: 'white'}),
stroke: new Stroke({
color: 'gray',
width: 2,
})
})
});
2023-11-28 21:10:12 +01:00
}
}