Tags box: Fix multiline editing after editable-text changes
This commit is contained in:
parent
fca87eff9c
commit
691e5d8cc1
2 changed files with 17 additions and 1 deletions
|
@ -43,6 +43,10 @@
|
||||||
get noWrap() {
|
get noWrap() {
|
||||||
return this.hasAttribute('nowrap');
|
return this.hasAttribute('nowrap');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set noWrap(noWrap) {
|
||||||
|
this.toggleAttribute('nowrap', noWrap);
|
||||||
|
}
|
||||||
|
|
||||||
get multiline() {
|
get multiline() {
|
||||||
return this.hasAttribute('multiline');
|
return this.hasAttribute('multiline');
|
||||||
|
@ -134,7 +138,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
sizeToContent = () => {
|
sizeToContent = () => {
|
||||||
// Add a temp span, fetch it's width with current paddings and set max-width based on that
|
// Add a temp span, fetch its width with current paddings and set max-width based on that
|
||||||
let span = document.createElement("span");
|
let span = document.createElement("span");
|
||||||
span.innerText = this.value;
|
span.innerText = this.value;
|
||||||
this.append(span);
|
this.append(span);
|
||||||
|
|
|
@ -440,11 +440,17 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
makeMultiline(editable, value) {
|
makeMultiline(editable, value) {
|
||||||
|
editable.noWrap = false;
|
||||||
editable.multiline = true;
|
editable.multiline = true;
|
||||||
editable.value = value;
|
editable.value = value;
|
||||||
// Move cursor to end
|
// Move cursor to end
|
||||||
editable.ref.selectionStart = value.length;
|
editable.ref.selectionStart = value.length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
makeSingleLine(editable) {
|
||||||
|
editable.noWrap = true;
|
||||||
|
editable.multiline = false;
|
||||||
|
}
|
||||||
|
|
||||||
saveTag = async (event) => {
|
saveTag = async (event) => {
|
||||||
var textbox = event.currentTarget;
|
var textbox = event.currentTarget;
|
||||||
|
@ -467,6 +473,7 @@
|
||||||
|
|
||||||
// If row hasn't changed, we're done
|
// If row hasn't changed, we're done
|
||||||
if (oldValue == value) {
|
if (oldValue == value) {
|
||||||
|
this.makeSingleLine(textbox);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -546,6 +553,11 @@
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If we didn't remove the textbox, make it single-line
|
||||||
|
if (textbox.parentElement) {
|
||||||
|
this.makeSingleLine(textbox);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
newTag() {
|
newTag() {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue