Added apply link button in markup tooltip

This commit is contained in:
Eduard Kuzmenko 2020-12-05 12:48:07 +02:00
parent cd6026f516
commit e7f483b573
4 changed files with 62 additions and 18 deletions

View File

@ -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();

View File

@ -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;

View File

@ -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);

View File

@ -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;
}
} }
} }