Skip to main content

Crud operation with firebase in react js

React with Firebase


1. Install firebase using command
npm i firebase
it will include all the stuff need to connect with firebase firestore database.
After that go to firebase website
2) Register your App
Add firebase SDK in you project

// Import the functions you need from the SDKs you need

import { initializeApp } from "firebase/app";

import { getAnalytics } from "firebase/analytics";

// TODO: Add SDKs for Firebase products that you want to use

// https://firebase.google.com/docs/web/setup#available-libraries


// Your web app's Firebase configuration

// For Firebase JS SDK v7.20.0 and later, measurementId is optional

const firebaseConfig = {

  apiKey
: "AIzaSyCCrfZjlVpghgvbX0MTfIydQnbFtkOZvjUw",

  authDomain
: "crud-reactjs-92ddb.firebaseapp.com",

  projectId
: "crud-reactjs-952ddb",

  storageBucket
: "crud-reactjs-92ddb.appfspot.com",

  messagingSenderId
: "13233136550278",

  appId
: "1:132331350278:web:bdf26e1565475bd5d75429687",

  measurementId
: "G-VCB51B4RC4C3"

};


// Initialize Firebase

const app = initializeApp(firebaseConfig);

const analytics = getAnalytics(app);

3) Create Database.
1. Go to firestore and create database.
2. Choose the location of your database.
3. Go to rules if needed to change.
allow read, write: if true;
Note : firebase don;t have sql schema database .it is like mongo db and dynamo db. here we have collections similar to tables and document is the record or you can say one of the entry (single row record of the collection).
4) Now connection to you database.
first you need to import method
import { getFirestore } from '@firebase/firestore';
Than you need to connect.
// now connect to your firestore
export const db = getFirestore(app);

5) Read (fetch) record from database.
So first we need to create reference to which collection on database we are going to fetch.
1. first import the db
import {db} from './firebase/firebase-config';
2. call method collection it accepts two variable first which db, and second with collection.
  const usersCollectionRef = collection(db,'users');

3.Complete code of fetching data
import React ,{ useState, useEffect } from 'react'
import { db } from './firebase/firebase-config';
import { collection, getDocs } from 'firebase/firestore';
function FirebaseCrud() {
  const [users,setUsers] = useState([]);
  const usersCollectionRef = collection(db,'users');
  useEffect(()=>{
     const getUsers  = async () => {
      const data = await getDocs(usersCollectionRef);
      setUsers(data.docs.map((doc) => ({...doc.data(), id:doc.id}) ));
      console.log(data.docs);
     }
     getUsers();
  },[])
  return (
    <div>firebase-crud
      {users.map((users) => {
        return <div>
          <h1>Name: {users.name}</h1>
          <h1>Age: {users.age}</h1>
        </div>
      })}
    </div>
  )
}

export default FirebaseCrud
6) Complete crud operation.

import React ,{ useState, useEffect } from 'react'
import { db } from './firebase/firebase-config';
import { collection, getDocs, addDoc, updateDoc, doc ,deleteDoc } from 'firebase/firestore';
import { async } from '@firebase/util';
function FirebaseCrud() {
  const [users,setUsers] = useState([]);
  const usersCollectionRef = collection(db,'users');

  // for new user
  const [newName, setNewName] = useState('');
  const [newAge, setNewAge] = useState('');
  useEffect(()=>{
     const getUsers  = async () => {
      const data = await getDocs(usersCollectionRef);
      setUsers(data.docs.map((doc) => ({...doc.data(), id:doc.id}) ));
      // console.log(data.docs);
     }
     getUsers();
  },[])


// create user
const createUser = async () => {
  await addDoc(usersCollectionRef,{name:newName,age: Number(newAge)});
  setNewName('');
  setNewAge('');
}

// update user

const updateUser = async (id, age) => {
  const userDoc  = doc(db,'users',id);
  const newFeilds = {age: age+1};
  await updateDoc(userDoc,newFeilds);

}

// delete user
const deleteUser  = async (id) => {
  const userDoc  = doc(db,'users',id);
  await deleteDoc(userDoc);
}



  return (
    <div>
      <h1>firebase-crud</h1>
      <input placeholder='Enter name'
      value={newName}
      onChange={(e) => {
        setNewName(e.target.value)
      }}
      />
      <input placeholder='Enter age'
      value={newAge}
      onChange={(e) => {
        setNewAge(e.target.value)
      }}
      />
      <button onClick={createUser}>Create user</button>
      {users.map((users) => {
        return <div>
          <h1>Name: {users.name}</h1>
          <h1>Age: {users.age}</h1>
          <button onClick={()=>{updateUser(users.id,users.age)}}>Increase age</button>
          <button onClick={()=>{deleteUser(users.id)}}>Delete User</button>
        </div>
      })}
    </div>
  )
}

export default FirebaseCrud






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...

Redis installation in Red Hat Linux

 In this post we will see step by step installation of Redis service in Redhat/CentOS operation system. To install Redis, run this command in terminal -dnf install redis This command will install the redis service in your machine. Verify installation -systemctl status redis -systemctl start redis -systemctl enable redis Note: Before start redis service set Linux Kernal overcommit memory to 1 by adding vm.overcommit_memory = 1 to /etc/sysctl.conf file. Why we should do that: As we know redis is in memory data store. It primarily uses RAM to store data. Redis and other processes use RAM memory. We set vm.overcommit_memory = 1 to make sure Kernal not overcommit the memory by allocating memory to new program which required more memory than available memory. In this scenario OOM (Out Of Memory) killer terminate the rest of processes. We also restricting Kernal not to terminate the important services running and also stop swapping redis and other importance service to device i/o device,...

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"), ...