Fix highlighting of selection.

This commit is contained in:
Edward Betts 2018-11-22 20:47:44 +00:00
parent d18cadd884
commit baaa9b9c37

View file

@ -1,47 +1,83 @@
$('#new-link').hide();
$('#new-link').click((e) => {
var selection = window.getSelection();
if(selection.type != 'Range')
return;
function one_line(e, range) {
var text = e.text();
var before = text.substring(0, range.startOffset);
var span = text.substring(range.startOffset, range.endOffset);
var after = text.substring(range.endOffset);
var range = selection.getRangeAt(0);
var start = range.startContainer;
var start_element = range.startContainer.parentElement;
var end_element = range.endContainer.parentElement;
(e.empty()
.append(before)
.append($('<span class="selected-span">').text(span))
.append(after));
}
var start = parseInt(start_element.getAttribute('data-start')) + range.startOffset;
var end = parseInt(end_element.getAttribute('data-start')) + range.endOffset;
var length = end - start;
function first_line(e, range) {
var text = e.text();
var before = text.substring(0, range.startOffset);
var span = text.substring(range.startOffset);
console.log('start', start, 'length', length);
(e.empty()
.append(before)
.append($('<span class="selected-span">').text(span)));
}
var text = start_element.textContent;
var text1 = text.substring(0, range.startOffset);
var text2 = text.substring(range.startOffset + 1);
function last_line(e, range) {
var text = e.text();
var span = text.substring(0, range.endOffset);
var after = text.substring(range.endOffset);
console.log([text1, text2]);
(e.empty()
.append($('<span class="selected-span">').text(span))
.append(after));
}
var e = start_element;
var count = 0;
function highlight_selection() {
var selection = window.getSelection();
if(selection.type != 'Range')
return;
while (e != end_element && count < 50) {
$(e).wrapInner('<span class="selected-span"></span>');
count++;
e = e.nextElementSibling;
}
e = end_element;
var range = selection.getRangeAt(0);
var start = range.startContainer;
var start_element = range.startContainer.parentElement;
var end_element = range.endContainer.parentElement;
var start = parseInt(start_element.getAttribute('data-start')) + range.startOffset;
var end = parseInt(end_element.getAttribute('data-start')) + range.endOffset;
var length = end - start;
console.log('start', start, 'length', length);
if (start_element == end_element) {
console.log('one line');
return one_line($(start_element), range);
}
first_line($(start_element), range);
var e = start_element.nextElementSibling;
var count = 0;
while (e != end_element && count < 50) {
$(e).wrapInner('<span class="selected-span"></span>');
count++;
e = e.nextElementSibling;
}
selection.removeAllRanges();
last_line($(end_element), range);
}
$('#new-link').hide();
$('#new-link').click((e) => {
var selection = window.getSelection();
highlight_selection();
selection.removeAllRanges();
$('#new-link').hide();
});
document.addEventListener('selectionchange', () => {
var selection = window.getSelection();
if (selection.toString()) {
$('#new-link').show();
} else {
$('#new-link').hide();
});
document.addEventListener('selectionchange', () => {
var selection = window.getSelection();
if (selection.toString()) {
$('#new-link').show();
} else {
$('#new-link').hide();
}
});
}
});