Fix 'forwarded messages' subtitle
Suggest deleting the message that being edited Fix changing webpage on input
This commit is contained in:
parent
3547a42a3e
commit
645286a40e
@ -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(webpage._ === 'webPage') {
|
if(this.getWebPagePromise === promise) this.getWebPagePromise = undefined;
|
||||||
if(this.lastUrl !== url) return;
|
if(this.lastUrl !== url) return;
|
||||||
|
if(webpage._ === 'webPage') {
|
||||||
//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) {
|
||||||
|
if(!!value.trim()) {
|
||||||
this.appMessagesManager.editMessage(this.chat.getMessage(this.editMsgId), value, {
|
this.appMessagesManager.editMessage(this.chat.getMessage(this.editMsgId), value, {
|
||||||
entities,
|
entities,
|
||||||
noWebPage: this.noWebPage
|
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') {
|
||||||
|
Loading…
Reference in New Issue
Block a user