UNPKG

zmp-react

Version:

Build full featured iOS & Android apps using ZMP & React

250 lines (215 loc) 9.05 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); exports.__esModule = true; exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireWildcard(require("react")); var _useIsomorphicLayoutEffect = require("../shared/use-isomorphic-layout-effect"); var _utils = require("../shared/utils"); var _mixins = require("../shared/mixins"); var _zmp = require("../shared/zmp"); var _watchProp = require("../shared/watch-prop"); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(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 = {}; 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; } var Stepper = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) { var _zmpStepper = (0, _react.useRef)(null); var className = props.className, id = props.id, style = props.style, _props$init = props.init, init = _props$init === void 0 ? true : _props$init, _props$value = props.value, value = _props$value === void 0 ? 0 : _props$value, _props$min = props.min, min = _props$min === void 0 ? 0 : _props$min, _props$max = props.max, max = _props$max === void 0 ? 100 : _props$max, _props$step = props.step, step = _props$step === void 0 ? 1 : _props$step, formatValue = props.formatValue, name = props.name, inputId = props.inputId, _props$input = props.input, input = _props$input === void 0 ? true : _props$input, _props$inputType = props.inputType, inputType = _props$inputType === void 0 ? 'text' : _props$inputType, _props$inputReadonly = props.inputReadonly, inputReadonly = _props$inputReadonly === void 0 ? false : _props$inputReadonly, _props$autorepeat = props.autorepeat, autorepeat = _props$autorepeat === void 0 ? false : _props$autorepeat, _props$autorepeatDyna = props.autorepeatDynamic, autorepeatDynamic = _props$autorepeatDyna === void 0 ? false : _props$autorepeatDyna, _props$wraps = props.wraps, wraps = _props$wraps === void 0 ? false : _props$wraps, _props$manualInputMod = props.manualInputMode, manualInputMode = _props$manualInputMod === void 0 ? false : _props$manualInputMod, _props$decimalPoint = props.decimalPoint, decimalPoint = _props$decimalPoint === void 0 ? 4 : _props$decimalPoint, _props$buttonsEndInpu = props.buttonsEndInputMode, buttonsEndInputMode = _props$buttonsEndInpu === void 0 ? true : _props$buttonsEndInpu, disabled = props.disabled, buttonsOnly = props.buttonsOnly, round = props.round, roundMd = props.roundMd, roundIos = props.roundIos, roundAurora = props.roundAurora, fill = props.fill, fillMd = props.fillMd, fillIos = props.fillIos, fillAurora = props.fillAurora, large = props.large, largeMd = props.largeMd, largeIos = props.largeIos, largeAurora = props.largeAurora, small = props.small, smallMd = props.smallMd, smallIos = props.smallIos, smallAurora = props.smallAurora, raised = props.raised, raisedMd = props.raisedMd, raisedIos = props.raisedIos, raisedAurora = props.raisedAurora; var extraAttrs = (0, _utils.getExtraAttrs)(props); var elRef = (0, _react.useRef)(null); var increment = function increment() { if (!_zmpStepper.current) return; _zmpStepper.current.increment(); }; var decrement = function decrement() { if (!_zmpStepper.current) return; _zmpStepper.current.decrement(); }; var setValue = function setValue(newValue) { if (_zmpStepper.current && _zmpStepper.current.setValue) _zmpStepper.current.setValue(newValue); }; var getValue = function getValue() { if (_zmpStepper.current && _zmpStepper.current.getValue) { return _zmpStepper.current.getValue(); } return undefined; }; var onInput = function onInput(event) { (0, _utils.emit)(props, 'input', event, _zmpStepper.current); }; var onChange = function onChange(event) { (0, _utils.emit)(props, 'change', event, _zmpStepper.current); }; var onMinusClick = function onMinusClick(event) { (0, _utils.emit)(props, 'stepperMinusClick', event, _zmpStepper.current); }; var onPlusClick = function onPlusClick(event) { (0, _utils.emit)(props, 'stepperPlusClick', event, _zmpStepper.current); }; (0, _react.useImperativeHandle)(ref, function () { return { el: elRef.current, zmpStepper: function zmpStepper() { return _zmpStepper.current; }, increment: increment, decrement: decrement, setValue: setValue, getValue: getValue }; }); (0, _watchProp.watchProp)(value, function (newValue) { if (!_zmpStepper.current) return; _zmpStepper.current.setValue(newValue); }); var onMount = function onMount() { (0, _zmp.zmpready)(function () { if (!init || !elRef.current) return; _zmpStepper.current = _zmp.zmp.stepper.create((0, _utils.noUndefinedProps)({ el: elRef.current, min: min, max: max, value: value, step: step, formatValue: formatValue, autorepeat: autorepeat, autorepeatDynamic: autorepeatDynamic, wraps: wraps, manualInputMode: manualInputMode, decimalPoint: decimalPoint, buttonsEndInputMode: buttonsEndInputMode, on: { change: function change(stepper, newValue) { (0, _utils.emit)(props, 'stepperChange', newValue); } } })); }); }; var onDestroy = function onDestroy() { if (_zmpStepper.current && _zmpStepper.current.destroy) { _zmpStepper.current.destroy(); } _zmpStepper.current = null; }; (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () { onMount(); return onDestroy; }, []); var inputWrapEl; var valueEl; if (input && !buttonsOnly) { var inputEl = /*#__PURE__*/_react.default.createElement("input", { name: name, id: inputId, type: inputType, min: inputType === 'number' ? min : undefined, max: inputType === 'number' ? max : undefined, step: inputType === 'number' ? step : undefined, onInput: onInput, onChange: onChange, value: value, readOnly: inputReadonly }); inputWrapEl = /*#__PURE__*/_react.default.createElement("div", { className: "stepper-input-wrap" }, inputEl); } if (!input && !buttonsOnly) { valueEl = /*#__PURE__*/_react.default.createElement("div", { className: "stepper-value" }, value); } var classes = (0, _utils.classNames)(className, 'stepper', { disabled: disabled, 'stepper-round': round, 'stepper-round-ios': roundIos, 'stepper-round-md': roundMd, 'stepper-round-aurora': roundAurora, 'stepper-fill': fill, 'stepper-fill-ios': fillIos, 'stepper-fill-md': fillMd, 'stepper-fill-aurora': fillAurora, 'stepper-large': large, 'stepper-large-ios': largeIos, 'stepper-large-md': largeMd, 'stepper-large-aurora': largeAurora, 'stepper-small': small, 'stepper-small-ios': smallIos, 'stepper-small-md': smallMd, 'stepper-small-aurora': smallAurora, 'stepper-raised': raised, 'stepper-raised-ios': raisedIos, 'stepper-raised-md': raisedMd, 'stepper-raised-aurora': raisedAurora }, (0, _mixins.colorClasses)(props)); return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({ ref: elRef, id: id, style: style, className: classes }, extraAttrs), /*#__PURE__*/_react.default.createElement("div", { className: "stepper-button-minus", onClick: onMinusClick }), inputWrapEl, valueEl, /*#__PURE__*/_react.default.createElement("div", { className: "stepper-button-plus", onClick: onPlusClick })); }); Stepper.displayName = 'zmp-stepper'; var _default = Stepper; exports.default = _default;