Empty folder placeholder

Fix long text overflow in service messages
Fix two stickers margin in stickers helper
This commit is contained in:
morethanwords 2021-06-03 16:14:43 +03:00
parent 7a1ad9f879
commit 29485c058f
6 changed files with 58 additions and 49 deletions

View File

@ -528,13 +528,15 @@ export default class ChatBubbles {
this.setMessagesQueuePromise(); this.setMessagesQueuePromise();
} }
for(const mid in this.bubbles) { const mids = getObjectKeysAndSort(this.bubbles, 'desc');
mids.forEach(mid => {
const bubble = this.bubbles[mid]; const bubble = this.bubbles[mid];
if(bubble.classList.contains('can-have-big-emoji')) { if(bubble.classList.contains('can-have-big-emoji')) {
const message = this.chat.getMessage(+mid); const message = this.chat.getMessage(mid);
this.renderMessage(message, undefined, false, bubble); this.renderMessage(message, undefined, false, bubble);
// this.bubbleGroups.addBubble(bubble, message, false);
} }
} });
if(isScrolledDown) { if(isScrolledDown) {
this.scrollable.scrollTop = 99999; this.scrollable.scrollTop = 99999;

View File

@ -90,7 +90,8 @@ export default class StickersHelper extends AutocompleteHelper {
if(!this.onChangeScreen) { if(!this.onChangeScreen) {
this.onChangeScreen = () => { this.onChangeScreen = () => {
this.list.style.width = this.list.childElementCount * mediaSizes.active.esgSticker.width + 'px'; const width = (this.list.childElementCount * mediaSizes.active.esgSticker.width) + (this.list.childElementCount - 1 * 1);
this.list.style.width = width + 'px';
}; };
mediaSizes.addEventListener('changeScreen', this.onChangeScreen); mediaSizes.addEventListener('changeScreen', this.onChangeScreen);
} }

View File

@ -15,18 +15,13 @@ export default class AppArchivedTab extends SliderSuperTab {
this.container.id = 'chats-archived-container'; this.container.id = 'chats-archived-container';
this.setTitle('ArchivedChats'); this.setTitle('ArchivedChats');
//this.scrollable = new Scrollable(this.container, 'CLA', 500); if(!appDialogsManager.chatLists[AppArchivedTab.filterId]) {
const chatList = appDialogsManager.chatLists[AppArchivedTab.filterId]; appDialogsManager.generateScrollable(appDialogsManager.createChatList(), AppArchivedTab.filterId);
this.scrollable.append(chatList); }
this.scrollable.container.addEventListener('scroll', appDialogsManager.onChatsRegularScroll);
this.scrollable.setVirtualContainer(chatList);
this.scrollable.onScrolledTop = appDialogsManager.onChatsScrollTop;
this.scrollable.onScrolledBottom = appDialogsManager.onChatsScroll;
///this.scroll.attachSentinels();
this.listenerSetter.add(window, 'resize', () => { const scrollable = appDialogsManager.scrollables[AppArchivedTab.filterId];
setTimeout(appDialogsManager.scroll.checkForTriggers, 0); this.scrollable.container.replaceWith(scrollable.container);
}); this.scrollable = scrollable;
} }
onOpen() { onOpen() {
@ -36,7 +31,6 @@ export default class AppArchivedTab extends SliderSuperTab {
} }
this.wasFilterId = appDialogsManager.filterId; this.wasFilterId = appDialogsManager.filterId;
appDialogsManager.scroll = this.scrollable;
appDialogsManager.filterId = AppArchivedTab.filterId; appDialogsManager.filterId = AppArchivedTab.filterId;
appDialogsManager.onTabChange(); appDialogsManager.onTabChange();
} }
@ -47,7 +41,6 @@ export default class AppArchivedTab extends SliderSuperTab {
} }
onClose() { onClose() {
appDialogsManager.scroll = appDialogsManager._scroll;
appDialogsManager.filterId = this.wasFilterId; appDialogsManager.filterId = this.wasFilterId;
appDialogsManager.onTabChange(); appDialogsManager.onTabChange();
} }

View File

@ -196,23 +196,23 @@ class ConnectionStatusComponent {
} }
export class AppDialogsManager { export class AppDialogsManager {
public chatList: HTMLUListElement; private chatList: HTMLUListElement;
public doms: {[peerId: number]: DialogDom} = {}; private doms: {[peerId: number]: DialogDom} = {};
public chatsContainer = document.getElementById('chatlist-container') as HTMLDivElement; private chatsContainer = document.getElementById('chatlist-container') as HTMLDivElement;
private chatsPreloader: HTMLElement; private chatsPreloader: HTMLElement;
public loadDialogsPromise: Promise<any>; private loadDialogsPromise: Promise<any>;
public scroll: Scrollable = null; private scroll: Scrollable = null;
public _scroll: Scrollable = null;
private log = logger('DIALOGS', LogTypes.Log | LogTypes.Error | LogTypes.Warn | LogTypes.Debug); private log = logger('DIALOGS', LogTypes.Log | LogTypes.Error | LogTypes.Warn | LogTypes.Debug);
public contextMenu = new DialogsContextMenu(); private contextMenu = new DialogsContextMenu();
public chatLists: {[filterId: number]: HTMLUListElement}; public chatLists: {[filterId: number]: HTMLUListElement};
public scrollables: {[filterId: number]: Scrollable} = {};
public filterId: number; public filterId: number;
private folders: {[k in 'menu' | 'container' | 'menuScrollContainer']: HTMLElement} = { private folders: {[k in 'menu' | 'container' | 'menuScrollContainer']: HTMLElement} = {
menu: document.getElementById('folders-tabs'), menu: document.getElementById('folders-tabs'),
@ -244,6 +244,9 @@ export class AppDialogsManager {
this.chatLists = { this.chatLists = {
1: archivedChatList 1: archivedChatList
}; };
this.scrollables = {
1: this.generateScrollable(this.chatLists[1], 1)
};
this.setListClickListener(archivedChatList, null, true); this.setListClickListener(archivedChatList, null, true);
//this.setListClickListener(archivedChatList, null, true); // * to test peer changing //this.setListClickListener(archivedChatList, null, true); // * to test peer changing
@ -258,12 +261,6 @@ export class AppDialogsManager {
bottomPart.classList.add('connection-status-bottom'); bottomPart.classList.add('connection-status-bottom');
bottomPart.append(this.folders.container); bottomPart.append(this.folders.container);
this.scroll = this._scroll = new Scrollable(bottomPart, 'CL', 500);
/* this.scroll.container.addEventListener('scroll', this.onChatsRegularScroll);
this.scroll.onScrolledTop = this.onChatsScrollTop;
this.scroll.onScrolledBottom = this.onChatsScroll; */
//this.scroll.attachSentinels();
/* if(isTouchSupported && isSafari) { /* if(isTouchSupported && isSafari) {
let allowUp: boolean, allowDown: boolean, slideBeginY: number; let allowUp: boolean, allowDown: boolean, slideBeginY: number;
const container = this.scroll.container; const container = this.scroll.container;
@ -295,7 +292,7 @@ export class AppDialogsManager {
}); });
this.chatList = this.chatLists[this.filterId]; this.chatList = this.chatLists[this.filterId];
this.scroll.setVirtualContainer(this.chatList); this.scroll = this.scrollables[this.filterId];
/* if(testScroll) { /* if(testScroll) {
let i = 0; let i = 0;
@ -486,7 +483,6 @@ export class AppDialogsManager {
if(this.filterId === id) return; if(this.filterId === id) return;
this.chatLists[id].innerHTML = ''; this.chatLists[id].innerHTML = '';
this.scroll.setVirtualContainer(this.chatLists[id]);
this.filterId = id; this.filterId = id;
this.onTabChange(); this.onTabChange();
}, () => { }, () => {
@ -631,8 +627,9 @@ export class AppDialogsManager {
} }
} }
onTabChange = () => { public onTabChange = () => {
this.doms = {}; this.doms = {};
this.scroll = this.scrollables[this.filterId];
this.scroll.loadedAll.top = true; this.scroll.loadedAll.top = true;
this.scroll.loadedAll.bottom = false; this.scroll.loadedAll.bottom = false;
this.loadDialogsPromise = undefined; this.loadDialogsPromise = undefined;
@ -693,6 +690,21 @@ export class AppDialogsManager {
} }
} }
public generateScrollable(list: HTMLUListElement, filterId: number) {
const scrollable = new Scrollable(null, 'CL', 500);
scrollable.container.addEventListener('scroll', this.onChatsRegularScroll);
scrollable.container.dataset.filterId = '' + filterId;
scrollable.container.append(list);
scrollable.onScrolledTop = this.onChatsScrollTop;
scrollable.onScrolledBottom = this.onChatsScroll;
scrollable.setVirtualContainer(list);
this.chatLists[filterId] = list;
this.scrollables[filterId] = scrollable;
return scrollable;
}
private addFilter(filter: Pick<DialogFilter, 'title' | 'id' | 'orderIndex'> & Partial<{titleEl: HTMLElement}>) { private addFilter(filter: Pick<DialogFilter, 'title' | 'id' | 'orderIndex'> & Partial<{titleEl: HTMLElement}>) {
if(this.filtersRendered[filter.id]) return; if(this.filtersRendered[filter.id]) return;
@ -715,16 +727,11 @@ export class AppDialogsManager {
//containerToAppend.append(li); //containerToAppend.append(li);
const ul = this.createChatList(); const ul = this.createChatList();
const scrollable = new Scrollable(null, 'CL', 500); const scrollable = this.generateScrollable(ul, filter.id);
const div = scrollable.container; const div = scrollable.container;
div.append(ul);
div.dataset.filterId = '' + filter.id;
scrollable.onScrolledTop = this.onChatsScrollTop;
scrollable.onScrolledBottom = this.onChatsScroll;
//this.folders.container.append(div); //this.folders.container.append(div);
positionElementByIndex(div, this.folders.container, filter.orderIndex); positionElementByIndex(scrollable.container, this.folders.container, filter.orderIndex);
this.chatLists[filter.id] = ul;
this.setListClickListener(ul, null, true); this.setListClickListener(ul, null, true);
this.filtersRendered[filter.id] = { this.filtersRendered[filter.id] = {
@ -909,14 +916,18 @@ export class AppDialogsManager {
observer.observe(el); observer.observe(el);
}); */ }); */
//const scrollTopWas = this.scroll.scrollTop; const scrollTopWas = this.scroll.scrollTop;
const firstElementChild = this.chatList.firstElementChild; const firstElementChild = this.chatList.firstElementChild;
const rectContainer = this.scroll.container.getBoundingClientRect(); const rectContainer = this.scroll.container.getBoundingClientRect();
const rectTarget = firstElementChild.getBoundingClientRect(); const rectTarget = firstElementChild.getBoundingClientRect();
const children = Array.from(this.scroll.splitUp.children) as HTMLElement[]; const children = Array.from(this.scroll.splitUp.children) as HTMLElement[];
const offsetTop = this.folders.container.offsetTop; // const padding = 8;
// const offsetTop = this.folders.container.offsetTop;
let offsetTop = this.scroll.splitUp.offsetTop;
if(offsetTop && scrollTopWas < offsetTop) offsetTop -= scrollTopWas;
// const offsetTop = scrollTopWas < padding ? padding - scrollTopWas : 0;
const firstY = rectContainer.y + offsetTop; const firstY = rectContainer.y + offsetTop;
const lastY = rectContainer.y/* - 8 */; // 8px - .chatlist padding-bottom const lastY = rectContainer.y/* - 8 */; // 8px - .chatlist padding-bottom

View File

@ -1671,6 +1671,7 @@ $bubble-margin: .25rem;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
text-align: center; text-align: center;
word-break: break-word;
i { i {
font-style: normal; font-style: normal;

View File

@ -124,13 +124,17 @@
//line-height: inherit !important; //line-height: inherit !important;
} }
&:not(.hide) + .scrollable { &:not(.hide) + #folders-container {
top: var(--menu-size);
height: calc(100% - var(--menu-size)); height: calc(100% - var(--menu-size));
position: relative;
#folders-container { .scrollable {
margin-top: .5rem; padding-top: .5rem;
} }
/* .chatlist {
top: .5rem;
} */
} }
} }
@ -232,12 +236,9 @@
} }
#folders-container { #folders-container {
min-height: 100%;
> div { > div {
background-color: transparent; background-color: transparent;
position: absolute; position: absolute;
top: .5rem;
} }
} }