temp
This commit is contained in:
parent
fabba00f73
commit
101c6f2ca3
@ -32,6 +32,8 @@ import { isSafari } from "../helpers/userAgent";
|
||||
import { LangPackKey, i18n } from "../lib/langPack";
|
||||
import findUpClassName from "../helpers/dom/findUpClassName";
|
||||
import { getMiddleware } from "../helpers/middleware";
|
||||
import appProfileManager from "../lib/appManagers/appProfileManager";
|
||||
import { ChannelParticipant, ChatFull, ChatParticipant, ChatParticipants } from "../layer";
|
||||
|
||||
//const testScroll = false;
|
||||
|
||||
@ -824,6 +826,81 @@ export default class AppSearchSuper {
|
||||
} else return Promise.resolve();
|
||||
}
|
||||
|
||||
private loadMembers(mediaTab: SearchSuperMediaTab) {
|
||||
const id = -this.searchContext.peerId;
|
||||
const middleware = this.middleware.get();
|
||||
let promise: Promise<void>;
|
||||
|
||||
const renderParticipants = async(participants: (ChatParticipant | ChannelParticipant)[]) => {
|
||||
if(this.loadMutex) {
|
||||
await this.loadMutex;
|
||||
|
||||
if(!middleware()) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
let list = mediaTab.contentTab.firstElementChild as HTMLUListElement;
|
||||
if(!list) {
|
||||
list = appDialogsManager.createChatList();
|
||||
appDialogsManager.setListClickListener(list, undefined, undefined, true, true);
|
||||
mediaTab.contentTab.append(list);
|
||||
this.afterPerforming(1, mediaTab.contentTab);
|
||||
}
|
||||
|
||||
participants.forEach(participant => {
|
||||
let {dialog, dom} = appDialogsManager.addDialogNew({
|
||||
dialog: participant.user_id,
|
||||
container: list,
|
||||
drawStatus: false,
|
||||
avatarSize: 48,
|
||||
autonomous: true,
|
||||
meAsSaved: false,
|
||||
rippleEnabled: false
|
||||
});
|
||||
|
||||
let status = appUsersManager.getUserStatusString(participant.user_id);
|
||||
dom.lastMessageSpan.append(status);
|
||||
});
|
||||
};
|
||||
|
||||
if(appChatsManager.isChannel(id)) {
|
||||
const LOAD_COUNT = 50;
|
||||
promise = appProfileManager.getChannelParticipants(id, undefined, LOAD_COUNT, this.nextRates[mediaTab.inputFilter]).then(participants => {
|
||||
if(!middleware()) {
|
||||
return;
|
||||
}
|
||||
|
||||
let list = mediaTab.contentTab.firstElementChild as HTMLUListElement;
|
||||
this.nextRates[mediaTab.inputFilter] = (list ? list.childElementCount : 0) + participants.participants.length;
|
||||
|
||||
if(participants.participants.length < LOAD_COUNT) {
|
||||
this.loaded[mediaTab.inputFilter] = true;
|
||||
}
|
||||
|
||||
return renderParticipants(participants.participants);
|
||||
});
|
||||
} else {
|
||||
promise = (appProfileManager.getChatFull(id) as Promise<ChatFull.chatFull>).then(chatFull => {
|
||||
if(!middleware()) {
|
||||
return;
|
||||
}
|
||||
|
||||
console.log('anymore', chatFull);
|
||||
this.loaded[mediaTab.inputFilter] = true;
|
||||
return renderParticipants((chatFull.participants as ChatParticipants.chatParticipants).participants);
|
||||
});
|
||||
}
|
||||
|
||||
return this.loadPromises[mediaTab.inputFilter] = promise.finally(() => {
|
||||
if(!middleware()) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.loadPromises[mediaTab.inputFilter] = null;
|
||||
});
|
||||
}
|
||||
|
||||
private loadType(mediaTab: SearchSuperMediaTab, justLoad: boolean, loadCount: number, middleware: () => boolean) {
|
||||
const type = mediaTab.inputFilter;
|
||||
|
||||
@ -831,6 +908,10 @@ export default class AppSearchSuper {
|
||||
return this.loadPromises[type];
|
||||
}
|
||||
|
||||
if(mediaTab.type === 'members') {
|
||||
return this.loadMembers(mediaTab);
|
||||
}
|
||||
|
||||
const history = this.historyStorage[type] ?? (this.historyStorage[type] = []);
|
||||
|
||||
if(type === 'inputMessagesFilterEmpty' && !history.length) {
|
||||
@ -1023,6 +1104,10 @@ export default class AppSearchSuper {
|
||||
return containers[dateTimestamp];
|
||||
}
|
||||
|
||||
public canViewMembers() {
|
||||
return this.searchContext.peerId < 0 && !appChatsManager.isBroadcast(-this.searchContext.peerId) && appChatsManager.hasRights(-this.searchContext.peerId, 'view_participants');
|
||||
}
|
||||
|
||||
public cleanup() {
|
||||
this.loadPromises = {};
|
||||
this.loaded = {};
|
||||
@ -1035,6 +1120,13 @@ export default class AppSearchSuper {
|
||||
this.usedFromHistory[mediaTab.inputFilter] = -1;
|
||||
});
|
||||
|
||||
// * must go to first tab (это костыль)
|
||||
const membersTab = this.mediaTabsMap.get('members');
|
||||
if(membersTab) {
|
||||
const tab = this.canViewMembers() ? membersTab : this.mediaTabs[this.mediaTabs.indexOf(membersTab) + 1];
|
||||
this.mediaTab = tab;
|
||||
}
|
||||
|
||||
this.middleware.clean();
|
||||
this.cleanScrollPositions();
|
||||
}
|
||||
@ -1045,7 +1137,7 @@ export default class AppSearchSuper {
|
||||
});
|
||||
}
|
||||
|
||||
public cleanupHTML() {
|
||||
public cleanupHTML(goFirst = false) {
|
||||
if(this.urlsToRevoke.length) {
|
||||
this.urlsToRevoke.forEach(url => {
|
||||
URL.revokeObjectURL(url);
|
||||
@ -1056,6 +1148,10 @@ export default class AppSearchSuper {
|
||||
this.mediaTabs.forEach((tab) => {
|
||||
tab.contentTab.innerHTML = '';
|
||||
|
||||
/* if(this.hideEmptyTabs) {
|
||||
tab.menuTab.classList.add('hide');
|
||||
} */
|
||||
|
||||
if(tab.type === 'chats') {
|
||||
return;
|
||||
}
|
||||
@ -1075,6 +1171,18 @@ export default class AppSearchSuper {
|
||||
}
|
||||
});
|
||||
|
||||
if(goFirst) {
|
||||
const membersTab = this.mediaTabsMap.get('members');
|
||||
if(membersTab) {
|
||||
let idx = this.canViewMembers() ? 0 : 1;
|
||||
membersTab.menuTab.classList.toggle('hide', idx !== 0);
|
||||
|
||||
this.selectTab(idx, false);
|
||||
} else {
|
||||
this.selectTab(0, false);
|
||||
}
|
||||
}
|
||||
|
||||
this.monthContainers = {};
|
||||
this.searchGroupMedia.clear();
|
||||
this.scrollable.scrollTop = 0;
|
||||
|
@ -725,8 +725,30 @@ export default class ChatBubbles {
|
||||
return;
|
||||
}
|
||||
|
||||
const nameDiv = findUpClassName(target, 'peer-title') || findUpClassName(target, 'name') || findUpTag(target, 'AVATAR-ELEMENT');
|
||||
if(nameDiv) {
|
||||
target = nameDiv || target;
|
||||
const peerId = +(target.dataset.peerId || target.getAttribute('peer'));
|
||||
const savedFrom = target.dataset.savedFrom;
|
||||
if(savedFrom) {
|
||||
const splitted = savedFrom.split('_');
|
||||
const peerId = +splitted[0];
|
||||
const msgId = +splitted[1];
|
||||
|
||||
this.chat.appImManager.setInnerPeer(peerId, msgId);
|
||||
} else {
|
||||
if(peerId) {
|
||||
this.chat.appImManager.setInnerPeer(peerId);
|
||||
} else {
|
||||
toast(I18n.format('HidAccount', true));
|
||||
}
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
//this.log('chatInner click:', target);
|
||||
const isVideoComponentElement = target.tagName === 'SPAN' && !target.classList.contains('peer-title');
|
||||
const isVideoComponentElement = target.tagName === 'SPAN';
|
||||
/* if(isVideoComponentElement) {
|
||||
const video = target.parentElement.querySelector('video') as HTMLElement;
|
||||
if(video) {
|
||||
@ -748,7 +770,7 @@ export default class ChatBubbles {
|
||||
return;
|
||||
}
|
||||
|
||||
if((target.tagName === 'IMG' && !target.classList.contains('emoji') && target.parentElement.tagName !== "AVATAR-ELEMENT" && !target.classList.contains('document-thumb'))
|
||||
if((target.tagName === 'IMG' && !target.classList.contains('emoji') && !target.classList.contains('document-thumb'))
|
||||
|| target.classList.contains('album-item')
|
||||
|| isVideoComponentElement
|
||||
|| (target.tagName === 'VIDEO' && !bubble.classList.contains('round'))) {
|
||||
@ -818,9 +840,9 @@ export default class ChatBubbles {
|
||||
return;
|
||||
}
|
||||
|
||||
if(['IMG', 'DIV', "AVATAR-ELEMENT", 'SPAN'/* , 'A' */].indexOf(target.tagName) === -1) target = findUpTag(target, 'DIV');
|
||||
if(['IMG', 'DIV', 'SPAN'/* , 'A' */].indexOf(target.tagName) === -1) target = findUpTag(target, 'DIV');
|
||||
|
||||
if(['DIV', 'SPAN', 'AVATAR-ELEMENT'].indexOf(target.tagName) !== -1/* || target.tagName === 'A' */) {
|
||||
if(['DIV', 'SPAN'].indexOf(target.tagName) !== -1/* || target.tagName === 'A' */) {
|
||||
if(target.classList.contains('goto-original')) {
|
||||
const savedFrom = bubble.dataset.savedFrom;
|
||||
const splitted = savedFrom.split('_');
|
||||
@ -833,35 +855,6 @@ export default class ChatBubbles {
|
||||
const mid = +bubble.dataset.mid;
|
||||
new PopupForward(this.peerId, [mid]);
|
||||
//appSidebarRight.forwardTab.open([mid]);
|
||||
return;
|
||||
} else if(target.classList.contains('peer-title') || target.classList.contains('name')) {
|
||||
target = findUpClassName(target, 'name') || target;
|
||||
const peerId = +target.dataset.peerId;
|
||||
const savedFrom = target.dataset.savedFrom;
|
||||
if(savedFrom) {
|
||||
const splitted = savedFrom.split('_');
|
||||
const peerId = +splitted[0];
|
||||
const msgId = +splitted[1];
|
||||
|
||||
this.chat.appImManager.setInnerPeer(peerId, msgId);
|
||||
} else {
|
||||
if(peerId) {
|
||||
this.chat.appImManager.setInnerPeer(peerId);
|
||||
} else {
|
||||
toast(I18n.format('HidAccount', true));
|
||||
}
|
||||
}
|
||||
|
||||
return;
|
||||
} else if(target.tagName === "AVATAR-ELEMENT") {
|
||||
const peerId = +target.getAttribute('peer');
|
||||
|
||||
if(peerId) {
|
||||
this.chat.appImManager.setInnerPeer(peerId);
|
||||
} else {
|
||||
toast(I18n.format('HidAccount', true));
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
@ -889,14 +882,6 @@ export default class ChatBubbles {
|
||||
} */
|
||||
//this.chat.setMessageId(, originalMessageId);
|
||||
}
|
||||
} else if(target.tagName === 'IMG' && target.parentElement.tagName === "AVATAR-ELEMENT") {
|
||||
let peerId = +target.parentElement.getAttribute('peer');
|
||||
|
||||
if(peerId) {
|
||||
this.chat.appImManager.setInnerPeer(peerId);
|
||||
} else {
|
||||
toast(I18n.format('HidAccount', true));
|
||||
}
|
||||
}
|
||||
|
||||
//console.log('chatInner click', e);
|
||||
|
@ -39,6 +39,7 @@ import { forEachReverse } from "../../../helpers/array";
|
||||
import appPhotosManager from "../../../lib/appManagers/appPhotosManager";
|
||||
import renderImageFromUrl from "../../../helpers/dom/renderImageFromUrl";
|
||||
import SwipeHandler from "../../swipeHandler";
|
||||
import { MOUNT_CLASS_TO } from "../../../config/debug";
|
||||
|
||||
let setText = (text: string, row: Row) => {
|
||||
fastRaf(() => {
|
||||
@ -628,30 +629,29 @@ class PeerProfile {
|
||||
|
||||
// TODO: отредактированное сообщение не изменится
|
||||
export default class AppSharedMediaTab extends SliderSuperTab {
|
||||
public editBtn: HTMLElement;
|
||||
private editBtn: HTMLElement;
|
||||
|
||||
private peerId = 0;
|
||||
private threadId = 0;
|
||||
|
||||
public historiesStorage: {
|
||||
private historiesStorage: {
|
||||
[peerId: number]: Partial<{
|
||||
[type in SearchSuperType]: {mid: number, peerId: number}[]
|
||||
}>
|
||||
} = {};
|
||||
|
||||
private log = logger('SM'/* , LogLevels.error */);
|
||||
private cleaned: boolean;
|
||||
private searchSuper: AppSearchSuper;
|
||||
|
||||
public profile: PeerProfile;
|
||||
private profile: PeerProfile;
|
||||
|
||||
constructor(slider: SidebarSlider) {
|
||||
super(slider, false);
|
||||
}
|
||||
|
||||
protected init() {
|
||||
this.container.id = 'shared-media-container';
|
||||
this.container.classList.add('profile-container');
|
||||
public init() {
|
||||
const perf = performance.now();
|
||||
|
||||
this.container.classList.add('shared-media-container', 'profile-container');
|
||||
|
||||
// * header
|
||||
const newCloseBtn = Button('btn-icon sidebar-close-button', {noRipple: true});
|
||||
@ -769,6 +769,13 @@ export default class AppSharedMediaTab extends SliderSuperTab {
|
||||
}],
|
||||
scrollable: this.scrollable
|
||||
});
|
||||
|
||||
this.profile.element.append(this.searchSuper.container);
|
||||
|
||||
const btnAddMembers = Button('btn-corner btn-circle', {icon: 'adduser'});
|
||||
this.content.append(btnAddMembers);
|
||||
|
||||
console.log('construct shared media time:', performance.now() - perf);
|
||||
}
|
||||
|
||||
public renderNewMessages(peerId: number, mids: number[]) {
|
||||
@ -832,15 +839,16 @@ export default class AppSharedMediaTab extends SliderSuperTab {
|
||||
}
|
||||
|
||||
public cleanupHTML() {
|
||||
const perf = performance.now();
|
||||
this.profile.cleanupHTML();
|
||||
|
||||
this.editBtn.style.display = 'none';
|
||||
this.searchSuper.cleanupHTML();
|
||||
this.searchSuper.selectTab(0, false);
|
||||
|
||||
if(!this.searchSuper.container.parentElement) {
|
||||
this.profile.element.append(this.searchSuper.container);
|
||||
}
|
||||
this.searchSuper.cleanupHTML(true);
|
||||
|
||||
this.container.classList.toggle('can-add-members', this.searchSuper.canViewMembers() && appChatsManager.hasRights(-this.peerId, 'invite_users'));
|
||||
|
||||
console.log('cleanupHTML shared media time:', performance.now() - perf);
|
||||
}
|
||||
|
||||
public setLoadMutex(promise: Promise<any>) {
|
||||
@ -850,13 +858,14 @@ export default class AppSharedMediaTab extends SliderSuperTab {
|
||||
public setPeer(peerId: number, threadId = 0) {
|
||||
if(this.peerId === peerId && this.threadId === peerId) return;
|
||||
|
||||
this.peerId = peerId;
|
||||
this.threadId = threadId;
|
||||
|
||||
if(this.init) {
|
||||
this.init();
|
||||
this.init = null;
|
||||
}
|
||||
|
||||
this.peerId = peerId;
|
||||
this.threadId = threadId;
|
||||
this.searchSuper.setQuery({
|
||||
peerId,
|
||||
//threadId,
|
||||
@ -864,7 +873,6 @@ export default class AppSharedMediaTab extends SliderSuperTab {
|
||||
});
|
||||
|
||||
this.profile.setPeer(peerId, threadId);
|
||||
this.cleaned = true;
|
||||
}
|
||||
|
||||
public fillProfileElements() {
|
||||
@ -892,3 +900,5 @@ export default class AppSharedMediaTab extends SliderSuperTab {
|
||||
this.scrollable.onScroll();
|
||||
}
|
||||
}
|
||||
|
||||
MOUNT_CLASS_TO && (MOUNT_CLASS_TO.AppSharedMediaTab = AppSharedMediaTab);
|
||||
|
@ -27,7 +27,7 @@ import appUsersManager from "./appUsersManager";
|
||||
|
||||
export type Channel = Chat.channel;
|
||||
|
||||
export type ChatRights = keyof ChatBannedRights['pFlags'] | keyof ChatAdminRights['pFlags'] | 'change_type' | 'change_permissions' | 'delete_chat';
|
||||
export type ChatRights = keyof ChatBannedRights['pFlags'] | keyof ChatAdminRights['pFlags'] | 'change_type' | 'change_permissions' | 'delete_chat' | 'view_participants';
|
||||
|
||||
export type UserTyping = Partial<{userId: number, action: SendMessageAction, timeout: number}>;
|
||||
|
||||
@ -289,6 +289,10 @@ export class AppChatsManager {
|
||||
case 'change_permissions': {
|
||||
return rights._ === 'chatAdminRights' && myFlags['ban_users'];
|
||||
}
|
||||
|
||||
case 'view_participants': {
|
||||
return !!(chat._ === 'chat' || !chat.pFlags.broadcast || chat.pFlags.creator || chat.admin_rights);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
|
@ -920,9 +920,11 @@ export class AppDialogsManager {
|
||||
this.loadDialogs(side);
|
||||
};
|
||||
|
||||
public setListClickListener(list: HTMLUListElement, onFound?: () => void, withContext = false, autonomous = false) {
|
||||
public setListClickListener(list: HTMLUListElement, onFound?: () => void, withContext = false, autonomous = false, openInner = false) {
|
||||
let lastActiveListElement: HTMLElement;
|
||||
|
||||
const setPeerFunc = (openInner ? appImManager.setInnerPeer : appImManager.setPeer).bind(appImManager);
|
||||
|
||||
list.dataset.autonomous = '' + +autonomous;
|
||||
list.addEventListener('mousedown', (e) => {
|
||||
if(e.button !== 0) return;
|
||||
@ -955,9 +957,9 @@ export class AppDialogsManager {
|
||||
const peerId = +elem.dataset.peerId;
|
||||
const lastMsgId = +elem.dataset.mid || undefined;
|
||||
|
||||
appImManager.setPeer(peerId, lastMsgId);
|
||||
setPeerFunc(peerId, lastMsgId);
|
||||
} else {
|
||||
appImManager.setPeer(0);
|
||||
setPeerFunc(0);
|
||||
}
|
||||
}, {capture: true});
|
||||
|
||||
|
@ -99,9 +99,7 @@
|
||||
border-radius: $border-radius-medium;
|
||||
opacity: 0;
|
||||
transform: scale(.8);
|
||||
transition-property: opacity, transform, visibility;
|
||||
transition-duration: .2s;
|
||||
transition-timing-function: cubic-bezier(.4, 0, .2, 1);
|
||||
transition: opacity var(--btn-menu-transition), transform var(--btn-menu-transition), visibility var(--btn-menu-transition);
|
||||
font-size: 16px;
|
||||
|
||||
body.animation-level-0 & {
|
||||
|
@ -1130,9 +1130,9 @@ $chat-helper-size: 39px;
|
||||
}
|
||||
}
|
||||
|
||||
/* .bubbles.is-chat-input-hidden & {
|
||||
padding-bottom: 55px;
|
||||
} */
|
||||
.bubbles.is-chat-input-hidden & {
|
||||
margin-bottom: 1.25rem;
|
||||
}
|
||||
|
||||
&:not(.is-channel), &.is-chat {
|
||||
.message {
|
||||
|
@ -25,8 +25,7 @@
|
||||
box-shadow: 0px 5px 10px 5px rgba(16, 35, 47, .14);
|
||||
z-index: 3;
|
||||
border-radius: 10px;
|
||||
transition: transform .2s, opacity .2s;
|
||||
transition-timing-function: cubic-bezier(.4, 0, .2, 1);
|
||||
transition: transform var(--esg-transition), opacity var(--esg-transition);
|
||||
transform: scale(0);
|
||||
opacity: 0;
|
||||
transform-origin: 0 100%;
|
||||
|
@ -95,8 +95,13 @@
|
||||
@include hover() {
|
||||
&:not(:focus):not(.error):not(.valid) {
|
||||
//border-color: var(--color-gray);
|
||||
border-color: #000;
|
||||
//border-color: #000;
|
||||
border-color: var(--primary-color);
|
||||
transition: .2s border-color;
|
||||
|
||||
& ~ label {
|
||||
color: var(--primary-color);
|
||||
}
|
||||
}
|
||||
|
||||
/* &:not(:focus):not(.error):not(.valid) ~ label {
|
||||
|
@ -99,7 +99,7 @@
|
||||
}
|
||||
}
|
||||
|
||||
#shared-media-container {
|
||||
.shared-media-container {
|
||||
/* .search-super {
|
||||
top: 100%;
|
||||
min-height: calc((var(--vh, 1vh) * 100) - 100% - 56px);
|
||||
@ -441,6 +441,26 @@
|
||||
} */
|
||||
}
|
||||
}
|
||||
|
||||
&-content-members {
|
||||
.chatlist {
|
||||
padding-top: .5rem;
|
||||
padding-bottom: .5rem;
|
||||
|
||||
li {
|
||||
padding: .75rem;
|
||||
}
|
||||
|
||||
.user-caption {
|
||||
padding-left: .75rem;
|
||||
}
|
||||
|
||||
.dialog-subtitle {
|
||||
font-size: .875rem;
|
||||
margin-top: -.375rem;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#search-container {
|
||||
|
@ -48,7 +48,7 @@
|
||||
}
|
||||
|
||||
&__circle {
|
||||
background-color: rgba(0, 0, 0, .08);
|
||||
background-color: var(--ripple-color);
|
||||
display: block;
|
||||
position: absolute;
|
||||
transform: scale(0);
|
||||
|
@ -76,10 +76,6 @@
|
||||
padding: 0 .5rem .5rem;
|
||||
}
|
||||
|
||||
hr {
|
||||
border-top: 1px solid #edeff1;
|
||||
}
|
||||
|
||||
.subtitle {
|
||||
margin-top: .875rem;
|
||||
font-size: .875rem;
|
||||
|
@ -5,7 +5,6 @@
|
||||
*/
|
||||
|
||||
.popup {
|
||||
--transition-time: .15s;
|
||||
position: fixed!important;
|
||||
left: 0;
|
||||
top: 0;
|
||||
@ -19,7 +18,10 @@
|
||||
box-shadow: none;
|
||||
opacity: 0;
|
||||
visibility: hidden;
|
||||
transition: opacity var(--transition-time) ease-in-out, visibility 0s var(--transition-time) ease-in-out;
|
||||
transition-property: opacity, visibility;
|
||||
transition-duration: var(--popup-transition-time), 0s;
|
||||
transition-delay: 0s, var(--popup-transition-time);
|
||||
transition-timing-function: var(--popup-transition-function);
|
||||
overflow: auto;
|
||||
display: flex;
|
||||
|
||||
@ -30,7 +32,7 @@
|
||||
&.active {
|
||||
opacity: 1;
|
||||
visibility: visible;
|
||||
transition: opacity var(--transition-time) ease-in-out, visibility 0s 0s ease-in-out;
|
||||
transition-delay: 0s, 0s;
|
||||
z-index: 4;
|
||||
|
||||
.popup-container {
|
||||
@ -52,7 +54,7 @@
|
||||
padding: 1rem;
|
||||
transform: translate3d(0, 3rem, 0);
|
||||
backface-visibility: hidden;
|
||||
transition: transform var(--transition-time) ease-in-out;
|
||||
transition: transform var(--popup-transition-time) var(--popup-transition-function);
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
overflow: hidden;
|
||||
|
@ -46,6 +46,10 @@ $chat-padding-handhelds: .5rem;
|
||||
--layer-transition: .2s ease-in-out;
|
||||
--slide-header-transition: .4s ease-in-out;
|
||||
--tabs-transition: .25s ease-in-out;
|
||||
--btn-menu-transition: .2s cubic-bezier(.4, 0, .2, 1);
|
||||
--esg-transition: var(--btn-menu-transition);
|
||||
--popup-transition-function: cubic-bezier(.4, 0, .2, 1);
|
||||
--popup-transition-time: .15s;
|
||||
//--layer-transition: .3s cubic-bezier(.33, 1, .68, 1);
|
||||
//--layer-transition: none;
|
||||
--btn-corner-transition: .2s cubic-bezier(.34, 1.56, .64, 1);
|
||||
@ -137,6 +141,7 @@ $chat-padding-handhelds: .5rem;
|
||||
--chatlist-pinned-color: #a2abb2;
|
||||
--badge-text-color: #fff;
|
||||
--link-color: #00488f;
|
||||
--ripple-color: rgba(0, 0, 0, .08);
|
||||
|
||||
--message-background-color: var(--surface-color);
|
||||
--message-checkbox-color: #61c642;
|
||||
@ -177,6 +182,7 @@ html.night {
|
||||
--chatlist-pinned-color: var(--secondary-color);
|
||||
--badge-text-color: #fff;
|
||||
--link-color: var(--primary-color);
|
||||
--ripple-color: rgba(255, 255, 255, .08);
|
||||
|
||||
--message-background-color: var(--surface-color);
|
||||
--message-checkbox-color: var(--primary-color);
|
||||
|
Loading…
x
Reference in New Issue
Block a user