From 3129b2decb4fc127998a2630aeca501757585277 Mon Sep 17 00:00:00 2001 From: YunMeng99 Date: Wed, 27 Mar 2024 15:52:52 +0800 Subject: [PATCH 1/2] fix(TimePicker2): should support custom formatting close ##3651 --- components/time-picker2/__tests__/index-spec.js | 9 +++++++++ components/time-picker2/time-picker.jsx | 3 ++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/components/time-picker2/__tests__/index-spec.js b/components/time-picker2/__tests__/index-spec.js index 22f14589de..e6589db8df 100644 --- a/components/time-picker2/__tests__/index-spec.js +++ b/components/time-picker2/__tests__/index-spec.js @@ -385,6 +385,15 @@ describe('TimePicker2', () => { done(); }, 1000); }); + + it('should support custom formatting , close #3651', () => { + const div = document.createElement('div'); + document.body.appendChild(div); + mount(, { attachTo: div }); + assert( + document.querySelector('li[title="12"][role="option"]').classList.contains('next-selected') + ); + }); }); }); diff --git a/components/time-picker2/time-picker.jsx b/components/time-picker2/time-picker.jsx index f33911fcf7..c84f69165a 100644 --- a/components/time-picker2/time-picker.jsx +++ b/components/time-picker2/time-picker.jsx @@ -402,7 +402,8 @@ class TimePicker2 extends Component { checkValue = (value, strictly) => { const { inputType } = this.state; - const formatter = v => (typeof v === 'string' ? datejs(v, 'HH:mm:ss') : v); + const { format } = this.props; + const formatter = v => (typeof v === 'string' ? datejs(v, format ? format : 'HH:mm:ss') : v); const formattedValue = Array.isArray(value) ? value.map(v => formatter(v)) : formatter(value); return this.props.type === TIME_PICKER_TYPE.RANGE From daa79e75bd686fe22821fbd973c099e92d9558d8 Mon Sep 17 00:00:00 2001 From: YunMeng99 Date: Thu, 28 Mar 2024 10:31:22 +0800 Subject: [PATCH 2/2] feat(TimePicker2): test case modification --- components/time-picker2/__tests__/index-spec.js | 10 ++++++++-- components/time-picker2/time-picker.jsx | 8 ++++---- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/components/time-picker2/__tests__/index-spec.js b/components/time-picker2/__tests__/index-spec.js index e6589db8df..f260aef5d8 100644 --- a/components/time-picker2/__tests__/index-spec.js +++ b/components/time-picker2/__tests__/index-spec.js @@ -389,9 +389,15 @@ describe('TimePicker2', () => { it('should support custom formatting , close #3651', () => { const div = document.createElement('div'); document.body.appendChild(div); - mount(, { attachTo: div }); + const wrapper = mount(, { attachTo: div }); + wrapper + .find('.next-time-picker2-input input') + .simulate('change', { target: { value: '12' } }); + wrapper.update(); assert( - document.querySelector('li[title="12"][role="option"]').classList.contains('next-selected') + document + .querySelector('li[title="12"][role="option"]') + .classList.contains('next-selected') ); }); }); diff --git a/components/time-picker2/time-picker.jsx b/components/time-picker2/time-picker.jsx index c84f69165a..882631ae13 100644 --- a/components/time-picker2/time-picker.jsx +++ b/components/time-picker2/time-picker.jsx @@ -402,12 +402,12 @@ class TimePicker2 extends Component { checkValue = (value, strictly) => { const { inputType } = this.state; - const { format } = this.props; - const formatter = v => (typeof v === 'string' ? datejs(v, format ? format : 'HH:mm:ss') : v); + const { format, type, disabled } = this.props; + const formatter = v => (typeof v === 'string' ? datejs(v, format) : v); const formattedValue = Array.isArray(value) ? value.map(v => formatter(v)) : formatter(value); - return this.props.type === TIME_PICKER_TYPE.RANGE - ? checkRangeDate(formattedValue, inputType, this.props.disabled, strictly) + return type === TIME_PICKER_TYPE.RANGE + ? checkRangeDate(formattedValue, inputType, disabled, strictly) : checkDate(formattedValue); };