AddQueryParameterButton.jsx
1 year ago
BlockSettings.jsx
1 year ago
ControlBuilder.jsx
1 year ago
DateQueryControl.jsx
1 year ago
DateTimeControl.jsx
1 year ago
ParameterControl.jsx
1 year ago
ParameterList.jsx
1 year ago
QueryInspectorControls.jsx
1 year ago
SelectQueryParameter.jsx
1 year ago
TaxonomyParameterControl.jsx
1 year ago
editor.scss
1 year ago
DateTimeControl.jsx
34 lines
| 1 | import { BaseControl, DateTimePicker, TimePicker } from '@wordpress/components'; |
| 2 | |
| 3 | import clsx from 'clsx'; |
| 4 | import { isValid } from 'date-fns'; |
| 5 | |
| 6 | import './editor.scss'; |
| 7 | |
| 8 | export function DateTimeControl( { id, label, help, value, onChange, className = '', calendar = false } ) { |
| 9 | const currentDate = !! value ? new Date( value ) : ''; |
| 10 | |
| 11 | return ( |
| 12 | <BaseControl |
| 13 | id={ id } |
| 14 | label={ label } |
| 15 | help={ help } |
| 16 | className={ clsx( 'gb-datetime-control', className ) } |
| 17 | > |
| 18 | { calendar ? ( |
| 19 | <DateTimePicker |
| 20 | currentDate={ isValid( currentDate ) ? currentDate : '' } |
| 21 | onChange={ onChange } |
| 22 | is12Hour={ true } |
| 23 | /> |
| 24 | ) : ( |
| 25 | <TimePicker |
| 26 | is12Hour={ true } |
| 27 | currentTime={ isValid( value ) ? value : '' } |
| 28 | onChange={ onChange } |
| 29 | /> |
| 30 | ) } |
| 31 | </BaseControl> |
| 32 | ); |
| 33 | } |
| 34 |