beta-parity-react
Version:
Beta Parity React Components
1 lines • 10.2 kB
JavaScript
;function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){return typeof o}:function(o){return o&&"function"==typeof Symbol&&o.constructor===Symbol&&o!==Symbol.prototype?"symbol":typeof o},_typeof(o)}Object.defineProperty(exports,"__esModule",{value:true});exports.DatePickerLocales=exports.DatePicker=void 0;var _react=_interopRequireDefault(require("react"));var _reactDom=_interopRequireDefault(require("react-dom"));var _classnames=_interopRequireDefault(require("classnames"));var _lucideReact=require("lucide-react");var _reactFlatpickr=_interopRequireDefault(require("react-flatpickr"));require("./index.css");require("./variables.css");require("../BaseInput/index.css");var _FloatingLabel=require("../FloatingLabel");var _useCombinedRefs=_interopRequireDefault(require("../hooks/useCombinedRefs"));var _BaseInput=require("../BaseInput");var _zh=require("flatpickr/dist/l10n/zh.js");var _vn=require("flatpickr/dist/l10n/vn.js");var _zhTw=require("flatpickr/dist/l10n/zh-tw.js");var _default=_interopRequireDefault(require("flatpickr/dist/l10n/default.js"));var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","value","options","floatingLabel","wrapperProps","calenderHeader","icon","sideIcon","color","locale","theme","isError","errorMessage","inputSize","placeholder","onFocus","onInputChange","readOnly","disabled"],_excluded2=["defaultDate","onClose","onOpen","onReady"],_excluded3=["value"];function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{"default":obj}}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}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}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}function _toPropertyKey(t){var i=_toPrimitive(t,"string");return"symbol"==_typeof(i)?i:i+""}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)}function _slicedToArray(arr,i){return _arrayWithHoles(arr)||_iterableToArrayLimit(arr,i)||_unsupportedIterableToArray(arr,i)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(o,minLen){if(!o)return;if(typeof o==="string")return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(o);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}function _arrayLikeToArray(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++)arr2[i]=arr[i];return arr2}function _iterableToArrayLimit(r,l){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var e,n,i,u,a=[],f=!0,o=!1;try{if(i=(t=t.call(r)).next,0===l){if(Object(t)!==t)return;f=!1}else for(;!(f=(e=i.call(t)).done)&&(a.push(e.value),a.length!==l);f=!0);}catch(r){o=!0,n=r}finally{try{if(!f&&null!=t["return"]&&(u=t["return"](),Object(u)!==u))return}finally{if(o)throw n}}return a}}function _arrayWithHoles(arr){if(Array.isArray(arr))return arr}function _objectWithoutProperties(source,excluded){if(source==null)return{};var target=_objectWithoutPropertiesLoose(source,excluded);var key,i;if(Object.getOwnPropertySymbols){var sourceSymbolKeys=Object.getOwnPropertySymbols(source);for(i=0;i<sourceSymbolKeys.length;i++){key=sourceSymbolKeys[i];if(excluded.indexOf(key)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(source,key))continue;target[key]=source[key]}}return target}function _objectWithoutPropertiesLoose(source,excluded){if(source==null)return{};var target={};for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){if(excluded.indexOf(key)>=0)continue;target[key]=source[key]}}return target}var DatePickerLocales=exports.DatePickerLocales={"default":_default["default"],en:_default["default"],vn:_vn.Vietnamese,"zh-cn":_zh.Mandarin,"zh-tw":_zhTw.MandarinTraditional};var DatePicker=exports.DatePicker=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,value=_ref.value,_ref$options=_ref.options,options=_ref$options===void 0?{}:_ref$options,floatingLabel=_ref.floatingLabel,wrapperProps=_ref.wrapperProps,calenderHeader=_ref.calenderHeader,icon=_ref.icon,_ref$sideIcon=_ref.sideIcon,sideIcon=_ref$sideIcon===void 0?"right":_ref$sideIcon,_ref$color=_ref.color,color=_ref$color===void 0?"neutral":_ref$color,_ref$locale=_ref.locale,locale=_ref$locale===void 0?"default":_ref$locale,_ref$theme=_ref.theme,theme=_ref$theme===void 0?"default":_ref$theme,_ref$isError=_ref.isError,isError=_ref$isError===void 0?false:_ref$isError,_ref$errorMessage=_ref.errorMessage,errorMessage=_ref$errorMessage===void 0?"":_ref$errorMessage,_ref$inputSize=_ref.inputSize,inputSize=_ref$inputSize===void 0?"md":_ref$inputSize,placeholder=_ref.placeholder,onFocus=_ref.onFocus,onInputChange=_ref.onInputChange,readOnly=_ref.readOnly,disabled=_ref.disabled,props=_objectWithoutProperties(_ref,_excluded);var defaultDate=options.defaultDate,onClose=options.onClose,onOpen=options.onOpen,onReady=options.onReady,restOptions=_objectWithoutProperties(options,_excluded2);var inputRef=_react["default"].useRef(null);var combinedRefs=(0,_useCombinedRefs["default"])(ref,inputRef);var flatPickrInstance=_react["default"].useRef(null);var calenderHeaderRef=_react["default"].useRef(null);var _React$useState=_react["default"].useState(false),_React$useState2=_slicedToArray(_React$useState,2),isFocused=_React$useState2[0],setIsFocused=_React$useState2[1];var _React$useState3=_react["default"].useState(defaultDate||value||""),_React$useState4=_slicedToArray(_React$useState3,2),currentValue=_React$useState4[0],setCurrentValue=_React$useState4[1];var handleIconClick=function handleIconClick(e){combinedRefs.current&&combinedRefs.current.flatpickr.input.focus()};var handleFocus=function handleFocus(e){setIsFocused(true);onFocus===null||onFocus===void 0||onFocus(e)};var handleOnClose=function handleOnClose(selectedDates,dateStr,instance,data){setCurrentValue(dateStr);setIsFocused(false);onClose===null||onClose===void 0||onClose(selectedDates,dateStr,instance,data)};var handleOnReady=function handleOnReady(selectedDates,dateStr,instance,data){if(readOnly||disabled)return instance.close();flatPickrInstance.current=instance;instance.calendarContainer.classList.add("flatpickr-calendar-".concat(color));if(calenderHeader){var headerElement=document.createElement("div");headerElement.classList.add("flatpickr-calendar-header");instance.calendarContainer.prepend(headerElement);calenderHeaderRef.current=headerElement}onReady===null||onReady===void 0||onReady(selectedDates,dateStr,instance,data)};var handleOnOpen=function handleOnOpen(selectedDates,dateStr,instance,data){onOpen===null||onOpen===void 0||onOpen(selectedDates,dateStr,instance,data)};var handleOnInputChange=function handleOnInputChange(e){onInputChange===null||onInputChange===void 0||onInputChange(e,flatPickrInstance.current)};var CalenderIcon=(0,_jsxRuntime.jsx)("button",{type:"button",className:"square-icon input-icon cursor-pointer",tabIndex:-1,onClick:handleIconClick,disabled:disabled||readOnly,children:icon?icon:(0,_jsxRuntime.jsx)(_lucideReact.Calendar,{})});var floatingLabelActive=disabled?undefined:floatingLabel;var inputValueActive=disabled?undefined:value||defaultDate||"";var defaultValueActive=disabled?undefined:defaultDate;var placeholderActive=disabled?undefined:placeholder;var addedClassname=CalenderIcon&&sideIcon==="right"&&"input-action";_react["default"].useEffect(function(){setCurrentValue(value||"")},[value]);return(0,_jsxRuntime.jsxs)(_BaseInput.InputWrapper,_objectSpread(_objectSpread({className:(0,_classnames["default"])(addedClassname,wrapperProps===null||wrapperProps===void 0?void 0:wrapperProps.className),rightElement:sideIcon==="right"&&CalenderIcon,leftElement:sideIcon==="left"&&CalenderIcon},wrapperProps),{},{children:[floatingLabel&&(0,_jsxRuntime.jsx)(_FloatingLabel.ContainedLabel,{isActive:isFocused||!!currentValue,children:floatingLabelActive}),calenderHeader&&calenderHeaderRef.current&&_reactDom["default"].createPortal(calenderHeader,calenderHeaderRef.current),(0,_jsxRuntime.jsx)(_reactFlatpickr["default"],_objectSpread(_objectSpread(_objectSpread({ref:combinedRefs,className:(0,_classnames["default"])("date-picker","par-input",theme,_defineProperty({"error-state":isError},_BaseInput.sizeInputMap[inputSize],inputSize),className)},!readOnly?{"data-readonly":"not-allowed-input"}:{}),{},{placeholder:placeholderActive,value:inputValueActive,onFocus:handleFocus,disabled:disabled,readOnly:readOnly,options:_objectSpread({disableMobile:true,clickOpens:!readOnly&&!disabled,locale:DatePickerLocales[locale],defaultDate:defaultValueActive,onClose:handleOnClose,onOpen:handleOnOpen,onReady:handleOnReady},restOptions)},props),{},{render:function render(_ref2,ref){var value=_ref2.value,props=_objectWithoutProperties(_ref2,_excluded3);return(0,_jsxRuntime.jsx)("input",_objectSpread(_objectSpread({ref:ref},props),{},{onChange:handleOnInputChange}))}})),errorMessage&&isError&&(0,_jsxRuntime.jsx)(_BaseInput.ErrorMessage,{children:errorMessage})]}))});DatePicker.displayName="DatePicker";