Chamaka Mendis
Chamaka Mendis

Reputation: 55

I want to get the total of 'No of vacancy column'

I want to calculate the total of "No of vacancy column" values, so how to write a function or logic to calculate it?

const [vacancy, setVacancy] = useState([]); 

console.log(vacancy[0].noOfVacancy) gives the first index output, but I put the for loop and try to get all the values, but its gives an error.

Finally, I want to get the sum/total of "No of vacancy column values"

See this screenshot:

enter image description here

import React, { useEffect, useState, useRef } from "react";
import axios from "axios";
import jwt_decode from "jwt-decode";
import { useReactToPrint } from "react-to-print";
import image from "../../../images/back1.jpg";

export default function GenerateVacancyReport() {
  const componentRef = useRef();
  const handlePrint = useReactToPrint({
    content: () => componentRef.current,
  });

  const [vacancy, setVacancy] = useState([]);
  const [filteredResults, setFilteredResults] = useState([]);
  const [searchInput, setSearchInput] = useState("");
  const [companyName, setCompanyName] = useState("");

  useEffect(() => {
    const userToken = localStorage.userToken;
    const decoded = jwt_decode(userToken);
    setCompanyName(decoded.name);
    let name = companyName;
    console.log(name);
    axios
      .get(`http://localhost:5000/vacancy/get/name/${name}`)
      .then((response) => {
        setVacancy(response.data.exsitingVacancies);
      });
  }, [companyName]);

  //search record

  const searchItems = (searchValue) => {
    setSearchInput(searchValue);
    if (searchInput !== "") {
      const filteredData = vacancy.filter((item) => {
        return Object.values(item)
          .join("")
          .toLowerCase()
          .includes(searchInput.toLowerCase());
      });
      setFilteredResults(filteredData);
    } else {
      setFilteredResults(vacancy);
    }
  };

Upvotes: 3

Views: 64

Answers (1)

otejiri
otejiri

Reputation: 1017

The code below should do the trick

 useEffect(() => {
    useEffect(() => {
    let sumVacancies = 0;
    for(let i = 0; i < vacancy.length; i++){

     sumVacancies += +vacancy[i].noOfVacancy;
   
     setTotal(sumVacancies);
    }
    setTotal(sum);
    }, [vacancy])

or use reduce function

const [total, setTotal] = useState(0);

useEffect(() => {
let sum = vacancy.reduce((prev,curr) => +prev.noOfVacancy + 
+curr.noOfVacancy)
setTotal(sum);
}, [vacancy])

You can access the sum value from total

Upvotes: 2

Related Questions