From 9b9cffdb5d20e19c8777a4d63155e76e5a880a97 Mon Sep 17 00:00:00 2001 From: Batuhan Tomo <91488737+Rekl0w@users.noreply.github.com> Date: Mon, 9 Sep 2024 15:54:31 +0300 Subject: [PATCH] Fix #7134:Refactor Dropdown component to support using option as value (#7141) --- components/lib/dropdown/Dropdown.js | 4 ++++ components/lib/dropdown/dropdown.d.ts | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/components/lib/dropdown/Dropdown.js b/components/lib/dropdown/Dropdown.js index 4ce9724498..7a526776a9 100644 --- a/components/lib/dropdown/Dropdown.js +++ b/components/lib/dropdown/Dropdown.js @@ -825,6 +825,10 @@ export const Dropdown = React.memo( }; const getOptionValue = (option) => { + if (props.useOptionAsValue) { + return option; + } + const optionValue = props.optionValue ? ObjectUtils.resolveFieldData(option, props.optionValue) : option ? option['value'] : ObjectUtils.resolveFieldData(option, 'value'); return props.optionValue || ObjectUtils.isNotEmpty(optionValue) ? optionValue : option; diff --git a/components/lib/dropdown/dropdown.d.ts b/components/lib/dropdown/dropdown.d.ts index de11f4e693..5b84f2fb5f 100644 --- a/components/lib/dropdown/dropdown.d.ts +++ b/components/lib/dropdown/dropdown.d.ts @@ -407,6 +407,10 @@ export interface DropdownProps extends Omit boolean) | undefined; + /** + * Whether the option should be used as the value for the select element. + */ + useOptionAsValue?: boolean; /** * Property name or getter function that refers to the children options of option group. * @defaultValue items