From 97e06c1a83db1a96618582f3fe6cda5e11be116c Mon Sep 17 00:00:00 2001 From: Chanuka Lakshan Chandra Yapa <118423471+Chanuka-ChandraYapa@users.noreply.github.com> Date: Wed, 13 Sep 2023 10:29:58 +0530 Subject: [PATCH] update dashboard --- .../components/barCharts/categoryDist.js | 2 +- .../components/barCharts/houseSaleChart.js | 2 +- .../components/barCharts/landSaleChart.js | 2 +- .../components/lineCharts/demographic.js | 2 +- .../components/lineCharts/pricefluctuation.js | 2 +- .../components/pieCharts/houseSaleDDist.js | 2 +- .../components/pieCharts/marriageDist.js | 2 +- src/layouts/graph/index.js | 24 +++-- src/layouts/reports/data/reportsdata.js | 90 ++++++++++++++----- src/layouts/reports/graphs/graphdetails.js | 21 +++++ src/layouts/reports/reports.js | 33 +++---- src/layouts/upload/inputURL.js | 74 ++++++++------- 12 files changed, 178 insertions(+), 78 deletions(-) diff --git a/src/layouts/graph/components/barCharts/categoryDist.js b/src/layouts/graph/components/barCharts/categoryDist.js index 8daf046..ecedb51 100644 --- a/src/layouts/graph/components/barCharts/categoryDist.js +++ b/src/layouts/graph/components/barCharts/categoryDist.js @@ -25,7 +25,7 @@ function CategoryDistribution() { return ( data._id), datasets: { label: "City", - backgroundColors: ["info", "dark", "error", "secondary", "primary", "success"], + backgroundColors: ["info", "dark", "#8A6FC5", "secondary", "primary", "#C08DD8"], data: housesalebyCity.map((data) => data.count), }, }} diff --git a/src/layouts/graph/components/pieCharts/marriageDist.js b/src/layouts/graph/components/pieCharts/marriageDist.js index 2bf29f1..df11082 100644 --- a/src/layouts/graph/components/pieCharts/marriageDist.js +++ b/src/layouts/graph/components/pieCharts/marriageDist.js @@ -28,7 +28,7 @@ function MarriageDistribution() { return ( { @@ -74,6 +80,8 @@ function GraphViewer() { setIncludeLandSale(true); setIncludeMarriageDist(true); setIncludePriceFluct(true); + setIncludeDemographic(true); + setIncludeHouseSale(true); }; const createPDF = () => { const selectedComponents = []; @@ -94,6 +102,12 @@ function GraphViewer() { if (includePriceFluct) { selectedComponents.push(); } + if (includeDemographic) { + selectedComponents.push(); + } + if (includeHouseSale) { + selectedComponents.push(); + } // Pass the selected components to your PDF generator function (ChartToPDF) generatePDF(selectedComponents, contentRef, title, user.user_ID); @@ -134,8 +148,8 @@ function GraphViewer() { setIncludeLandSale(!includeLandSale)} + checked={includeHouseSale} + onChange={() => setIncludeHouseSale(!includeHouseSale)} /> @@ -215,8 +229,8 @@ function GraphViewer() { setIncludePriceFluct(!includePriceFluct)} + checked={includeDemographic} + onChange={() => setIncludeDemographic(!includeDemographic)} /> diff --git a/src/layouts/reports/data/reportsdata.js b/src/layouts/reports/data/reportsdata.js index a7aa182..2d40fe8 100644 --- a/src/layouts/reports/data/reportsdata.js +++ b/src/layouts/reports/data/reportsdata.js @@ -64,34 +64,84 @@ export default function Data() { return { rawData: [ { - Name: "John Doe", - Age: 30, - Email: "johndoe@example.com", - City: "New York", + id: 1, + name: "Historic Estate", + location: "Jaffna", + date: "Sun, 03 Sep 2023 18:30:04 GMT", + contactNumbers: ["0774698456", "0768596489"], + price: "Rs.250000", }, { - Name: "Jane Smith", - Age: 28, - Email: "janesmith@example.com", - City: "Los Angeles", + id: 2, + name: "Seaview Bungalow", + location: "Trincomalee", + date: "Wed, 30 Aug 2023 18:30:07 GMT", + contactNumbers: ["0774698459", "0768596492"], + price: "Rs.190000", }, { - Name: "Bob Johnson", - Age: 35, - Email: "bobjohnson@example.com", - City: "Chicago", + id: 3, + name: "Ancient Property", + location: "Anuradhapura", + date: "Wed, 30 Aug 2023 18:30:05 GMT", + contactNumbers: ["0774698457", "0768596490"], + price: "Rs.120000", }, { - Name: "Alice Brown", - Age: 25, - Email: "alicebrown@example.com", - City: "San Francisco", + id: 4, + name: "Mountain View Property", + location: "Kandy", + date: "Wed, 30 Aug 2023 18:30:01 GMT", + contactNumbers: ["0774698453", "0768596486"], + price: "Rs.150000", }, { - Name: "What", - Age: "am", - Email: "I", - City: "doing?", + id: 5, + name: "Hillside Property", + location: "Nuwara Eliya", + date: "Thu, 24 Aug 2023 18:30:09 GMT", + contactNumbers: ["0774698461", "0768596494"], + price: "Rs.120000", + }, + { + id: 6, + name: "Seaside Paradise", + location: "Galle", + date: "Sat, 19 Aug 2023 18:30:02 GMT", + contactNumbers: ["0774698454", "0768596487"], + price: "Rs.200000", + }, + { + id: 7, + name: "Beachfront Villa", + location: "Negombo", + date: "Thu, 10 Aug 2023 18:30:03 GMT", + contactNumbers: ["0774698455", "0768596488"], + price: "Rs.180000", + }, + { + id: 8, + name: "Riverside Land", + location: "Matara", + date: "Fri, 04 Aug 2023 18:30:08 GMT", + contactNumbers: ["0774698460", "0768596493"], + price: "Rs.80000", + }, + { + id: 9, + name: "Lakefront Retreat", + location: "Batticaloa", + date: "Thu, 03 Aug 2023 18:30:06 GMT", + contactNumbers: ["0774698458", "0768596491"], + price: "Rs.150000", + }, + { + id: 10, + name: "Prime Lands", + location: "Colombo", + date: "Sun, 30 Jul 2023 18:30:00 GMT", + contactNumbers: ["0774698452", "0768596485"], + price: "Rs.100000", }, ], columns: [ diff --git a/src/layouts/reports/graphs/graphdetails.js b/src/layouts/reports/graphs/graphdetails.js index 1d84f5f..b361175 100644 --- a/src/layouts/reports/graphs/graphdetails.js +++ b/src/layouts/reports/graphs/graphdetails.js @@ -2,7 +2,17 @@ import React from "react"; import { useParams } from "react-router-dom"; // For accessing route parameters import { Container, Typography } from "@mui/material"; +// Material Dashboard 2 React components +import MDBox from "components/MDBox"; + +import data from "../data/reportsdata"; +import MDButton from "components/MDButton"; +import { generateExcel } from "../reports"; +import { CSVLink } from "react-csv"; +import Projects from "layouts/dashboard/components/Projects"; + const GraphDetails = () => { + const { rawData } = data(); // Get the advertisement id from the URL const { title } = useParams(); @@ -13,6 +23,17 @@ const GraphDetails = () => { {title} + + + generateExcel(rawData, "uselessReport")}> + Export to Excel + + + + + Export to CSV + + ); }; diff --git a/src/layouts/reports/reports.js b/src/layouts/reports/reports.js index 5d94cb2..f5ad1e1 100644 --- a/src/layouts/reports/reports.js +++ b/src/layouts/reports/reports.js @@ -3,9 +3,9 @@ import "jspdf-autotable"; import html2canvas from "html2canvas"; import * as XLSX from "xlsx"; -import { savePdf } from "api/report/saveReport"; -import { storage } from "../../firebase"; -import { ref, uploadBytes, getDownloadURL } from "firebase/storage"; +// import { savePdf } from "api/report/saveReport"; +// import { storage } from "../../firebase"; +// import { ref, uploadBytes, getDownloadURL } from "firebase/storage"; export const generateCSV = (data, filename) => { const csvContent = "data:text/csv;charset=utf-8," + data.map((row) => row.join(",")).join("\n"); @@ -55,23 +55,24 @@ const generatePDF = async (componentsToPrint, contentRef, title, user_ID) => { } doc.save(`${title}.pdf`); - const pdfBlob = doc.output("blob"); + // const pdfBlob = doc.output("blob"); const userID = user_ID; - const pdfRef = ref(storage, `Reports/${title}`); + console.log(userID); + // const pdfRef = ref(storage, `Reports/${title}`); - // Upload the PDF to Firebase Storage - await uploadBytes(pdfRef, pdfBlob); + // // Upload the PDF to Firebase Storage + // await uploadBytes(pdfRef, pdfBlob); - // Get the download URL of the uploaded PDF - const downloadURL = await getDownloadURL(pdfRef); // Add this import: import { getDownloadURL } from "firebase/storage"; - // Send the PDF URL to the backend using the savePdf function or do whatever you need with it - const response = await savePdf(downloadURL, userID, title); + // // Get the download URL of the uploaded PDF + // const downloadURL = await getDownloadURL(pdfRef); // Add this import: import { getDownloadURL } from "firebase/storage"; + // // Send the PDF URL to the backend using the savePdf function or do whatever you need with it + // const response = await savePdf(downloadURL, userID, title); - if (response && response.message) { - console.log("PDF uploaded successfully!"); - } else { - console.error("Failed to upload PDF:", response.error); - } + // if (response && response.message) { + // console.log("PDF uploaded successfully!"); + // } else { + // console.error("Failed to upload PDF:", response.error); + // } } catch (error) { console.error("An error occurred while generating/uploading PDF:", error); } diff --git a/src/layouts/upload/inputURL.js b/src/layouts/upload/inputURL.js index c287774..acec12d 100644 --- a/src/layouts/upload/inputURL.js +++ b/src/layouts/upload/inputURL.js @@ -62,38 +62,52 @@ function InputURL() { maxWidth: "100%", }} > -
- - - - Analyze - - -
+ + {loading && (