From 50929c5e4ae33402b53771f5e5231e6e73b407a1 Mon Sep 17 00:00:00 2001 From: Min Nyan Lin <72118807+Curis-lab@users.noreply.github.com> Date: Wed, 4 Dec 2024 21:37:29 +0630 Subject: [PATCH] refactor: Autocomplete component in PlaygroundCodeFieldset (#8912) Custom context fields that have a list of allowed values, show values with autocomplete list --- .../PlaygroundCodeFieldset.tsx | 36 +++++++++++++++---- 1 file changed, 29 insertions(+), 7 deletions(-) diff --git a/frontend/src/component/playground/Playground/PlaygroundForm/PlaygroundCodeFieldset/PlaygroundCodeFieldset.tsx b/frontend/src/component/playground/Playground/PlaygroundForm/PlaygroundCodeFieldset/PlaygroundCodeFieldset.tsx index 6459c05c7195..8ac07e8d1a9b 100644 --- a/frontend/src/component/playground/Playground/PlaygroundForm/PlaygroundCodeFieldset/PlaygroundCodeFieldset.tsx +++ b/frontend/src/component/playground/Playground/PlaygroundForm/PlaygroundCodeFieldset/PlaygroundCodeFieldset.tsx @@ -19,6 +19,7 @@ import { useTheme, Autocomplete, type SelectChangeEvent, + Checkbox, } from '@mui/material'; import debounce from 'debounce'; @@ -31,6 +32,9 @@ import { isStringOrStringArray, normalizeCustomContextProperties, } from '../../playground.utils'; +import CheckBoxOutlineBlank from '@mui/icons-material/CheckBoxOutlineBlank'; +import CheckBoxIcon from '@mui/icons-material/CheckBox'; + interface IPlaygroundCodeFieldsetProps { context: string | undefined; setContext: Dispatch>; @@ -155,7 +159,6 @@ export const PlaygroundCodeFieldset: VFC = ({ const value = validDate ? parseDateValue(validDate.toISOString()) : parseDateValue(now.toISOString()); - return ( = ({ ); if (foundField?.legalValues && foundField.legalValues.length > 0) { const options = foundField.legalValues.map(({ value }) => value); + return ( option} + renderOption={(props, option, { selected }) => { + return ( +
  • + + } + checkedIcon={ + + } + sx={(theme) => ({ + marginRight: theme.spacing(0.5), + })} + checked={selected} + /> + {option} +
  • + ); + }} sx={{ width: 370, maxWidth: '100%' }} - renderInput={(params: any) => ( + renderInput={(params) => ( )} - disableCloseOnSelect={false} /> ); }