2020-01-25 09:56:08 +01:00
|
|
|
import treeService from "./tree.js";
|
2018-03-26 22:29:14 -04:00
|
|
|
import linkService from "./link.js";
|
2020-01-25 14:37:12 +01:00
|
|
|
import treeCache from "./tree_cache.js";
|
2020-04-04 22:40:32 +02:00
|
|
|
import utils from "./utils.js";
|
2018-03-26 22:29:14 -04:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
function setupGlobalTooltip() {
|
|
|
|
$(document).on("mouseenter", "a", mouseEnterHandler);
|
|
|
|
$(document).on("mouseleave", "a", mouseLeaveHandler);
|
2018-08-15 18:22:02 +02:00
|
|
|
|
2019-04-20 09:39:39 +02:00
|
|
|
// close any note tooltip after click, this fixes the problem that sometimes tooltips remained on the screen
|
|
|
|
$(document).on("click", () => $('.note-tooltip').remove());
|
2018-12-22 20:57:09 +01:00
|
|
|
}
|
2018-08-15 18:22:02 +02:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
function setupElementTooltip($el) {
|
|
|
|
$el.on('mouseenter', mouseEnterHandler);
|
|
|
|
$el.on('mouseleave', mouseLeaveHandler);
|
|
|
|
}
|
2018-10-06 22:00:43 +02:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
async function mouseEnterHandler() {
|
|
|
|
const $link = $(this);
|
2018-07-28 17:59:55 +02:00
|
|
|
|
2019-11-01 20:00:56 +01:00
|
|
|
if ($link.hasClass("no-tooltip-preview")
|
|
|
|
|| $link.hasClass("disabled")
|
|
|
|
|| $link.attr("data-action") === 'note-revision') {
|
2018-12-22 20:57:09 +01:00
|
|
|
return;
|
|
|
|
}
|
2018-11-06 19:35:42 +01:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
// this is to avoid showing tooltip from inside CKEditor link editor dialog
|
|
|
|
if ($link.closest(".ck-link-actions").length) {
|
|
|
|
return;
|
|
|
|
}
|
2018-03-26 22:29:14 -04:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
let notePath = linkService.getNotePathFromUrl($link.attr("href"));
|
2018-03-26 22:29:14 -04:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
if (!notePath) {
|
|
|
|
notePath = $link.attr("data-note-path");
|
|
|
|
}
|
2018-08-22 15:31:36 +02:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
if (!notePath) {
|
|
|
|
return;
|
|
|
|
}
|
2018-11-06 19:35:42 +01:00
|
|
|
|
2020-01-25 09:56:08 +01:00
|
|
|
const noteId = treeService.getNoteIdFromNotePath(notePath);
|
2018-11-06 19:35:42 +01:00
|
|
|
|
2020-01-25 14:37:12 +01:00
|
|
|
const note = await treeCache.getNote(noteId);
|
2020-02-01 18:29:18 +01:00
|
|
|
const noteComplement = await treeCache.getNoteComplement(noteId);
|
2018-11-06 19:35:42 +01:00
|
|
|
|
2020-08-06 00:06:42 +02:00
|
|
|
const html = '<div class="note-tooltip-content">' + await renderTooltip(note, noteComplement) + '</div>';
|
2018-11-14 14:52:05 +01:00
|
|
|
|
2018-12-22 20:57:09 +01:00
|
|
|
// we need to check if we're still hovering over the element
|
|
|
|
// since the operation to get tooltip content was async, it is possible that
|
|
|
|
// we now create tooltip which won't close because it won't receive mouseleave event
|
|
|
|
if ($(this).is(":hover")) {
|
|
|
|
$(this).tooltip({
|
|
|
|
delay: {"show": 300, "hide": 100},
|
|
|
|
container: 'body',
|
|
|
|
placement: 'auto',
|
|
|
|
trigger: 'manual',
|
|
|
|
boundary: 'window',
|
|
|
|
title: html,
|
2019-04-20 09:39:39 +02:00
|
|
|
html: true,
|
2020-04-08 21:38:11 +02:00
|
|
|
template: '<div class="tooltip note-tooltip" role="tooltip"><div class="arrow"></div><div class="tooltip-inner"></div></div>',
|
|
|
|
sanitize: false
|
2018-12-22 20:57:09 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
$(this).tooltip('show');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function mouseLeaveHandler() {
|
|
|
|
$(this).tooltip('dispose');
|
2018-03-26 22:29:14 -04:00
|
|
|
}
|
|
|
|
|
2020-02-01 11:15:58 +01:00
|
|
|
async function renderTooltip(note, noteComplement) {
|
2020-03-23 16:39:03 +01:00
|
|
|
if (note.isDeleted) {
|
|
|
|
return '<div>Note has been deleted.</div>';
|
|
|
|
}
|
|
|
|
|
2020-04-04 22:40:32 +02:00
|
|
|
const attributes = note.getAttributes();
|
2020-01-25 14:37:12 +01:00
|
|
|
|
2018-08-22 15:31:36 +02:00
|
|
|
let content = '';
|
2020-04-04 22:40:32 +02:00
|
|
|
|
|
|
|
const promoted = attributes
|
|
|
|
.filter(attr => attr.type === 'label-definition' || attr.type === 'relation-definition')
|
|
|
|
.filter(attr => !attr.name.startsWith("child:"))
|
|
|
|
.filter(attr => {
|
|
|
|
const json = attr.jsonValue;
|
|
|
|
|
|
|
|
return json && json.isPromoted;
|
|
|
|
});
|
2018-08-22 15:31:36 +02:00
|
|
|
|
|
|
|
if (promoted.length > 0) {
|
|
|
|
const $table = $("<table>").addClass("promoted-attributes-in-tooltip");
|
|
|
|
|
|
|
|
for (const definitionAttr of promoted) {
|
|
|
|
const definitionType = definitionAttr.type;
|
|
|
|
const valueType = definitionType.substr(0, definitionType.length - 11);
|
|
|
|
|
|
|
|
let valueAttrs = attributes.filter(el => el.name === definitionAttr.name && el.type === valueType);
|
|
|
|
|
|
|
|
for (const valueAttr of valueAttrs) {
|
2018-08-27 13:35:45 +02:00
|
|
|
if (!valueAttr.value) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2018-08-22 15:31:36 +02:00
|
|
|
let $value = "";
|
|
|
|
|
|
|
|
if (valueType === 'label') {
|
|
|
|
$value = $("<td>").text(valueAttr.value);
|
|
|
|
}
|
|
|
|
else if (valueType === 'relation' && valueAttr.value) {
|
|
|
|
$value = $("<td>").append(await linkService.createNoteLink(valueAttr.value));
|
|
|
|
}
|
|
|
|
|
|
|
|
const $row = $("<tr>")
|
|
|
|
.append($("<th>").text(definitionAttr.name))
|
|
|
|
.append($value);
|
|
|
|
|
|
|
|
$table.append($row);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
content += $table.prop('outerHTML');
|
|
|
|
}
|
|
|
|
|
2020-04-04 22:40:32 +02:00
|
|
|
if (note.type === 'text' && !utils.isHtmlEmpty(noteComplement.content)) {
|
2020-04-08 21:38:11 +02:00
|
|
|
content += '<div class="ck-content">' + noteComplement.content + '</div>';
|
2018-08-22 15:31:36 +02:00
|
|
|
}
|
2020-04-04 22:40:32 +02:00
|
|
|
else if (note.type === 'code' && noteComplement.content && noteComplement.content.trim()) {
|
2018-11-14 08:36:19 +01:00
|
|
|
content += $("<pre>")
|
2020-02-01 11:15:58 +01:00
|
|
|
.text(noteComplement.content)
|
2018-11-14 08:36:19 +01:00
|
|
|
.prop('outerHTML');
|
|
|
|
}
|
|
|
|
else if (note.type === 'image') {
|
|
|
|
content += $("<img>")
|
2019-02-22 23:03:20 +01:00
|
|
|
.prop("src", `api/images/${note.noteId}/${note.title}`)
|
2018-11-14 08:36:19 +01:00
|
|
|
.prop('outerHTML');
|
2018-08-22 15:31:36 +02:00
|
|
|
}
|
|
|
|
// other types of notes don't have tooltip preview
|
|
|
|
|
2018-11-06 19:35:42 +01:00
|
|
|
return content;
|
2018-08-22 15:31:36 +02:00
|
|
|
}
|
|
|
|
|
2018-03-26 22:29:14 -04:00
|
|
|
export default {
|
2018-12-22 20:57:09 +01:00
|
|
|
setupGlobalTooltip,
|
|
|
|
setupElementTooltip
|
2020-08-06 00:06:42 +02:00
|
|
|
}
|