import React from 'react'; import PropTypes from 'prop-types'; import { FlatList, Text, View, StyleSheet } from 'react-native'; import RNUserDefaults from 'rn-user-defaults'; import I18n from '../i18n'; import { withTheme } from '../theme'; import { themes } from '../constants/colors'; import sharedStyles from './Styles'; import StatusBar from '../containers/StatusBar'; import Separator from '../containers/Separator'; import ListItem from '../containers/ListItem'; import { CustomIcon } from '../lib/Icons'; import { THEME_PREFERENCES_KEY } from '../lib/rocketchat'; import { supportSystemTheme } from '../utils/deviceInfo'; import SafeAreaView from '../containers/SafeAreaView'; const THEME_GROUP = 'THEME_GROUP'; const DARK_GROUP = 'DARK_GROUP'; const SYSTEM_THEME = { label: I18n.t('Automatic'), value: 'automatic', group: THEME_GROUP }; const THEMES = [ { label: I18n.t('Light'), value: 'light', group: THEME_GROUP }, { label: I18n.t('Dark'), value: 'dark', group: THEME_GROUP }, { label: I18n.t('Dark'), value: 'dark', separator: true, header: I18n.t('Dark_level'), group: DARK_GROUP }, { label: I18n.t('Black'), value: 'black', group: DARK_GROUP } ]; if (supportSystemTheme()) { THEMES.unshift(SYSTEM_THEME); } const styles = StyleSheet.create({ list: { paddingBottom: 18 }, info: { paddingTop: 25, paddingBottom: 18, paddingHorizontal: 16 }, infoText: { fontSize: 16, ...sharedStyles.textRegular } }); class ThemeView extends React.Component { static navigationOptions = { title: I18n.t('Theme') } static propTypes = { theme: PropTypes.string, themePreferences: PropTypes.object, setTheme: PropTypes.func } isSelected = (item) => { const { themePreferences } = this.props; const { group } = item; const { darkLevel, currentTheme } = themePreferences; if (group === THEME_GROUP) { return item.value === currentTheme; } if (group === DARK_GROUP) { return item.value === darkLevel; } } onClick = (item) => { const { themePreferences } = this.props; const { darkLevel, currentTheme } = themePreferences; const { value, group } = item; let changes = {}; if (group === THEME_GROUP && currentTheme !== value) { changes = { currentTheme: value }; } if (group === DARK_GROUP && darkLevel !== value) { changes = { darkLevel: value }; } this.setTheme(changes); } setTheme = async(theme) => { const { setTheme, themePreferences } = this.props; const newTheme = { ...themePreferences, ...theme }; setTheme(newTheme); await RNUserDefaults.setObjectForKey(THEME_PREFERENCES_KEY, newTheme); }; renderSeparator = () => { const { theme } = this.props; return ; } renderIcon = () => { const { theme } = this.props; return ; } renderItem = ({ item, index }) => { const { theme } = this.props; const { label, value } = item; const isFirst = index === 0; return ( <> {item.separator || isFirst ? this.renderSectionHeader(item.header) : null} this.onClick(item)} testID={`theme-view-${ value }`} right={this.isSelected(item) ? this.renderIcon : null} theme={theme} /> ); } renderSectionHeader = (header = I18n.t('Theme')) => { const { theme } = this.props; return ( <> {header} {this.renderSeparator()} ); } renderFooter = () => { const { theme } = this.props; return ( {I18n.t('Applying_a_theme_will_change_how_the_app_looks')} ); } render() { const { theme } = this.props; return ( item.value} contentContainerStyle={[ styles.list, { borderColor: themes[theme].separatorColor } ]} renderItem={this.renderItem} ListHeaderComponent={this.renderHeader} ListFooterComponent={this.renderFooter} ItemSeparatorComponent={this.renderSeparator} /> ); } } export default withTheme(ThemeView);