Fix edit empty message with photo

Fix audio play
This commit is contained in:
Eduard Kuzmenko 2020-11-24 06:13:16 +02:00
parent 2ac1159413
commit acf836d078
6 changed files with 72 additions and 50 deletions

View File

@ -11,7 +11,7 @@ import { isSafari } from "../helpers/userAgent";
import appMessagesManager from "../lib/appManagers/appMessagesManager"; import appMessagesManager from "../lib/appManagers/appMessagesManager";
import rootScope from "../lib/rootScope"; import rootScope from "../lib/rootScope";
import './middleEllipsis'; import './middleEllipsis';
import { cancelEvent, CLICK_EVENT_NAME } from "../helpers/dom"; import { attachClickEvent, cancelEvent, detachClickEvent } from "../helpers/dom";
rootScope.on('messages_media_read', e => { rootScope.on('messages_media_read', e => {
const mids = e.detail; const mids = e.detail;
@ -214,13 +214,20 @@ function wrapVoiceMessage(doc: MyDocument, audioEl: AudioElement, mid: number) {
mousedown = false; mousedown = false;
} }
}); });
progress.addEventListener(CLICK_EVENT_NAME, (e) => { attachClickEvent(progress, (e) => {
cancelEvent(e); cancelEvent(e);
if(!audio.paused) scrub(e); if(!audio.paused) scrub(e);
}); });
function scrub(e: MouseEvent | TouchEvent) { function scrub(e: MouseEvent | TouchEvent) {
const offsetX = e instanceof MouseEvent ? e.offsetX : e.changedTouches[0].clientX; let offsetX: number;
if(e instanceof MouseEvent) {
offsetX = e.offsetX;
} else { // touch
const rect = (e.target as HTMLElement).getBoundingClientRect();
offsetX = e.targetTouches[0].pageX - rect.left;
}
const scrubTime = offsetX / availW /* width */ * audio.duration; const scrubTime = offsetX / availW /* width */ * audio.duration;
lastIndex = Math.round(scrubTime / audio.duration * barCount); lastIndex = Math.round(scrubTime / audio.duration * barCount);
@ -369,12 +376,12 @@ export default class AudioElement extends HTMLElement {
audioTimeDiv.innerText = String(audio.currentTime | 0).toHHMMSS(true) + ' / ' + durationStr; audioTimeDiv.innerText = String(audio.currentTime | 0).toHHMMSS(true) + ' / ' + durationStr;
} }
toggle.addEventListener(CLICK_EVENT_NAME, (e) => { attachClickEvent(toggle, (e) => {
cancelEvent(e); cancelEvent(e);
if(audio.paused) audio.play().catch(() => {}); if(audio.paused) audio.play().catch(() => {});
else audio.pause(); else audio.pause();
}); });
this.addAudioListener('ended', () => { this.addAudioListener('ended', () => {
//toggle.classList.add('tgico-largeplay'); //toggle.classList.add('tgico-largeplay');
toggle.classList.remove('tgico-largepause'); toggle.classList.remove('tgico-largepause');
@ -400,7 +407,10 @@ export default class AudioElement extends HTMLElement {
let download: Download; let download: Download;
const onClick = (e: Event) => { const onClick = (e: Event) => {
cancelEvent(e); if(e) {
cancelEvent(e);
}
if(!download) { if(!download) {
if(!preloader) { if(!preloader) {
preloader = new ProgressivePreloader(null, true); preloader = new ProgressivePreloader(null, true);
@ -411,7 +421,7 @@ export default class AudioElement extends HTMLElement {
download.then(() => { download.then(() => {
downloadDiv.remove(); downloadDiv.remove();
this.removeEventListener(CLICK_EVENT_NAME, onClick); detachClickEvent(this, onClick);
onLoad(); onLoad();
}).catch(err => { }).catch(err => {
if(err.name === 'AbortError') { if(err.name === 'AbortError') {
@ -427,8 +437,8 @@ export default class AudioElement extends HTMLElement {
} }
}; };
this.addEventListener(CLICK_EVENT_NAME, onClick); attachClickEvent(this, onClick);
this.click(); onClick(null);
} else { } else {
onLoad(false); onLoad(false);
@ -437,7 +447,7 @@ export default class AudioElement extends HTMLElement {
//} else { //} else {
const r = (e: Event) => { const r = (e: Event) => {
//onLoad(); //onLoad();
cancelEvent(e); //cancelEvent(e);
appMediaPlaybackController.resolveWaitingForLoadMedia(mid); appMediaPlaybackController.resolveWaitingForLoadMedia(mid);
appMediaPlaybackController.willBePlayed(this.audio); // prepare for loading audio appMediaPlaybackController.willBePlayed(this.audio); // prepare for loading audio
@ -469,8 +479,8 @@ export default class AudioElement extends HTMLElement {
//}, 10e3); //}, 10e3);
}); });
}; };
this.addEventListener(CLICK_EVENT_NAME, r, {once: true}); attachClickEvent(this, r, {once: true, capture: true, passive: false});
//} //}
} }
} else { } else {

View File

@ -1,4 +1,4 @@
import { cancelEvent, CLICK_EVENT_NAME } from "../helpers/dom"; import { attachClickEvent, cancelEvent, CLICK_EVENT_NAME } from "../helpers/dom";
import { closeBtnMenu } from "./misc"; import { closeBtnMenu } from "./misc";
import { ripple } from "./ripple"; import { ripple } from "./ripple";
@ -13,24 +13,13 @@ const ButtonMenuItem = (options: ButtonMenuItemOptions) => {
el.innerText = text; el.innerText = text;
ripple(el); ripple(el);
/* if(options.cancelEvent) {
el.addEventListener(CLICK_EVENT_NAME, (e) => { // * cancel keyboard close
cancelEvent(e); attachClickEvent(el, CLICK_EVENT_NAME == 'touchend' ? (e) => {
closeBtnMenu(); cancelEvent(e);
options.onClick(e); onClick(e);
}); closeBtnMenu();
} else { } : onClick);
el.addEventListener(CLICK_EVENT_NAME, onClick);
} */
if(CLICK_EVENT_NAME == 'touchend') { // * cancel keyboard close
el.addEventListener(CLICK_EVENT_NAME, (e) => {
cancelEvent(e);
options.onClick(e);
closeBtnMenu();
});
} else {
el.addEventListener(CLICK_EVENT_NAME, onClick);
}
return options.element = el; return options.element = el;
}; };

View File

@ -5,7 +5,7 @@ import appMessagesManager from "../../lib/appManagers/appMessagesManager";
import appPeersManager from "../../lib/appManagers/appPeersManager"; import appPeersManager from "../../lib/appManagers/appPeersManager";
import appPollsManager, { Poll } from "../../lib/appManagers/appPollsManager"; import appPollsManager, { Poll } from "../../lib/appManagers/appPollsManager";
import rootScope from "../../lib/rootScope"; import rootScope from "../../lib/rootScope";
import { cancelEvent, cancelSelection, findUpClassName } from "../../helpers/dom"; import { attachClickEvent, cancelEvent, cancelSelection, findUpClassName } from "../../helpers/dom";
import ButtonMenu, { ButtonMenuItemOptions } from "../buttonMenu"; import ButtonMenu, { ButtonMenuItemOptions } from "../buttonMenu";
import { attachContextMenuListener, openBtnMenu, positionMenu } from "../misc"; import { attachContextMenuListener, openBtnMenu, positionMenu } from "../misc";
import PopupDeleteMessages from "../popupDeleteMessages"; import PopupDeleteMessages from "../popupDeleteMessages";
@ -97,22 +97,6 @@ export default class ChatContextMenu {
}; };
if(isTouchSupported) { if(isTouchSupported) {
const attachClickEvent = (elem: HTMLElement, callback: (e: TouchEvent) => void) => {
elem.addEventListener('touchstart', (e) => {
const onTouchMove = (e: TouchEvent) => {
elem.removeEventListener('touchend', onTouchEnd);
};
const onTouchEnd = (e: TouchEvent) => {
elem.removeEventListener('touchmove', onTouchMove);
callback(e);
};
elem.addEventListener('touchend', onTouchEnd, {once: true});
elem.addEventListener('touchmove', onTouchMove, {once: true});
});
};
attachClickEvent(attachTo, (e) => { attachClickEvent(attachTo, (e) => {
if(appImManager.chatSelection.isSelecting) { if(appImManager.chatSelection.isSelecting) {
return; return;
@ -126,7 +110,7 @@ export default class ChatContextMenu {
const good = ['bubble', 'bubble__container', 'message', 'time', 'inner'].find(c => className.match(new RegExp(c + '($|\\s)'))); const good = ['bubble', 'bubble__container', 'message', 'time', 'inner'].find(c => className.match(new RegExp(c + '($|\\s)')));
if(good) { if(good) {
cancelEvent(e); cancelEvent(e);
onContextMenu(e.changedTouches[0]); onContextMenu((e as TouchEvent).changedTouches[0]);
} }
}); });

View File

@ -442,3 +442,37 @@ export function blurActiveElement() {
} }
export const CLICK_EVENT_NAME = isTouchSupported ? 'touchend' : 'click'; export const CLICK_EVENT_NAME = isTouchSupported ? 'touchend' : 'click';
export const attachClickEvent = (elem: HTMLElement, callback: (e: TouchEvent | MouseEvent) => void, options?: AddEventListenerOptions) => {
if(CLICK_EVENT_NAME == 'touchend') {
const o = {...options, once: true};
const onTouchStart = (e: TouchEvent) => {
const onTouchMove = (e: TouchEvent) => {
elem.removeEventListener('touchend', onTouchEnd, o);
};
const onTouchEnd = (e: TouchEvent) => {
elem.removeEventListener('touchmove', onTouchMove, o);
callback(e);
if(options.once) {
elem.removeEventListener('touchstart', onTouchStart);
}
};
elem.addEventListener('touchend', onTouchEnd, o);
elem.addEventListener('touchmove', onTouchMove, o);
};
elem.addEventListener('touchstart', onTouchStart);
} else {
elem.addEventListener(CLICK_EVENT_NAME, callback, options);
}
};
export const detachClickEvent = (elem: HTMLElement, callback: (e: TouchEvent | MouseEvent) => void, options?: AddEventListenerOptions) => {
if(CLICK_EVENT_NAME == 'touchend') {
elem.removeEventListener('touchstart', callback, options);
} else {
elem.removeEventListener(CLICK_EVENT_NAME, callback, options);
}
};

View File

@ -723,7 +723,11 @@ namespace RichTextProcessor {
export function wrapDraftText(text: string, options: Partial<{ export function wrapDraftText(text: string, options: Partial<{
entities: MessageEntity[] entities: MessageEntity[]
}> = {}) { }> = {}) {
let entities = options.entities.slice(); if(!text) {
return '';
}
let entities = (options.entities || []).slice();
if(emojiSupported) { // * fix safari emoji if(emojiSupported) { // * fix safari emoji
entities = entities.filter(e => e._ != 'messageEntityEmoji'); entities = entities.filter(e => e._ != 'messageEntityEmoji');
} }

View File

@ -353,6 +353,7 @@ $chat-helper-size: 39px;
> .tgico { > .tgico {
position: absolute; position: absolute;
animation: hide-icon .4s forwards ease-in-out; animation: hide-icon .4s forwards ease-in-out;
height: 24px;
} }
&.send { &.send {