108 lines
4.2 KiB
TypeScript
Raw Normal View History

import $ from 'jquery';
import LinkIcon from './LinkIcon';
import LinkModel from './model/LinkModel';
import NoteModel from './model/NoteModel';
import NoteIcon from './NoteIcon';
import Topic from './Topic';
import { $msg } from './Messages';
class WidgetManager {
// eslint-disable-next-line no-use-before-define
static _instance: WidgetManager;
static init = (instance: WidgetManager) => {
this._instance = instance;
};
static getInstance(): WidgetManager {
return this._instance;
}
private createTooltip(mindmapElement, title, linkModel: LinkModel, noteModel: NoteModel) {
const webcomponentShadowRoot = $($('#mindmap-comp')[0].shadowRoot);
let tooltip = webcomponentShadowRoot.find('#mindplot-svg-tooltip');
if (!tooltip.length) {
webcomponentShadowRoot.append(
'<div id="mindplot-svg-tooltip" class="mindplot-svg-tooltip">' +
'<div id="mindplot-svg-tooltip-title" class="mindplot-svg-tooltip-title"></div>' +
'<div id="mindplot-svg-tooltip-content" class="mindplot-svg-tooltip-content">' +
'<a id="mindplot-svg-tooltip-content-link" alt="Open in new window ..." class="mindplot-svg-tooltip-content-link" target="_blank"></a>' +
'<p id="mindplot-svg-tooltip-content-note" class="mindplot-svg-tooltip-content-note"></p>' +
'</div>' +
'</div>',
);
tooltip = webcomponentShadowRoot.find('#mindplot-svg-tooltip');
tooltip.on('mouseover', (evt) => {
tooltip.css({ display: 'block' });
evt.stopPropagation();
});
tooltip.on('mouseleave', (evt) => {
tooltip.css({ display: 'none' });
evt.stopPropagation();
});
}
mindmapElement.addEvent('mouseenter', (evt) => {
webcomponentShadowRoot.find('#mindplot-svg-tooltip-title').html(title);
if (linkModel) {
webcomponentShadowRoot
.find('#mindplot-svg-tooltip-content-link')
.attr('href', linkModel.getUrl());
webcomponentShadowRoot.find('#mindplot-svg-tooltip-content-link').html(linkModel.getUrl());
webcomponentShadowRoot.find('#mindplot-svg-tooltip-content-link').css({ display: 'block' });
webcomponentShadowRoot.find('#mindplot-svg-tooltip-content-note').css({ display: 'none' });
}
if (noteModel) {
webcomponentShadowRoot.find('#mindplot-svg-tooltip-content-note').html(noteModel.getText());
webcomponentShadowRoot.find('#mindplot-svg-tooltip-content-note').css({ display: 'block' });
webcomponentShadowRoot.find('#mindplot-svg-tooltip-content-link').css({ display: 'none' });
}
const targetRect = evt.target.getBoundingClientRect();
const newX = Math.max(0, targetRect.left + targetRect.width / 2 - tooltip.width() / 2);
const newY = Math.max(0, targetRect.bottom + 10);
tooltip.css({ top: newY, left: newX, position: 'absolute' });
tooltip.css({ display: 'block' });
evt.stopPropagation();
});
mindmapElement.addEvent('mouseleave', (evt) => {
tooltip.css({ display: 'none' });
evt.stopPropagation();
});
}
createTooltipForLink(topic: Topic, linkModel: LinkModel, linkIcon: LinkIcon) {
this.createTooltip(linkIcon.getImage().peer, $msg('LINK'), linkModel, undefined);
}
createTooltipForNote(topic: Topic, noteModel: NoteModel, noteIcon: NoteIcon) {
this.createTooltip(noteIcon.getImage().peer, $msg('NOTE'), undefined, noteModel);
}
configureEditorForLink(topic: Topic, linkModel: LinkModel, linkIcon: LinkIcon) {
const htmlImage = linkIcon.getImage().peer;
htmlImage.addEvent('click', (evt) => {
this.showEditorForLink(topic, linkModel, linkIcon);
evt.stopPropagation();
});
}
configureEditorForNote(topic: Topic, noteModel: NoteModel, noteIcon: NoteIcon) {
const htmlImage = noteIcon.getImage().peer;
htmlImage.addEvent('click', (evt) => {
this.showEditorForNote(topic, noteModel, noteIcon);
evt.stopPropagation();
});
}
showEditorForLink(topic: Topic, linkModel: LinkModel, linkIcon: LinkIcon) {
console.log('Show link editor not yet implemented');
}
showEditorForNote(topic: Topic, noteModel: NoteModel, noteIcon: NoteIcon) {
console.log('Show note editor not yet implemented');
}
}
export default WidgetManager;