From 7c1f8fc18c5dada2cb1d6787262baf40e4d1e4eb Mon Sep 17 00:00:00 2001 From: "Qingyang(Abby) Hu" Date: Wed, 24 Jul 2024 15:23:02 -0700 Subject: [PATCH] Fix add filter for numeric scripted field (#7022) * Fix add filter for scripted field Signed-off-by: abbyhu2000 * add unit test Signed-off-by: abbyhu2000 * change from nested ternary to if else Signed-off-by: abbyhu2000 * add more unit tests Signed-off-by: abbyhu2000 * change unit tests Signed-off-by: abbyhu2000 * fix typo Signed-off-by: abbyhu2000 --------- Signed-off-by: abbyhu2000 --- .../filter_editor/value_input_type.test.tsx | 80 +++++++++++++++++++ .../filter_editor/value_input_type.tsx | 13 ++- 2 files changed, 92 insertions(+), 1 deletion(-) create mode 100644 src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.test.tsx diff --git a/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.test.tsx b/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.test.tsx new file mode 100644 index 00000000000..aa4f4b4cd21 --- /dev/null +++ b/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.test.tsx @@ -0,0 +1,80 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { ValueInputType } from './value_input_type'; + +let onChangeMock: any; + +describe('Value input type', () => { + beforeAll(() => { + onChangeMock = jest.fn(); + }); + it('is number', async () => { + const valueInputProps = { + value: 1, + type: 'number', + onChange: onChangeMock, + onBlur: () => {}, + placeholder: '', + }; + const component = mountWithIntl(); + expect(component.find('EuiFieldNumber').exists()).toBeTruthy(); + expect(component.find('EuiFieldNumber').prop('value')).toBe(1); + }); + + it('is string', async () => { + const valueInputProps = { + value: 'value', + type: 'string', + onChange: () => {}, + onBlur: () => {}, + placeholder: '', + }; + const component = mountWithIntl(); + expect(component.find('EuiFieldText').exists()).toBeTruthy(); + expect(component.find('EuiFieldText').prop('value')).toBe('value'); + }); + + it('is boolean', async () => { + const valueInputProps = { + value: 'true', + type: 'boolean', + onChange: () => {}, + onBlur: () => {}, + placeholder: '', + }; + const component = mountWithIntl(); + expect(component.find('EuiSelect').exists()).toBeTruthy(); + expect(component.find('EuiSelect').prop('value')).toBe('true'); + }); + + it('is date', async () => { + const valueInputProps = { + value: 'Jun 18, 2024 @ 12:01:55.000', + type: 'date', + onChange: () => {}, + onBlur: () => {}, + placeholder: '', + }; + const component = mountWithIntl(); + expect(component.find('EuiFieldText').exists()).toBeTruthy(); + expect(component.find('EuiFieldText').prop('value')).toBe('Jun 18, 2024 @ 12:01:55.000'); + }); + + it('is ip', async () => { + const valueInputProps = { + value: '127.0.0.1', + type: 'ip', + onChange: () => {}, + onBlur: () => {}, + placeholder: '', + }; + const component = mountWithIntl(); + expect(component.find('EuiFieldText').exists()).toBeTruthy(); + expect(component.find('EuiFieldText').prop('value')).toBe('127.0.0.1'); + }); +}); diff --git a/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.tsx b/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.tsx index 9d7709a5f66..fd1743e96c1 100644 --- a/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.tsx +++ b/src/plugins/data/public/ui/filter_bar/filter_editor/value_input_type.tsx @@ -79,7 +79,7 @@ class ValueInputTypeUI extends Component { ? (value as BigInt).toString() : value } - onChange={this.onChange} + onChange={this.onNumberChange} controlOnly={this.props.controlOnly} className={this.props.className} /> @@ -151,6 +151,17 @@ class ValueInputTypeUI extends Component { this.props.onChange(boolValue); }; + private onNumberChange = (event: React.ChangeEvent) => { + const params = event.target.value; + let numValue; + if (typeof params === 'string') { + numValue = parseFloat(params); + } else if (typeof params === 'bigint') { + numValue = (params as BigInt).toString(); + } + this.props.onChange(numValue ?? params); + }; + private onChange = (event: React.ChangeEvent) => { const params = event.target.value; this.props.onChange(params);