Fix emoji margin on non-Safari browsers on macOS
This commit is contained in:
parent
7ede67a405
commit
733c0e4762
@ -292,7 +292,7 @@ export default class EmojiTab implements EmoticonsTab {
|
|||||||
const messageInput = appImManager.chat.input.messageInput;
|
const messageInput = appImManager.chat.input.messageInput;
|
||||||
let inputHTML = messageInput.innerHTML;
|
let inputHTML = messageInput.innerHTML;
|
||||||
|
|
||||||
const html = RichTextProcessor.wrapEmojiText(emoji);
|
const html = RichTextProcessor.wrapEmojiText(emoji, true);
|
||||||
let inserted = false;
|
let inserted = false;
|
||||||
if(window.getSelection) {
|
if(window.getSelection) {
|
||||||
const savedRange = isTouchSupported ? undefined : emoticonsDropdown.getSavedRange();
|
const savedRange = isTouchSupported ? undefined : emoticonsDropdown.getSavedRange();
|
||||||
|
@ -446,7 +446,7 @@ namespace RichTextProcessor {
|
|||||||
noLinks: true,
|
noLinks: true,
|
||||||
noLinebreaks: true,
|
noLinebreaks: true,
|
||||||
noCommands: true,
|
noCommands: true,
|
||||||
wrappingDraft: true,
|
wrappingDraft: boolean,
|
||||||
//mustWrapEmoji: boolean,
|
//mustWrapEmoji: boolean,
|
||||||
fromBot: boolean,
|
fromBot: boolean,
|
||||||
noTextFormat: true,
|
noTextFormat: true,
|
||||||
@ -581,6 +581,8 @@ namespace RichTextProcessor {
|
|||||||
//} else if(options.mustWrapEmoji) {
|
//} else if(options.mustWrapEmoji) {
|
||||||
} else if(!options.wrappingDraft) {
|
} else if(!options.wrappingDraft) {
|
||||||
insertPart(entity, '<span class="emoji">', '</span>');
|
insertPart(entity, '<span class="emoji">', '</span>');
|
||||||
|
} else if(!isSafari) {
|
||||||
|
insertPart(entity, '<span class="emoji" contenteditable="false">', '</span>');
|
||||||
}
|
}
|
||||||
/* if(!emojiSupported) {
|
/* if(!emojiSupported) {
|
||||||
insertPart(entity, `<img src="assets/img/emoji/${entity.unicode}.png" alt="`, `" class="emoji">`);
|
insertPart(entity, `<img src="assets/img/emoji/${entity.unicode}.png" alt="`, `" class="emoji">`);
|
||||||
@ -825,11 +827,11 @@ namespace RichTextProcessor {
|
|||||||
return arr.join('');
|
return arr.join('');
|
||||||
}
|
}
|
||||||
|
|
||||||
export function wrapEmojiText(text: string) {
|
export function wrapEmojiText(text: string, isDraft = false) {
|
||||||
if(!text) return '';
|
if(!text) return '';
|
||||||
|
|
||||||
let entities = parseEntities(text).filter(e => e._ === 'messageEntityEmoji');
|
let entities = parseEntities(text).filter(e => e._ === 'messageEntityEmoji');
|
||||||
return wrapRichText(text, {entities});
|
return wrapRichText(text, {entities, wrappingDraft: isDraft});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function wrapUrl(url: string, unsafe?: number | boolean): {url: string, onclick: string} {
|
export function wrapUrl(url: string, unsafe?: number | boolean): {url: string, onclick: string} {
|
||||||
|
@ -839,6 +839,19 @@ span.emoji {
|
|||||||
line-height: 1 !important;
|
line-height: 1 !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// non-Retina device
|
||||||
|
@media
|
||||||
|
not screen and (-webkit-min-device-pixel-ratio: 2),
|
||||||
|
not screen and ( min--moz-device-pixel-ratio: 2),
|
||||||
|
not screen and ( -o-min-device-pixel-ratio: 2/1),
|
||||||
|
not screen and ( min-device-pixel-ratio: 2),
|
||||||
|
not screen and ( min-resolution: 192dpi),
|
||||||
|
not screen and ( min-resolution: 2dppx) {
|
||||||
|
span.emoji {
|
||||||
|
margin-right: 5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
img.emoji {
|
img.emoji {
|
||||||
width: 18px;
|
width: 18px;
|
||||||
height: 18px;
|
height: 18px;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user