Как избежать многократного вызова хуков для темы и адаптивных стилей в нативных компонентах React?Javascript

Форум по Javascript
Ответить Пред. темаСлед. тема
Anonymous
 Как избежать многократного вызова хуков для темы и адаптивных стилей в нативных компонентах React?

Сообщение Anonymous »

Чего я хочу достичь: Эффективный встроенный менеджер тем/сменщик тем.
Стили должны использоваться следующим образом: где стили берутся из файлаstyles.ts, в котором я определяю свой стиль. Там у меня должен быть доступ к цвету темы (например: «Темный/Светлый») и динамическим размерам (ширина, высота), а это означает, что если я переключусь на альбомную ориентацию и обратно, стиль обновится соответствующим образом.
На данный момент у меня есть эта реализация. Однако в каждом компоненте мне приходится вызывать этот хук с моим конкретным стилем const Styles = useStyles();. Я хотел бы избежать этого (или скрыть это) и просто импортировать их перед использованием, чтобы мне не приходилось вызывать такой крючок для каждого импортируемого стиля в каждом компоненте.
App.tsx
import { NavigationContainer, DefaultTheme } from '@react-navigation/native';
import { createStackNavigator, StackScreenProps } from '@react-navigation/stack';
import { Button, View, Text, TouchableOpacity } from 'react-native';
import { useThemeStore, colors } from './themeStore';
import { useStyles } from './styles';

type RootStackParamList = {
Home: undefined;
Settings: undefined;
};

const Stack = createStackNavigator();

function HomeScreen({ navigation }: StackScreenProps) {
const styles = useStyles();
const toggleTheme = useThemeStore(state => state.toggleTheme);

return (


Home Screen
Current theme settings




navigation.navigate('Settings')}
>
Go to Settings



);
}

function SettingsScreen({ navigation }: StackScreenProps) {
const styles = useStyles();
const theme = useThemeStore(state => state.theme);

return (


Settings Screen
Current Theme: {theme.toUpperCase()}

navigation.goBack()}
>
Go Back



);
}

export default function App() {
const theme = useThemeStore(state => state.theme);

const navigationTheme = {
...DefaultTheme,
dark: theme === 'dark',
colors: {
...DefaultTheme.colors,
...colors[theme],
},
};

return (






);
}

themeStore.ts
import { MMKVLoader } from 'react-native-mmkv-storage';
import {create} from 'zustand';
import { persist } from 'zustand/middleware';
import { storage } from './storage';

export const storage = new MMKVLoader()
.withInstanceID('themeStorage')
.initialize();

export const colors = {
light: {
primary: '#007AFF',
background: '#FFFFFF',
card: '#FFFFFF',
text: '#000000',
border: '#D3D3D3',
notification: '#FF3B30',
},
dark: {
primary: '#BB86FC',
background: '#121212',
card: '#1E1E1E',
text: '#FFFFFF',
border: '#383838',
notification: '#CF6679',
},
};

interface ThemeState {
theme: 'light' | 'dark';
toggleTheme: () => void;
}

export const useThemeStore = create()(
persist(
(set) => ({
theme: 'light',
toggleTheme: () => set((state) => ({
theme: state.theme === 'light' ? 'dark' : 'light'
})),
}),
{
name: 'theme-storage',
storage: {
getItem: async (name) => {
const value = storage.getString(name);
return value ? JSON.parse(value) : null;
},
setItem: async (name, value) => {
storage.setString(name, JSON.stringify(value));
},
removeItem: async (name) => {
storage.removeItem(name);
},
},
}
)
);

styles.ts
import { useThemeStore } from './themeStore';
import { useDimensionsStore } from './dimensionsStore';
import { StyleSheet } from 'react-native';
import { colors } from './themeStore';

export const useStyles = () => {
const theme = useThemeStore(state => state.theme);
const { width, height } = useDimensionsStore();
const themeColors = colors[theme];

return StyleSheet.create({
screen: {
flex: 1,
backgroundColor: themeColors.background,
width,
height,
},
container: {
padding: 16,
backgroundColor: themeColors.card,
borderRadius: 8,
margin: 8,
},
text: {
color: themeColors.text,
fontSize: 16,
},
header: {
color: themeColors.primary,
fontSize: 24,
fontWeight: 'bold',
},
button: {
backgroundColor: themeColors.primary,
padding: 12,
borderRadius: 8,
alignItems: 'center',
},
buttonText: {
color: themeColors.background,
fontWeight: 'bold',
},
});
};


Подробнее здесь: https://stackoverflow.com/questions/793 ... in-react-n
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Drupal 7: печать темы из меню хуков с хорошей производительностью
    Anonymous » » в форуме Php
    0 Ответы
    16 Просмотры
    Последнее сообщение Anonymous
  • Как избежать многократного вызова обратного вызова onClick Jetpack Compose
    Anonymous » » в форуме Android
    0 Ответы
    55 Просмотры
    Последнее сообщение Anonymous
  • Как избежать многократного вызова обратного вызова onClick Jetpack Compose
    Anonymous » » в форуме Android
    0 Ответы
    24 Просмотры
    Последнее сообщение Anonymous
  • Как избежать многократного вызова pytest_generate_tests
    Anonymous » » в форуме Python
    0 Ответы
    28 Просмотры
    Последнее сообщение Anonymous
  • Как избежать выемки с контекстом области просмотра в нативных приложениях React
    Anonymous » » в форуме CSS
    0 Ответы
    3 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Javascript»