From 0019128daf2a9f4a2a0f7295c392488a67adb96e Mon Sep 17 00:00:00 2001
From: "ashutosh.nehete" 
Date: Fri, 18 Apr 2025 18:18:20 +0530
Subject: [PATCH] Create form to request demo of application
---
 .../Activities/ReportTaskComments.jsx         |   4 +-
 src/pages/authentication/RegisterPage.jsx     | 257 ++++++++++++++----
 src/repositories/AuthRepository.jsx           |   1 +
 src/repositories/MastersRepository.jsx        |   2 +-
 4 files changed, 205 insertions(+), 59 deletions(-)
diff --git a/src/components/Activities/ReportTaskComments.jsx b/src/components/Activities/ReportTaskComments.jsx
index f116eb07..daa368cf 100644
--- a/src/components/Activities/ReportTaskComments.jsx
+++ b/src/components/Activities/ReportTaskComments.jsx
@@ -38,8 +38,8 @@ const ReportTaskComments = ({ commentsData, closeModal }) => {
 
     try {
       setloading(true);
-      // const resp = await TasksRepository.taskComments( sendComment );
-      // console.timeLog( resp )
+      const resp = await TasksRepository.taskComments( sendComment );
+      console.timeLog( resp )
       reset();
       setloading(false);
       showToast("Successfully Sent", "success");
diff --git a/src/pages/authentication/RegisterPage.jsx b/src/pages/authentication/RegisterPage.jsx
index 9f58cf68..01368df0 100644
--- a/src/pages/authentication/RegisterPage.jsx
+++ b/src/pages/authentication/RegisterPage.jsx
@@ -1,65 +1,108 @@
-import { useState } from "react";
+import { useEffect, useState } from "react";
 import { Link } from "react-router-dom";
 import "./page-auth.css";
 import { AuthWrapper } from "./AuthWrapper";
-import { useForm,Controller } from 'react-hook-form';
-import { zodResolver } from '@hookform/resolvers/zod';
-import { z } from 'zod';
+import { useForm, Controller } from "react-hook-form";
+import { zodResolver } from "@hookform/resolvers/zod";
+import { z } from "zod";
 import showToast from "../../services/toastService";
 import AuthRepository from "../../repositories/AuthRepository";
+import { MasterRespository } from "../../repositories/MastersRepository";
 
 const mobileNumberRegex = /^(?:\d{10}|\d{3}[-\s]?\d{3}[-\s]?\d{4})$/;
 
 const registerSchema = z.object({
-  orgName:z.string().min(1,{message:"Organization Name is required"}),
-  email:z.string().email(),
-  contactPerson:z.string().min(1,{message:"Person Name is required"}),
-  contactNo:z.string().min(1,{message: "Phone Number is required"})
-        .regex(mobileNumberRegex, {message:"Invalid phone number "}),
-  orgSize:z.string().min(1,{message:"please Select Organization Size "}),
+  organizatioinName: z
+    .string()
+    .min(1, { message: "Organization Name is required" }),
+  email: z.string().email(),
+  about: z
+    .string()
+    .min(1, { message: "Current Address is required" })
+    .max(500, { message: "Address cannot exceed 500 characters" }),
+  contactPerson: z.string().min(1, { message: "Person Name is required" }),
+  contactNumber: z
+    .string()
+    .min(1, { message: "Phone Number is required" })
+    .regex(mobileNumberRegex, { message: "Invalid phone number " }),
+  oragnizationSize: z
+    .string()
+    .min(1, { message: "please Select Organization Size " }),
+  industryId: z.string(),
   terms: z.boolean().refine((val) => val === true, {
     message: "Please accept the terms and conditions.",
   }),
-} )
+});
 
 const RegisterPage = () => {
-  
-  const {register,handleSubmit,formState: { errors }}  = useForm({
-    resolver:zodResolver(registerSchema)
-  })
-  
- const onSubmit= async(data)=>{
-   try
-   {
-    //  const response = await AuthRepository.register( data );
-    
-     showToast("Your Registration SuccessFully !")
-   } catch ( error )
-   {
-     console.log(error)
-     showToast(error.message,"error")
-   }
- }
+  const [registered,setRegristered] = useState(false); 
+  const [industries, setIndustries] = useState([]);
+  const {
+    register,
+    handleSubmit,
+    formState: { errors },
+  } = useForm({
+    resolver: zodResolver(registerSchema),
+  });
+
+  const onSubmit = async (data) => {
+    try {
+      const response = await AuthRepository.requestDemo(data);
+      showToast("Your Registration SuccessFully !");
+      setRegristered(true);
+    } catch (error) {
+      // console.log(error);
+      showToast(error.message, "error");
+    }
+  };
+  useEffect(() => {
+    fetchIndustries();
+  }, []);
+
+  useEffect(() => {
+  }, [industries]);
+
+  const fetchIndustries = async () => {
+    try {
+      const response = await MasterRespository.getIndustries();
+      const industry = response.data;
+      setIndustries(industry);
+    } catch (error) {
+      showToast(error.message, "error");
+    }
+  };
   return (
-    
+    <>
+    {!registered && (
       Adventure starts here 🚀
       Make your app management easy and fun!
 
-      
-    
+    )}
+    {registered && (
+      Thank you for contacting us
+      We will get back to you soon
+      
+          
+          Back to login
+        
+    )}
+    >
   );
 };
 
diff --git a/src/repositories/AuthRepository.jsx b/src/repositories/AuthRepository.jsx
index 058693d5..b8a10e2d 100644
--- a/src/repositories/AuthRepository.jsx
+++ b/src/repositories/AuthRepository.jsx
@@ -9,6 +9,7 @@ const AuthRepository = {
   register: ( data ) => api.post( 'api/auth/register', data ),
   resetPassword: ( data ) => api.post( '/api/auth/reset-password', data ),
   forgotPassword: (data) => api.post( '/api/auth/forgot-password', data),
+  requestDemo: (data) => api.post('/api/auth/inquiry',data),
   sendMail:(data)=>api.post("/api/auth/sendmail",data)
 };
 
diff --git a/src/repositories/MastersRepository.jsx b/src/repositories/MastersRepository.jsx
index a785c152..44724cfd 100644
--- a/src/repositories/MastersRepository.jsx
+++ b/src/repositories/MastersRepository.jsx
@@ -32,6 +32,6 @@ export const MasterRespository = {
   getActivites: () => api.get( 'api/master/activities' ),
   createActivity: (data) => api.post( 'api/master/activity',data ),
   updateActivity:(id,data) =>api.post(`api/master/edit/${id}`,data),
-  
+  getIndustries:()=> api.get('api/master/industries'),
   
 }
\ No newline at end of file