payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
147 lines (146 loc) • 14.5 kB
JavaScript
;
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"}