decap-cms-widget-datetime 3.4.0 → 3.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -17,22 +17,26 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
17
17
  styles: "display:flex;gap:20px;width:fit-content;label:Buttons;"
18
18
  } : {
19
19
  name: "1tfa1p6-Buttons",
20
- styles: "display:flex;gap:20px;width:fit-content;label:Buttons;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAiBc","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle, t, isDisabled } =\n      this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons t={t} handleChange={v => this.handleChange(v)} getNow={() => this.getNow()} />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */",
20
+ styles: "display:flex;gap:20px;width:fit-content;label:Buttons;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAiBc","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, fieldName, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        aria-label={t('editor.editorWidgets.datetime.setToNow', { fieldLabel: fieldName })}\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const {\n      forID,\n      field,\n      value,\n      classNameWrapper,\n      setActiveStyle,\n      setInactiveStyle,\n      t,\n      isDisabled,\n    } = this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons\n            t={t}\n            fieldName={field.get('name')}\n            handleChange={v => this.handleChange(v)}\n            getNow={() => this.getNow()}\n          />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */",
21
21
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
22
  };
23
23
  function Buttons({
24
24
  t,
25
+ fieldName,
25
26
  handleChange,
26
27
  getNow
27
28
  }) {
28
29
  return jsx("div", {
29
30
  css: _ref3
30
31
  }, jsx("button", {
31
- css: /*#__PURE__*/css(buttons.button, " ", buttons.widget, ";;label:Buttons;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAwBgB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle, t, isDisabled } =\n      this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons t={t} handleChange={v => this.handleChange(v)} getNow={() => this.getNow()} />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */")),
32
+ "aria-label": t('editor.editorWidgets.datetime.setToNow', {
33
+ fieldLabel: fieldName
34
+ }),
35
+ css: /*#__PURE__*/css(buttons.button, " ", buttons.widget, ";;label:Buttons;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAyBgB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, fieldName, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        aria-label={t('editor.editorWidgets.datetime.setToNow', { fieldLabel: fieldName })}\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const {\n      forID,\n      field,\n      value,\n      classNameWrapper,\n      setActiveStyle,\n      setInactiveStyle,\n      t,\n      isDisabled,\n    } = this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons\n            t={t}\n            fieldName={field.get('name')}\n            handleChange={v => this.handleChange(v)}\n            getNow={() => this.getNow()}\n          />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */")),
32
36
  onClick: () => handleChange(getNow()),
33
37
  "data-testid": "now-button"
34
38
  }, t('editor.editorWidgets.datetime.now')), jsx("button", {
35
- css: /*#__PURE__*/css(buttons.button, " ", buttons.widget, ";;label:Buttons;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAkCgB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle, t, isDisabled } =\n      this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons t={t} handleChange={v => this.handleChange(v)} getNow={() => this.getNow()} />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */")),
39
+ css: /*#__PURE__*/css(buttons.button, " ", buttons.widget, ";;label:Buttons;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAmCgB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, fieldName, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        aria-label={t('editor.editorWidgets.datetime.setToNow', { fieldLabel: fieldName })}\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const {\n      forID,\n      field,\n      value,\n      classNameWrapper,\n      setActiveStyle,\n      setInactiveStyle,\n      t,\n      isDisabled,\n    } = this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons\n            t={t}\n            fieldName={field.get('name')}\n            handleChange={v => this.handleChange(v)}\n            getNow={() => this.getNow()}\n          />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */")),
36
40
  onClick: () => handleChange(''),
37
41
  "data-testid": "clear-button"
38
42
  }, t('editor.editorWidgets.datetime.clear')));
@@ -42,7 +46,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
42
46
  styles: "font-size:0.8em;color:#666;label:DateTimeControl;"
43
47
  } : {
44
48
  name: "1mn76l5-DateTimeControl",
45
- styles: "font-size:0.8em;color:#666;label:DateTimeControl;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AA6LoB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle, t, isDisabled } =\n      this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons t={t} handleChange={v => this.handleChange(v)} getNow={() => this.getNow()} />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */",
49
+ styles: "font-size:0.8em;color:#666;label:DateTimeControl;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAsMoB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, fieldName, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        aria-label={t('editor.editorWidgets.datetime.setToNow', { fieldLabel: fieldName })}\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const {\n      forID,\n      field,\n      value,\n      classNameWrapper,\n      setActiveStyle,\n      setInactiveStyle,\n      t,\n      isDisabled,\n    } = this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons\n            t={t}\n            fieldName={field.get('name')}\n            handleChange={v => this.handleChange(v)}\n            getNow={() => this.getNow()}\n          />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */",
46
50
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
51
  };
48
52
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -50,7 +54,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
50
54
  styles: "display:flex!important;gap:20px;align-items:center;label:DateTimeControl;"
51
55
  } : {
52
56
  name: "ptu1mf-DateTimeControl",
53
- styles: "display:flex!important;gap:20px;align-items:center;label:DateTimeControl;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AA2KgB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle, t, isDisabled } =\n      this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons t={t} handleChange={v => this.handleChange(v)} getNow={() => this.getNow()} />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */",
57
+ styles: "display:flex!important;gap:20px;align-items:center;label:DateTimeControl;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/DateTimeControl.js"],"names":[],"mappings":"AAoLgB","file":"../../src/DateTimeControl.js","sourcesContent":["/** @jsx jsx */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx, css } from '@emotion/react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport localizedFormat from 'dayjs/plugin/localizedFormat';\nimport utc from 'dayjs/plugin/utc';\nimport { buttons } from 'decap-cms-ui-default';\n\ndayjs.extend(customParseFormat);\ndayjs.extend(localizedFormat);\ndayjs.extend(utc);\n\nfunction Buttons({ t, fieldName, handleChange, getNow }) {\n  return (\n    <div\n      css={css`\n        display: flex;\n        gap: 20px;\n        width: fit-content;\n      `}\n    >\n      <button\n        aria-label={t('editor.editorWidgets.datetime.setToNow', { fieldLabel: fieldName })}\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange(getNow())}\n        data-testid=\"now-button\"\n      >\n        {t('editor.editorWidgets.datetime.now')}\n      </button>\n      <button\n        css={css`\n          ${buttons.button}\n          ${buttons.widget}\n        `}\n        onClick={() => handleChange('')}\n        data-testid=\"clear-button\"\n      >\n        {t('editor.editorWidgets.datetime.clear')}\n      </button>\n    </div>\n  );\n}\n\nclass DateTimeControl extends React.Component {\n  static propTypes = {\n    field: PropTypes.object.isRequired,\n    forID: PropTypes.string,\n    onChange: PropTypes.func.isRequired,\n    classNameWrapper: PropTypes.string.isRequired,\n    setActiveStyle: PropTypes.func.isRequired,\n    setInactiveStyle: PropTypes.func.isRequired,\n    value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n    t: PropTypes.func.isRequired,\n    isDisabled: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    isDisabled: false,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');\n\n    const { value } = this.props;\n    if (value === '{{now}}') {\n      this.handleChange(this.getNow());\n    }\n  }\n\n  isUtc = this.props.field.get('picker_utc') || false;\n\n  escapeZ(str) {\n    if (/Z(?![\\]])/.test(str)) {\n      return str.replace('Z', '[Z]');\n    }\n    return str;\n  }\n\n  getFormat() {\n    const { field } = this.props;\n    let inputType = 'datetime-local';\n    let inputFormat = 'YYYY-MM-DDTHH:mm';\n    let format = `YYYY-MM-DDTHH:mm:ss.SSS${this.isUtc ? '[Z]' : 'Z'}`;\n    let userFormat = field?.get('format');\n    let dateFormat = field?.get('date_format');\n    let timeFormat = field?.get('time_format');\n    if (dateFormat === true) dateFormat = 'YYYY-MM-DD';\n    if (timeFormat === true) timeFormat = 'HH:mm';\n\n    if (this.isUtc) {\n      userFormat = this.escapeZ(userFormat);\n      dateFormat = this.escapeZ(dateFormat);\n      timeFormat = this.escapeZ(timeFormat);\n    }\n\n    if (typeof dateFormat === 'string' && typeof timeFormat === 'string') {\n      format = `${dateFormat}T${timeFormat}`;\n    } else if (typeof timeFormat === 'string') {\n      inputType = 'time';\n      format = timeFormat;\n    } else if (typeof dateFormat === 'string') {\n      inputType = 'date';\n      format = dateFormat;\n    }\n\n    if (typeof userFormat === 'string') {\n      format = userFormat;\n      inputType = 'datetime-local';\n    }\n\n    if (dateFormat === false) inputType = 'time';\n    if (timeFormat === false) inputType = 'date';\n    if (inputType === 'datetime-local') inputFormat = 'YYYY-MM-DDTHH:mm';\n    if (inputType === 'date') inputFormat = 'YYYY-MM-DD';\n    if (inputType === 'time') inputFormat = 'HH:mm';\n\n    return { format, inputType, inputFormat };\n  }\n\n  isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';\n\n  getNow() {\n    const { inputFormat } = this.getFormat();\n    return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);\n  }\n\n  formatInputValue(value) {\n    if (value === '') return value;\n    const { format, inputFormat } = this.getFormat();\n\n    const inputValue = this.isUtc\n      ? dayjs.utc(value, format).format(inputFormat)\n      : dayjs(value, format).format(inputFormat);\n\n    if (this.isValidDate(inputValue)) {\n      return inputValue;\n    }\n    return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);\n  }\n\n  handleChange = datetime => {\n    if (!this.isValidDate(datetime)) return;\n    const { onChange } = this.props;\n\n    if (datetime === '') {\n      onChange('');\n    } else {\n      const { format, inputFormat } = this.getFormat();\n      const formattedValue = dayjs(datetime, inputFormat).format(format);\n      onChange(formattedValue);\n    }\n  };\n\n  onInputChange = e => {\n    const etv = e.target.value;\n    this.handleChange(etv);\n  };\n\n  render() {\n    const {\n      forID,\n      field,\n      value,\n      classNameWrapper,\n      setActiveStyle,\n      setInactiveStyle,\n      t,\n      isDisabled,\n    } = this.props;\n    const { inputType } = this.getFormat();\n\n    return (\n      <div\n        className={classNameWrapper}\n        css={css`\n          display: flex !important;\n          gap: 20px;\n          align-items: center;\n        `}\n      >\n        <input\n          id={forID}\n          data-testid={forID}\n          type={inputType}\n          value={value ? this.formatInputValue(value) : ''}\n          onChange={this.onInputChange}\n          onFocus={setActiveStyle}\n          onBlur={setInactiveStyle}\n          disabled={isDisabled}\n        />\n        {this.isUtc && (\n          <span\n            css={css`\n              font-size: 0.8em;\n              color: #666;\n            `}\n          >\n            UTC\n          </span>\n        )}\n        {!isDisabled && (\n          <Buttons\n            t={t}\n            fieldName={field.get('name')}\n            handleChange={v => this.handleChange(v)}\n            getNow={() => this.getNow()}\n          />\n        )}\n      </div>\n    );\n  }\n}\n\nexport default DateTimeControl;\n"]} */",
54
58
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
55
59
  };
56
60
  class DateTimeControl extends React.Component {
@@ -168,6 +172,7 @@ class DateTimeControl extends React.Component {
168
172
  render() {
169
173
  const {
170
174
  forID,
175
+ field,
171
176
  value,
172
177
  classNameWrapper,
173
178
  setActiveStyle,
@@ -194,6 +199,7 @@ class DateTimeControl extends React.Component {
194
199
  css: _ref
195
200
  }, "UTC"), !isDisabled && jsx(Buttons, {
196
201
  t: t,
202
+ fieldName: field.get('name'),
197
203
  handleChange: v => this.handleChange(v),
198
204
  getNow: () => this.getNow()
199
205
  }));
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "decap-cms-widget-datetime",
3
3
  "description": "Widget for editing dates and times in Decap CMS.",
4
- "version": "3.4.0",
4
+ "version": "3.4.1",
5
5
  "homepage": "https://www.decapcms.org/docs/widgets/#datetime",
6
6
  "repository": "https://github.com/decaporg/decap-cms/tree/main/packages/decap-cms-widget-datetime",
7
7
  "bugs": "https://github.com/decaporg/decap-cms/issues",
@@ -28,5 +28,5 @@
28
28
  "@emotion/react": "^11.11.1",
29
29
  "react": "^19.1.0"
30
30
  },
31
- "gitHead": "d3465f53b7f056ad5d872948a07eaa8e4ae63315"
31
+ "gitHead": "46c6646c68ead2cd982acb236d7aff0356f313ba"
32
32
  }
@@ -12,7 +12,7 @@ dayjs.extend(customParseFormat);
12
12
  dayjs.extend(localizedFormat);
13
13
  dayjs.extend(utc);
14
14
 
15
- function Buttons({ t, handleChange, getNow }) {
15
+ function Buttons({ t, fieldName, handleChange, getNow }) {
16
16
  return (
17
17
  <div
18
18
  css={css`
@@ -22,6 +22,7 @@ function Buttons({ t, handleChange, getNow }) {
22
22
  `}
23
23
  >
24
24
  <button
25
+ aria-label={t('editor.editorWidgets.datetime.setToNow', { fieldLabel: fieldName })}
25
26
  css={css`
26
27
  ${buttons.button}
27
28
  ${buttons.widget}
@@ -162,8 +163,16 @@ class DateTimeControl extends React.Component {
162
163
  };
163
164
 
164
165
  render() {
165
- const { forID, value, classNameWrapper, setActiveStyle, setInactiveStyle, t, isDisabled } =
166
- this.props;
166
+ const {
167
+ forID,
168
+ field,
169
+ value,
170
+ classNameWrapper,
171
+ setActiveStyle,
172
+ setInactiveStyle,
173
+ t,
174
+ isDisabled,
175
+ } = this.props;
167
176
  const { inputType } = this.getFormat();
168
177
 
169
178
  return (
@@ -196,7 +205,12 @@ class DateTimeControl extends React.Component {
196
205
  </span>
197
206
  )}
198
207
  {!isDisabled && (
199
- <Buttons t={t} handleChange={v => this.handleChange(v)} getNow={() => this.getNow()} />
208
+ <Buttons
209
+ t={t}
210
+ fieldName={field.get('name')}
211
+ handleChange={v => this.handleChange(v)}
212
+ getNow={() => this.getNow()}
213
+ />
200
214
  )}
201
215
  </div>
202
216
  );