/* * Copyright [2021] [wisemapping] * * Licensed under WiseMapping Public License, Version 1.0 (the "License"). * It is basically the Apache License, Version 2.0 (the "License") plus the * "powered by wisemapping" text requirement on every single page; * you may not use this file except in compliance with the License. * You may obtain a copy of the license at * * http://www.wisemapping.org/license * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { $assert } from '@wisemapping/core-js'; import $ from 'jquery'; import LinkIcon from '../LinkIcon'; import LinkModel from '../model/LinkModel'; import { $msg } from '../Messages'; import FloatingTip from './FloatingTip'; class LinkIconTooltip extends FloatingTip { constructor(linkIcon: LinkIcon) { $assert(linkIcon, 'linkIcon can not be null'); const nativeElement = $(linkIcon.getImage().peer._native); super(nativeElement, { // Content can also be a function of the target element! content() { return LinkIconTooltip._buildContent(linkIcon); }, html: true, placement: 'bottom', title: $msg('LINK'), trigger: 'manual', template: '', destroyOnExit: true, }); } private static _buildContent(linkIcon: LinkIcon): JQuery { const model = linkIcon.getModel() as LinkModel; const url = model.getUrl(); const linkText = `${url}`; const result = $('
').css({ padding: '5px', width: '100%', }); const link = $('').attr({ href: url, alt: 'Open in new window ...', target: '_blank', }); link.append(linkText); result.append(link); return result; } } export default LinkIconTooltip;