forked from Ivasoft/mattermost-mobile
69 lines
2.3 KiB
TypeScript
69 lines
2.3 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import React, {useCallback, useMemo} from 'react';
|
|
|
|
import {savePreference} from '@actions/remote/preference';
|
|
import {Preferences} from '@constants';
|
|
import {useServerUrl} from '@context/server';
|
|
import {useTheme} from '@context/theme';
|
|
import useAndroidHardwareBackHandler from '@hooks/android_back_handler';
|
|
import {popTopScreen} from '@screens/navigation';
|
|
|
|
import SettingContainer from '../setting_container';
|
|
|
|
import CustomTheme from './custom_theme';
|
|
import {ThemeTiles} from './theme_tiles';
|
|
|
|
type DisplayThemeProps = {
|
|
allowedThemeKeys: string[];
|
|
componentId: string;
|
|
currentTeamId: string;
|
|
currentUserId: string;
|
|
}
|
|
const DisplayTheme = ({allowedThemeKeys, componentId, currentTeamId, currentUserId}: DisplayThemeProps) => {
|
|
const serverUrl = useServerUrl();
|
|
const theme = useTheme();
|
|
const initialTheme = useMemo(() => theme.type, [/* dependency array should remain empty */]);
|
|
|
|
const close = () => popTopScreen(componentId);
|
|
|
|
const setThemePreference = useCallback((newTheme?: string) => {
|
|
const allowedTheme = allowedThemeKeys.find((tk) => tk === newTheme);
|
|
const differentTheme = initialTheme?.toLowerCase() !== newTheme?.toLowerCase();
|
|
|
|
if (!allowedTheme || !differentTheme) {
|
|
close();
|
|
return;
|
|
}
|
|
|
|
const pref: PreferenceType = {
|
|
category: Preferences.CATEGORY_THEME,
|
|
name: currentTeamId,
|
|
user_id: currentUserId,
|
|
value: JSON.stringify(Preferences.THEMES[allowedTheme]),
|
|
};
|
|
savePreference(serverUrl, [pref]);
|
|
}, [allowedThemeKeys, currentTeamId, initialTheme, serverUrl]);
|
|
|
|
useAndroidHardwareBackHandler(componentId, setThemePreference);
|
|
|
|
return (
|
|
<SettingContainer testID='theme_display_settings'>
|
|
<ThemeTiles
|
|
allowedThemeKeys={allowedThemeKeys}
|
|
onThemeChange={setThemePreference}
|
|
selectedTheme={initialTheme}
|
|
/>
|
|
{theme.type === 'custom' && (
|
|
<CustomTheme
|
|
setTheme={setThemePreference}
|
|
displayTheme={initialTheme}
|
|
/>
|
|
)}
|
|
</SettingContainer>
|
|
);
|
|
};
|
|
|
|
export default DisplayTheme;
|