Added apply link button in markup tooltip
This commit is contained in:
parent
cd6026f516
commit
e7f483b573
@ -8,6 +8,7 @@ export default class MarkupTooltip {
|
|||||||
private wrapper: HTMLElement;
|
private wrapper: HTMLElement;
|
||||||
private buttons: {[type in MarkdownType]: HTMLElement} = {} as any;
|
private buttons: {[type in MarkdownType]: HTMLElement} = {} as any;
|
||||||
private linkBackButton: HTMLElement;
|
private linkBackButton: HTMLElement;
|
||||||
|
private linkApplyButton: HTMLButtonElement;
|
||||||
private hideTimeout: number;
|
private hideTimeout: number;
|
||||||
private addedListener = false;
|
private addedListener = false;
|
||||||
private waitingForMouseUp = false;
|
private waitingForMouseUp = false;
|
||||||
@ -50,6 +51,8 @@ export default class MarkupTooltip {
|
|||||||
} else {
|
} else {
|
||||||
this.linkInput.value = '';
|
this.linkInput.value = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.linkInput.classList.toggle('is-valid', this.isLinkValid());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -59,8 +62,9 @@ export default class MarkupTooltip {
|
|||||||
this.linkInput.placeholder = 'Enter URL...';
|
this.linkInput.placeholder = 'Enter URL...';
|
||||||
this.linkInput.classList.add('input-clear');
|
this.linkInput.classList.add('input-clear');
|
||||||
this.linkInput.addEventListener('keydown', (e) => {
|
this.linkInput.addEventListener('keydown', (e) => {
|
||||||
|
const valid = !this.linkInput.value.length || !!RichTextProcessor.matchUrl(this.linkInput.value);///^(http)|(https):\/\//i.test(this.linkInput.value);
|
||||||
|
|
||||||
if(e.code == 'Enter') {
|
if(e.code == 'Enter') {
|
||||||
const valid = !this.linkInput.value.length || RichTextProcessor.matchUrl(this.linkInput.value);///^(http)|(https):\/\//i.test(this.linkInput.value);
|
|
||||||
if(!valid) {
|
if(!valid) {
|
||||||
if(this.linkInput.classList.contains('error')) {
|
if(this.linkInput.classList.contains('error')) {
|
||||||
this.linkInput.classList.remove('error');
|
this.linkInput.classList.remove('error');
|
||||||
@ -69,14 +73,16 @@ export default class MarkupTooltip {
|
|||||||
|
|
||||||
this.linkInput.classList.add('error');
|
this.linkInput.classList.add('error');
|
||||||
} else {
|
} else {
|
||||||
cancelEvent(e);
|
this.applyLink(e);
|
||||||
this.resetSelection();
|
|
||||||
this.appImManager.chat.input.applyMarkdown('link', this.linkInput.value);
|
|
||||||
this.hide();
|
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this.linkInput.addEventListener('input', (e) => {
|
||||||
|
const valid = this.isLinkValid();
|
||||||
|
|
||||||
|
this.linkInput.classList.toggle('is-valid', valid);
|
||||||
this.linkInput.classList.remove('error');
|
this.linkInput.classList.remove('error');
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
this.linkBackButton.addEventListener('click', () => {
|
this.linkBackButton.addEventListener('click', () => {
|
||||||
@ -85,12 +91,23 @@ export default class MarkupTooltip {
|
|||||||
this.resetSelection();
|
this.resetSelection();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.linkApplyButton = ButtonIcon('check markup-tooltip-link-apply', {noRipple: true});
|
||||||
|
this.linkApplyButton.addEventListener('click', (e) => {
|
||||||
|
this.applyLink(e);
|
||||||
|
});
|
||||||
|
|
||||||
|
const applyDiv = document.createElement('div');
|
||||||
|
applyDiv.classList.add('markup-tooltip-link-apply-container');
|
||||||
|
|
||||||
const delimiter1 = document.createElement('span');
|
const delimiter1 = document.createElement('span');
|
||||||
const delimiter2 = document.createElement('span');
|
const delimiter2 = document.createElement('span');
|
||||||
|
const delimiter3 = document.createElement('span');
|
||||||
delimiter1.classList.add('markup-tooltip-delimiter');
|
delimiter1.classList.add('markup-tooltip-delimiter');
|
||||||
delimiter2.classList.add('markup-tooltip-delimiter');
|
delimiter2.classList.add('markup-tooltip-delimiter');
|
||||||
|
delimiter3.classList.add('markup-tooltip-delimiter');
|
||||||
tools1.insertBefore(delimiter1, this.buttons.link);
|
tools1.insertBefore(delimiter1, this.buttons.link);
|
||||||
tools2.append(this.linkBackButton, delimiter2, this.linkInput);
|
applyDiv.append(delimiter3, this.linkApplyButton);
|
||||||
|
tools2.append(this.linkBackButton, delimiter2, this.linkInput, applyDiv);
|
||||||
//tools1.insertBefore(delimiter2, this.buttons.link.nextSibling);
|
//tools1.insertBefore(delimiter2, this.buttons.link.nextSibling);
|
||||||
|
|
||||||
this.wrapper.append(tools1, tools2);
|
this.wrapper.append(tools1, tools2);
|
||||||
@ -98,6 +115,17 @@ export default class MarkupTooltip {
|
|||||||
document.body.append(this.container);
|
document.body.append(this.container);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private applyLink(e: Event) {
|
||||||
|
cancelEvent(e);
|
||||||
|
this.resetSelection();
|
||||||
|
this.appImManager.chat.input.applyMarkdown('link', this.linkInput.value);
|
||||||
|
this.hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
private isLinkValid() {
|
||||||
|
return !this.linkInput.value.length || !!RichTextProcessor.matchUrl(this.linkInput.value);
|
||||||
|
}
|
||||||
|
|
||||||
private resetSelection() {
|
private resetSelection() {
|
||||||
const selection = window.getSelection();
|
const selection = window.getSelection();
|
||||||
selection.removeAllRanges();
|
selection.removeAllRanges();
|
||||||
|
@ -91,13 +91,13 @@ Utility Classes
|
|||||||
user-select: none;
|
user-select: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* .no-transition {
|
.no-transition {
|
||||||
transition: none !important;
|
transition: none !important;
|
||||||
|
|
||||||
&-all, &-all * {
|
/* &-all, &-all * {
|
||||||
transition: none !important;
|
transition: none !important;
|
||||||
}
|
|
||||||
} */
|
} */
|
||||||
|
}
|
||||||
|
|
||||||
.inline {
|
.inline {
|
||||||
display: inline;
|
display: inline;
|
||||||
|
@ -232,7 +232,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ! example: multiselect input
|
// ! example: multiselect input, button in pinned messages chat
|
||||||
.btn-transparent {
|
.btn-transparent {
|
||||||
color: #000;
|
color: #000;
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
@ -240,6 +240,7 @@
|
|||||||
align-items: center;
|
align-items: center;
|
||||||
padding: 0 .875rem;
|
padding: 0 .875rem;
|
||||||
//width: auto;
|
//width: auto;
|
||||||
|
text-transform: capitalize;
|
||||||
|
|
||||||
html.no-touch &:hover {
|
html.no-touch &:hover {
|
||||||
background-color: var(--color-gray-hover);
|
background-color: var(--color-gray-hover);
|
||||||
|
@ -43,8 +43,7 @@
|
|||||||
width: $widthLink;
|
width: $widthLink;
|
||||||
|
|
||||||
.markup-tooltip-delimiter {
|
.markup-tooltip-delimiter {
|
||||||
margin-left: .25rem;
|
margin: 0 .25rem;
|
||||||
margin-right: .75rem;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -83,12 +82,28 @@
|
|||||||
transform: translateX(#{-$widthRegular});
|
transform: translateX(#{-$widthRegular});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&-link-apply {
|
||||||
|
color: $color-blue;
|
||||||
|
font-size: 2rem;
|
||||||
|
|
||||||
|
&-container {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
opacity: 0;
|
||||||
|
transition: opacity var(--layer-transition);
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.input-clear {
|
.input-clear {
|
||||||
flex: 1 1 auto;
|
flex: 1 1 auto;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
}
|
|
||||||
|
|
||||||
&.no-transition {
|
margin: 0 .5rem;
|
||||||
transition: none;
|
|
||||||
|
&.is-valid + .markup-tooltip-link-apply-container {
|
||||||
|
opacity: 1;
|
||||||
|
pointer-events: all;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user