Skip to main content

Redux in react native

 Step 1

Install the packages

 -npm install @reduxjs/toolkit react-redux

Step 2

Create a store by creating store.js file

paste that default code inside that file

import { configureStore } from '@reduxjs/toolkit'

export const store = configureStore({
  reducer: {},
})

Step 3

Now wrap your application around with  <provider> by react-redux

Go Inside your App.js file 

import { Provider } from 'react-redux';
import { store } from "./store";

Now use that provider and store like so

<NavigationContainer>
      <Provider store={store}>
          <Stack.Navigator>
            <Stack.Screen name='home' component={HomeScreen} />
            <Stack.Screen name='restaurant' component={RestaurantScreen} />
          </Stack.Navigator>
      </Provider>
    </NavigationContainer>

Step 3

Create a redux state slice e.g baskitSlice inside feature folder

import { createSlice } from '@reduxjs/toolkit'

const initialState = {
  items: [],
}

export const basketSlice = createSlice({
  name: 'basket',
  initialState,
//   reducer actually an actions that allow us to modify global state
  reducers: {
    addToBasket: (state, action) => {
      // Redux Toolkit allows us to write "mutating" logic in reducers. It
      // doesn't actually mutate the state because it uses the Immer library,
      // which detects changes to a "draft state" and produces a brand new
      // immutable state based off those changes
      state.items = [...state.items, action.payload]    
    },
    removeFromBasket: (state, action) => {
      state.value -= 1
    },
   
  },
})

// Action creators are generated for each case reducer function
export const { addToBasket, removeFromBasket, } = basketSlice.actions


export default basketSlice.reducer

Step 4

Create a selector that allow us to select specific state, let say basket state from global state

/*
Now creating a selector that allows us to access global store.
pull your item from the basket state
This is your initial state or data in you state.
*/
export const selectBasketItems = (state) => state.basket.items;

Step 5

Connect this basketSlice to global store(state).

Go to the store file and combine all slices to make big store

import { configureStore } from '@reduxjs/toolkit'
import basketReducer from './features/basketSlice'
export const store = configureStore({
    /*
        so what i have done here,
        I combine basketSlice with the global store,
        You can add multiple slice in your reducer object.
    */
  reducer: {
    basket: basketReducer,
  },
})


Step 6

How to add item to state. we are going to add item into basket for that, 

1) first create a function that will be call on onPress event.

2) Import useDispatch hook from react-redux to call action on redux

example code


import { useDispatch, useSelector } from "react-redux";
import { addToBasket, selectBasketItems } from "../features/basketSlice";

const items = useSelector(selectBasketItems);
    /*
    useDispatch is a hook of redux to call/pass action
    in redux
    */
    const dispatch = useDispatch();
    const addItemToBasket = () => {
        dispatch(addToBasket({
            id,
            name,
            description,
            price,
            image
        }));
    }


    <TouchableOpacity onPress={addItemToBasket}>
        <PlusCircleIcon
        color="#00CCBB" size={30} />
    </TouchableOpacity>






Comments

Popular posts from this blog

Install MariaDB Latest Version 11.4 in Red Hat Version 9

 This this post i will show you step by step the installation process of mariaDB in red hat version 9. Step1 Run the command to pull the latest updated packages on applications installed in your system. -dnf update If you get Kernal update than reboot the system -reboot Step2 Go to official mariaDB site Make mariadb repository in /etc/yum.repos.d Place the configuration in this file # MariaDB 11.4 RedHatEnterpriseLinux repository list - created 2024-09-24 11:12 UTC # https://mariadb.org/download/ [mariadb] name = MariaDB # rpm.mariadb.org is a dynamic mirror if your preferred mirror goes offline. See https://mariadb.org/mirrorbits/ for details. # baseurl = https://rpm.mariadb.org/11.4/rhel/$releasever/$basearch baseurl = https://mirrors.aliyun.com/mariadb/yum/11.4/rhel/$releasever/$basearch # gpgkey = https://rpm.mariadb.org/RPM-GPG-KEY-MariaDB gpgkey = https://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB gpgcheck = 1 Now install the mariaDB with its dependencies package...

MySQL course to learn queries to manage DBMS.

1. Create Table CREATE TABLE statement allows you to create new table in database. The example code is given below.  create table profile( id int, name varchar(50), birth_date date, phone varchar(12), gender varchar(1) ); Code language: SQL (Structured Query Language) ( sql ) 2. Insert data in table INSERT INTO statement is use to insert new record/data into table. INSERT INTO profile (id, name, birth_date, phone, gender) VALUES (2, "Zaib", "1996-03-15", "9238975404", "M"); Code language: SQL (Structured Query Language) ( sql ) 3. Insert multiple records at-once INSERT INTO state is use to insert multiple new record/data into table. INSERT INTO profile (id, name, birth_date, phone, gender) VALUES (1, "Usamn ali", "1990-08-26", "9238785094", "M", 18, "Karachi"), (2, "Aisha", "1997-06-12", "9238974468", "F", 19, "Lahore"), ...

Send email in php "without less secure" restriction

 => https://www.youtube.com/watch?v=Kjn5vBbBsi8 (less secure link) https://www.youtube.com/watch?v=dNTZ8X9Xk_Q&t=259s https://www.thapatechnical.com/2020/03/how-to-send-mail-from-localhost-xampp.html LARAVEL env file setup for gmail configuration MAIL_DRIVER=smtp MAIL_HOST=smtp.gmail.com MAIL_PORT=465 MAIL_USERNAME=exampleEmail@gmail.com MAIL_PASSWORD=yourAppPassword MAIL_ENCRYPTION=ssl MAIL_FROM_ADDRESS=exampleEmail@gmail.com MAIL_FROM_NAME="Adnan Zaib" Note: for TLS use Port : 587 for SSL use Port : 465