From bc1f521be4f66f30e044bf1d0bb387ff5f14770a Mon Sep 17 00:00:00 2001 From: Christopher Cave-Ayland Date: Wed, 26 Jul 2023 14:03:43 +0100 Subject: [PATCH] feat: add closed source toggle to add and edit software forms --- .../components/software/add/AddSoftwareCard.tsx | 13 ++++++++++++- frontend/components/software/add/addConfig.ts | 4 ++++ .../components/software/edit/editSoftwareConfig.tsx | 3 +++ .../edit/information/SoftwareInformationForm.tsx | 7 +++++++ frontend/types/SoftwareTypes.ts | 2 ++ 5 files changed, 28 insertions(+), 1 deletion(-) diff --git a/frontend/components/software/add/AddSoftwareCard.tsx b/frontend/components/software/add/AddSoftwareCard.tsx index b28482310..e655ff17e 100644 --- a/frontend/components/software/add/AddSoftwareCard.tsx +++ b/frontend/components/software/add/AddSoftwareCard.tsx @@ -10,6 +10,8 @@ import {useEffect, useState} from 'react' import {useRouter} from 'next/router' import Button from '@mui/material/Button' import Alert from '@mui/material/Alert' +import FormControlLabel from '@mui/material/FormControlLabel' +import Switch from '@mui/material/Switch' import CircularProgress from '@mui/material/CircularProgress' import {useForm} from 'react-hook-form' @@ -35,6 +37,7 @@ type AddSoftwareForm = { slug: string, brand_name: string, short_statement: string|null, + closed_source: boolean } let lastValidatedSlug = '' @@ -52,7 +55,7 @@ export default function AddSoftwareCard() { }) const {errors, isValid} = formState // watch for data change in the form - const [slug,brand_name,short_statement] = watch(['slug', 'brand_name', 'short_statement']) + const [slug,brand_name,short_statement,closed_source] = watch(['slug', 'brand_name', 'short_statement', 'closed_source']) // take the last slugValue const bouncedSlug = useDebounce(slugValue, 700) @@ -142,6 +145,7 @@ export default function AddSoftwareCard() { brand_name: data.brand_name, slug: data.slug, short_statement: data.short_statement, + closed_source: data.closed_source, is_published: false, description: null, description_type: 'markdown', @@ -252,6 +256,13 @@ export default function AddSoftwareCard() { }} register={register('slug',config.slug.validation)} /> +
+ + } + label="Closed Source" + />