yomichan/ext/util.js

91 lines
2.6 KiB
JavaScript
Raw Normal View History

2016-03-17 03:33:15 +00:00
/*
2016-03-20 02:02:58 +00:00
* Copyright (C) 2016 Alex Yatskov <alex@foosoft.net>
2016-03-17 03:33:15 +00:00
* Author: Alex Yatskov <alex@foosoft.net>
*
2016-03-20 02:02:58 +00:00
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
2016-03-17 03:33:15 +00:00
*
2016-03-20 02:02:58 +00:00
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
2016-03-17 03:33:15 +00:00
*
2016-03-20 02:02:58 +00:00
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
2016-03-17 03:33:15 +00:00
*/
2016-03-24 02:25:32 +00:00
2016-03-20 02:02:58 +00:00
function getRangeAtCursor(e, lookAhead) {
const range = document.caretRangeFromPoint(e.clientX, e.clientY);
if (range === null) {
2016-03-21 01:27:11 +00:00
return null;
2016-03-17 05:04:56 +00:00
}
2016-03-20 02:02:58 +00:00
const node = range.startContainer;
if (node.nodeType !== 3 /* TEXT_NODE */) {
return null;
2016-03-17 05:04:56 +00:00
}
2016-03-20 02:02:58 +00:00
const offset = range.startOffset;
const length = Math.min(node.length - offset, lookAhead);
2016-03-27 20:21:52 +00:00
if (length === 0) {
return null;
}
2016-03-20 02:02:58 +00:00
range.setEnd(node, offset + length);
return range;
2016-03-17 05:04:56 +00:00
}
2016-03-27 20:21:52 +00:00
function getRangePaddedRect(range) {
const node = range.startContainer;
const startOffset = range.startOffset;
const endOffset = range.endOffset;
2016-03-27 20:21:52 +00:00
range.setStart(node, Math.max(0, startOffset - 1));
range.setEnd(node, Math.min(node.length, endOffset + 1));
const rect = range.getBoundingClientRect();
range.setStart(node, startOffset);
range.setEnd(node, endOffset);
2016-03-24 02:25:32 +00:00
2016-03-27 20:21:52 +00:00
return rect;
}
function getPopupPositionForRange(popup, range, offset) {
const rangeRect = range.getBoundingClientRect();
const popupRect = popup.get(0).getBoundingClientRect();
let posX = rangeRect.left;
if (posX + popupRect.width >= window.innerWidth) {
posX = window.innerWidth - popupRect.width;
2016-03-20 02:02:58 +00:00
}
2016-03-27 20:21:52 +00:00
let posY = rangeRect.bottom + offset;
if (posY + popupRect.height >= window.innerHeight) {
posY = rangeRect.top - popupRect.height - offset;
}
2016-03-20 02:02:58 +00:00
2016-03-27 20:21:52 +00:00
return {x: posX, y: posY};
2016-03-17 05:04:56 +00:00
}
2016-03-28 01:24:04 +00:00
function renderDefs(terms) {
const outputs = [];
for (let term of terms) {
outputs.push(renderDef(term));
}
return outputs.join('');
}
function renderDef(term) {
return `
<div class="yomichan-def">
<span class="yomichan-def-expression">${term.expression}</span>
<span class="yomichan-def-rules">${term.rules.join('&nbsp;&lt;&nbsp;')}</span>
<span class="yomichan-def-reading">${term.reading}</span>
<span class="yomichan-def-glossary">${term.glossary}</span>
</div>
`;
}