2023-07-05 13:23:12 +02:00

148 lines
4.8 KiB
TypeScript

import { addCallback } from '../../../lib/teact/teactn';
import { requestMutation } from '../../../lib/fasterdom/fasterdom';
import { addActionHandler, getActions } from '../../index';
import { SettingsScreens } from '../../../types';
import type { ActionReturnType, GlobalState } from '../../types';
import { replaceSettings, replaceThemeSettings } from '../../reducers';
import switchTheme from '../../../util/switchTheme';
import { setLanguage, setTimeFormat } from '../../../util/langProvider';
import { IS_IOS } from '../../../util/windowEnvironment';
import { updateTabState } from '../../reducers/tabs';
import { getCurrentTabId } from '../../../util/establishMultitabRole';
import { applyPerformanceSettings } from '../../../util/perfomanceSettings';
import { selectCanAnimateInterface, selectChatFolder } from '../../selectors';
let prevGlobal: GlobalState | undefined;
addCallback((global: GlobalState) => {
// eslint-disable-next-line eslint-multitab-tt/no-getactions-in-actions
const { updatePageTitle } = getActions();
const oldGlobal = prevGlobal;
prevGlobal = global;
if (!oldGlobal) return;
const settings = global.settings.byKey;
const prevSettings = oldGlobal.settings.byKey;
const performance = global.settings.performance;
const prevPerformance = oldGlobal.settings.performance;
if (performance !== prevPerformance) {
requestMutation(() => {
applyPerformanceSettings(performance);
});
}
if (settings.theme !== prevSettings.theme) {
const withAnimation = document.hasFocus() ? selectCanAnimateInterface(global) : false;
switchTheme(settings.theme, withAnimation);
}
if (settings.language !== prevSettings.language) {
setLanguage(settings.language);
}
if (settings.timeFormat !== prevSettings.timeFormat) {
setTimeFormat(settings.timeFormat);
}
if (settings.messageTextSize !== prevSettings.messageTextSize) {
document.documentElement.style.setProperty(
'--composer-text-size', `${Math.max(settings.messageTextSize, IS_IOS ? 16 : 15)}px`,
);
document.documentElement.style.setProperty('--message-meta-height',
`${Math.floor(settings.messageTextSize * 1.3125)}px`);
document.documentElement.style.setProperty('--message-text-size', `${settings.messageTextSize}px`);
document.documentElement.setAttribute('data-message-text-size', settings.messageTextSize.toString());
}
if (settings.canDisplayChatInTitle !== prevSettings.canDisplayChatInTitle) {
updatePageTitle();
}
});
addActionHandler('setSettingOption', (global, actions, payload): ActionReturnType => {
return replaceSettings(global, payload);
});
addActionHandler('updatePerformanceSettings', (global, actions, payload): ActionReturnType => {
global = {
...global,
settings: {
...global.settings,
performance: {
...global.settings.performance,
...payload,
},
},
};
return global;
});
addActionHandler('setThemeSettings', (global, actions, payload): ActionReturnType => {
const { theme, ...settings } = payload;
return replaceThemeSettings(global, theme, settings);
});
addActionHandler('requestNextSettingsScreen', (global, actions, payload): ActionReturnType => {
const { screen, foldersAction, tabId = getCurrentTabId() } = payload;
return updateTabState(global, {
nextSettingsScreen: screen,
nextFoldersAction: foldersAction,
}, tabId);
});
addActionHandler('openEditChatFolder', (global, actions, payload): ActionReturnType => {
const { folderId, isOnlyInvites, tabId = getCurrentTabId() } = payload;
const chatFolder = selectChatFolder(global, folderId);
if (!chatFolder) return;
actions.requestNextSettingsScreen({
screen: isOnlyInvites ? SettingsScreens.FoldersEditFolderInvites : SettingsScreens.FoldersEditFolderFromChatList,
foldersAction: {
type: 'editFolder',
payload: chatFolder,
},
tabId,
});
});
addActionHandler('openShareChatFolderModal', (global, actions, payload): ActionReturnType => {
const {
folderId, url, noRequestNextScreen, tabId = getCurrentTabId(),
} = payload;
const chatFolder = selectChatFolder(global, folderId);
const isChatList = chatFolder?.isChatList;
if (isChatList && !noRequestNextScreen) {
actions.openEditChatFolder({ folderId, isOnlyInvites: true, tabId });
return undefined;
}
if (!noRequestNextScreen) actions.requestNextSettingsScreen({ screen: SettingsScreens.FoldersShare, tabId });
return updateTabState(global, {
shareFolderScreen: {
folderId,
isFromSettings: Boolean(noRequestNextScreen),
url,
},
}, tabId);
});
addActionHandler('closeShareChatFolderModal', (global, actions, payload): ActionReturnType => {
const { tabId = getCurrentTabId() } = payload || {};
actions.requestNextSettingsScreen({ screen: undefined, tabId });
return updateTabState(global, {
shareFolderScreen: undefined,
}, tabId);
});