2020-07-22 15:00:22 +00:00
|
|
|
// Copyright 2020 the V8 project authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
2020-08-13 12:55:19 +00:00
|
|
|
import { V8CustomElement, defineCustomElement } from "../helper.mjs";
|
|
|
|
import { FocusEvent } from "../events.mjs";
|
2020-07-22 15:00:22 +00:00
|
|
|
|
2020-08-13 12:55:19 +00:00
|
|
|
defineCustomElement(
|
|
|
|
"./map-panel/map-details",
|
|
|
|
(templateText) =>
|
|
|
|
class MapDetails extends V8CustomElement {
|
|
|
|
constructor() {
|
|
|
|
super(templateText);
|
|
|
|
this.mapDetails.addEventListener("click", () =>
|
|
|
|
this.handleClickSourcePositions()
|
|
|
|
);
|
|
|
|
this.selectedMap = undefined;
|
|
|
|
}
|
|
|
|
get mapDetails() {
|
|
|
|
return this.$("#mapDetails");
|
|
|
|
}
|
2020-07-22 15:00:22 +00:00
|
|
|
|
2020-08-13 12:55:19 +00:00
|
|
|
setSelectedMap(value) {
|
|
|
|
this.selectedMap = value;
|
|
|
|
}
|
2020-07-22 15:00:22 +00:00
|
|
|
|
2020-08-13 12:55:19 +00:00
|
|
|
set mapDetails(map) {
|
|
|
|
let details = "";
|
|
|
|
if (map) {
|
|
|
|
details += "ID: " + map.id;
|
|
|
|
details += "\nSource location: " + map.filePosition;
|
|
|
|
details += "\n" + map.description;
|
|
|
|
this.setSelectedMap(map);
|
|
|
|
}
|
|
|
|
this.mapDetails.innerText = details;
|
|
|
|
}
|
2020-07-22 15:00:22 +00:00
|
|
|
|
2020-08-13 12:55:19 +00:00
|
|
|
handleClickSourcePositions() {
|
|
|
|
this.dispatchEvent(new FocusEvent(this.selectedMap.filePosition));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|