<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های majid lotfinia</title>
        <link>https://virgool.io/feed/@majidln</link>
        <description></description>
        <language>fa</language>
        <pubDate>2026-04-15 10:04:39</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/14796/avatar/smMOBE.png?height=120&amp;width=120</url>
            <title>majid lotfinia</title>
            <link>https://virgool.io/@majidln</link>
        </image>

                    <item>
                <title>تم ها مختلف در ری اکت نیتیو - React Native Multi Theme</title>
                <link>https://virgool.io/@majidln/%D8%AA%D9%85-%D9%87%D8%A7-%D9%85%D8%AE%D8%AA%D9%84%D9%81-%D8%AF%D8%B1-%D8%B1%DB%8C-%D8%A7%DA%A9%D8%AA-%D9%86%DB%8C%D8%AA%DB%8C%D9%88-react-native-multi-theme-ajrwf7j0wkjz</link>
                <description>در این نوشته قصد داریم در مورد نحوه ایجاد تم های مختلف مثل light و dark در ری اکت نیتیو به صورت عملی صبحت کنیم. همونطور که میدونید هر دو سیستم عامل Android و IOS قابلیت تغییر تم بین حالت دارک و لایت رو دارا هستن، در نتیجه کاربران معمولا انتظار دارن که این قابلیت از سمت اپلیکیشن هایی که ما توسعه میدیم وجود داشته باشه. برای افزودن این قابلیت بهتره که تا آخر این مقاله با من همراه باشید.خلاصه کاری که قراره انجام بدیم رو میتونید تو تصویر پایین ببیند و به کد اون تو این ریپازیتوری گیت هاب دسترسی داشته باشید.خروجی نهاییپیش نیاز هااول از همه یه پروژه ری اکت نیتیو با دستور زیر ایجاد میکنیم:npx react-native init rn_themingگام بعدی پکیج react-navigation رو از طریق دستورالعمل های خودش نصب کنید. برای ذخیره حالت دارک یا لایت برای استفاده های بعدی اپلیکیشن هم از پکیج react-native-community/async-storage استفاده میکنیمساختار پروژهتو این مرحله ساختار پروژه رو عوض میکنیم. من خودم معمولا از چنین ساختاری تو پروژه هام استفاده میکنم:-src
- components برای قرار دادن کامپوننت های پروژه
                    - TabBar.js
                   - StatusBar.js
      - navigation
                          - index.js برای تعریف کردن صفحات
      - screens صفحات مختلف پروژه
                 - Home.js صفحه اصلی
                 - Setting.js صفحه تنظیمات
       - providers
                 - themeProvider.js برای هوک های مربوط به تغییر تم
                 - theme.json نگه داری مقادیر تم های مختلف
         App.js 
index.js فایل اصلی و اولیه پروژهبعد از اینکه ساختار رو عوض کنیم یه ادیتی تو فایل index.js میزنیم  و ایمپورت فایل App رو تو اون عوض میکنیم:import App from &#039;./App&#039;; 
to ----&gt; 
import App from &#039;./src/App&#039;;بخش Navigationبرای Navigation پروژه یه bottom tab navigator ایجاد میکنیم که داخل اون دو تب یکی برای home و دیگری برای setting باشه. tabBar مربوط به اون رو هم از کامپوننت TabBar  که خودمون تو کامپوننت ها ساختیم استفاده میکنیم.import React from &#039;react&#039;;
import {NavigationContainer} from &#039;@react-navigation/native&#039;;
import {createBottomTabNavigator} from &#039;@react-navigation/bottom-tabs&#039;;
import HomeScreen from &#039;./../screens/Home&#039;;
import SettingScreen from &#039;./../screens/Setting&#039;;
import MyTabBar from &#039;./../components/TabBar&#039;

const Tab = createBottomTabNavigator();
export default function MainNavigation() {
    return (
         &lt;NavigationContainer&gt;
             &lt;Tab.Navigator tabBar={props =&gt; &lt;MyTabBar {...props} /&gt;}&gt;
               &lt;Tab.Screen name=&amp;quotHome&amp;quot component={HomeScreen} /&gt;
              &lt;Tab.Screen name=&amp;quotSettings&amp;quot component={SettingScreen} /&gt;
            &lt;/Tab.Navigator&gt;
        &lt;/NavigationContainer&gt;
     );
}تم های مختلف پروژهاول رنگای مختلفی که میخایم تو مد دارک و لایت استفاده کنیم رو با کلیدهای دلخواه به فرمت جیسون در میاریم و تو فایل  themes.json میریزیم:{{
    &amp;quotlight&amp;quot: {         &amp;quotprimaryText&amp;quot: &amp;quot#0b132b&amp;quot,         &amp;quotbackgroundColor&amp;quot: &amp;quot#eff7f6&amp;quot,         &amp;quottabBarBackgroundColor&amp;quot: &amp;quot#e6ebe0&amp;quot,        &amp;quottabBarActiveColor&amp;quot: &amp;quot#02c39a&amp;quot   },   &amp;quotdark&amp;quot: {       &amp;quotprimaryText&amp;quot: &amp;quot#98c1d9&amp;quot,        &amp;quotbackgroundColor&amp;quot: &amp;quot#14213d&amp;quot,         &amp;quottabBarBackgroundColor&amp;quot: &amp;quot#2b2d42&amp;quot,        &amp;quottabBarActiveColor&amp;quot: &amp;quot#fcbf49&amp;quot    }}هوک های مربوط به تغییر تمحالا میریم سراغ فایل themeProvider که لاجیک اصلی تغییر تم رو تو اون قرار بدیم:در ابتدا پکیج ها و کامپوننت های لازم رو ایمپورت میکنیم و متغیرهای ثابت مورد نیاز برای کل فایل رو تعریف میکنیم:providers/themeProvider.js 
import React, { useContext, useState, useEffect } from &#039;react&#039;;import AsyncStorage from &#039;@react-native-community/async-storage&#039;;import THEMES from &#039;./themes.json&#039;;const STORAGE_KEY = &#039;THEME_ID&#039;; کلید مربوطه به ذخیره وضعیت تم در  حافظه برای استفاده های بعدیconst ThemeContext = React.createContext();در ادامه فایل themeProvider یک context به نام ThemeContextProvider میسازیم و یک state به نام themeID تو اون تعریف می کنیم که این state رو در بقیه کامپوننت ها به اشتراک بزاره. providers/themeProvider.js 
export const ThemeContextProvider = ({ children }) =&gt; {const [themeID, setThemeID] = useState();useEffect(() =&gt; {(async () =&gt; {const storedThemeID = await AsyncStorage.getItem(STORAGE_KEY);if (storedThemeID) {setThemeID(storedThemeID);} else {setThemeID(&#039;light&#039;);}})();}, []);return (&lt;ThemeContext.Provider value={{ themeID, setThemeID }}&gt;{!!themeID ? children : null}&lt;/ThemeContext.Provider&gt;);};حالا برای استفاده از این context باید فایل App.js را به شکل زیر ویرایش کنیم:App.js
import React from &#039;react&#039;;import {View, Text} from &#039;react-native&#039;;import MainNavigation from &#039;./navigation&#039;import { ThemeContextProvider } from &#039;./providers/themeProvider&#039;;function App() {return (    &lt;ThemeContextProvider&gt;          &lt;MainNavigation /&gt;     &lt;/ThemeContextProvider&gt;   );}export default App;تو این فایل کل navigation اپلیکیشنمون رو درون ThemeContextProvider قرار میدیم. دیگه حالا تو همه کامپوننت هامون به themeID و setThemeID دسترسی داریم و میتونیم مقادیر themeID رو استفاده یا عوض کنیم.هنوز کارمون تموم نشده. بیاید با توجه به مفهموم HOC یه تغیری دیگه تو فایل themeProvider بدیم. در انتهای این فایل یه تابع دیگه به اسم withTheme اضافه میکنیم. کار این تابع اینه که یه Component رندر میکنه که مقادیر تم فعلی مثه لایت یا دارک رو در اختیار هر کامپوننتی که ازش استفاده کنه قرار میدهexport function withTheme(Component) {return props =&gt; { function changeTheme (id) {emeID } = useContext(ThemeContext);function changeTheme (id) { // تابعی که تم رو تغییر میده براساس اون چیزی که از ورودی میگیرهAsyncStorage.setItem(STORAGE_KEY, id);setThemeID(id)}const getTheme = themeID =&gt; THEMES[themeID]; // تابعی که تم فعلی رو برمیگردونهconst switchTheme = () =&gt; { // تابعی که تم رو سوئیچ میکنه بین لایت و دارکconst newTheme = themeID === &#039;light&#039; ? &#039;dark&#039; : &#039;light&#039;;    changeTheme(newTheme)};const setTheme = (key) =&gt; {  تابعی برای تغییر تم   changeTheme(newTheme))};return (&lt;Component{...props}themes={THEMES}theme={getTheme(themeID)}themeID={themeID}setTheme={setTheme}switchTheme={switchTheme}
این بخش توابعی و متغیرهای مورد نیاز برای مدیریت تم رو در اختیار کامپوننت های قرار میده که از withTheme استفاده می کنند/&gt;);};}تعریف کامپوننت هاحالا که کارمون با themeContext تموم شد کامپوننت های مختلف رو به شکل زیر تعریف می کنیم:components -&gt; TabBar.js
import React from &#039;react&#039;;import {BottomTabBar} from &#039;@react-navigation/bottom-tabs&#039;;import { withTheme } from &#039;./../providers/themeProvider&#039;;const MyTabBar = props =&gt; {return (&lt;BottomTabBar{...props}activeTintColor={props.theme.tabBarActiveColor}inactiveTintColor={props.theme.primaryText}style={{backgroundColor: props.theme.tabBarBackgroundColor, fontWeight: &#039;bold&#039;}}/&gt;);};export default withTheme(MyTabBar);

components -&gt; StatusBar.js
import React from &#039;react&#039;;import {StatusBar} from &#039;react-native&#039;;import { withTheme } from &#039;./../providers/themeProvider&#039;;function MyStatusBar({themeID}) {const oppositeTheme = themeID === &#039;light&#039; ? &#039;dark&#039; : &#039;light&#039;return (&lt;StatusBar barStyle ={oppositeTheme + &#039;-content&#039;} hidden = {false} backgroundColor = &amp;quot#00BCD4&amp;quot translucent = {true}/&gt;);};export default withTheme(MyStatusBar);screens -&gt; Home.js
import * as React from &#039;react&#039;;import {Text, View, StyleSheet} from &#039;react-native&#039;;import { withTheme } from &#039;./../providers/themeProvider&#039;;import MyStatusBar from &#039;./../components/StatusBar&#039;;function HomeScreen({theme}) {return (&lt;View style={{...styles.container, backgroundColor: theme.backgroundColor}}&gt;&lt;MyStatusBar /&gt;&lt;Text style={{...styles.text, color: theme.primaryText}}&gt;Welcome to change React Native Theme Changer Sample APP&lt;/Text&gt;&lt;/View&gt;);}const styles = StyleSheet.create({container: {flex: 1, justifyContent: &#039;center&#039;, alignItems: &#039;center&#039;},text: {fontSize: 24,fontWeight: &#039;bold&#039;,textAlign: &#039;center&#039;}})export default withTheme(HomeScreen);صفحه setting که عملیات تغییر تم تو اون اتفاق میفته هم به شکل زیر خواهد بود:screens -&gt; Setting.js
import * as React from &#039;react&#039;;import {Text, View, StyleSheet, TouchableOpacity} from &#039;react-native&#039;;import { withTheme } from &#039;./../providers/themeProvider&#039;;import MyStatusBar from &#039;./../components/StatusBar&#039;;function SettingsScreen({theme, setTheme, switchTheme, themeID}) {return (&lt;View style={{...styles.container, backgroundColor: theme.backgroundColor}}&gt;&lt;MyStatusBar /&gt;&lt;TouchableOpacity style={styles.button} onPress={() =&gt; switchTheme()}&gt;&lt;Text style={{...styles.text, color: theme.primaryText}}&gt;Switch Theme&lt;/Text&gt;&lt;/TouchableOpacity&gt;{themeID === &#039;light&#039; &amp;&amp; &lt;TouchableOpacity style={styles.button} onPress={() =&gt; setTheme(&#039;dark&#039;)}&gt;&lt;Text style={{...styles.text, color: theme.primaryText}}&gt;Change To Dark&lt;/Text&gt;&lt;/TouchableOpacity&gt; }{themeID === &#039;dark&#039; &amp;&amp; &lt;TouchableOpacity style={styles.button} onPress={() =&gt; setTheme(&#039;light&#039;)}&gt;&lt;Text style={{...styles.text, color: theme.primaryText}}&gt;Change to light&lt;/Text&gt;&lt;/TouchableOpacity&gt;}&lt;/View&gt;);}const styles = StyleSheet.create({container: {flex: 1,justifyContent: &#039;center&#039;,alignItems: &#039;center&#039;,},button: {borderWidth: 1,borderRadius: 8,borderColor: &#039;grey&#039;,padding: 10,margin: 20},text: {fontSize: 20,fontWeight: &#039;bold&#039;}})export default withTheme(SettingsScreen);
جمع بندیدر این مقاله اومدیم یه نمونه پروژه از نحوه ایجاد تم های مختلف مثل dark و light رو در React Native پیاده سازی کردیم. می تونید سورس کد پروژه رو اینجا ببینید.</description>
                <category>majid lotfinia</category>
                <author>majid lotfinia</author>
                <pubDate>Sat, 25 Jul 2020 18:06:07 +0430</pubDate>
            </item>
            </channel>
</rss>