Fix 'forwarded messages' subtitle

Suggest deleting the message that being edited
Fix changing webpage on input
This commit is contained in:
morethanwords 2021-08-09 21:47:45 +03:00
parent 3547a42a3e
commit 645286a40e

View File

@ -32,10 +32,9 @@ import PopupNewMedia from '../popups/newMedia';
import { toast } from "../toast"; import { toast } from "../toast";
import { wrapReply } from "../wrappers"; import { wrapReply } from "../wrappers";
import InputField from '../inputField'; import InputField from '../inputField';
import { MessageEntity, DraftMessage } from '../../layer'; import { MessageEntity, DraftMessage, WebPage } from '../../layer';
import StickersHelper from './stickersHelper'; import StickersHelper from './stickersHelper';
import ButtonIcon from '../buttonIcon'; import ButtonIcon from '../buttonIcon';
import DivAndCaption from '../divAndCaption';
import ButtonMenuToggle from '../buttonMenuToggle'; import ButtonMenuToggle from '../buttonMenuToggle';
import ListenerSetter from '../../helpers/listenerSetter'; import ListenerSetter from '../../helpers/listenerSetter';
import Button from '../button'; import Button from '../button';
@ -46,7 +45,7 @@ import PopupPinMessage from '../popups/unpinMessage';
import { tsNow } from '../../helpers/date'; import { tsNow } from '../../helpers/date';
import appNavigationController from '../appNavigationController'; import appNavigationController from '../appNavigationController';
import { isMobile, isMobileSafari } from '../../helpers/userAgent'; import { isMobile, isMobileSafari } from '../../helpers/userAgent';
import { i18n } from '../../lib/langPack'; import { i18n, join } from '../../lib/langPack';
import { generateTail } from './bubbles'; import { generateTail } from './bubbles';
import findUpClassName from '../../helpers/dom/findUpClassName'; import findUpClassName from '../../helpers/dom/findUpClassName';
import ButtonCorner from '../buttonCorner'; import ButtonCorner from '../buttonCorner';
@ -76,6 +75,8 @@ import { putPreloader } from '../misc';
import SetTransition from '../singleTransition'; import SetTransition from '../singleTransition';
import replaceContent from '../../helpers/dom/replaceContent'; import replaceContent from '../../helpers/dom/replaceContent';
import PeerTitle from '../peerTitle'; import PeerTitle from '../peerTitle';
import { fastRaf } from '../../helpers/schedulers';
import PopupDeleteMessages from '../popups/deleteMessages';
const RECORD_MIN_TIME = 500; const RECORD_MIN_TIME = 500;
const POSTING_MEDIA_NOT_ALLOWED = 'Posting media content isn\'t allowed in this group.'; const POSTING_MEDIA_NOT_ALLOWED = 'Posting media content isn\'t allowed in this group.';
@ -114,7 +115,8 @@ export default class ChatInput {
cancelBtn: HTMLButtonElement cancelBtn: HTMLButtonElement
} = {} as any; } = {} as any;
private willSendWebPage: any = null; private getWebPagePromise: Promise<void>;
private willSendWebPage: WebPage = null;
private forwardingMids: number[] = []; private forwardingMids: number[] = [];
private forwardingFromPeerId: number = 0; private forwardingFromPeerId: number = 0;
public replyToMsgId: number; public replyToMsgId: number;
@ -484,6 +486,20 @@ export default class ChatInput {
} }
}); });
if(this.chat.type === 'scheduled') {
this.listenerSetter.add(rootScope)('scheduled_delete', ({peerId, mids}) => {
if(this.chat.peerId === peerId && mids.includes(this.editMsgId)) {
this.onMessageSent();
}
});
} else {
this.listenerSetter.add(rootScope)('history_delete', ({peerId, msgs}) => {
if(this.chat.peerId === peerId && msgs[this.editMsgId]) {
this.onMessageSent();
}
});
}
try { try {
this.recorder = new Recorder({ this.recorder = new Recorder({
//encoderBitRate: 32, //encoderBitRate: 32,
@ -1122,20 +1138,21 @@ export default class ChatInput {
if(this.lastUrl !== url) { if(this.lastUrl !== url) {
this.lastUrl = url; this.lastUrl = url;
this.willSendWebPage = null; // this.willSendWebPage = null;
apiManager.invokeApi('messages.getWebPage', { const promise = this.getWebPagePromise = apiManager.invokeApiHashable('messages.getWebPage', {
url, url,
hash: 0
}).then((webpage) => { }).then((webpage) => {
webpage = this.appWebPagesManager.saveWebPage(webpage); webpage = this.appWebPagesManager.saveWebPage(webpage);
if(this.getWebPagePromise === promise) this.getWebPagePromise = undefined;
if(this.lastUrl !== url) return;
if(webpage._ === 'webPage') { if(webpage._ === 'webPage') {
if(this.lastUrl !== url) return;
//console.log('got webpage: ', webpage); //console.log('got webpage: ', webpage);
this.setTopInfo('webpage', () => {}, webpage.site_name || webpage.title || 'Webpage', webpage.description || webpage.url || ''); this.setTopInfo('webpage', () => {}, webpage.site_name || webpage.title || 'Webpage', webpage.description || webpage.url || '');
delete this.noWebPage; delete this.noWebPage;
this.willSendWebPage = webpage; this.willSendWebPage = webpage;
} else if(this.willSendWebPage) {
this.onHelperCancel();
} }
}); });
} }
@ -1478,6 +1495,7 @@ export default class ChatInput {
const mids = this.forwardingMids.slice(); const mids = this.forwardingMids.slice();
const helperFunc = this.helperFunc; const helperFunc = this.helperFunc;
this.clearHelper(); this.clearHelper();
this.updateSendBtn();
let selected = false; let selected = false;
new PopupForward(fromId, mids, () => { new PopupForward(fromId, mids, () => {
selected = true; selected = true;
@ -1596,17 +1614,23 @@ export default class ChatInput {
//return; //return;
if(this.editMsgId) { if(this.editMsgId) {
this.appMessagesManager.editMessage(this.chat.getMessage(this.editMsgId), value, { if(!!value.trim()) {
entities, this.appMessagesManager.editMessage(this.chat.getMessage(this.editMsgId), value, {
noWebPage: this.noWebPage entities,
}); noWebPage: this.noWebPage
});
} else {
new PopupDeleteMessages(this.chat.peerId, [this.editMsgId], this.chat.type);
return;
}
} else { } else {
this.appMessagesManager.sendText(this.chat.peerId, value, { this.appMessagesManager.sendText(this.chat.peerId, value, {
entities, entities,
replyToMsgId: this.replyToMsgId, replyToMsgId: this.replyToMsgId,
threadId: this.chat.threadId, threadId: this.chat.threadId,
noWebPage: this.noWebPage, noWebPage: this.noWebPage,
webPage: this.willSendWebPage, webPage: this.getWebPagePromise ? undefined : this.willSendWebPage,
scheduleDate: this.scheduleDate, scheduleDate: this.scheduleDate,
silent: this.sendSilent, silent: this.sendSilent,
clearDraft: true clearDraft: true
@ -1683,11 +1707,8 @@ export default class ChatInput {
let input = RichTextProcessor.wrapDraftText(message.message, {entities: message.totalEntities}); let input = RichTextProcessor.wrapDraftText(message.message, {entities: message.totalEntities});
const f = () => { const f = () => {
// ! костыль
const replyFragment = this.appMessagesManager.wrapMessageForReply(message, undefined, [message.mid]); const replyFragment = this.appMessagesManager.wrapMessageForReply(message, undefined, [message.mid]);
this.setTopInfo('edit', f, 'Editing', undefined, input, message); this.setTopInfo('edit', f, i18n('AccDescrEditing'), replyFragment, input, message);
const subtitleEl = this.replyElements.container.querySelector('.reply-subtitle') as HTMLElement;
replaceContent(subtitleEl, replyFragment);
this.editMsgId = mid; this.editMsgId = mid;
input = undefined; input = undefined;
@ -1707,17 +1728,23 @@ export default class ChatInput {
} }
})); }));
const onlyFirstName = smth.size > 1; const onlyFirstName = smth.size > 2;
const peerTitles = [...smth].map(smth => { const peerTitles = [...smth].map(smth => {
return typeof(smth) === 'number' ? return typeof(smth) === 'number' ?
this.appPeersManager.getPeerTitle(smth, true, onlyFirstName) : new PeerTitle({peerId: smth, dialog: false, onlyFirstName}).element :
(onlyFirstName ? smth.split(' ')[0] : smth); (onlyFirstName ? smth.split(' ')[0] : smth);
}); });
const title = peerTitles.length < 3 ? peerTitles.join(' and ') : peerTitles[0] + ' and ' + (peerTitles.length - 1) + ' others'; const title = document.createDocumentFragment();
if(peerTitles.length < 3) {
title.append(...join(peerTitles, false));
} else {
title.append(peerTitles[0], i18n('AndOther', [peerTitles.length - 1]));
}
const firstMessage = this.appMessagesManager.getMessageByPeer(fromPeerId, mids[0]); const firstMessage = this.appMessagesManager.getMessageByPeer(fromPeerId, mids[0]);
let usingFullAlbum = true; let usingFullAlbum = !!firstMessage.grouped_id;
if(firstMessage.grouped_id) { if(firstMessage.grouped_id) {
const albumMids = this.appMessagesManager.getMidsByMessage(firstMessage); const albumMids = this.appMessagesManager.getMidsByMessage(firstMessage);
if(albumMids.length !== mids.length || albumMids.find(mid => !mids.includes(mid))) { if(albumMids.length !== mids.length || albumMids.find(mid => !mids.includes(mid))) {
@ -1727,13 +1754,9 @@ export default class ChatInput {
const replyFragment = this.appMessagesManager.wrapMessageForReply(firstMessage, undefined, mids); const replyFragment = this.appMessagesManager.wrapMessageForReply(firstMessage, undefined, mids);
if(usingFullAlbum || mids.length === 1) { if(usingFullAlbum || mids.length === 1) {
this.setTopInfo('forward', f, title); this.setTopInfo('forward', f, title, replyFragment);
// ! костыль
const subtitleEl = this.replyElements.container.querySelector('.reply-subtitle') as HTMLElement;
replaceContent(subtitleEl, replyFragment);
} else { } else {
this.setTopInfo('forward', f, title, mids.length + ' ' + (mids.length > 1 ? 'forwarded messages' : 'forwarded message')); this.setTopInfo('forward', f, title, i18n('ForwardedMessageCount', [mids.length]));
} }
this.forwardingMids = mids.slice(); this.forwardingMids = mids.slice();
@ -1785,7 +1808,7 @@ export default class ChatInput {
if(clear) this.clearInput(false, false, value); if(clear) this.clearInput(false, false, value);
else this.messageInputField.setValueSilently(value); else this.messageInputField.setValueSilently(value);
window.requestAnimationFrame(() => { fastRaf(() => {
focus && placeCaretAtEnd(this.messageInput); focus && placeCaretAtEnd(this.messageInput);
this.onMessageInput(); this.onMessageInput();
this.messageInput.scrollTop = this.messageInput.scrollHeight; this.messageInput.scrollTop = this.messageInput.scrollHeight;
@ -1794,8 +1817,8 @@ export default class ChatInput {
public setTopInfo(type: ChatInputHelperType, public setTopInfo(type: ChatInputHelperType,
callerFunc: () => void, callerFunc: () => void,
title: HTMLElement | string = '', title: Parameters<typeof wrapReply>[0] = '',
subtitle: HTMLElement | string = '', subtitle: Parameters<typeof wrapReply>[1] = '',
input?: string, input?: string,
message?: any) { message?: any) {
if(type !== 'webpage') { if(type !== 'webpage') {