decap-cms-widget-datetime 3.2.3 → 3.3.0

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.
@@ -1,32 +1,23 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _react = _interopRequireDefault(require("react"));
8
- var _propTypes = _interopRequireDefault(require("prop-types"));
9
- var _react2 = require("@emotion/react");
10
- var _dayjs = _interopRequireDefault(require("dayjs"));
11
- var _customParseFormat = _interopRequireDefault(require("dayjs/plugin/customParseFormat"));
12
- var _localizedFormat = _interopRequireDefault(require("dayjs/plugin/localizedFormat"));
13
- var _utc = _interopRequireDefault(require("dayjs/plugin/utc"));
14
- var _decapCmsUiDefault = require("decap-cms-ui-default");
15
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
18
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
19
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } /** @jsx jsx */
20
- _dayjs.default.extend(_customParseFormat.default);
21
- _dayjs.default.extend(_localizedFormat.default);
22
- _dayjs.default.extend(_utc.default);
1
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
2
+ /** @jsx jsx */
3
+ import React from 'react';
4
+ import PropTypes from 'prop-types';
5
+ import { jsx, css } from '@emotion/react';
6
+ import dayjs from 'dayjs';
7
+ import customParseFormat from 'dayjs/plugin/customParseFormat';
8
+ import localizedFormat from 'dayjs/plugin/localizedFormat';
9
+ import utc from 'dayjs/plugin/utc';
10
+ import { buttons } from 'decap-cms-ui-default';
11
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
+ dayjs.extend(customParseFormat);
13
+ dayjs.extend(localizedFormat);
14
+ dayjs.extend(utc);
23
15
  var _ref3 = process.env.NODE_ENV === "production" ? {
24
16
  name: "1tfa1p6-Buttons",
25
17
  styles: "display:flex;gap:20px;width:fit-content;label:Buttons;"
26
18
  } : {
27
19
  name: "1tfa1p6-Buttons",
28
- styles: "display:flex;gap:20px;width:fit-content;label:Buttons;",
29
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EYXRlVGltZUNvbnRyb2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUJjIiwiZmlsZSI6Ii4uLy4uL3NyYy9EYXRlVGltZUNvbnRyb2wuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsganN4LCBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgZGF5anMgZnJvbSAnZGF5anMnO1xuaW1wb3J0IGN1c3RvbVBhcnNlRm9ybWF0IGZyb20gJ2RheWpzL3BsdWdpbi9jdXN0b21QYXJzZUZvcm1hdCc7XG5pbXBvcnQgbG9jYWxpemVkRm9ybWF0IGZyb20gJ2RheWpzL3BsdWdpbi9sb2NhbGl6ZWRGb3JtYXQnO1xuaW1wb3J0IHV0YyBmcm9tICdkYXlqcy9wbHVnaW4vdXRjJztcbmltcG9ydCB7IGJ1dHRvbnMgfSBmcm9tICdkZWNhcC1jbXMtdWktZGVmYXVsdCc7XG5cbmRheWpzLmV4dGVuZChjdXN0b21QYXJzZUZvcm1hdCk7XG5kYXlqcy5leHRlbmQobG9jYWxpemVkRm9ybWF0KTtcbmRheWpzLmV4dGVuZCh1dGMpO1xuXG5mdW5jdGlvbiBCdXR0b25zKHsgdCwgaGFuZGxlQ2hhbmdlLCBnZXROb3cgfSkge1xuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17Y3NzYFxuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBnYXA6IDIwcHg7XG4gICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGJ1dHRvblxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAke2J1dHRvbnMuYnV0dG9ufVxuICAgICAgICAgICR7YnV0dG9ucy53aWRnZXR9XG4gICAgICAgIGB9XG4gICAgICAgIG9uQ2xpY2s9eygpID0+IGhhbmRsZUNoYW5nZShnZXROb3coKSl9XG4gICAgICAgIGRhdGEtdGVzdGlkPVwibm93LWJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIHt0KCdlZGl0b3IuZWRpdG9yV2lkZ2V0cy5kYXRldGltZS5ub3cnKX1cbiAgICAgIDwvYnV0dG9uPlxuICAgICAgPGJ1dHRvblxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAke2J1dHRvbnMuYnV0dG9ufVxuICAgICAgICAgICR7YnV0dG9ucy53aWRnZXR9XG4gICAgICAgIGB9XG4gICAgICAgIG9uQ2xpY2s9eygpID0+IGhhbmRsZUNoYW5nZSgnJyl9XG4gICAgICAgIGRhdGEtdGVzdGlkPVwiY2xlYXItYnV0dG9uXCJcbiAgICAgID5cbiAgICAgICAge3QoJ2VkaXRvci5lZGl0b3JXaWRnZXRzLmRhdGV0aW1lLmNsZWFyJyl9XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgKTtcbn1cblxuY2xhc3MgRGF0ZVRpbWVDb250cm9sIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBmaWVsZDogUHJvcFR5cGVzLm9iamVjdC5pc1JlcXVpcmVkLFxuICAgIGZvcklEOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIGNsYXNzTmFtZVdyYXBwZXI6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBzZXRBY3RpdmVTdHlsZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBzZXRJbmFjdGl2ZVN0eWxlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIHZhbHVlOiBQcm9wVHlwZXMub25lT2ZUeXBlKFtQcm9wVHlwZXMub2JqZWN0LCBQcm9wVHlwZXMuc3RyaW5nXSksXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgfTtcblxuICBzdGF0aWMgZGVmYXVsdFByb3BzID0ge1xuICAgIGlzRGlzYWJsZWQ6IGZhbHNlLFxuICB9O1xuXG4gIGNvbXBvbmVudERpZE1vdW50KCkge1xuICAgIGNvbnN0IHsgdmFsdWUgfSA9IHRoaXMucHJvcHM7XG4gICAgaWYgKHZhbHVlID09PSAne3tub3d9fScpIHtcbiAgICAgIHRoaXMuaGFuZGxlQ2hhbmdlKHRoaXMuZ2V0Tm93KCkpO1xuICAgIH1cbiAgfVxuXG4gIGlzVXRjID0gdGhpcy5wcm9wcy5maWVsZC5nZXQoJ3BpY2tlcl91dGMnKSB8fCBmYWxzZTtcblxuICBlc2NhcGVaKHN0cikge1xuICAgIGlmICgvWig/IVtcXF1dKS8udGVzdChzdHIpKSB7XG4gICAgICByZXR1cm4gc3RyLnJlcGxhY2UoJ1onLCAnW1pdJyk7XG4gICAgfVxuICAgIHJldHVybiBzdHI7XG4gIH1cblxuICBnZXRGb3JtYXQoKSB7XG4gICAgY29uc3QgeyBmaWVsZCB9ID0gdGhpcy5wcm9wcztcbiAgICBsZXQgaW5wdXRUeXBlID0gJ2RhdGV0aW1lLWxvY2FsJztcbiAgICBsZXQgaW5wdXRGb3JtYXQgPSAnWVlZWS1NTS1ERFRISDptbSc7XG4gICAgbGV0IGZvcm1hdCA9ICdZWVlZLU1NLUREVEhIOm1tOnNzLlNTU1taXSc7XG4gICAgbGV0IHVzZXJGb3JtYXQgPSBmaWVsZD8uZ2V0KCdmb3JtYXQnKTtcbiAgICBsZXQgZGF0ZUZvcm1hdCA9IGZpZWxkPy5nZXQoJ2RhdGVfZm9ybWF0Jyk7XG4gICAgbGV0IHRpbWVGb3JtYXQgPSBmaWVsZD8uZ2V0KCd0aW1lX2Zvcm1hdCcpO1xuICAgIGlmIChkYXRlRm9ybWF0ID09PSB0cnVlKSBkYXRlRm9ybWF0ID0gJ1lZWVktTU0tREQnO1xuICAgIGlmICh0aW1lRm9ybWF0ID09PSB0cnVlKSB0aW1lRm9ybWF0ID0gJ0hIOm1tJztcblxuICAgIGlmICh0aGlzLmlzVXRjKSB7XG4gICAgICB1c2VyRm9ybWF0ID0gdGhpcy5lc2NhcGVaKHVzZXJGb3JtYXQpO1xuICAgICAgZGF0ZUZvcm1hdCA9IHRoaXMuZXNjYXBlWihkYXRlRm9ybWF0KTtcbiAgICAgIHRpbWVGb3JtYXQgPSB0aGlzLmVzY2FwZVoodGltZUZvcm1hdCk7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBkYXRlRm9ybWF0ID09PSAnc3RyaW5nJyAmJiB0eXBlb2YgdGltZUZvcm1hdCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdCA9IGAke2RhdGVGb3JtYXR9VCR7dGltZUZvcm1hdH1gO1xuICAgIH0gZWxzZSBpZiAodHlwZW9mIHRpbWVGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBpbnB1dFR5cGUgPSAndGltZSc7XG4gICAgICBmb3JtYXQgPSB0aW1lRm9ybWF0O1xuICAgIH0gZWxzZSBpZiAodHlwZW9mIGRhdGVGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBpbnB1dFR5cGUgPSAnZGF0ZSc7XG4gICAgICBmb3JtYXQgPSBkYXRlRm9ybWF0O1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdXNlckZvcm1hdCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGZvcm1hdCA9IHVzZXJGb3JtYXQ7XG4gICAgICBpbnB1dFR5cGUgPSAnZGF0ZXRpbWUtbG9jYWwnO1xuICAgIH1cblxuICAgIGlmIChkYXRlRm9ybWF0ID09PSBmYWxzZSkgaW5wdXRUeXBlID0gJ3RpbWUnO1xuICAgIGlmICh0aW1lRm9ybWF0ID09PSBmYWxzZSkgaW5wdXRUeXBlID0gJ2RhdGUnO1xuICAgIGlmIChpbnB1dFR5cGUgPT09ICdkYXRldGltZS1sb2NhbCcpIGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tRERUSEg6bW0nO1xuICAgIGlmIChpbnB1dFR5cGUgPT09ICdkYXRlJykgaW5wdXRGb3JtYXQgPSAnWVlZWS1NTS1ERCc7XG4gICAgaWYgKGlucHV0VHlwZSA9PT0gJ3RpbWUnKSBpbnB1dEZvcm1hdCA9ICdISDptbSc7XG5cbiAgICByZXR1cm4geyBmb3JtYXQsIGlucHV0VHlwZSwgaW5wdXRGb3JtYXQgfTtcbiAgfVxuXG4gIGlzVmFsaWREYXRlID0gZHQgPT4gZGF5anMoZHQsIHRoaXMuZ2V0Rm9ybWF0KCkuaW5wdXRGb3JtYXQpLmlzVmFsaWQoKSB8fCBkdCA9PT0gJyc7XG5cbiAgZ2V0Tm93KCkge1xuICAgIGNvbnN0IHsgaW5wdXRGb3JtYXQgfSA9IHRoaXMuZ2V0Rm9ybWF0KCk7XG4gICAgcmV0dXJuIHRoaXMuaXNVdGMgPyBkYXlqcy51dGMoKS5mb3JtYXQoaW5wdXRGb3JtYXQpIDogZGF5anMoKS5mb3JtYXQoaW5wdXRGb3JtYXQpO1xuICB9XG5cbiAgZm9ybWF0SW5wdXRWYWx1ZSh2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSA9PT0gJycpIHJldHVybiB2YWx1ZTtcbiAgICBjb25zdCB7IGZvcm1hdCwgaW5wdXRGb3JtYXQgfSA9IHRoaXMuZ2V0Rm9ybWF0KCk7XG5cbiAgICBjb25zdCBpbnB1dFZhbHVlID0gdGhpcy5pc1V0Y1xuICAgICAgPyBkYXlqcy51dGModmFsdWUsIGZvcm1hdCkuZm9ybWF0KGlucHV0Rm9ybWF0KVxuICAgICAgOiBkYXlqcyh2YWx1ZSwgZm9ybWF0KS5mb3JtYXQoaW5wdXRGb3JtYXQpO1xuXG4gICAgaWYgKHRoaXMuaXNWYWxpZERhdGUoaW5wdXRWYWx1ZSkpIHtcbiAgICAgIHJldHVybiBpbnB1dFZhbHVlO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5pc1V0YyA/IGRheWpzLnV0Yyh2YWx1ZSkuZm9ybWF0KGlucHV0Rm9ybWF0KSA6IGRheWpzKHZhbHVlKS5mb3JtYXQoaW5wdXRGb3JtYXQpO1xuICB9XG5cbiAgaGFuZGxlQ2hhbmdlID0gZGF0ZXRpbWUgPT4ge1xuICAgIGlmICghdGhpcy5pc1ZhbGlkRGF0ZShkYXRldGltZSkpIHJldHVybjtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuXG4gICAgaWYgKGRhdGV0aW1lID09PSAnJykge1xuICAgICAgb25DaGFuZ2UoJycpO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCB7IGZvcm1hdCwgaW5wdXRGb3JtYXQgfSA9IHRoaXMuZ2V0Rm9ybWF0KCk7XG4gICAgICBjb25zdCBmb3JtYXR0ZWRWYWx1ZSA9IGRheWpzKGRhdGV0aW1lLCBpbnB1dEZvcm1hdCkuZm9ybWF0KGZvcm1hdCk7XG4gICAgICBvbkNoYW5nZShmb3JtYXR0ZWRWYWx1ZSk7XG4gICAgfVxuICB9O1xuXG4gIG9uSW5wdXRDaGFuZ2UgPSBlID0+IHtcbiAgICBjb25zdCBldHYgPSBlLnRhcmdldC52YWx1ZTtcbiAgICB0aGlzLmhhbmRsZUNoYW5nZShldHYpO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGZvcklELCB2YWx1ZSwgY2xhc3NOYW1lV3JhcHBlciwgc2V0QWN0aXZlU3R5bGUsIHNldEluYWN0aXZlU3R5bGUsIHQsIGlzRGlzYWJsZWQgfSA9XG4gICAgICB0aGlzLnByb3BzO1xuICAgIGNvbnN0IHsgaW5wdXRUeXBlIH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxkaXZcbiAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWVXcmFwcGVyfVxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4ICFpbXBvcnRhbnQ7XG4gICAgICAgICAgZ2FwOiAyMHB4O1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgIGlkPXtmb3JJRH1cbiAgICAgICAgICBkYXRhLXRlc3RpZD17Zm9ySUR9XG4gICAgICAgICAgdHlwZT17aW5wdXRUeXBlfVxuICAgICAgICAgIHZhbHVlPXt2YWx1ZSA/IHRoaXMuZm9ybWF0SW5wdXRWYWx1ZSh2YWx1ZSkgOiAnJ31cbiAgICAgICAgICBvbkNoYW5nZT17dGhpcy5vbklucHV0Q2hhbmdlfVxuICAgICAgICAgIG9uRm9jdXM9e3NldEFjdGl2ZVN0eWxlfVxuICAgICAgICAgIG9uQmx1cj17c2V0SW5hY3RpdmVTdHlsZX1cbiAgICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgLz5cbiAgICAgICAge3RoaXMuaXNVdGMgJiYgKFxuICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZm9udC1zaXplOiAwLjhlbTtcbiAgICAgICAgICAgICAgY29sb3I6ICM2NjY7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIFVUQ1xuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgKX1cbiAgICAgICAgeyFpc0Rpc2FibGVkICYmIChcbiAgICAgICAgICA8QnV0dG9ucyB0PXt0fSBoYW5kbGVDaGFuZ2U9e3YgPT4gdGhpcy5oYW5kbGVDaGFuZ2Uodil9IGdldE5vdz17KCkgPT4gdGhpcy5nZXROb3coKX0gLz5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgRGF0ZVRpbWVDb250cm9sO1xuIl19 */",
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[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"]} */",
30
21
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
22
  };
32
23
  function Buttons({
@@ -34,14 +25,14 @@ function Buttons({
34
25
  handleChange,
35
26
  getNow
36
27
  }) {
37
- return (0, _react2.jsx)("div", {
28
+ return jsx("div", {
38
29
  css: _ref3
39
- }, (0, _react2.jsx)("button", {
40
- css: /*#__PURE__*/(0, _react2.css)(_decapCmsUiDefault.buttons.button, " ", _decapCmsUiDefault.buttons.widget, ";;label:Buttons;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EYXRlVGltZUNvbnRyb2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JnQiIsImZpbGUiOiIuLi8uLi9zcmMvRGF0ZVRpbWVDb250cm9sLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBqc3gganN4ICovXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IGpzeCwgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IGRheWpzIGZyb20gJ2RheWpzJztcbmltcG9ydCBjdXN0b21QYXJzZUZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vY3VzdG9tUGFyc2VGb3JtYXQnO1xuaW1wb3J0IGxvY2FsaXplZEZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vbG9jYWxpemVkRm9ybWF0JztcbmltcG9ydCB1dGMgZnJvbSAnZGF5anMvcGx1Z2luL3V0Yyc7XG5pbXBvcnQgeyBidXR0b25zIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5kYXlqcy5leHRlbmQoY3VzdG9tUGFyc2VGb3JtYXQpO1xuZGF5anMuZXh0ZW5kKGxvY2FsaXplZEZvcm1hdCk7XG5kYXlqcy5leHRlbmQodXRjKTtcblxuZnVuY3Rpb24gQnV0dG9ucyh7IHQsIGhhbmRsZUNoYW5nZSwgZ2V0Tm93IH0pIHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZ2FwOiAyMHB4O1xuICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICBgfVxuICAgID5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoZ2V0Tm93KCkpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cIm5vdy1idXR0b25cIlxuICAgICAgPlxuICAgICAgICB7dCgnZWRpdG9yLmVkaXRvcldpZGdldHMuZGF0ZXRpbWUubm93Jyl9XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoJycpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cImNsZWFyLWJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIHt0KCdlZGl0b3IuZWRpdG9yV2lkZ2V0cy5kYXRldGltZS5jbGVhcicpfVxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gICk7XG59XG5cbmNsYXNzIERhdGVUaW1lQ29udHJvbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZmllbGQ6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBmb3JJRDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWVXcmFwcGVyOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgc2V0QWN0aXZlU3R5bGU6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgc2V0SW5hY3RpdmVTdHlsZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICB2YWx1ZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLm9iamVjdCwgUHJvcFR5cGVzLnN0cmluZ10pLFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBpc0Rpc2FibGVkOiBmYWxzZSxcbiAgfTtcblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IHZhbHVlIH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICh2YWx1ZSA9PT0gJ3t7bm93fX0nKSB7XG4gICAgICB0aGlzLmhhbmRsZUNoYW5nZSh0aGlzLmdldE5vdygpKTtcbiAgICB9XG4gIH1cblxuICBpc1V0YyA9IHRoaXMucHJvcHMuZmllbGQuZ2V0KCdwaWNrZXJfdXRjJykgfHwgZmFsc2U7XG5cbiAgZXNjYXBlWihzdHIpIHtcbiAgICBpZiAoL1ooPyFbXFxdXSkvLnRlc3Qoc3RyKSkge1xuICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKCdaJywgJ1taXScpO1xuICAgIH1cbiAgICByZXR1cm4gc3RyO1xuICB9XG5cbiAgZ2V0Rm9ybWF0KCkge1xuICAgIGNvbnN0IHsgZmllbGQgfSA9IHRoaXMucHJvcHM7XG4gICAgbGV0IGlucHV0VHlwZSA9ICdkYXRldGltZS1sb2NhbCc7XG4gICAgbGV0IGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tRERUSEg6bW0nO1xuICAgIGxldCBmb3JtYXQgPSAnWVlZWS1NTS1ERFRISDptbTpzcy5TU1NbWl0nO1xuICAgIGxldCB1c2VyRm9ybWF0ID0gZmllbGQ/LmdldCgnZm9ybWF0Jyk7XG4gICAgbGV0IGRhdGVGb3JtYXQgPSBmaWVsZD8uZ2V0KCdkYXRlX2Zvcm1hdCcpO1xuICAgIGxldCB0aW1lRm9ybWF0ID0gZmllbGQ/LmdldCgndGltZV9mb3JtYXQnKTtcbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gdHJ1ZSkgZGF0ZUZvcm1hdCA9ICdZWVlZLU1NLUREJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gdHJ1ZSkgdGltZUZvcm1hdCA9ICdISDptbSc7XG5cbiAgICBpZiAodGhpcy5pc1V0Yykge1xuICAgICAgdXNlckZvcm1hdCA9IHRoaXMuZXNjYXBlWih1c2VyRm9ybWF0KTtcbiAgICAgIGRhdGVGb3JtYXQgPSB0aGlzLmVzY2FwZVooZGF0ZUZvcm1hdCk7XG4gICAgICB0aW1lRm9ybWF0ID0gdGhpcy5lc2NhcGVaKHRpbWVGb3JtYXQpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgZGF0ZUZvcm1hdCA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHRpbWVGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSBgJHtkYXRlRm9ybWF0fVQke3RpbWVGb3JtYXR9YDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB0aW1lRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ3RpbWUnO1xuICAgICAgZm9ybWF0ID0gdGltZUZvcm1hdDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBkYXRlRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGUnO1xuICAgICAgZm9ybWF0ID0gZGF0ZUZvcm1hdDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHVzZXJGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSB1c2VyRm9ybWF0O1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGV0aW1lLWxvY2FsJztcbiAgICB9XG5cbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICd0aW1lJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICdkYXRlJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZXRpbWUtbG9jYWwnKSBpbnB1dEZvcm1hdCA9ICdZWVlZLU1NLUREVEhIOm1tJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZScpIGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tREQnO1xuICAgIGlmIChpbnB1dFR5cGUgPT09ICd0aW1lJykgaW5wdXRGb3JtYXQgPSAnSEg6bW0nO1xuXG4gICAgcmV0dXJuIHsgZm9ybWF0LCBpbnB1dFR5cGUsIGlucHV0Rm9ybWF0IH07XG4gIH1cblxuICBpc1ZhbGlkRGF0ZSA9IGR0ID0+IGRheWpzKGR0LCB0aGlzLmdldEZvcm1hdCgpLmlucHV0Rm9ybWF0KS5pc1ZhbGlkKCkgfHwgZHQgPT09ICcnO1xuXG4gIGdldE5vdygpIHtcbiAgICBjb25zdCB7IGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgIHJldHVybiB0aGlzLmlzVXRjID8gZGF5anMudXRjKCkuZm9ybWF0KGlucHV0Rm9ybWF0KSA6IGRheWpzKCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGZvcm1hdElucHV0VmFsdWUodmFsdWUpIHtcbiAgICBpZiAodmFsdWUgPT09ICcnKSByZXR1cm4gdmFsdWU7XG4gICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuXG4gICAgY29uc3QgaW5wdXRWYWx1ZSA9IHRoaXMuaXNVdGNcbiAgICAgID8gZGF5anMudXRjKHZhbHVlLCBmb3JtYXQpLmZvcm1hdChpbnB1dEZvcm1hdClcbiAgICAgIDogZGF5anModmFsdWUsIGZvcm1hdCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcblxuICAgIGlmICh0aGlzLmlzVmFsaWREYXRlKGlucHV0VmFsdWUpKSB7XG4gICAgICByZXR1cm4gaW5wdXRWYWx1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuaXNVdGMgPyBkYXlqcy51dGModmFsdWUpLmZvcm1hdChpbnB1dEZvcm1hdCkgOiBkYXlqcyh2YWx1ZSkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGhhbmRsZUNoYW5nZSA9IGRhdGV0aW1lID0+IHtcbiAgICBpZiAoIXRoaXMuaXNWYWxpZERhdGUoZGF0ZXRpbWUpKSByZXR1cm47XG4gICAgY29uc3QgeyBvbkNoYW5nZSB9ID0gdGhpcy5wcm9wcztcblxuICAgIGlmIChkYXRldGltZSA9PT0gJycpIHtcbiAgICAgIG9uQ2hhbmdlKCcnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgICAgY29uc3QgZm9ybWF0dGVkVmFsdWUgPSBkYXlqcyhkYXRldGltZSwgaW5wdXRGb3JtYXQpLmZvcm1hdChmb3JtYXQpO1xuICAgICAgb25DaGFuZ2UoZm9ybWF0dGVkVmFsdWUpO1xuICAgIH1cbiAgfTtcblxuICBvbklucHV0Q2hhbmdlID0gZSA9PiB7XG4gICAgY29uc3QgZXR2ID0gZS50YXJnZXQudmFsdWU7XG4gICAgdGhpcy5oYW5kbGVDaGFuZ2UoZXR2KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBmb3JJRCwgdmFsdWUsIGNsYXNzTmFtZVdyYXBwZXIsIHNldEFjdGl2ZVN0eWxlLCBzZXRJbmFjdGl2ZVN0eWxlLCB0LCBpc0Rpc2FibGVkIH0gPVxuICAgICAgdGhpcy5wcm9wcztcbiAgICBjb25zdCB7IGlucHV0VHlwZSB9ID0gdGhpcy5nZXRGb3JtYXQoKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lV3JhcHBlcn1cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgICAgICAgIGdhcDogMjBweDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8aW5wdXRcbiAgICAgICAgICBpZD17Zm9ySUR9XG4gICAgICAgICAgZGF0YS10ZXN0aWQ9e2ZvcklEfVxuICAgICAgICAgIHR5cGU9e2lucHV0VHlwZX1cbiAgICAgICAgICB2YWx1ZT17dmFsdWUgPyB0aGlzLmZvcm1hdElucHV0VmFsdWUodmFsdWUpIDogJyd9XG4gICAgICAgICAgb25DaGFuZ2U9e3RoaXMub25JbnB1dENoYW5nZX1cbiAgICAgICAgICBvbkZvY3VzPXtzZXRBY3RpdmVTdHlsZX1cbiAgICAgICAgICBvbkJsdXI9e3NldEluYWN0aXZlU3R5bGV9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIC8+XG4gICAgICAgIHt0aGlzLmlzVXRjICYmIChcbiAgICAgICAgICA8c3BhblxuICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgIGZvbnQtc2l6ZTogMC44ZW07XG4gICAgICAgICAgICAgIGNvbG9yOiAjNjY2O1xuICAgICAgICAgICAgYH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICBVVENcbiAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICl9XG4gICAgICAgIHshaXNEaXNhYmxlZCAmJiAoXG4gICAgICAgICAgPEJ1dHRvbnMgdD17dH0gaGFuZGxlQ2hhbmdlPXt2ID0+IHRoaXMuaGFuZGxlQ2hhbmdlKHYpfSBnZXROb3c9eygpID0+IHRoaXMuZ2V0Tm93KCl9IC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IERhdGVUaW1lQ29udHJvbDtcbiJdfQ== */")),
30
+ }, 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[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"]} */")),
41
32
  onClick: () => handleChange(getNow()),
42
33
  "data-testid": "now-button"
43
- }, t('editor.editorWidgets.datetime.now')), (0, _react2.jsx)("button", {
44
- css: /*#__PURE__*/(0, _react2.css)(_decapCmsUiDefault.buttons.button, " ", _decapCmsUiDefault.buttons.widget, ";;label:Buttons;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EYXRlVGltZUNvbnRyb2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0NnQiIsImZpbGUiOiIuLi8uLi9zcmMvRGF0ZVRpbWVDb250cm9sLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBqc3gganN4ICovXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IGpzeCwgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IGRheWpzIGZyb20gJ2RheWpzJztcbmltcG9ydCBjdXN0b21QYXJzZUZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vY3VzdG9tUGFyc2VGb3JtYXQnO1xuaW1wb3J0IGxvY2FsaXplZEZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vbG9jYWxpemVkRm9ybWF0JztcbmltcG9ydCB1dGMgZnJvbSAnZGF5anMvcGx1Z2luL3V0Yyc7XG5pbXBvcnQgeyBidXR0b25zIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5kYXlqcy5leHRlbmQoY3VzdG9tUGFyc2VGb3JtYXQpO1xuZGF5anMuZXh0ZW5kKGxvY2FsaXplZEZvcm1hdCk7XG5kYXlqcy5leHRlbmQodXRjKTtcblxuZnVuY3Rpb24gQnV0dG9ucyh7IHQsIGhhbmRsZUNoYW5nZSwgZ2V0Tm93IH0pIHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZ2FwOiAyMHB4O1xuICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICBgfVxuICAgID5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoZ2V0Tm93KCkpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cIm5vdy1idXR0b25cIlxuICAgICAgPlxuICAgICAgICB7dCgnZWRpdG9yLmVkaXRvcldpZGdldHMuZGF0ZXRpbWUubm93Jyl9XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoJycpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cImNsZWFyLWJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIHt0KCdlZGl0b3IuZWRpdG9yV2lkZ2V0cy5kYXRldGltZS5jbGVhcicpfVxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gICk7XG59XG5cbmNsYXNzIERhdGVUaW1lQ29udHJvbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZmllbGQ6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBmb3JJRDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWVXcmFwcGVyOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgc2V0QWN0aXZlU3R5bGU6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgc2V0SW5hY3RpdmVTdHlsZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICB2YWx1ZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLm9iamVjdCwgUHJvcFR5cGVzLnN0cmluZ10pLFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBpc0Rpc2FibGVkOiBmYWxzZSxcbiAgfTtcblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IHZhbHVlIH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICh2YWx1ZSA9PT0gJ3t7bm93fX0nKSB7XG4gICAgICB0aGlzLmhhbmRsZUNoYW5nZSh0aGlzLmdldE5vdygpKTtcbiAgICB9XG4gIH1cblxuICBpc1V0YyA9IHRoaXMucHJvcHMuZmllbGQuZ2V0KCdwaWNrZXJfdXRjJykgfHwgZmFsc2U7XG5cbiAgZXNjYXBlWihzdHIpIHtcbiAgICBpZiAoL1ooPyFbXFxdXSkvLnRlc3Qoc3RyKSkge1xuICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKCdaJywgJ1taXScpO1xuICAgIH1cbiAgICByZXR1cm4gc3RyO1xuICB9XG5cbiAgZ2V0Rm9ybWF0KCkge1xuICAgIGNvbnN0IHsgZmllbGQgfSA9IHRoaXMucHJvcHM7XG4gICAgbGV0IGlucHV0VHlwZSA9ICdkYXRldGltZS1sb2NhbCc7XG4gICAgbGV0IGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tRERUSEg6bW0nO1xuICAgIGxldCBmb3JtYXQgPSAnWVlZWS1NTS1ERFRISDptbTpzcy5TU1NbWl0nO1xuICAgIGxldCB1c2VyRm9ybWF0ID0gZmllbGQ/LmdldCgnZm9ybWF0Jyk7XG4gICAgbGV0IGRhdGVGb3JtYXQgPSBmaWVsZD8uZ2V0KCdkYXRlX2Zvcm1hdCcpO1xuICAgIGxldCB0aW1lRm9ybWF0ID0gZmllbGQ/LmdldCgndGltZV9mb3JtYXQnKTtcbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gdHJ1ZSkgZGF0ZUZvcm1hdCA9ICdZWVlZLU1NLUREJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gdHJ1ZSkgdGltZUZvcm1hdCA9ICdISDptbSc7XG5cbiAgICBpZiAodGhpcy5pc1V0Yykge1xuICAgICAgdXNlckZvcm1hdCA9IHRoaXMuZXNjYXBlWih1c2VyRm9ybWF0KTtcbiAgICAgIGRhdGVGb3JtYXQgPSB0aGlzLmVzY2FwZVooZGF0ZUZvcm1hdCk7XG4gICAgICB0aW1lRm9ybWF0ID0gdGhpcy5lc2NhcGVaKHRpbWVGb3JtYXQpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgZGF0ZUZvcm1hdCA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHRpbWVGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSBgJHtkYXRlRm9ybWF0fVQke3RpbWVGb3JtYXR9YDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB0aW1lRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ3RpbWUnO1xuICAgICAgZm9ybWF0ID0gdGltZUZvcm1hdDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBkYXRlRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGUnO1xuICAgICAgZm9ybWF0ID0gZGF0ZUZvcm1hdDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHVzZXJGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSB1c2VyRm9ybWF0O1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGV0aW1lLWxvY2FsJztcbiAgICB9XG5cbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICd0aW1lJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICdkYXRlJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZXRpbWUtbG9jYWwnKSBpbnB1dEZvcm1hdCA9ICdZWVlZLU1NLUREVEhIOm1tJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZScpIGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tREQnO1xuICAgIGlmIChpbnB1dFR5cGUgPT09ICd0aW1lJykgaW5wdXRGb3JtYXQgPSAnSEg6bW0nO1xuXG4gICAgcmV0dXJuIHsgZm9ybWF0LCBpbnB1dFR5cGUsIGlucHV0Rm9ybWF0IH07XG4gIH1cblxuICBpc1ZhbGlkRGF0ZSA9IGR0ID0+IGRheWpzKGR0LCB0aGlzLmdldEZvcm1hdCgpLmlucHV0Rm9ybWF0KS5pc1ZhbGlkKCkgfHwgZHQgPT09ICcnO1xuXG4gIGdldE5vdygpIHtcbiAgICBjb25zdCB7IGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgIHJldHVybiB0aGlzLmlzVXRjID8gZGF5anMudXRjKCkuZm9ybWF0KGlucHV0Rm9ybWF0KSA6IGRheWpzKCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGZvcm1hdElucHV0VmFsdWUodmFsdWUpIHtcbiAgICBpZiAodmFsdWUgPT09ICcnKSByZXR1cm4gdmFsdWU7XG4gICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuXG4gICAgY29uc3QgaW5wdXRWYWx1ZSA9IHRoaXMuaXNVdGNcbiAgICAgID8gZGF5anMudXRjKHZhbHVlLCBmb3JtYXQpLmZvcm1hdChpbnB1dEZvcm1hdClcbiAgICAgIDogZGF5anModmFsdWUsIGZvcm1hdCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcblxuICAgIGlmICh0aGlzLmlzVmFsaWREYXRlKGlucHV0VmFsdWUpKSB7XG4gICAgICByZXR1cm4gaW5wdXRWYWx1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuaXNVdGMgPyBkYXlqcy51dGModmFsdWUpLmZvcm1hdChpbnB1dEZvcm1hdCkgOiBkYXlqcyh2YWx1ZSkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGhhbmRsZUNoYW5nZSA9IGRhdGV0aW1lID0+IHtcbiAgICBpZiAoIXRoaXMuaXNWYWxpZERhdGUoZGF0ZXRpbWUpKSByZXR1cm47XG4gICAgY29uc3QgeyBvbkNoYW5nZSB9ID0gdGhpcy5wcm9wcztcblxuICAgIGlmIChkYXRldGltZSA9PT0gJycpIHtcbiAgICAgIG9uQ2hhbmdlKCcnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgICAgY29uc3QgZm9ybWF0dGVkVmFsdWUgPSBkYXlqcyhkYXRldGltZSwgaW5wdXRGb3JtYXQpLmZvcm1hdChmb3JtYXQpO1xuICAgICAgb25DaGFuZ2UoZm9ybWF0dGVkVmFsdWUpO1xuICAgIH1cbiAgfTtcblxuICBvbklucHV0Q2hhbmdlID0gZSA9PiB7XG4gICAgY29uc3QgZXR2ID0gZS50YXJnZXQudmFsdWU7XG4gICAgdGhpcy5oYW5kbGVDaGFuZ2UoZXR2KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBmb3JJRCwgdmFsdWUsIGNsYXNzTmFtZVdyYXBwZXIsIHNldEFjdGl2ZVN0eWxlLCBzZXRJbmFjdGl2ZVN0eWxlLCB0LCBpc0Rpc2FibGVkIH0gPVxuICAgICAgdGhpcy5wcm9wcztcbiAgICBjb25zdCB7IGlucHV0VHlwZSB9ID0gdGhpcy5nZXRGb3JtYXQoKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lV3JhcHBlcn1cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgICAgICAgIGdhcDogMjBweDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8aW5wdXRcbiAgICAgICAgICBpZD17Zm9ySUR9XG4gICAgICAgICAgZGF0YS10ZXN0aWQ9e2ZvcklEfVxuICAgICAgICAgIHR5cGU9e2lucHV0VHlwZX1cbiAgICAgICAgICB2YWx1ZT17dmFsdWUgPyB0aGlzLmZvcm1hdElucHV0VmFsdWUodmFsdWUpIDogJyd9XG4gICAgICAgICAgb25DaGFuZ2U9e3RoaXMub25JbnB1dENoYW5nZX1cbiAgICAgICAgICBvbkZvY3VzPXtzZXRBY3RpdmVTdHlsZX1cbiAgICAgICAgICBvbkJsdXI9e3NldEluYWN0aXZlU3R5bGV9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIC8+XG4gICAgICAgIHt0aGlzLmlzVXRjICYmIChcbiAgICAgICAgICA8c3BhblxuICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgIGZvbnQtc2l6ZTogMC44ZW07XG4gICAgICAgICAgICAgIGNvbG9yOiAjNjY2O1xuICAgICAgICAgICAgYH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICBVVENcbiAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICl9XG4gICAgICAgIHshaXNEaXNhYmxlZCAmJiAoXG4gICAgICAgICAgPEJ1dHRvbnMgdD17dH0gaGFuZGxlQ2hhbmdlPXt2ID0+IHRoaXMuaGFuZGxlQ2hhbmdlKHYpfSBnZXROb3c9eygpID0+IHRoaXMuZ2V0Tm93KCl9IC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IERhdGVUaW1lQ29udHJvbDtcbiJdfQ== */")),
34
+ }, 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[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"]} */")),
45
36
  onClick: () => handleChange(''),
46
37
  "data-testid": "clear-button"
47
38
  }, t('editor.editorWidgets.datetime.clear')));
@@ -51,8 +42,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
51
42
  styles: "font-size:0.8em;color:#666;label:DateTimeControl;"
52
43
  } : {
53
44
  name: "1mn76l5-DateTimeControl",
54
- styles: "font-size:0.8em;color:#666;label:DateTimeControl;",
55
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EYXRlVGltZUNvbnRyb2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMExvQiIsImZpbGUiOiIuLi8uLi9zcmMvRGF0ZVRpbWVDb250cm9sLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBqc3gganN4ICovXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IGpzeCwgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IGRheWpzIGZyb20gJ2RheWpzJztcbmltcG9ydCBjdXN0b21QYXJzZUZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vY3VzdG9tUGFyc2VGb3JtYXQnO1xuaW1wb3J0IGxvY2FsaXplZEZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vbG9jYWxpemVkRm9ybWF0JztcbmltcG9ydCB1dGMgZnJvbSAnZGF5anMvcGx1Z2luL3V0Yyc7XG5pbXBvcnQgeyBidXR0b25zIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5kYXlqcy5leHRlbmQoY3VzdG9tUGFyc2VGb3JtYXQpO1xuZGF5anMuZXh0ZW5kKGxvY2FsaXplZEZvcm1hdCk7XG5kYXlqcy5leHRlbmQodXRjKTtcblxuZnVuY3Rpb24gQnV0dG9ucyh7IHQsIGhhbmRsZUNoYW5nZSwgZ2V0Tm93IH0pIHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZ2FwOiAyMHB4O1xuICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICBgfVxuICAgID5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoZ2V0Tm93KCkpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cIm5vdy1idXR0b25cIlxuICAgICAgPlxuICAgICAgICB7dCgnZWRpdG9yLmVkaXRvcldpZGdldHMuZGF0ZXRpbWUubm93Jyl9XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoJycpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cImNsZWFyLWJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIHt0KCdlZGl0b3IuZWRpdG9yV2lkZ2V0cy5kYXRldGltZS5jbGVhcicpfVxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gICk7XG59XG5cbmNsYXNzIERhdGVUaW1lQ29udHJvbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZmllbGQ6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBmb3JJRDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWVXcmFwcGVyOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgc2V0QWN0aXZlU3R5bGU6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgc2V0SW5hY3RpdmVTdHlsZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICB2YWx1ZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLm9iamVjdCwgUHJvcFR5cGVzLnN0cmluZ10pLFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBpc0Rpc2FibGVkOiBmYWxzZSxcbiAgfTtcblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IHZhbHVlIH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICh2YWx1ZSA9PT0gJ3t7bm93fX0nKSB7XG4gICAgICB0aGlzLmhhbmRsZUNoYW5nZSh0aGlzLmdldE5vdygpKTtcbiAgICB9XG4gIH1cblxuICBpc1V0YyA9IHRoaXMucHJvcHMuZmllbGQuZ2V0KCdwaWNrZXJfdXRjJykgfHwgZmFsc2U7XG5cbiAgZXNjYXBlWihzdHIpIHtcbiAgICBpZiAoL1ooPyFbXFxdXSkvLnRlc3Qoc3RyKSkge1xuICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKCdaJywgJ1taXScpO1xuICAgIH1cbiAgICByZXR1cm4gc3RyO1xuICB9XG5cbiAgZ2V0Rm9ybWF0KCkge1xuICAgIGNvbnN0IHsgZmllbGQgfSA9IHRoaXMucHJvcHM7XG4gICAgbGV0IGlucHV0VHlwZSA9ICdkYXRldGltZS1sb2NhbCc7XG4gICAgbGV0IGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tRERUSEg6bW0nO1xuICAgIGxldCBmb3JtYXQgPSAnWVlZWS1NTS1ERFRISDptbTpzcy5TU1NbWl0nO1xuICAgIGxldCB1c2VyRm9ybWF0ID0gZmllbGQ/LmdldCgnZm9ybWF0Jyk7XG4gICAgbGV0IGRhdGVGb3JtYXQgPSBmaWVsZD8uZ2V0KCdkYXRlX2Zvcm1hdCcpO1xuICAgIGxldCB0aW1lRm9ybWF0ID0gZmllbGQ/LmdldCgndGltZV9mb3JtYXQnKTtcbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gdHJ1ZSkgZGF0ZUZvcm1hdCA9ICdZWVlZLU1NLUREJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gdHJ1ZSkgdGltZUZvcm1hdCA9ICdISDptbSc7XG5cbiAgICBpZiAodGhpcy5pc1V0Yykge1xuICAgICAgdXNlckZvcm1hdCA9IHRoaXMuZXNjYXBlWih1c2VyRm9ybWF0KTtcbiAgICAgIGRhdGVGb3JtYXQgPSB0aGlzLmVzY2FwZVooZGF0ZUZvcm1hdCk7XG4gICAgICB0aW1lRm9ybWF0ID0gdGhpcy5lc2NhcGVaKHRpbWVGb3JtYXQpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgZGF0ZUZvcm1hdCA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHRpbWVGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSBgJHtkYXRlRm9ybWF0fVQke3RpbWVGb3JtYXR9YDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB0aW1lRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ3RpbWUnO1xuICAgICAgZm9ybWF0ID0gdGltZUZvcm1hdDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBkYXRlRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGUnO1xuICAgICAgZm9ybWF0ID0gZGF0ZUZvcm1hdDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHVzZXJGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSB1c2VyRm9ybWF0O1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGV0aW1lLWxvY2FsJztcbiAgICB9XG5cbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICd0aW1lJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICdkYXRlJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZXRpbWUtbG9jYWwnKSBpbnB1dEZvcm1hdCA9ICdZWVlZLU1NLUREVEhIOm1tJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZScpIGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tREQnO1xuICAgIGlmIChpbnB1dFR5cGUgPT09ICd0aW1lJykgaW5wdXRGb3JtYXQgPSAnSEg6bW0nO1xuXG4gICAgcmV0dXJuIHsgZm9ybWF0LCBpbnB1dFR5cGUsIGlucHV0Rm9ybWF0IH07XG4gIH1cblxuICBpc1ZhbGlkRGF0ZSA9IGR0ID0+IGRheWpzKGR0LCB0aGlzLmdldEZvcm1hdCgpLmlucHV0Rm9ybWF0KS5pc1ZhbGlkKCkgfHwgZHQgPT09ICcnO1xuXG4gIGdldE5vdygpIHtcbiAgICBjb25zdCB7IGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgIHJldHVybiB0aGlzLmlzVXRjID8gZGF5anMudXRjKCkuZm9ybWF0KGlucHV0Rm9ybWF0KSA6IGRheWpzKCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGZvcm1hdElucHV0VmFsdWUodmFsdWUpIHtcbiAgICBpZiAodmFsdWUgPT09ICcnKSByZXR1cm4gdmFsdWU7XG4gICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuXG4gICAgY29uc3QgaW5wdXRWYWx1ZSA9IHRoaXMuaXNVdGNcbiAgICAgID8gZGF5anMudXRjKHZhbHVlLCBmb3JtYXQpLmZvcm1hdChpbnB1dEZvcm1hdClcbiAgICAgIDogZGF5anModmFsdWUsIGZvcm1hdCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcblxuICAgIGlmICh0aGlzLmlzVmFsaWREYXRlKGlucHV0VmFsdWUpKSB7XG4gICAgICByZXR1cm4gaW5wdXRWYWx1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuaXNVdGMgPyBkYXlqcy51dGModmFsdWUpLmZvcm1hdChpbnB1dEZvcm1hdCkgOiBkYXlqcyh2YWx1ZSkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGhhbmRsZUNoYW5nZSA9IGRhdGV0aW1lID0+IHtcbiAgICBpZiAoIXRoaXMuaXNWYWxpZERhdGUoZGF0ZXRpbWUpKSByZXR1cm47XG4gICAgY29uc3QgeyBvbkNoYW5nZSB9ID0gdGhpcy5wcm9wcztcblxuICAgIGlmIChkYXRldGltZSA9PT0gJycpIHtcbiAgICAgIG9uQ2hhbmdlKCcnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgICAgY29uc3QgZm9ybWF0dGVkVmFsdWUgPSBkYXlqcyhkYXRldGltZSwgaW5wdXRGb3JtYXQpLmZvcm1hdChmb3JtYXQpO1xuICAgICAgb25DaGFuZ2UoZm9ybWF0dGVkVmFsdWUpO1xuICAgIH1cbiAgfTtcblxuICBvbklucHV0Q2hhbmdlID0gZSA9PiB7XG4gICAgY29uc3QgZXR2ID0gZS50YXJnZXQudmFsdWU7XG4gICAgdGhpcy5oYW5kbGVDaGFuZ2UoZXR2KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBmb3JJRCwgdmFsdWUsIGNsYXNzTmFtZVdyYXBwZXIsIHNldEFjdGl2ZVN0eWxlLCBzZXRJbmFjdGl2ZVN0eWxlLCB0LCBpc0Rpc2FibGVkIH0gPVxuICAgICAgdGhpcy5wcm9wcztcbiAgICBjb25zdCB7IGlucHV0VHlwZSB9ID0gdGhpcy5nZXRGb3JtYXQoKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lV3JhcHBlcn1cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgICAgICAgIGdhcDogMjBweDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8aW5wdXRcbiAgICAgICAgICBpZD17Zm9ySUR9XG4gICAgICAgICAgZGF0YS10ZXN0aWQ9e2ZvcklEfVxuICAgICAgICAgIHR5cGU9e2lucHV0VHlwZX1cbiAgICAgICAgICB2YWx1ZT17dmFsdWUgPyB0aGlzLmZvcm1hdElucHV0VmFsdWUodmFsdWUpIDogJyd9XG4gICAgICAgICAgb25DaGFuZ2U9e3RoaXMub25JbnB1dENoYW5nZX1cbiAgICAgICAgICBvbkZvY3VzPXtzZXRBY3RpdmVTdHlsZX1cbiAgICAgICAgICBvbkJsdXI9e3NldEluYWN0aXZlU3R5bGV9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIC8+XG4gICAgICAgIHt0aGlzLmlzVXRjICYmIChcbiAgICAgICAgICA8c3BhblxuICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgIGZvbnQtc2l6ZTogMC44ZW07XG4gICAgICAgICAgICAgIGNvbG9yOiAjNjY2O1xuICAgICAgICAgICAgYH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICBVVENcbiAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICl9XG4gICAgICAgIHshaXNEaXNhYmxlZCAmJiAoXG4gICAgICAgICAgPEJ1dHRvbnMgdD17dH0gaGFuZGxlQ2hhbmdlPXt2ID0+IHRoaXMuaGFuZGxlQ2hhbmdlKHYpfSBnZXROb3c9eygpID0+IHRoaXMuZ2V0Tm93KCl9IC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IERhdGVUaW1lQ29udHJvbDtcbiJdfQ== */",
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[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"]} */",
56
46
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
57
47
  };
58
48
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -60,37 +50,27 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
60
50
  styles: "display:flex!important;gap:20px;align-items:center;label:DateTimeControl;"
61
51
  } : {
62
52
  name: "ptu1mf-DateTimeControl",
63
- styles: "display:flex!important;gap:20px;align-items:center;label:DateTimeControl;",
64
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9EYXRlVGltZUNvbnRyb2wuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0tnQiIsImZpbGUiOiIuLi8uLi9zcmMvRGF0ZVRpbWVDb250cm9sLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBqc3gganN4ICovXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IGpzeCwgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IGRheWpzIGZyb20gJ2RheWpzJztcbmltcG9ydCBjdXN0b21QYXJzZUZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vY3VzdG9tUGFyc2VGb3JtYXQnO1xuaW1wb3J0IGxvY2FsaXplZEZvcm1hdCBmcm9tICdkYXlqcy9wbHVnaW4vbG9jYWxpemVkRm9ybWF0JztcbmltcG9ydCB1dGMgZnJvbSAnZGF5anMvcGx1Z2luL3V0Yyc7XG5pbXBvcnQgeyBidXR0b25zIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5kYXlqcy5leHRlbmQoY3VzdG9tUGFyc2VGb3JtYXQpO1xuZGF5anMuZXh0ZW5kKGxvY2FsaXplZEZvcm1hdCk7XG5kYXlqcy5leHRlbmQodXRjKTtcblxuZnVuY3Rpb24gQnV0dG9ucyh7IHQsIGhhbmRsZUNoYW5nZSwgZ2V0Tm93IH0pIHtcbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZ2FwOiAyMHB4O1xuICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICBgfVxuICAgID5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoZ2V0Tm93KCkpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cIm5vdy1idXR0b25cIlxuICAgICAgPlxuICAgICAgICB7dCgnZWRpdG9yLmVkaXRvcldpZGdldHMuZGF0ZXRpbWUubm93Jyl9XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgJHtidXR0b25zLmJ1dHRvbn1cbiAgICAgICAgICAke2J1dHRvbnMud2lkZ2V0fVxuICAgICAgICBgfVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBoYW5kbGVDaGFuZ2UoJycpfVxuICAgICAgICBkYXRhLXRlc3RpZD1cImNsZWFyLWJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIHt0KCdlZGl0b3IuZWRpdG9yV2lkZ2V0cy5kYXRldGltZS5jbGVhcicpfVxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gICk7XG59XG5cbmNsYXNzIERhdGVUaW1lQ29udHJvbCBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgZmllbGQ6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBmb3JJRDogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWVXcmFwcGVyOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgc2V0QWN0aXZlU3R5bGU6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgc2V0SW5hY3RpdmVTdHlsZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICB2YWx1ZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLm9iamVjdCwgUHJvcFR5cGVzLnN0cmluZ10pLFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBpc0Rpc2FibGVkOiBmYWxzZSxcbiAgfTtcblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IHZhbHVlIH0gPSB0aGlzLnByb3BzO1xuICAgIGlmICh2YWx1ZSA9PT0gJ3t7bm93fX0nKSB7XG4gICAgICB0aGlzLmhhbmRsZUNoYW5nZSh0aGlzLmdldE5vdygpKTtcbiAgICB9XG4gIH1cblxuICBpc1V0YyA9IHRoaXMucHJvcHMuZmllbGQuZ2V0KCdwaWNrZXJfdXRjJykgfHwgZmFsc2U7XG5cbiAgZXNjYXBlWihzdHIpIHtcbiAgICBpZiAoL1ooPyFbXFxdXSkvLnRlc3Qoc3RyKSkge1xuICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKCdaJywgJ1taXScpO1xuICAgIH1cbiAgICByZXR1cm4gc3RyO1xuICB9XG5cbiAgZ2V0Rm9ybWF0KCkge1xuICAgIGNvbnN0IHsgZmllbGQgfSA9IHRoaXMucHJvcHM7XG4gICAgbGV0IGlucHV0VHlwZSA9ICdkYXRldGltZS1sb2NhbCc7XG4gICAgbGV0IGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tRERUSEg6bW0nO1xuICAgIGxldCBmb3JtYXQgPSAnWVlZWS1NTS1ERFRISDptbTpzcy5TU1NbWl0nO1xuICAgIGxldCB1c2VyRm9ybWF0ID0gZmllbGQ/LmdldCgnZm9ybWF0Jyk7XG4gICAgbGV0IGRhdGVGb3JtYXQgPSBmaWVsZD8uZ2V0KCdkYXRlX2Zvcm1hdCcpO1xuICAgIGxldCB0aW1lRm9ybWF0ID0gZmllbGQ/LmdldCgndGltZV9mb3JtYXQnKTtcbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gdHJ1ZSkgZGF0ZUZvcm1hdCA9ICdZWVlZLU1NLUREJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gdHJ1ZSkgdGltZUZvcm1hdCA9ICdISDptbSc7XG5cbiAgICBpZiAodGhpcy5pc1V0Yykge1xuICAgICAgdXNlckZvcm1hdCA9IHRoaXMuZXNjYXBlWih1c2VyRm9ybWF0KTtcbiAgICAgIGRhdGVGb3JtYXQgPSB0aGlzLmVzY2FwZVooZGF0ZUZvcm1hdCk7XG4gICAgICB0aW1lRm9ybWF0ID0gdGhpcy5lc2NhcGVaKHRpbWVGb3JtYXQpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgZGF0ZUZvcm1hdCA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHRpbWVGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSBgJHtkYXRlRm9ybWF0fVQke3RpbWVGb3JtYXR9YDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB0aW1lRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ3RpbWUnO1xuICAgICAgZm9ybWF0ID0gdGltZUZvcm1hdDtcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiBkYXRlRm9ybWF0ID09PSAnc3RyaW5nJykge1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGUnO1xuICAgICAgZm9ybWF0ID0gZGF0ZUZvcm1hdDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHVzZXJGb3JtYXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBmb3JtYXQgPSB1c2VyRm9ybWF0O1xuICAgICAgaW5wdXRUeXBlID0gJ2RhdGV0aW1lLWxvY2FsJztcbiAgICB9XG5cbiAgICBpZiAoZGF0ZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICd0aW1lJztcbiAgICBpZiAodGltZUZvcm1hdCA9PT0gZmFsc2UpIGlucHV0VHlwZSA9ICdkYXRlJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZXRpbWUtbG9jYWwnKSBpbnB1dEZvcm1hdCA9ICdZWVlZLU1NLUREVEhIOm1tJztcbiAgICBpZiAoaW5wdXRUeXBlID09PSAnZGF0ZScpIGlucHV0Rm9ybWF0ID0gJ1lZWVktTU0tREQnO1xuICAgIGlmIChpbnB1dFR5cGUgPT09ICd0aW1lJykgaW5wdXRGb3JtYXQgPSAnSEg6bW0nO1xuXG4gICAgcmV0dXJuIHsgZm9ybWF0LCBpbnB1dFR5cGUsIGlucHV0Rm9ybWF0IH07XG4gIH1cblxuICBpc1ZhbGlkRGF0ZSA9IGR0ID0+IGRheWpzKGR0LCB0aGlzLmdldEZvcm1hdCgpLmlucHV0Rm9ybWF0KS5pc1ZhbGlkKCkgfHwgZHQgPT09ICcnO1xuXG4gIGdldE5vdygpIHtcbiAgICBjb25zdCB7IGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgIHJldHVybiB0aGlzLmlzVXRjID8gZGF5anMudXRjKCkuZm9ybWF0KGlucHV0Rm9ybWF0KSA6IGRheWpzKCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGZvcm1hdElucHV0VmFsdWUodmFsdWUpIHtcbiAgICBpZiAodmFsdWUgPT09ICcnKSByZXR1cm4gdmFsdWU7XG4gICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuXG4gICAgY29uc3QgaW5wdXRWYWx1ZSA9IHRoaXMuaXNVdGNcbiAgICAgID8gZGF5anMudXRjKHZhbHVlLCBmb3JtYXQpLmZvcm1hdChpbnB1dEZvcm1hdClcbiAgICAgIDogZGF5anModmFsdWUsIGZvcm1hdCkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcblxuICAgIGlmICh0aGlzLmlzVmFsaWREYXRlKGlucHV0VmFsdWUpKSB7XG4gICAgICByZXR1cm4gaW5wdXRWYWx1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuaXNVdGMgPyBkYXlqcy51dGModmFsdWUpLmZvcm1hdChpbnB1dEZvcm1hdCkgOiBkYXlqcyh2YWx1ZSkuZm9ybWF0KGlucHV0Rm9ybWF0KTtcbiAgfVxuXG4gIGhhbmRsZUNoYW5nZSA9IGRhdGV0aW1lID0+IHtcbiAgICBpZiAoIXRoaXMuaXNWYWxpZERhdGUoZGF0ZXRpbWUpKSByZXR1cm47XG4gICAgY29uc3QgeyBvbkNoYW5nZSB9ID0gdGhpcy5wcm9wcztcblxuICAgIGlmIChkYXRldGltZSA9PT0gJycpIHtcbiAgICAgIG9uQ2hhbmdlKCcnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgeyBmb3JtYXQsIGlucHV0Rm9ybWF0IH0gPSB0aGlzLmdldEZvcm1hdCgpO1xuICAgICAgY29uc3QgZm9ybWF0dGVkVmFsdWUgPSBkYXlqcyhkYXRldGltZSwgaW5wdXRGb3JtYXQpLmZvcm1hdChmb3JtYXQpO1xuICAgICAgb25DaGFuZ2UoZm9ybWF0dGVkVmFsdWUpO1xuICAgIH1cbiAgfTtcblxuICBvbklucHV0Q2hhbmdlID0gZSA9PiB7XG4gICAgY29uc3QgZXR2ID0gZS50YXJnZXQudmFsdWU7XG4gICAgdGhpcy5oYW5kbGVDaGFuZ2UoZXR2KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBmb3JJRCwgdmFsdWUsIGNsYXNzTmFtZVdyYXBwZXIsIHNldEFjdGl2ZVN0eWxlLCBzZXRJbmFjdGl2ZVN0eWxlLCB0LCBpc0Rpc2FibGVkIH0gPVxuICAgICAgdGhpcy5wcm9wcztcbiAgICBjb25zdCB7IGlucHV0VHlwZSB9ID0gdGhpcy5nZXRGb3JtYXQoKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lV3JhcHBlcn1cbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgICAgICAgIGdhcDogMjBweDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8aW5wdXRcbiAgICAgICAgICBpZD17Zm9ySUR9XG4gICAgICAgICAgZGF0YS10ZXN0aWQ9e2ZvcklEfVxuICAgICAgICAgIHR5cGU9e2lucHV0VHlwZX1cbiAgICAgICAgICB2YWx1ZT17dmFsdWUgPyB0aGlzLmZvcm1hdElucHV0VmFsdWUodmFsdWUpIDogJyd9XG4gICAgICAgICAgb25DaGFuZ2U9e3RoaXMub25JbnB1dENoYW5nZX1cbiAgICAgICAgICBvbkZvY3VzPXtzZXRBY3RpdmVTdHlsZX1cbiAgICAgICAgICBvbkJsdXI9e3NldEluYWN0aXZlU3R5bGV9XG4gICAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIC8+XG4gICAgICAgIHt0aGlzLmlzVXRjICYmIChcbiAgICAgICAgICA8c3BhblxuICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgIGZvbnQtc2l6ZTogMC44ZW07XG4gICAgICAgICAgICAgIGNvbG9yOiAjNjY2O1xuICAgICAgICAgICAgYH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICBVVENcbiAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICl9XG4gICAgICAgIHshaXNEaXNhYmxlZCAmJiAoXG4gICAgICAgICAgPEJ1dHRvbnMgdD17dH0gaGFuZGxlQ2hhbmdlPXt2ID0+IHRoaXMuaGFuZGxlQ2hhbmdlKHYpfSBnZXROb3c9eygpID0+IHRoaXMuZ2V0Tm93KCl9IC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IERhdGVUaW1lQ29udHJvbDtcbiJdfQ== */",
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[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"]} */",
65
54
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
66
55
  };
67
- class DateTimeControl extends _react.default.Component {
68
- constructor(...args) {
69
- super(...args);
70
- _defineProperty(this, "isUtc", this.props.field.get('picker_utc') || false);
71
- _defineProperty(this, "isValidDate", dt => (0, _dayjs.default)(dt, this.getFormat().inputFormat).isValid() || dt === '');
72
- _defineProperty(this, "handleChange", datetime => {
73
- if (!this.isValidDate(datetime)) return;
74
- const {
75
- onChange
76
- } = this.props;
77
- if (datetime === '') {
78
- onChange('');
79
- } else {
80
- const {
81
- format,
82
- inputFormat
83
- } = this.getFormat();
84
- const formattedValue = (0, _dayjs.default)(datetime, inputFormat).format(format);
85
- onChange(formattedValue);
86
- }
87
- });
88
- _defineProperty(this, "onInputChange", e => {
89
- const etv = e.target.value;
90
- this.handleChange(etv);
91
- });
92
- }
56
+ class DateTimeControl extends React.Component {
57
+ static propTypes = {
58
+ field: PropTypes.object.isRequired,
59
+ forID: PropTypes.string,
60
+ onChange: PropTypes.func.isRequired,
61
+ classNameWrapper: PropTypes.string.isRequired,
62
+ setActiveStyle: PropTypes.func.isRequired,
63
+ setInactiveStyle: PropTypes.func.isRequired,
64
+ value: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),
65
+ t: PropTypes.func.isRequired,
66
+ isDisabled: PropTypes.bool
67
+ };
68
+ static defaultProps = {
69
+ isDisabled: false
70
+ };
93
71
  componentDidMount() {
72
+ // Manually validate PropTypes - React 19 breaking change
73
+ PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');
94
74
  const {
95
75
  value
96
76
  } = this.props;
@@ -98,6 +78,7 @@ class DateTimeControl extends _react.default.Component {
98
78
  this.handleChange(this.getNow());
99
79
  }
100
80
  }
81
+ isUtc = this.props.field.get('picker_utc') || false;
101
82
  escapeZ(str) {
102
83
  if (/Z(?![\]])/.test(str)) {
103
84
  return str.replace('Z', '[Z]');
@@ -111,9 +92,9 @@ class DateTimeControl extends _react.default.Component {
111
92
  let inputType = 'datetime-local';
112
93
  let inputFormat = 'YYYY-MM-DDTHH:mm';
113
94
  let format = 'YYYY-MM-DDTHH:mm:ss.SSS[Z]';
114
- let userFormat = field === null || field === void 0 ? void 0 : field.get('format');
115
- let dateFormat = field === null || field === void 0 ? void 0 : field.get('date_format');
116
- let timeFormat = field === null || field === void 0 ? void 0 : field.get('time_format');
95
+ let userFormat = field?.get('format');
96
+ let dateFormat = field?.get('date_format');
97
+ let timeFormat = field?.get('time_format');
117
98
  if (dateFormat === true) dateFormat = 'YYYY-MM-DD';
118
99
  if (timeFormat === true) timeFormat = 'HH:mm';
119
100
  if (this.isUtc) {
@@ -145,11 +126,12 @@ class DateTimeControl extends _react.default.Component {
145
126
  inputFormat
146
127
  };
147
128
  }
129
+ isValidDate = dt => dayjs(dt, this.getFormat().inputFormat).isValid() || dt === '';
148
130
  getNow() {
149
131
  const {
150
132
  inputFormat
151
133
  } = this.getFormat();
152
- return this.isUtc ? _dayjs.default.utc().format(inputFormat) : (0, _dayjs.default)().format(inputFormat);
134
+ return this.isUtc ? dayjs.utc().format(inputFormat) : dayjs().format(inputFormat);
153
135
  }
154
136
  formatInputValue(value) {
155
137
  if (value === '') return value;
@@ -157,12 +139,32 @@ class DateTimeControl extends _react.default.Component {
157
139
  format,
158
140
  inputFormat
159
141
  } = this.getFormat();
160
- const inputValue = this.isUtc ? _dayjs.default.utc(value, format).format(inputFormat) : (0, _dayjs.default)(value, format).format(inputFormat);
142
+ const inputValue = this.isUtc ? dayjs.utc(value, format).format(inputFormat) : dayjs(value, format).format(inputFormat);
161
143
  if (this.isValidDate(inputValue)) {
162
144
  return inputValue;
163
145
  }
164
- return this.isUtc ? _dayjs.default.utc(value).format(inputFormat) : (0, _dayjs.default)(value).format(inputFormat);
146
+ return this.isUtc ? dayjs.utc(value).format(inputFormat) : dayjs(value).format(inputFormat);
165
147
  }
148
+ handleChange = datetime => {
149
+ if (!this.isValidDate(datetime)) return;
150
+ const {
151
+ onChange
152
+ } = this.props;
153
+ if (datetime === '') {
154
+ onChange('');
155
+ } else {
156
+ const {
157
+ format,
158
+ inputFormat
159
+ } = this.getFormat();
160
+ const formattedValue = dayjs(datetime, inputFormat).format(format);
161
+ onChange(formattedValue);
162
+ }
163
+ };
164
+ onInputChange = e => {
165
+ const etv = e.target.value;
166
+ this.handleChange(etv);
167
+ };
166
168
  render() {
167
169
  const {
168
170
  forID,
@@ -176,10 +178,10 @@ class DateTimeControl extends _react.default.Component {
176
178
  const {
177
179
  inputType
178
180
  } = this.getFormat();
179
- return (0, _react2.jsx)("div", {
181
+ return jsx("div", {
180
182
  className: classNameWrapper,
181
183
  css: _ref2
182
- }, (0, _react2.jsx)("input", {
184
+ }, jsx("input", {
183
185
  id: forID,
184
186
  "data-testid": forID,
185
187
  type: inputType,
@@ -188,27 +190,13 @@ class DateTimeControl extends _react.default.Component {
188
190
  onFocus: setActiveStyle,
189
191
  onBlur: setInactiveStyle,
190
192
  disabled: isDisabled
191
- }), this.isUtc && (0, _react2.jsx)("span", {
193
+ }), this.isUtc && jsx("span", {
192
194
  css: _ref
193
- }, "UTC"), !isDisabled && (0, _react2.jsx)(Buttons, {
195
+ }, "UTC"), !isDisabled && jsx(Buttons, {
194
196
  t: t,
195
197
  handleChange: v => this.handleChange(v),
196
198
  getNow: () => this.getNow()
197
199
  }));
198
200
  }
199
201
  }
200
- _defineProperty(DateTimeControl, "propTypes", {
201
- field: _propTypes.default.object.isRequired,
202
- forID: _propTypes.default.string,
203
- onChange: _propTypes.default.func.isRequired,
204
- classNameWrapper: _propTypes.default.string.isRequired,
205
- setActiveStyle: _propTypes.default.func.isRequired,
206
- setInactiveStyle: _propTypes.default.func.isRequired,
207
- value: _propTypes.default.oneOfType([_propTypes.default.object, _propTypes.default.string]),
208
- t: _propTypes.default.func.isRequired,
209
- isDisabled: _propTypes.default.bool
210
- });
211
- _defineProperty(DateTimeControl, "defaultProps", {
212
- isDisabled: false
213
- });
214
- var _default = exports.default = DateTimeControl;
202
+ export default DateTimeControl;
@@ -1,20 +1,13 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _react = _interopRequireDefault(require("react"));
8
- var _propTypes = _interopRequireDefault(require("prop-types"));
9
- var _decapCmsUiDefault = require("decap-cms-ui-default");
10
- var _react2 = require("@emotion/react");
11
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { WidgetPreviewContainer } from 'decap-cms-ui-default';
4
+ import { jsx as ___EmotionJSX } from "@emotion/react";
12
5
  function DatePreview({
13
6
  value
14
7
  }) {
15
- return (0, _react2.jsx)(_decapCmsUiDefault.WidgetPreviewContainer, null, value ? value.toString() : null);
8
+ return ___EmotionJSX(WidgetPreviewContainer, null, value ? value.toString() : null);
16
9
  }
17
10
  DatePreview.propTypes = {
18
- value: _propTypes.default.oneOfType([_propTypes.default.object, _propTypes.default.string])
11
+ value: PropTypes.oneOfType([PropTypes.object, PropTypes.string])
19
12
  };
20
- var _default = exports.default = DatePreview;
13
+ export default DatePreview;
package/dist/esm/index.js CHANGED
@@ -1,29 +1,18 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = exports.DecapCmsWidgetDatetime = void 0;
7
- var _DateTimeControl = _interopRequireDefault(require("./DateTimeControl"));
8
- var _DateTimePreview = _interopRequireDefault(require("./DateTimePreview"));
9
- var _schema = _interopRequireDefault(require("./schema"));
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
12
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
13
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
14
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
15
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
1
+ import controlComponent from './DateTimeControl';
2
+ import previewComponent from './DateTimePreview';
3
+ import schema from './schema';
16
4
  function Widget(opts = {}) {
17
- return _objectSpread({
5
+ return {
18
6
  name: 'datetime',
19
- controlComponent: _DateTimeControl.default,
20
- previewComponent: _DateTimePreview.default,
21
- schema: _schema.default
22
- }, opts);
7
+ controlComponent,
8
+ previewComponent,
9
+ schema,
10
+ ...opts
11
+ };
23
12
  }
24
- const DecapCmsWidgetDatetime = exports.DecapCmsWidgetDatetime = {
13
+ export const DecapCmsWidgetDatetime = {
25
14
  Widget,
26
- controlComponent: _DateTimeControl.default,
27
- previewComponent: _DateTimePreview.default
15
+ controlComponent,
16
+ previewComponent
28
17
  };
29
- var _default = exports.default = DecapCmsWidgetDatetime;
18
+ export default DecapCmsWidgetDatetime;
@@ -1,10 +1,4 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _default = exports.default = {
1
+ export default {
8
2
  properties: {
9
3
  format: {
10
4
  type: 'string'
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.2.3",
4
+ "version": "3.3.0",
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",
@@ -26,7 +26,7 @@
26
26
  },
27
27
  "peerDependencies": {
28
28
  "@emotion/react": "^11.11.1",
29
- "react": "^18.2.0"
29
+ "react": "^19.1.0"
30
30
  },
31
- "gitHead": "51eb7e831e9b587faed62314c4397b2966a8eefe"
31
+ "gitHead": "ed7e99318007b83f4c57f3237bf92b931676820a"
32
32
  }
@@ -63,6 +63,9 @@ class DateTimeControl extends React.Component {
63
63
  };
64
64
 
65
65
  componentDidMount() {
66
+ // Manually validate PropTypes - React 19 breaking change
67
+ PropTypes.checkPropTypes(DateTimeControl.propTypes, this.props, 'prop', 'DateTimeControl');
68
+
66
69
  const { value } = this.props;
67
70
  if (value === '{{now}}') {
68
71
  this.handleChange(this.getNow());
@@ -1,19 +0,0 @@
1
- /**
2
- * @license React
3
- * react-dom.production.min.js
4
- *
5
- * Copyright (c) Facebook, Inc. and its affiliates.
6
- *
7
- * This source code is licensed under the MIT license found in the
8
- * LICENSE file in the root directory of this source tree.
9
- */
10
-
11
- /**
12
- * @license React
13
- * scheduler.production.min.js
14
- *
15
- * Copyright (c) Facebook, Inc. and its affiliates.
16
- *
17
- * This source code is licensed under the MIT license found in the
18
- * LICENSE file in the root directory of this source tree.
19
- */