2019-08-16 03:18:33 +08:00
|
|
|
import StandardWidget from "./standard_widget.js";
|
2019-07-22 03:55:48 +08:00
|
|
|
|
|
|
|
let linkMapContainerIdCtr = 1;
|
|
|
|
|
|
|
|
const TPL = `
|
|
|
|
<div style="outline: none; overflow: hidden;">
|
|
|
|
<div class="link-map-container"></div>
|
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
|
2019-08-16 03:18:33 +08:00
|
|
|
class LinkMapWidget extends StandardWidget {
|
2019-08-17 16:45:20 +08:00
|
|
|
getWidgetTitle() { return "Link map"; }
|
2019-07-25 04:52:51 +08:00
|
|
|
|
2019-08-17 16:45:20 +08:00
|
|
|
getHeaderActions() {
|
2019-07-25 04:52:51 +08:00
|
|
|
const $showFullButton = $("<a>").append("show full").addClass('widget-header-action');
|
2019-08-21 03:40:47 +08:00
|
|
|
$showFullButton.click(async () => {
|
|
|
|
const linkMapDialog = await import("../dialogs/link_map.js");
|
2019-07-25 04:52:51 +08:00
|
|
|
linkMapDialog.showDialog();
|
|
|
|
});
|
|
|
|
|
2019-08-17 16:45:20 +08:00
|
|
|
return [$showFullButton];
|
2019-07-22 03:55:48 +08:00
|
|
|
}
|
|
|
|
|
2019-08-16 03:18:33 +08:00
|
|
|
async doRenderBody() {
|
|
|
|
this.$body.html(TPL);
|
2019-08-15 16:04:03 +08:00
|
|
|
|
2019-08-28 02:20:00 +08:00
|
|
|
const $linkMapContainer = this.$body.find('.link-map-container');
|
|
|
|
$linkMapContainer.attr("id", "link-map-container-" + linkMapContainerIdCtr++);
|
2019-08-28 04:19:32 +08:00
|
|
|
$linkMapContainer.css("height", "300px");
|
2019-07-22 03:55:48 +08:00
|
|
|
|
2019-08-28 02:20:00 +08:00
|
|
|
const LinkMapServiceClass = (await import('../services/link_map.js')).default;
|
2019-07-22 03:55:48 +08:00
|
|
|
|
2019-08-28 04:19:32 +08:00
|
|
|
const linkMapService = new LinkMapServiceClass(this.ctx.note, $linkMapContainer, {
|
|
|
|
maxDepth: 1,
|
|
|
|
zoom: 0.7
|
|
|
|
});
|
2019-07-22 03:55:48 +08:00
|
|
|
|
2019-08-28 02:20:00 +08:00
|
|
|
await linkMapService.render();
|
2019-07-22 03:55:48 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default LinkMapWidget;
|