Fix scroll interrupting by message render

Fix is-selected render message
Hide chat input for deleted account
This commit is contained in:
morethanwords 2020-10-11 16:14:58 +03:00
parent c69c6a841b
commit 28b6653e65
3 changed files with 27 additions and 9 deletions

View File

@ -1,3 +1,4 @@
import { CancellablePromise, deferredPromise } from "../helpers/cancellablePromise";
import { isTouchSupported } from "../helpers/touchSupport"; import { isTouchSupported } from "../helpers/touchSupport";
import { logger, LogLevels } from "../lib/logger"; import { logger, LogLevels } from "../lib/logger";
import smoothscroll, { SCROLL_TIME, SmoothScrollToOptions } from '../vendor/smoothscroll'; import smoothscroll, { SCROLL_TIME, SmoothScrollToOptions } from '../vendor/smoothscroll';
@ -55,6 +56,7 @@ export class ScrollableBase {
public getScrollValue: () => number; public getScrollValue: () => number;
public scrollLocked = 0; public scrollLocked = 0;
public scrollLockedPromise: CancellablePromise<void> = Promise.resolve();
constructor(public el: HTMLElement, logPrefix = '', public appendTo = el, public container: HTMLElement = document.createElement('div')) { constructor(public el: HTMLElement, logPrefix = '', public appendTo = el, public container: HTMLElement = document.createElement('div')) {
this.container.classList.add('scrollable'); this.container.classList.add('scrollable');
@ -103,13 +105,13 @@ export class ScrollableBase {
} }
if(this.scrollLocked) clearTimeout(this.scrollLocked); if(this.scrollLocked) clearTimeout(this.scrollLocked);
/* else { else {
this.scrollLockedPromise = deferredPromise<void>(); this.scrollLockedPromise = deferredPromise<void>();
} */ }
this.scrollLocked = window.setTimeout(() => { this.scrollLocked = window.setTimeout(() => {
this.scrollLocked = 0; this.scrollLocked = 0;
//this.scrollLockedPromise.resolve(); this.scrollLockedPromise.resolve();
//this.onScroll(); //this.onScroll();
this.container.dispatchEvent(new CustomEvent('scroll')); this.container.dispatchEvent(new CustomEvent('scroll'));
}, scrollTime); }, scrollTime);
@ -156,7 +158,6 @@ export default class Scrollable extends ScrollableBase {
/* private onScrolledTopFired = false; /* private onScrolledTopFired = false;
private onScrolledBottomFired = false; */ private onScrolledBottomFired = false; */
//public scrollLockedPromise: CancellablePromise<void> = Promise.resolve();
public isVisible = false; public isVisible = false;
private reorderTimeout: number; private reorderTimeout: number;

View File

@ -334,6 +334,10 @@ export class AppImManager {
}); });
} }
/* const promise = (this.scrollable.scrollLocked && this.scrollable.scrollLockedPromise) || Promise.resolve();
promise.then(() => {
}); */
this.needUpdate.forEachReverse((obj, idx) => { this.needUpdate.forEachReverse((obj, idx) => {
if(obj.replyMid == mid) { if(obj.replyMid == mid) {
let {mid, replyMid} = this.needUpdate.splice(idx, 1)[0]; let {mid, replyMid} = this.needUpdate.splice(idx, 1)[0];
@ -1268,7 +1272,10 @@ export class AppImManager {
const hasRights = isChannel && appChatsManager.hasRights(-peerID, 'send'); const hasRights = isChannel && appChatsManager.hasRights(-peerID, 'send');
this.chatInner.classList.toggle('has-rights', hasRights); this.chatInner.classList.toggle('has-rights', hasRights);
this.chatInput.style.display = !isChannel || hasRights ? '' : 'none'; const canWrite = (!isChannel || hasRights) && (peerID < 0 || !appUsersManager.getUser(peerID).pFlags.deleted);
this.chatInput.style.display = canWrite ? '' : 'none';
this.chatInner.classList.toggle('is-chat-input-hidden', !canWrite);
this.topbar.classList.remove('is-pinned-shown'); this.topbar.classList.remove('is-pinned-shown');
this.topbar.style.display = ''; this.topbar.style.display = '';
@ -1498,6 +1505,12 @@ export class AppImManager {
this.messagesQueue.length = 0; this.messagesQueue.length = 0;
const promises = queue.reduce((acc, {promises}) => acc.concat(promises), []); const promises = queue.reduce((acc, {promises}) => acc.concat(promises), []);
// * это нужно для того, чтобы если захочет подгрузить reply или какое-либо сообщение, то скролл не прервался
if(this.scrollable.scrollLocked) {
promises.push(this.scrollable.scrollLockedPromise);
}
//this.log('promises to call', promises, queue); //this.log('promises to call', promises, queue);
Promise.all(promises).then(() => { Promise.all(promises).then(() => {
if(this.chatInner != chatInner) { if(this.chatInner != chatInner) {
@ -1566,7 +1579,11 @@ export class AppImManager {
bubble.appendChild(bubbleContainer); bubble.appendChild(bubbleContainer);
this.bubbles[+message.mid] = bubble; this.bubbles[+message.mid] = bubble;
} else { } else {
bubble.className = 'bubble'; const save = ['is-selected'];
const wasClassNames = bubble.className.split(' ');
const classNames = ['bubble'].concat(save.filter(c => wasClassNames.includes(c)));
bubble.className = classNames.join(' ');
bubbleContainer = bubble.firstElementChild as HTMLDivElement; bubbleContainer = bubble.firstElementChild as HTMLDivElement;
bubbleContainer.innerHTML = ''; bubbleContainer.innerHTML = '';
bubbleContainer.style.marginBottom = ''; bubbleContainer.style.marginBottom = '';

View File

@ -1088,10 +1088,10 @@
max-width: calc(100% - var(--message-beside-button-margin)) !important; max-width: calc(100% - var(--message-beside-button-margin)) !important;
} }
} }
}
&:not(.has-rights) { &.is-chat-input-hidden {
padding-bottom: 55px; padding-bottom: 55px;
}
} }
&:not(.is-channel), &.is-chat { &:not(.is-channel), &.is-chat {