iglooform 3.7.0 → 3.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -30,7 +30,7 @@ export default function DumiContextWrapper() {
30
30
 
31
31
  return (
32
32
  <SiteContext.Provider value={{
33
- pkg: {"name":"iglooform","version":"3.5.0","license":"MIT"},
33
+ pkg: {"name":"iglooform","version":"3.7.1","license":"MIT"},
34
34
  historyType: "browser",
35
35
  entryExports,
36
36
  demos,
@@ -7,6 +7,10 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
7
7
  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; }
8
8
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
9
9
  function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
10
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
11
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
12
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
13
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
10
14
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
11
15
  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."); }
12
16
  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); }
@@ -14,11 +18,32 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len
14
18
  function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
15
19
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
16
20
  import { createRef, forwardRef, memo, useCallback, useImperativeHandle, useMemo, useRef, useState } from 'react';
17
- import usePatchElement from 'antd/es/_util/hooks/usePatchElement';
18
21
  import classnames from 'classnames';
19
22
  import IglooModal from "./";
20
23
  import { Fragment as _Fragment } from "react/jsx-runtime";
21
24
  import { jsx as _jsx } from "react/jsx-runtime";
25
+ var usePatchElement = function usePatchElement() {
26
+ var _useState = useState([]),
27
+ _useState2 = _slicedToArray(_useState, 2),
28
+ elements = _useState2[0],
29
+ setElements = _useState2[1];
30
+ var patchElement = useCallback(function (element) {
31
+ // append a new element to elements (and create a new ref)
32
+ setElements(function (originElements) {
33
+ return [].concat(_toConsumableArray(originElements), [element]);
34
+ });
35
+ // return a function that removes the new element out of elements (and create a new ref)
36
+ // it works a little like useEffect
37
+ return function () {
38
+ setElements(function (originElements) {
39
+ return originElements.filter(function (ele) {
40
+ return ele !== element;
41
+ });
42
+ });
43
+ };
44
+ }, []);
45
+ return [elements, patchElement];
46
+ };
22
47
  var ElementsHolder = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (_, ref) {
23
48
  var _usePatchElement = usePatchElement(),
24
49
  _usePatchElement2 = _slicedToArray(_usePatchElement, 2),
@@ -34,14 +59,14 @@ var ElementsHolder = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(function (_, ref
34
59
  });
35
60
  }));
36
61
  var HookModal = /*#__PURE__*/forwardRef(function (config, ref) {
37
- var _useState = useState(true),
38
- _useState2 = _slicedToArray(_useState, 2),
39
- open = _useState2[0],
40
- setOpen = _useState2[1];
41
- var _useState3 = useState(config),
62
+ var _useState3 = useState(true),
42
63
  _useState4 = _slicedToArray(_useState3, 2),
43
- modalConfig = _useState4[0],
44
- setModalConfig = _useState4[1];
64
+ open = _useState4[0],
65
+ setOpen = _useState4[1];
66
+ var _useState5 = useState(config),
67
+ _useState6 = _slicedToArray(_useState5, 2),
68
+ modalConfig = _useState6[0],
69
+ setModalConfig = _useState6[1];
45
70
  var destroy = useCallback(function () {
46
71
  return setOpen(false);
47
72
  }, []);
@@ -99,6 +99,9 @@ var IglooSelect = function IglooSelect(_ref) {
99
99
  var value = e.target.value;
100
100
  var filteredOptions = options.filter(function (option) {
101
101
  var _option$label, _option$label$toStrin;
102
+ if (typeof filterOption === 'function') {
103
+ return filterOption(value, option);
104
+ }
102
105
  return Boolean(option === null || option === void 0 ? void 0 : (_option$label = option.label) === null || _option$label === void 0 ? void 0 : (_option$label$toStrin = _option$label.toString()) === null || _option$label$toStrin === void 0 ? void 0 : _option$label$toStrin.includes(value));
103
106
  });
104
107
  setDisplay(filteredOptions);
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.default = void 0;
8
8
  var _react = require("react");
9
- var _usePatchElement3 = _interopRequireDefault(require("antd/es/_util/hooks/usePatchElement"));
10
9
  var _classnames = _interopRequireDefault(require("classnames"));
11
10
  var _2 = _interopRequireDefault(require("./"));
12
11
  var _jsxRuntime = require("react/jsx-runtime");
@@ -19,14 +18,40 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
19
18
  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; }
20
19
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
21
20
  function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
21
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
22
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
23
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
24
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
22
25
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
23
26
  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."); }
24
27
  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); }
25
28
  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; }
26
29
  function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
27
30
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
31
+ var usePatchElement = function usePatchElement() {
32
+ var _useState = (0, _react.useState)([]),
33
+ _useState2 = _slicedToArray(_useState, 2),
34
+ elements = _useState2[0],
35
+ setElements = _useState2[1];
36
+ var patchElement = (0, _react.useCallback)(function (element) {
37
+ // append a new element to elements (and create a new ref)
38
+ setElements(function (originElements) {
39
+ return [].concat(_toConsumableArray(originElements), [element]);
40
+ });
41
+ // return a function that removes the new element out of elements (and create a new ref)
42
+ // it works a little like useEffect
43
+ return function () {
44
+ setElements(function (originElements) {
45
+ return originElements.filter(function (ele) {
46
+ return ele !== element;
47
+ });
48
+ });
49
+ };
50
+ }, []);
51
+ return [elements, patchElement];
52
+ };
28
53
  var ElementsHolder = /*#__PURE__*/(0, _react.memo)( /*#__PURE__*/(0, _react.forwardRef)(function (_, ref) {
29
- var _usePatchElement = (0, _usePatchElement3.default)(),
54
+ var _usePatchElement = usePatchElement(),
30
55
  _usePatchElement2 = _slicedToArray(_usePatchElement, 2),
31
56
  elements = _usePatchElement2[0],
32
57
  patchElement = _usePatchElement2[1];
@@ -40,14 +65,14 @@ var ElementsHolder = /*#__PURE__*/(0, _react.memo)( /*#__PURE__*/(0, _react.forw
40
65
  });
41
66
  }));
42
67
  var HookModal = /*#__PURE__*/(0, _react.forwardRef)(function (config, ref) {
43
- var _useState = (0, _react.useState)(true),
44
- _useState2 = _slicedToArray(_useState, 2),
45
- open = _useState2[0],
46
- setOpen = _useState2[1];
47
- var _useState3 = (0, _react.useState)(config),
68
+ var _useState3 = (0, _react.useState)(true),
48
69
  _useState4 = _slicedToArray(_useState3, 2),
49
- modalConfig = _useState4[0],
50
- setModalConfig = _useState4[1];
70
+ open = _useState4[0],
71
+ setOpen = _useState4[1];
72
+ var _useState5 = (0, _react.useState)(config),
73
+ _useState6 = _slicedToArray(_useState5, 2),
74
+ modalConfig = _useState6[0],
75
+ setModalConfig = _useState6[1];
51
76
  var destroy = (0, _react.useCallback)(function () {
52
77
  return setOpen(false);
53
78
  }, []);
@@ -104,6 +104,9 @@ var IglooSelect = function IglooSelect(_ref) {
104
104
  var value = e.target.value;
105
105
  var filteredOptions = options.filter(function (option) {
106
106
  var _option$label, _option$label$toStrin;
107
+ if (typeof filterOption === 'function') {
108
+ return filterOption(value, option);
109
+ }
107
110
  return Boolean(option === null || option === void 0 ? void 0 : (_option$label = option.label) === null || _option$label === void 0 ? void 0 : (_option$label$toStrin = _option$label.toString()) === null || _option$label$toStrin === void 0 ? void 0 : _option$label$toStrin.includes(value));
108
111
  });
109
112
  setDisplay(filteredOptions);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "iglooform",
3
- "version": "3.7.0",
3
+ "version": "3.7.2",
4
4
  "scripts": {
5
5
  "start": "dumi dev",
6
6
  "build-dev": "dumi build",
@@ -1,12 +0,0 @@
1
- import { FC } from 'react';
2
- import { FormItemConfig, FormItemName } from '../../types';
3
- import './style';
4
- interface ElementProps {
5
- config: FormItemConfig;
6
- parentName?: FormItemName;
7
- preview?: boolean;
8
- disabled?: boolean;
9
- setShowStepButton?: (showButton: boolean) => void;
10
- }
11
- declare const Element: FC<ElementProps>;
12
- export default Element;
@@ -1,19 +0,0 @@
1
- import { Select } from 'antd';
2
- import { SelectProps as AntdSelectProps, SelectValue, DefaultOptionType } from 'antd/es/select';
3
- import { FC, IglooComponentProps } from '../types';
4
- import './style';
5
- type FilterOption = (inputValue: string, option?: DefaultOptionType) => boolean;
6
- interface SelectProps extends Omit<AntdSelectProps<SelectValue>, 'showSearch'> {
7
- showSearch?: boolean | {
8
- filterOption: FilterOption;
9
- };
10
- }
11
- type Props = SelectProps & IglooComponentProps;
12
- type OptionType = typeof Select.Option;
13
- type OptGroupType = typeof Select.OptGroup;
14
- interface IglooSelectType extends FC<Props> {
15
- Option: OptionType;
16
- OptGroup: OptGroupType;
17
- }
18
- declare const IglooSelect: IglooSelectType;
19
- export default IglooSelect;
@@ -1,12 +0,0 @@
1
- import { FC } from 'react';
2
- import { FormItemConfig, FormItemName } from '../../types';
3
- import './style';
4
- interface ElementProps {
5
- config: FormItemConfig;
6
- parentName?: FormItemName;
7
- preview?: boolean;
8
- disabled?: boolean;
9
- setShowStepButton?: (showButton: boolean) => void;
10
- }
11
- declare const Element: FC<ElementProps>;
12
- export default Element;
@@ -1,19 +0,0 @@
1
- import { Select } from 'antd';
2
- import { SelectProps as AntdSelectProps, SelectValue, DefaultOptionType } from 'antd/es/select';
3
- import { FC, IglooComponentProps } from '../types';
4
- import './style';
5
- type FilterOption = (inputValue: string, option?: DefaultOptionType) => boolean;
6
- interface SelectProps extends Omit<AntdSelectProps<SelectValue>, 'showSearch'> {
7
- showSearch?: boolean | {
8
- filterOption: FilterOption;
9
- };
10
- }
11
- type Props = SelectProps & IglooComponentProps;
12
- type OptionType = typeof Select.Option;
13
- type OptGroupType = typeof Select.OptGroup;
14
- interface IglooSelectType extends FC<Props> {
15
- Option: OptionType;
16
- OptGroup: OptGroupType;
17
- }
18
- declare const IglooSelect: IglooSelectType;
19
- export default IglooSelect;