Restrict selecting service messages

Fix returning by chat back button
This commit is contained in:
Eduard Kuzmenko 2020-12-23 05:40:30 +02:00
parent aa7ddf8004
commit c5570cd7af
7 changed files with 25 additions and 15 deletions

View File

@ -3,7 +3,7 @@ import type { AppPeersManager } from "../../lib/appManagers/appPeersManager";
import type ChatTopbar from "./topbar"; import type ChatTopbar from "./topbar";
import { RichTextProcessor } from "../../lib/richtextprocessor"; import { RichTextProcessor } from "../../lib/richtextprocessor";
import rootScope from "../../lib/rootScope"; import rootScope from "../../lib/rootScope";
import { cancelEvent } from "../../helpers/dom"; import { attachClickEvent, cancelEvent } from "../../helpers/dom";
import appMediaPlaybackController from "../appMediaPlaybackController"; import appMediaPlaybackController from "../appMediaPlaybackController";
import DivAndCaption from "../divAndCaption"; import DivAndCaption from "../divAndCaption";
import { formatDate } from "../wrappers"; import { formatDate } from "../wrappers";
@ -27,10 +27,10 @@ export default class ChatAudio extends PinnedContainer {
this.toggleEl = document.createElement('button'); this.toggleEl = document.createElement('button');
this.toggleEl.classList.add('pinned-audio-ico', 'tgico', 'btn-icon'); this.toggleEl.classList.add('pinned-audio-ico', 'tgico', 'btn-icon');
this.topbar.listenerSetter.add(this.toggleEl, 'click', (e) => { attachClickEvent(this.toggleEl, (e) => {
cancelEvent(e); cancelEvent(e);
appMediaPlaybackController.toggle(); appMediaPlaybackController.toggle();
}); }, {listenerSetter: this.topbar.listenerSetter});
this.wrapper.prepend(this.toggleEl); this.wrapper.prepend(this.toggleEl);

View File

@ -1546,7 +1546,7 @@ export default class ChatBubbles {
bubble.dataset.mid = message.mid; bubble.dataset.mid = message.mid;
bubble.dataset.timestamp = message.date; bubble.dataset.timestamp = message.date;
if(this.chat.selection.isSelecting) { if(this.chat.selection.isSelecting && message._ !== 'messageService') {
this.chat.selection.toggleBubbleCheckbox(bubble, true); this.chat.selection.toggleBubbleCheckbox(bubble, true);
} }

View File

@ -1,7 +1,7 @@
import type Chat from "./chat"; import type Chat from "./chat";
import type ChatTopbar from "./topbar"; import type ChatTopbar from "./topbar";
import mediaSizes from "../../helpers/mediaSizes"; import mediaSizes from "../../helpers/mediaSizes";
import { cancelEvent } from "../../helpers/dom"; import { attachClickEvent, cancelEvent } from "../../helpers/dom";
import DivAndCaption from "../divAndCaption"; import DivAndCaption from "../divAndCaption";
import { ripple } from "../ripple"; import { ripple } from "../ripple";
import ListenerSetter from "../../helpers/listenerSetter"; import ListenerSetter from "../../helpers/listenerSetter";
@ -41,7 +41,7 @@ export default class PinnedContainer {
divAndCaption.container.append(this.close, this.wrapper); divAndCaption.container.append(this.close, this.wrapper);
this.listenerSetter.add(this.close, 'click', (e) => { attachClickEvent(this.close, (e) => {
cancelEvent(e); cancelEvent(e);
((onClose ? onClose() : null) || Promise.resolve(true)).then(needClose => { ((onClose ? onClose() : null) || Promise.resolve(true)).then(needClose => {
@ -49,7 +49,7 @@ export default class PinnedContainer {
this.toggle(true); this.toggle(true);
} }
}); });
}); }, {listenerSetter: this.listenerSetter});
} }
public toggle(hide?: boolean) { public toggle(hide?: boolean) {

View File

@ -154,6 +154,8 @@ export default class ChatSelection {
} }
public toggleBubbleCheckbox(bubble: HTMLElement, show: boolean) { public toggleBubbleCheckbox(bubble: HTMLElement, show: boolean) {
if(!this.canSelectBubble(bubble)) return;
const hasCheckbox = !!this.getCheckboxInputFromBubble(bubble); const hasCheckbox = !!this.getCheckboxInputFromBubble(bubble);
const isGrouped = bubble.classList.contains('is-grouped'); const isGrouped = bubble.classList.contains('is-grouped');
if(show) { if(show) {
@ -183,7 +185,7 @@ export default class ChatSelection {
} }
} }
public getCheckboxInputFromBubble(bubble: HTMLElement): HTMLInputElement { private getCheckboxInputFromBubble(bubble: HTMLElement): HTMLInputElement {
/* let perf = performance.now(); /* let perf = performance.now();
let checkbox = bubble.firstElementChild.tagName == 'LABEL' && bubble.firstElementChild.firstElementChild as HTMLInputElement; let checkbox = bubble.firstElementChild.tagName == 'LABEL' && bubble.firstElementChild.firstElementChild as HTMLInputElement;
console.log('getCheckboxInputFromBubble firstElementChild time:', performance.now() - perf); console.log('getCheckboxInputFromBubble firstElementChild time:', performance.now() - perf);
@ -204,7 +206,7 @@ export default class ChatSelection {
bubble.firstElementChild.tagName == 'LABEL' && bubble.firstElementChild.firstElementChild as HTMLInputElement; bubble.firstElementChild.tagName == 'LABEL' && bubble.firstElementChild.firstElementChild as HTMLInputElement;
} }
public updateForwardContainer(forceSelection = false) { private updateForwardContainer(forceSelection = false) {
if(!this.selectedMids.size && !forceSelection) return; if(!this.selectedMids.size && !forceSelection) return;
this.selectionCountEl.innerText = this.selectedMids.size + ' Message' + (this.selectedMids.size == 1 ? '' : 's'); this.selectionCountEl.innerText = this.selectedMids.size + ' Message' + (this.selectedMids.size == 1 ? '' : 's');
@ -373,18 +375,20 @@ export default class ChatSelection {
SetTransition(bubble, 'is-selected', isSelected, 200); SetTransition(bubble, 'is-selected', isSelected, 200);
} }
public isGroupedBubbleSelected(bubble: HTMLElement) { private isGroupedBubbleSelected(bubble: HTMLElement) {
const groupedCheckboxInput = this.getCheckboxInputFromBubble(bubble); const groupedCheckboxInput = this.getCheckboxInputFromBubble(bubble);
return groupedCheckboxInput?.checked; return groupedCheckboxInput?.checked;
} }
public isGroupedMidsSelected(mid: number) { private isGroupedMidsSelected(mid: number) {
const mids = this.chat.getMidsByMid(mid); const mids = this.chat.getMidsByMid(mid);
const selectedMids = mids.filter(mid => this.selectedMids.has(mid)); const selectedMids = mids.filter(mid => this.selectedMids.has(mid));
return mids.length == selectedMids.length; return mids.length == selectedMids.length;
} }
public toggleByBubble = (bubble: HTMLElement) => { public toggleByBubble = (bubble: HTMLElement) => {
if(!this.canSelectBubble(bubble)) return;
const mid = +bubble.dataset.mid; const mid = +bubble.dataset.mid;
const isGrouped = bubble.classList.contains('is-grouped'); const isGrouped = bubble.classList.contains('is-grouped');
@ -438,4 +442,8 @@ export default class ChatSelection {
this.updateBubbleSelection(bubble, !found); this.updateBubbleSelection(bubble, !found);
}; };
private canSelectBubble(bubble: HTMLElement) {
return !bubble.classList.contains('service');
}
} }

View File

@ -1,4 +1,4 @@
import { isInDOM, cancelEvent } from "../helpers/dom"; import { isInDOM, cancelEvent, attachClickEvent } from "../helpers/dom";
import { CancellablePromise } from "../helpers/cancellablePromise"; import { CancellablePromise } from "../helpers/cancellablePromise";
export default class ProgressivePreloader { export default class ProgressivePreloader {
@ -42,7 +42,7 @@ export default class ProgressivePreloader {
} }
if(this.cancelable) { if(this.cancelable) {
this.preloader.addEventListener('click', (e) => { attachClickEvent(this.preloader, (e) => {
cancelEvent(e); cancelEvent(e);
if(this.promise && this.promise.cancel) { if(this.promise && this.promise.cancel) {

View File

@ -1,3 +1,4 @@
import { attachClickEvent } from "../helpers/dom";
import { horizontalMenu } from "./horizontalMenu"; import { horizontalMenu } from "./horizontalMenu";
export interface SliderTab { export interface SliderTab {
@ -41,7 +42,7 @@ export default class SidebarSlider {
} }
Array.from(this.sidebarEl.querySelectorAll('.sidebar-close-button') as any as HTMLElement[]).forEach(el => { Array.from(this.sidebarEl.querySelectorAll('.sidebar-close-button') as any as HTMLElement[]).forEach(el => {
el.addEventListener('click', () => this.closeTab()); attachClickEvent(el, () => this.closeTab());
}); });
} }

View File

@ -496,11 +496,12 @@ export class AppImManager {
if(chatIndex > 0) { if(chatIndex > 0) {
this.spliceChats(chatIndex); this.spliceChats(chatIndex);
return; return;
} else if(mediaSizes.activeScreen == ScreenSize.medium) { // * floating sidebar case } else if(mediaSizes.activeScreen === ScreenSize.medium) { // * floating sidebar case
const isNowOpen = document.body.classList.toggle(LEFT_COLUMN_ACTIVE_CLASSNAME); const isNowOpen = document.body.classList.toggle(LEFT_COLUMN_ACTIVE_CLASSNAME);
if(isNowOpen && document.body.classList.contains(RIGHT_COLUMN_ACTIVE_CLASSNAME)) { if(isNowOpen && document.body.classList.contains(RIGHT_COLUMN_ACTIVE_CLASSNAME)) {
appSidebarRight.toggleSidebar(false, false); appSidebarRight.toggleSidebar(false, false);
this.selectTab(0);
this.hideRightSidebar = isNowOpen; this.hideRightSidebar = isNowOpen;
} else if(this.hideRightSidebar) { } else if(this.hideRightSidebar) {
appSidebarRight.toggleSidebar(true); appSidebarRight.toggleSidebar(true);