From 0fb3cfacd7ba830381ee320ed7b1375a863c64b0 Mon Sep 17 00:00:00 2001 From: michho8 Date: Thu, 22 Feb 2024 13:06:09 -1000 Subject: [PATCH] Create Feedback page --- ui/package.json | 8 +- .../app/feedback/components/FeedbackForm.tsx | 131 +++++++++++++ ui/src/app/feedback/page.tsx | 43 +++++ .../components/layout/alerts/ErrorAlert.tsx | 24 +++ .../components/layout/alerts/SuccessAlert.tsx | 26 +++ ui/src/components/ui/alert.tsx | 11 +- ui/src/components/ui/button.tsx | 11 +- ui/src/components/ui/form.tsx | 176 ++++++++++++++++++ ui/src/components/ui/input.tsx | 31 +++ ui/src/components/ui/label.tsx | 26 +++ ui/src/services/EmailService.ts | 4 +- ui/tests/app/feedback/page.test.tsx | 57 ++++++ .../layout/alerts/ErrorAlert.test.tsx | 11 ++ .../layout/alerts/SuccessAlert.test.tsx | 11 ++ 14 files changed, 555 insertions(+), 15 deletions(-) create mode 100644 ui/src/app/feedback/components/FeedbackForm.tsx create mode 100644 ui/src/app/feedback/page.tsx create mode 100644 ui/src/components/layout/alerts/ErrorAlert.tsx create mode 100644 ui/src/components/layout/alerts/SuccessAlert.tsx create mode 100644 ui/src/components/ui/form.tsx create mode 100644 ui/src/components/ui/input.tsx create mode 100644 ui/src/components/ui/label.tsx create mode 100644 ui/tests/app/feedback/page.test.tsx create mode 100644 ui/tests/components/layout/alerts/ErrorAlert.test.tsx create mode 100644 ui/tests/components/layout/alerts/SuccessAlert.test.tsx diff --git a/ui/package.json b/ui/package.json index 3d92dd95..0aaed138 100644 --- a/ui/package.json +++ b/ui/package.json @@ -14,7 +14,9 @@ }, "dependencies": { "@radix-ui/react-alert-dialog": "^1.0.5", + "@hookform/resolvers": "^3.3.4", "@radix-ui/react-dialog": "^1.0.5", + "@radix-ui/react-label": "^2.0.2", "@radix-ui/react-slot": "^1.0.2", "@radix-ui/react-tabs": "^1.0.4", "camaro": "^6.2.2", @@ -27,15 +29,19 @@ "react": "^18", "react-dom": "^18", "react-idle-timer": "^5.7.2", + "react-hook-form": "^7.50.1", + "react-router-dom": "^6.22.1", "tailwind-merge": "^2.2.1", "tailwindcss-animate": "^1.0.7", - "uniqid": "^5.4.0" + "uniqid": "^5.4.0", + "zod": "^3.22.4" }, "devDependencies": { "@stylistic/eslint-plugin": "^1.6.1", "@swc/core": "^1.3.106", "@testing-library/jest-dom": "^6.3.0", "@testing-library/react": "^14.1.2", + "@testing-library/user-event": "^14.5.2", "@types/jest": "^29.5.11", "@types/node": "^20", "@types/react": "^18", diff --git a/ui/src/app/feedback/components/FeedbackForm.tsx b/ui/src/app/feedback/components/FeedbackForm.tsx new file mode 100644 index 00000000..286d7230 --- /dev/null +++ b/ui/src/app/feedback/components/FeedbackForm.tsx @@ -0,0 +1,131 @@ +'use client' +import React from 'react'; +import {Input} from '@/components/ui/input'; +import {Button} from '@/components/ui/button' +import {Form, FormControl, FormField, FormItem, FormLabel, FormMessage,} from '@/components/ui/form' +import {z} from 'zod' +import {zodResolver} from '@hookform/resolvers/zod' +import {useForm} from 'react-hook-form' +import {EmailResult, Feedback, sendFeedback} from '@/services/EmailService'; + +const FeedbackForm = ({ currUser, setShowSuccessAlert, setShowErrorAlert } : +{ currUser:string, setShowSuccessAlert:React.Dispatch>, + setShowErrorAlert:React.Dispatch> }) => { + + const formSchema = z.object({ + type: z.string(), + name: z.optional(z.string()), + email: z.string().email(), + message: z.string().min(15), + }) + + const form = useForm>({ + resolver: zodResolver(formSchema), + defaultValues: { + type: 'General', + email: currUser + '@hawaii.edu' + } + }); + + async function onSubmit(values: z.infer) { + const input: Feedback = { + type: values.type, + name: values.name, + email: values.email, + message: values.message, + exceptionMessage: 'test exception message' + }; + const results = await sendFeedback(input); + const emailResult: EmailResult = { + resultCode: results.resultCode, + recipient: results.recipient, + from: results.from, + subject: results.subject, + text: results.text + }; + + (emailResult.resultCode == 'SUCCESS') ? setShowSuccessAlert(true) : setShowErrorAlert(true); + + if (emailResult.resultCode == 'SUCCESS') { + setShowSuccessAlert(true); + } else { + setShowErrorAlert(true); + } + + //will break without curly braces + form.reset({}); + } + + return ( +
+ <> +
+ + ( + + Feedback Type: + * + + + + + )} + /> + ( + + Your Name (Optional): + + + + + + )} + /> + ( + + Email Address: + * + + + + + + )} + /> + ( + + Your Feedback: + * + +