UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

147 lines (146 loc) • 14.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _locale = /*#__PURE__*/ _interop_require_wildcard(require("date-fns/locale")); const _react = /*#__PURE__*/ _interop_require_default(require("react")); const _reactdatepicker = /*#__PURE__*/ _interop_require_wildcard(require("react-datepicker")); require("react-datepicker/dist/react-datepicker.css"); const _reacti18next = require("react-i18next"); const _getSupportedDateLocale = require("../../../utilities/formatDate/getSupportedDateLocale"); const _Calendar = /*#__PURE__*/ _interop_require_default(require("../../icons/Calendar")); const _X = /*#__PURE__*/ _interop_require_default(require("../../icons/X")); require("./index.scss"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interop_require_wildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = { __proto__: null }; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for(var key in obj){ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } const baseClass = 'date-time-picker'; const DateTime = (props)=>{ const { displayFormat: customDisplayFormat, maxDate, maxTime, minDate, minTime, monthsToShow = 1, onChange: onChangeFromProps, overrides, pickerAppearance = 'default', placeholder: placeholderText, readOnly, timeFormat = 'h:mm aa', timeIntervals = 30, value } = props; // Use the user's AdminUI language preference for the locale const { i18n } = (0, _reacti18next.useTranslation)(); const locale = (0, _getSupportedDateLocale.getSupportedDateLocale)(i18n.language); try { (0, _reactdatepicker.registerLocale)(locale, _locale[locale]); } catch (e) { console.warn(`Could not find DatePicker locale for ${locale}`); } let dateFormat = customDisplayFormat; if (!customDisplayFormat) { // when no displayFormat is provided, determine format based on the picker appearance if (pickerAppearance === 'default') dateFormat = 'MM/dd/yyyy'; else if (pickerAppearance === 'dayAndTime') dateFormat = 'MMM d, yyy h:mm a'; else if (pickerAppearance === 'timeOnly') dateFormat = 'h:mm a'; else if (pickerAppearance === 'dayOnly') dateFormat = 'MMM dd'; else if (pickerAppearance === 'monthOnly') dateFormat = 'MMMM'; } const onChange = (incomingDate)=>{ const newDate = incomingDate; if (newDate instanceof Date && [ 'dayOnly', 'default', 'monthOnly' ].includes(pickerAppearance)) { const tzOffset = incomingDate.getTimezoneOffset() / 60; newDate.setHours(12 - tzOffset, 0); } if (typeof onChangeFromProps === 'function') onChangeFromProps(newDate); }; const dateTimePickerProps = { customInputRef: 'ref', dateFormat, disabled: readOnly, maxDate, maxTime, minDate, minTime, monthsShown: Math.min(2, monthsToShow), onChange, placeholderText, selected: value && new Date(value), showMonthYearPicker: pickerAppearance === 'monthOnly', showPopperArrow: false, showTimeSelect: pickerAppearance === 'dayAndTime' || pickerAppearance === 'timeOnly', timeFormat, timeIntervals, ...overrides }; const classes = [ baseClass, `${baseClass}__appearance--${pickerAppearance}` ].filter(Boolean).join(' '); return /*#__PURE__*/ _react.default.createElement("div", { className: classes }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__icon-wrap` }, dateTimePickerProps.selected && /*#__PURE__*/ _react.default.createElement("button", { className: `${baseClass}__clear-button`, onClick: ()=>onChange(null), type: "button" }, /*#__PURE__*/ _react.default.createElement(_X.default, null)), /*#__PURE__*/ _react.default.createElement(_Calendar.default, null)), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__input-wrapper` }, /*#__PURE__*/ _react.default.createElement(_reactdatepicker.default, { ...dateTimePickerProps, dropdownMode: "select", locale: locale, popperModifiers: [ { name: 'preventOverflow', enabled: true } ], showMonthDropdown: true, showYearDropdown: true }))); }; const _default = DateTime; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/DatePicker/DatePicker.tsx"],"sourcesContent":["import * as Locales from 'date-fns/locale'\nimport React from 'react'\nimport DatePicker, { registerLocale } from 'react-datepicker'\nimport 'react-datepicker/dist/react-datepicker.css'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport { getSupportedDateLocale } from '../../../utilities/formatDate/getSupportedDateLocale'\nimport CalendarIcon from '../../icons/Calendar'\nimport XIcon from '../../icons/X'\nimport './index.scss'\n\nconst baseClass = 'date-time-picker'\n\nconst DateTime: React.FC<Props> = (props) => {\n  const {\n    displayFormat: customDisplayFormat,\n    maxDate,\n    maxTime,\n    minDate,\n    minTime,\n    monthsToShow = 1,\n    onChange: onChangeFromProps,\n    overrides,\n    pickerAppearance = 'default',\n    placeholder: placeholderText,\n    readOnly,\n    timeFormat = 'h:mm aa',\n    timeIntervals = 30,\n    value,\n  } = props\n\n  // Use the user's AdminUI language preference for the locale\n  const { i18n } = useTranslation()\n  const locale = getSupportedDateLocale(i18n.language)\n\n  try {\n    registerLocale(locale, Locales[locale])\n  } catch (e) {\n    console.warn(`Could not find DatePicker locale for ${locale}`)\n  }\n\n  let dateFormat = customDisplayFormat\n\n  if (!customDisplayFormat) {\n    // when no displayFormat is provided, determine format based on the picker appearance\n    if (pickerAppearance === 'default') dateFormat = 'MM/dd/yyyy'\n    else if (pickerAppearance === 'dayAndTime') dateFormat = 'MMM d, yyy h:mm a'\n    else if (pickerAppearance === 'timeOnly') dateFormat = 'h:mm a'\n    else if (pickerAppearance === 'dayOnly') dateFormat = 'MMM dd'\n    else if (pickerAppearance === 'monthOnly') dateFormat = 'MMMM'\n  }\n\n  const onChange = (incomingDate: Date) => {\n    const newDate = incomingDate\n    if (newDate instanceof Date && ['dayOnly', 'default', 'monthOnly'].includes(pickerAppearance)) {\n      const tzOffset = incomingDate.getTimezoneOffset() / 60\n      newDate.setHours(12 - tzOffset, 0)\n    }\n    if (typeof onChangeFromProps === 'function') onChangeFromProps(newDate)\n  }\n\n  const dateTimePickerProps = {\n    customInputRef: 'ref',\n    dateFormat,\n    disabled: readOnly,\n    maxDate,\n    maxTime,\n    minDate,\n    minTime,\n    monthsShown: Math.min(2, monthsToShow),\n    onChange,\n    placeholderText,\n    selected: value && new Date(value),\n    showMonthYearPicker: pickerAppearance === 'monthOnly',\n    showPopperArrow: false,\n    showTimeSelect: pickerAppearance === 'dayAndTime' || pickerAppearance === 'timeOnly',\n    timeFormat,\n    timeIntervals,\n    ...overrides,\n  }\n\n  const classes = [baseClass, `${baseClass}__appearance--${pickerAppearance}`]\n    .filter(Boolean)\n    .join(' ')\n\n  return (\n    <div className={classes}>\n      <div className={`${baseClass}__icon-wrap`}>\n        {dateTimePickerProps.selected && (\n          <button\n            className={`${baseClass}__clear-button`}\n            onClick={() => onChange(null)}\n            type=\"button\"\n          >\n            <XIcon />\n          </button>\n        )}\n        <CalendarIcon />\n      </div>\n      <div className={`${baseClass}__input-wrapper`}>\n        <DatePicker\n          {...dateTimePickerProps}\n          dropdownMode=\"select\"\n          locale={locale}\n          popperModifiers={[\n            {\n              name: 'preventOverflow',\n              enabled: true,\n            },\n          ]}\n          showMonthDropdown\n          showYearDropdown\n        />\n      </div>\n    </div>\n  )\n}\n\nexport default DateTime\n"],"names":["baseClass","DateTime","props","displayFormat","customDisplayFormat","maxDate","maxTime","minDate","minTime","monthsToShow","onChange","onChangeFromProps","overrides","pickerAppearance","placeholder","placeholderText","readOnly","timeFormat","timeIntervals","value","i18n","useTranslation","locale","getSupportedDateLocale","language","registerLocale","Locales","e","console","warn","dateFormat","incomingDate","newDate","Date","includes","tzOffset","getTimezoneOffset","setHours","dateTimePickerProps","customInputRef","disabled","monthsShown","Math","min","selected","showMonthYearPicker","showPopperArrow","showTimeSelect","classes","filter","Boolean","join","div","className","button","onClick","type","XIcon","CalendarIcon","DatePicker","dropdownMode","popperModifiers","name","enabled","showMonthDropdown","showYearDropdown"],"mappings":";;;;+BAwHA;;;eAAA;;;gEAxHyB;8DACP;yEACyB;QACpC;8BACwB;wCAIQ;iEACd;0DACP;QACX;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEP,MAAMA,YAAY;AAElB,MAAMC,WAA4B,CAACC;IACjC,MAAM,EACJC,eAAeC,mBAAmB,EAClCC,OAAO,EACPC,OAAO,EACPC,OAAO,EACPC,OAAO,EACPC,eAAe,CAAC,EAChBC,UAAUC,iBAAiB,EAC3BC,SAAS,EACTC,mBAAmB,SAAS,EAC5BC,aAAaC,eAAe,EAC5BC,QAAQ,EACRC,aAAa,SAAS,EACtBC,gBAAgB,EAAE,EAClBC,KAAK,EACN,GAAGjB;IAEJ,4DAA4D;IAC5D,MAAM,EAAEkB,IAAI,EAAE,GAAGC,IAAAA,4BAAc;IAC/B,MAAMC,SAASC,IAAAA,8CAAsB,EAACH,KAAKI,QAAQ;IAEnD,IAAI;QACFC,IAAAA,+BAAc,EAACH,QAAQI,OAAO,CAACJ,OAAO;IACxC,EAAE,OAAOK,GAAG;QACVC,QAAQC,IAAI,CAAC,CAAC,qCAAqC,EAAEP,OAAO,CAAC;IAC/D;IAEA,IAAIQ,aAAa1B;IAEjB,IAAI,CAACA,qBAAqB;QACxB,qFAAqF;QACrF,IAAIS,qBAAqB,WAAWiB,aAAa;aAC5C,IAAIjB,qBAAqB,cAAciB,aAAa;aACpD,IAAIjB,qBAAqB,YAAYiB,aAAa;aAClD,IAAIjB,qBAAqB,WAAWiB,aAAa;aACjD,IAAIjB,qBAAqB,aAAaiB,aAAa;IAC1D;IAEA,MAAMpB,WAAW,CAACqB;QAChB,MAAMC,UAAUD;QAChB,IAAIC,mBAAmBC,QAAQ;YAAC;YAAW;YAAW;SAAY,CAACC,QAAQ,CAACrB,mBAAmB;YAC7F,MAAMsB,WAAWJ,aAAaK,iBAAiB,KAAK;YACpDJ,QAAQK,QAAQ,CAAC,KAAKF,UAAU;QAClC;QACA,IAAI,OAAOxB,sBAAsB,YAAYA,kBAAkBqB;IACjE;IAEA,MAAMM,sBAAsB;QAC1BC,gBAAgB;QAChBT;QACAU,UAAUxB;QACVX;QACAC;QACAC;QACAC;QACAiC,aAAaC,KAAKC,GAAG,CAAC,GAAGlC;QACzBC;QACAK;QACA6B,UAAUzB,SAAS,IAAIc,KAAKd;QAC5B0B,qBAAqBhC,qBAAqB;QAC1CiC,iBAAiB;QACjBC,gBAAgBlC,qBAAqB,gBAAgBA,qBAAqB;QAC1EI;QACAC;QACA,GAAGN,SAAS;IACd;IAEA,MAAMoC,UAAU;QAAChD;QAAW,CAAC,EAAEA,UAAU,cAAc,EAAEa,iBAAiB,CAAC;KAAC,CACzEoC,MAAM,CAACC,SACPC,IAAI,CAAC;IAER,qBACE,6BAACC;QAAIC,WAAWL;qBACd,6BAACI;QAAIC,WAAW,CAAC,EAAErD,UAAU,WAAW,CAAC;OACtCsC,oBAAoBM,QAAQ,kBAC3B,6BAACU;QACCD,WAAW,CAAC,EAAErD,UAAU,cAAc,CAAC;QACvCuD,SAAS,IAAM7C,SAAS;QACxB8C,MAAK;qBAEL,6BAACC,UAAK,wBAGV,6BAACC,iBAAY,wBAEf,6BAACN;QAAIC,WAAW,CAAC,EAAErD,UAAU,eAAe,CAAC;qBAC3C,6BAAC2D,wBAAU;QACR,GAAGrB,mBAAmB;QACvBsB,cAAa;QACbtC,QAAQA;QACRuC,iBAAiB;YACf;gBACEC,MAAM;gBACNC,SAAS;YACX;SACD;QACDC,mBAAAA;QACAC,kBAAAA;;AAKV;MAEA,WAAehE"}