UNPKG

litepicker-react

Version:

This component is react wrapper for [litepicker](https://litepicker.com/).

70 lines (68 loc) 2.29 kB
var __defProp = Object.defineProperty; var __defProps = Object.defineProperties; var __getOwnPropDescs = Object.getOwnPropertyDescriptors; var __getOwnPropSymbols = Object.getOwnPropertySymbols; var __hasOwnProp = Object.prototype.hasOwnProperty; var __propIsEnum = Object.prototype.propertyIsEnumerable; var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; var __spreadValues = (a, b) => { for (var prop in b ||= {}) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]); if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) { if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]); } return a; }; var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); var __objRest = (source, exclude) => { var target = {}; for (var prop in source) if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0) target[prop] = source[prop]; if (source != null && __getOwnPropSymbols) for (var prop of __getOwnPropSymbols(source)) { if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop)) target[prop] = source[prop]; } return target; }; // src/index.ts import { memo, useRef, forwardRef, useLayoutEffect, useImperativeHandle, createElement } from "react"; import Litepicker from "litepicker"; var LitePickerWrapper = forwardRef(function LitePicker(props, ref) { const inputRef = useRef(null); useImperativeHandle(ref, () => inputRef.current); const _a = props, { options } = _a, inputProps = __objRest(_a, ["options"]); useLayoutEffect(() => { const element = inputRef.current; if (element) { if (element.litePickerInstance) { element.litePickerInstance.destroy(); if (!props.value) { element.value = ""; } } element.litePickerInstance = new Litepicker(__spreadProps(__spreadValues({}, props.options), { element })); } }, [options, props.value]); return createElement("input", __spreadProps(__spreadValues({}, inputProps), { ref: inputRef, type: "text" })); }); var src_default = memo(LitePickerWrapper); export { src_default as default };