/* * https://github.com/morethanwords/tweb * Copyright (C) 2019-2021 Eduard Kuzmenko * https://github.com/morethanwords/tweb/blob/master/LICENSE */ import { formatTime, getFullDate } from "../../helpers/date"; import { formatNumber } from "../../helpers/number"; import { Message } from "../../layer"; import { i18n, _i18n } from "../../lib/langPack"; import RichTextProcessor from "../../lib/richtextprocessor"; import { LazyLoadQueueIntersector } from "../lazyLoadQueue"; import PeerTitle from "../peerTitle"; import { wrapReply } from "../wrappers"; import Chat from "./chat"; import RepliesElement from "./replies"; export namespace MessageRender { /* export const setText = () => { }; */ export const setTime = (chat: Chat, message: Message.message, bubble: HTMLElement, bubbleContainer: HTMLElement, messageDiv: HTMLElement) => { const date = new Date(message.date * 1000); const args: (HTMLElement | string)[] = []; let time = formatTime(date); if(message.views) { const postAuthor = message.post_author || message.fwd_from?.post_author; bubble.classList.add('channel-post'); const postViewsSpan = document.createElement('span'); postViewsSpan.classList.add('post-views'); postViewsSpan.innerText = formatNumber(message.views, 1); const channelViews = document.createElement('i'); channelViews.classList.add('tgico-channelviews', 'time-icon'); args.push(postViewsSpan, ' ', channelViews); if(postAuthor) { const span = document.createElement('span'); span.innerHTML = RichTextProcessor.wrapEmojiText(postAuthor); args.push(span, ', '); } } if(message.edit_date && chat.type !== 'scheduled' && !message.pFlags.edit_hide) { bubble.classList.add('is-edited'); const edited = document.createElement('i'); edited.classList.add('edited'); _i18n(edited, 'EditedMessage'); args.unshift(edited); } if(chat.type !== 'pinned' && message.pFlags.pinned) { bubble.classList.add('is-pinned'); const i = document.createElement('i'); i.classList.add('tgico-pinnedchat', 'time-icon'); args.unshift(i); } args.push(time); const title = getFullDate(date) + (message.edit_date ? `\nEdited: ${getFullDate(new Date(message.edit_date * 1000))}` : '') + (message.fwd_from ? `\nOriginal: ${getFullDate(new Date(message.fwd_from.date * 1000))}` : ''); const timeSpan = document.createElement('span'); timeSpan.classList.add('time', 'tgico'); timeSpan.title = title; timeSpan.append(...args); const inner = document.createElement('div'); inner.classList.add('inner', 'tgico'); inner.title = title; const clonedArgs = args.slice(0, -1).map(a => a instanceof HTMLElement ? a.cloneNode(true) : a); clonedArgs.push(formatTime(date)); // clone time inner.append(...clonedArgs); timeSpan.append(inner); messageDiv.append(timeSpan); return timeSpan; }; export const renderReplies = ({bubble, bubbleContainer, message, messageDiv, loadPromises, lazyLoadQueue}: { bubble: HTMLElement, bubbleContainer: HTMLElement, message: Message.message, messageDiv: HTMLElement, loadPromises?: Promise[], lazyLoadQueue?: LazyLoadQueueIntersector }) => { const isFooter = !bubble.classList.contains('sticker') && !bubble.classList.contains('emoji-big') && !bubble.classList.contains('round'); const repliesFooter = new RepliesElement(); repliesFooter.message = message; repliesFooter.type = isFooter ? 'footer' : 'beside'; repliesFooter.loadPromises = loadPromises; repliesFooter.lazyLoadQueue = lazyLoadQueue; repliesFooter.init(); bubbleContainer.prepend(repliesFooter); return isFooter; }; export const setReply = ({chat, bubble, bubbleContainer, message}: { chat: Chat, bubble: HTMLElement, bubbleContainer?: HTMLElement, message: Message.message }) => { const isReplacing = !bubbleContainer; if(isReplacing) { bubbleContainer = bubble.querySelector('.bubble-content'); } const currentReplyDiv = isReplacing ? bubbleContainer.querySelector('.reply') : null; if(!message.reply_to_mid) { if(currentReplyDiv) { currentReplyDiv.remove(); } bubble.classList.remove('is-reply'); return; } const replyToPeerId = message.reply_to.reply_to_peer_id ? chat.appPeersManager.getPeerId(message.reply_to.reply_to_peer_id) : chat.peerId; let originalMessage = chat.appMessagesManager.getMessageByPeer(replyToPeerId, message.reply_to_mid); let originalPeerTitle: string | HTMLElement; /////////this.log('message to render reply', originalMessage, originalPeerTitle, bubble, message); // need to download separately if(originalMessage._ === 'messageEmpty') { //////////this.log('message to render reply empty, need download', message, message.reply_to_mid); chat.appMessagesManager.wrapSingleMessage(replyToPeerId, message.reply_to_mid); chat.bubbles.needUpdate.push({replyToPeerId, replyMid: message.reply_to_mid, mid: message.mid}); originalPeerTitle = i18n('Loading'); } else { originalPeerTitle = new PeerTitle({ peerId: originalMessage.fromId || originalMessage.fwdFromId, dialog: false, onlyFirstName: false, plainText: false }).element; } const wrapped = wrapReply(originalPeerTitle, undefined, originalMessage); if(currentReplyDiv) { currentReplyDiv.replaceWith(wrapped); } else { bubbleContainer.append(wrapped); } //bubbleContainer.insertBefore(, nameContainer); bubble.classList.add('is-reply'); }; }