funda-ui 4.5.666 → 4.5.671

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.
Files changed (65) hide show
  1. package/ColorPicker/index.js +3 -1
  2. package/Date/index.js +14 -1
  3. package/DragDropList/index.css +188 -0
  4. package/DragDropList/index.d.ts +44 -0
  5. package/DragDropList/index.js +1587 -0
  6. package/Input/index.d.ts +2 -0
  7. package/Input/index.js +14 -1
  8. package/LICENSE +21 -0
  9. package/MultipleSelect/index.css +237 -144
  10. package/MultipleSelect/index.d.ts +24 -10
  11. package/MultipleSelect/index.js +2240 -1225
  12. package/README.md +3 -1
  13. package/RangeSlider/index.js +14 -1
  14. package/Textarea/index.d.ts +2 -0
  15. package/Textarea/index.js +14 -1
  16. package/Tree/index.d.ts +1 -0
  17. package/Tree/index.js +29 -0
  18. package/Utils/useBoundedDrag.d.ts +125 -0
  19. package/Utils/useBoundedDrag.js +380 -0
  20. package/Utils/useDragDropPosition.d.ts +169 -0
  21. package/Utils/useDragDropPosition.js +456 -0
  22. package/Utils/useIsMobile.d.ts +2 -0
  23. package/Utils/useIsMobile.js +168 -0
  24. package/all.d.ts +1 -0
  25. package/all.js +1 -1
  26. package/lib/cjs/ColorPicker/index.js +3 -1
  27. package/lib/cjs/Date/index.js +14 -1
  28. package/lib/cjs/DragDropList/index.d.ts +44 -0
  29. package/lib/cjs/DragDropList/index.js +1587 -0
  30. package/lib/cjs/Input/index.d.ts +2 -0
  31. package/lib/cjs/Input/index.js +14 -1
  32. package/lib/cjs/MultipleSelect/index.d.ts +24 -10
  33. package/lib/cjs/MultipleSelect/index.js +2240 -1225
  34. package/lib/cjs/RangeSlider/index.js +14 -1
  35. package/lib/cjs/Textarea/index.d.ts +2 -0
  36. package/lib/cjs/Textarea/index.js +14 -1
  37. package/lib/cjs/Tree/index.d.ts +1 -0
  38. package/lib/cjs/Tree/index.js +29 -0
  39. package/lib/cjs/Utils/useBoundedDrag.d.ts +125 -0
  40. package/lib/cjs/Utils/useBoundedDrag.js +380 -0
  41. package/lib/cjs/Utils/useDragDropPosition.d.ts +169 -0
  42. package/lib/cjs/Utils/useDragDropPosition.js +456 -0
  43. package/lib/cjs/Utils/useIsMobile.d.ts +2 -0
  44. package/lib/cjs/Utils/useIsMobile.js +168 -0
  45. package/lib/cjs/index.d.ts +1 -0
  46. package/lib/cjs/index.js +1 -1
  47. package/lib/css/DragDropList/index.css +188 -0
  48. package/lib/css/MultipleSelect/index.css +237 -144
  49. package/lib/esm/ColorPicker/index.tsx +53 -49
  50. package/lib/esm/DragDropList/index.scss +245 -0
  51. package/lib/esm/DragDropList/index.tsx +494 -0
  52. package/lib/esm/Input/index.tsx +17 -3
  53. package/lib/esm/MultipleSelect/index.scss +288 -183
  54. package/lib/esm/MultipleSelect/index.tsx +305 -166
  55. package/lib/esm/MultipleSelect/utils/func.ts +21 -1
  56. package/lib/esm/Tabs/Tabs.tsx +1 -1
  57. package/lib/esm/Textarea/index.tsx +18 -1
  58. package/lib/esm/Tree/TreeList.tsx +32 -0
  59. package/lib/esm/Tree/index.tsx +3 -0
  60. package/lib/esm/Utils/hooks/useBoundedDrag.tsx +301 -0
  61. package/lib/esm/Utils/hooks/useDragDropPosition.tsx +420 -0
  62. package/lib/esm/Utils/hooks/useIsMobile.tsx +56 -0
  63. package/lib/esm/index.js +1 -0
  64. package/package.json +1 -1
  65. package/lib/esm/MultipleSelect/ItemList.tsx +0 -323
package/Input/index.d.ts CHANGED
@@ -52,6 +52,8 @@ export declare type InputProps = {
52
52
  onBlur?: (e: any, param: any, el: any) => void;
53
53
  onFocus?: (e: any, param: any, el: any) => void;
54
54
  onPressEnter?: (e: any, el: any) => void;
55
+ onKeyDown?: (e: any, el: any) => void;
56
+ onKeyUp?: (e: any, el: any) => void;
55
57
  };
56
58
  declare const Input: React.ForwardRefExoticComponent<InputProps & React.RefAttributes<unknown>>;
57
59
  export default Input;
package/Input/index.js CHANGED
@@ -924,7 +924,7 @@ __webpack_require__.r(__webpack_exports__);
924
924
  /* harmony import */ var funda_utils_dist_cjs_inputsCalculation__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(funda_utils_dist_cjs_inputsCalculation__WEBPACK_IMPORTED_MODULE_3__);
925
925
  /* harmony import */ var funda_utils_dist_cjs_useDebounce__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(702);
926
926
  /* harmony import */ var funda_utils_dist_cjs_useDebounce__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(funda_utils_dist_cjs_useDebounce__WEBPACK_IMPORTED_MODULE_4__);
927
- var _excluded = ["contentRef", "wrapperClassName", "controlClassName", "controlExClassName", "controlGroupWrapperClassName", "controlGroupTextClassName", "type", "disabled", "required", "placeholder", "pattern", "readOnly", "defaultValue", "value", "requiredLabel", "label", "units", "name", "step", "min", "max", "src", "size", "minLength", "maxLength", "alt", "inputMode", "id", "appendControl", "aiPredict", "aiPredictRemainingTextRGB", "aiPredictConfirmKey", "aiPredictFetchFuncAsync", "aiPredictFetchFuncMethod", "aiPredictFetchFuncMethodParams", "aiPredictFetchCallback", "iconLeft", "iconRight", "autoComplete", "autoCapitalize", "spellCheck", "style", "tabIndex", "onChangeCallback", "onInputCallback", "onKeyPressedCallback", "onChange", "onBlur", "onFocus", "onPressEnter"];
927
+ var _excluded = ["contentRef", "wrapperClassName", "controlClassName", "controlExClassName", "controlGroupWrapperClassName", "controlGroupTextClassName", "type", "disabled", "required", "placeholder", "pattern", "readOnly", "defaultValue", "value", "requiredLabel", "label", "units", "name", "step", "min", "max", "src", "size", "minLength", "maxLength", "alt", "inputMode", "id", "appendControl", "aiPredict", "aiPredictRemainingTextRGB", "aiPredictConfirmKey", "aiPredictFetchFuncAsync", "aiPredictFetchFuncMethod", "aiPredictFetchFuncMethodParams", "aiPredictFetchCallback", "iconLeft", "iconRight", "autoComplete", "autoCapitalize", "spellCheck", "style", "tabIndex", "onChangeCallback", "onInputCallback", "onKeyPressedCallback", "onChange", "onBlur", "onFocus", "onPressEnter", "onKeyDown", "onKeyUp"];
928
928
  function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) keys.push(key); return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
929
929
  function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
930
930
  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."); }
@@ -1001,6 +1001,8 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
1001
1001
  onBlur = props.onBlur,
1002
1002
  onFocus = props.onFocus,
1003
1003
  onPressEnter = props.onPressEnter,
1004
+ onKeyDown = props.onKeyDown,
1005
+ onKeyUp = props.onKeyUp,
1004
1006
  attributes = _objectWithoutProperties(props, _excluded);
1005
1007
  var uniqueID = funda_utils_dist_cjs_useComId__WEBPACK_IMPORTED_MODULE_1___default()();
1006
1008
  var idRes = id || uniqueID;
@@ -1206,6 +1208,12 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
1206
1208
  set: function set(value, cb) {
1207
1209
  setChangedVal("".concat(value));
1208
1210
  cb === null || cb === void 0 ? void 0 : cb();
1211
+ },
1212
+ aiPredictReset: function aiPredictReset() {
1213
+ setTimeout(function () {
1214
+ // Avoid conflicts with other asynchronous states, resulting in invalid clearing
1215
+ setCurrentSuggestion('');
1216
+ }, 0);
1209
1217
  }
1210
1218
  };
1211
1219
  }, [contentRef]);
@@ -1269,6 +1277,7 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
1269
1277
  }
1270
1278
 
1271
1279
  function handleKeyPressed(event) {
1280
+ onKeyDown === null || onKeyDown === void 0 ? void 0 : onKeyDown(event, valRef.current);
1272
1281
  if (typeof onKeyPressedCallback === 'function') {
1273
1282
  var newData = onKeyPressedCallback(event, valRef.current);
1274
1283
  if (newData) setChangedVal(newData); // Avoid the error "react checkbox changing an uncontrolled input to be controlled"
@@ -1312,6 +1321,9 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
1312
1321
  setCurrentSuggestion(tempMatchedSuggestion[currentSuggestionIndex.current] || '');
1313
1322
  }
1314
1323
  }
1324
+ function handleKeyUp(event) {
1325
+ onKeyUp === null || onKeyUp === void 0 ? void 0 : onKeyUp(event, valRef.current);
1326
+ }
1315
1327
  (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () {
1316
1328
  // update default value
1317
1329
  //--------------
@@ -1403,6 +1415,7 @@ var Input = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(funct
1403
1415
  }
1404
1416
  },
1405
1417
  onKeyDown: handleKeyPressed,
1418
+ onKeyUp: handleKeyUp,
1406
1419
  onCompositionStart: handleComposition,
1407
1420
  onCompositionUpdate: handleComposition,
1408
1421
  onCompositionEnd: handleComposition,
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2018 UIUX Lab
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAM AGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -1,220 +1,313 @@
1
1
  /* ======================================================
2
2
  <!-- Multiple Select -->
3
3
  /* ====================================================== */
4
- .m-select__wrapper {
5
- --m-select-wrapper-min-w: 350px;
6
- --m-select-wrapper-min-h: 315px;
7
- --m-select-header-font-size: 0.75rem;
8
- --m-select-body-font-size: 0.75rem;
9
- --m-select-scrollbar-color: rgba(0, 0, 0, 0.2);
10
- --m-select-scrollbar-track: rgba(0, 0, 0, 0);
11
- --m-select-scrollbar-w: 10px;
12
- --m-select-search-icon-color: #333;
13
- --m-select-body-bg: #fff;
14
- --m-select-header-bg: #dee2e6;
15
- --m-select-border-color: #dee2e6;
16
- --m-select-options-item-bg: #f6f6f6;
17
- --m-select-options-item-icon-color: #000;
18
- --m-select-options-item-selected-bg: #0b5ed7;
19
- --m-select-options-item-selected-icon-color: #fff;
20
- --m-select-options-item-selected-text-color: #fff;
21
- --m-select-options-item-dividingline-color: rgba(255, 255, 255, 1);
22
- --m-select-search-input-w: 100px;
23
- --m-select-search-input-bg: #fff;
24
- --m-select-search-input-text-color: #333;
25
- min-width: var(--m-select-wrapper-min-w);
26
- min-height: var(--m-select-wrapper-min-h);
4
+ .m-select-v2__wrapper {
5
+ --m-select-v2-wrapper-min-w: 350px;
6
+ --m-select-v2-wrapper-min-h: 315px;
7
+ --m-select-v2-header-font-size: 0.75rem;
8
+ --m-select-v2-body-font-size: 0.75rem;
9
+ --m-select-v2-scrollbar-color: rgba(0, 0, 0, 0.2);
10
+ --m-select-v2-scrollbar-track: rgba(0, 0, 0, 0);
11
+ --m-select-v2-scrollbar-w: 10px;
12
+ --m-select-v2-search-icon-color: #333;
13
+ --m-select-v2-body-bg: #fff;
14
+ --m-select-v2-header-bg: #dee2e6;
15
+ --m-select-v2-border-color: #dee2e6;
16
+ --m-select-v2-search-input-w: 100px;
17
+ --m-select-v2-search-input-bg: #fff;
18
+ --m-select-v2-search-input-text-color: #333;
19
+ min-width: var(--m-select-v2-wrapper-min-w);
20
+ min-height: var(--m-select-v2-wrapper-min-h);
27
21
  width: 100%;
28
22
  height: 100%;
29
- border: solid 1px var(--m-select-border-color);
23
+ border: solid 1px var(--m-select-v2-border-color);
30
24
  border-radius: 0.35rem;
31
25
  position: relative;
32
- background: var(--m-select-body-bg);
33
- /*-------- Multilevel --------*/
34
- /*-------- List --------*/
26
+ background: var(--m-select-v2-body-bg);
35
27
  }
36
- .m-select__wrapper .m-select-diving-line {
28
+ .m-select-v2__wrapper .m-select-v2-diving-line {
37
29
  width: 1px;
38
- background-color: var(--m-select-border-color);
30
+ background-color: var(--m-select-v2-border-color);
39
31
  left: 50%;
40
32
  top: 0;
41
33
  position: absolute;
42
34
  height: 100%;
43
35
  z-index: 1;
44
36
  }
45
- .m-select__wrapper .m-select-inner {
37
+ .m-select-v2__wrapper .m-select-v2-inner {
46
38
  display: flex;
47
39
  font-size: 0.8em;
48
40
  height: 100%;
41
+ /* Main */
42
+ /* List */
43
+ /* Header */
49
44
  /* Search */
50
45
  }
51
- .m-select__wrapper .m-select-inner ul,
52
- .m-select__wrapper .m-select-inner li {
53
- margin: 0;
54
- padding: 0;
55
- list-style: none;
56
- }
57
- .m-select__wrapper .m-select-inner div.m-select__selected__container,
58
- .m-select__wrapper .m-select-inner div.m-select__available__container {
46
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__selected__container,
47
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__available__container {
59
48
  position: relative;
60
49
  flex: 1;
61
50
  }
62
- .m-select__wrapper .m-select-inner ul.m-select__selected,
63
- .m-select__wrapper .m-select-inner ul.m-select__available {
64
- position: relative;
65
- overflow: auto;
66
- overflow-x: hidden;
67
- border: none;
68
- position: relative;
69
- width: 100%;
70
- }
71
- .m-select__wrapper .m-select-inner ul {
72
- user-select: none;
73
- }
74
- .m-select__wrapper .m-select-inner li {
75
- cursor: default;
76
- position: relative;
77
- font-size: var(--m-select-body-font-size);
78
- display: block;
79
- background: var(--m-select-options-item-bg);
80
- border-bottom: 1px solid var(--m-select-options-item-dividingline-color);
81
- }
82
- .m-select__wrapper .m-select-inner li.disabled {
83
- pointer-events: none;
84
- opacity: 0.4;
85
- }
86
- .m-select__wrapper .m-select-inner li.hide {
87
- display: none;
88
- }
89
- .m-select__wrapper .m-select-inner li:hover {
90
- opacity: 0.8;
91
- }
92
- .m-select__wrapper .m-select-inner li.selected {
93
- background: var(--m-select-options-item-selected-bg);
94
- color: var(--m-select-options-item-selected-text-color);
95
- }
96
- .m-select__wrapper .m-select-inner li.selected > i svg path {
97
- fill: var(--m-select-options-item-selected-icon-color);
51
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__selected__container .m-select-v2__header {
52
+ border-radius: 0 0.35rem 0 0;
98
53
  }
99
- .m-select__wrapper .m-select-inner li:last-child {
100
- border-bottom: none;
54
+ .m-select-v2__wrapper .m-select-v2-inner div.m-select-v2__available__container .m-select-v2__header {
55
+ border-radius: 0.35rem 0 0 0;
101
56
  }
102
- .m-select__wrapper .m-select-inner li > div {
103
- padding: 0.35rem 0.75rem;
104
- display: flex;
105
- justify-content: space-between;
106
- width: 100%;
57
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list {
58
+ font-size: var(--m-select-v2-body-font-size);
107
59
  overflow: hidden;
108
- text-overflow: ellipsis;
109
- word-wrap: break-word;
110
- word-break: break-word;
111
- }
112
- .m-select__wrapper .m-select-inner li > div > strong {
113
- font-weight: normal;
114
- display: flex;
115
- align-items: center;
116
- }
117
- .m-select__wrapper .m-select-inner li > div > strong .arrow {
118
- display: inline-block;
119
- margin-left: 0.2rem;
120
- }
121
- .m-select__wrapper .m-select-inner li > div.active .arrow {
122
- transform: rotate(90deg);
60
+ overflow-y: auto;
61
+ max-height: calc(var(--m-select-v2-wrapper-min-h) - 1.75rem);
62
+ /* Search Result */
123
63
  }
124
- .m-select__wrapper .m-select-inner li > div > i {
125
- display: inline-block;
126
- cursor: pointer;
64
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list::-webkit-scrollbar {
65
+ width: var(--m-select-v2-scrollbar-w);
127
66
  }
128
- .m-select__wrapper .m-select-inner li > div > i svg path {
129
- fill: var(--m-select-options-item-icon-color);
67
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list::-webkit-scrollbar-thumb {
68
+ background: var(--m-select-v2-scrollbar-color);
130
69
  }
131
- .m-select__wrapper .m-select-inner div.m-select__selected__container .m-select__header {
132
- border-radius: 0 0.35rem 0 0;
70
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list::-webkit-scrollbar-track {
71
+ background: var(--m-select-v2-scrollbar-track);
133
72
  }
134
- .m-select__wrapper .m-select-inner div.m-select__available__container .m-select__header {
135
- border-radius: 0.35rem 0 0 0;
73
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2-draggable-list .m-select-v2-draggable-list__item.hide {
74
+ display: none;
136
75
  }
137
- .m-select__wrapper .m-select-inner .m-select__header {
76
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__header {
138
77
  border: none;
139
- font-size: var(--m-select-header-font-size);
78
+ font-size: var(--m-select-v2-header-font-size);
140
79
  margin-bottom: 1px;
141
- background: var(--m-select-header-bg);
80
+ background: var(--m-select-v2-header-bg);
142
81
  display: flex;
143
82
  justify-content: space-between;
144
83
  align-items: center;
145
84
  height: 1.625rem;
146
85
  }
147
- .m-select__wrapper .m-select-inner .m-select__btn--add-all {
86
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__btn--add-all {
148
87
  padding: 0.2rem;
149
88
  }
150
- .m-select__wrapper .m-select-inner .m-select__btn--remove-all {
89
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__btn--remove-all {
151
90
  padding: 0.2rem;
152
91
  }
153
- .m-select__wrapper .m-select-inner .m-select__count {
92
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__count {
154
93
  padding: 0.2rem;
155
94
  }
156
- .m-select__wrapper .m-select-inner .m-select__title {
95
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__title {
157
96
  padding: 0.2rem;
158
97
  font-weight: bold;
159
98
  }
160
- .m-select__wrapper .m-select-inner .m-select__search__container {
99
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container {
161
100
  position: relative;
162
101
  /* required */
163
102
  align-items: center;
164
103
  display: flex;
165
104
  }
166
- .m-select__wrapper .m-select-inner .m-select__search__container input.m-select__search {
105
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container input.m-select-v2__search {
167
106
  height: 14px;
168
107
  padding: 0.1rem 0.5rem;
169
108
  opacity: 0.5;
170
109
  margin: 4px;
171
- width: var(--m-select-search-input-w);
172
- background-color: var(--m-select-search-input-bg);
173
- color: var(--m-select-search-input-text-color);
110
+ width: var(--m-select-v2-search-input-w);
111
+ background-color: var(--m-select-v2-search-input-bg);
112
+ color: var(--m-select-v2-search-input-text-color);
174
113
  border-radius: 25px;
175
114
  border: none;
176
115
  outline: none;
177
116
  box-shadow: none;
178
117
  }
179
- .m-select__wrapper .m-select-inner .m-select__search__container i {
118
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container i {
180
119
  position: absolute;
181
120
  right: 0.6em;
182
121
  }
183
- .m-select__wrapper .m-select-inner .m-select__search__container i svg {
184
- fill: var(--m-select-search-icon-color);
122
+ .m-select-v2__wrapper .m-select-v2-inner .m-select-v2__search__container i svg {
123
+ fill: var(--m-select-v2-search-icon-color);
124
+ }
125
+
126
+ /*
127
+ ///////////////////////////////////////////////////////////
128
+ //////////////////// DragDrop List //////////////////
129
+ ///////////////////////////////////////////////////////////
130
+ */
131
+ .m-select-v2-draggable-list {
132
+ --m-select-v2-draggable-content-bg: transparent;
133
+ --m-select-v2-draggable-content-color: inherit;
134
+ --m-select-v2-draggable-border-color: #ddd;
135
+ --m-select-v2-draggable-wrapper-radius: 0.25rem;
136
+ --m-select-v2-draggable-control-radius: 0.25rem;
137
+ --m-select-v2-draggable-primary-color: #ffa940;
138
+ --m-select-v2-draggable-content-diff-bg: #fafafa;
139
+ --m-select-v2-draggable-content-diff-border-color: #d9d9d9;
140
+ --m-select-v2-draggable-control-fs: 0.75rem;
141
+ --m-select-v2-draggable-control-w: 100px;
142
+ --m-select-v2-draggable-btn-confirm-bg: #52c41a;
143
+ --m-select-v2-draggable-btn-cancel-bg: #ff4d4f;
144
+ --m-select-v2-draggable-btn-color: #fff;
145
+ list-style: none;
146
+ padding: 0;
147
+ margin: 0;
148
+ width: 100%;
149
+ position: relative;
150
+ /* hide wrapper border */
151
+ border-width: 0;
152
+ border-radius: 0;
153
+ /* Fix the problem that mobile terminals cannot be touched, DO NOT USE "<svg>" */
154
+ /* FORM */
155
+ }
156
+ .m-select-v2-draggable-list li {
157
+ margin: 0;
158
+ padding: 0;
185
159
  }
186
- .m-select__wrapper ul.m-select__options-contentlist > li ul {
187
- transition: max-height 0.25s ease;
188
- overflow: hidden;
160
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item {
161
+ padding: 0;
162
+ position: relative;
163
+ transition: transform 0.15s ease;
189
164
  position: relative;
190
- padding-left: 1rem;
191
165
  }
192
- .m-select__wrapper ul.m-select__options-contentlist > li:not(.active) ul {
193
- max-height: 0;
166
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item .m-select-v2-draggable-list__itemcontent {
167
+ padding: 5px 15px;
168
+ background: var(--m-select-v2-draggable-content-bg);
169
+ color: var(--m-select-v2-draggable-content-color);
170
+ border-bottom: 1px solid var(--m-select-v2-draggable-border-color);
171
+ display: flex;
172
+ align-items: center;
173
+ user-select: none;
174
+ transition: all 0.15s ease;
175
+ }
176
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item .m-select-v2-draggable-list__itemcontent .m-select-v2-draggable-list__itemcontent-inner {
177
+ display: flex;
178
+ align-items: center;
179
+ justify-content: space-between;
180
+ width: 100%;
181
+ }
182
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.disabled {
183
+ pointer-events: none !important;
184
+ opacity: 0.4 !important;
185
+ }
186
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__collapse-arrow {
187
+ cursor: pointer;
188
+ display: inline-block;
189
+ width: 20px;
190
+ text-align: center;
191
+ user-select: none;
192
+ margin-left: 0.2rem;
193
+ }
194
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__collapse-arrow svg {
195
+ transition: all 0.15s ease;
194
196
  }
195
- .m-select__wrapper ul.m-select__options-contentlist > li ul ul {
196
- margin-top: auto;
197
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__collapse-arrow:hover {
198
+ opacity: 0.7;
197
199
  }
198
- .m-select__wrapper ul.m-select__options-contentlist {
200
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__item.has-children {
199
201
  position: relative;
200
- width: 100%;
201
- overflow: hidden;
202
- overflow-y: auto;
203
- max-height: calc(315px - 1.75rem);
204
202
  }
205
- .m-select__wrapper ul.m-select__options-contentlist::-webkit-scrollbar {
206
- width: var(--m-select-scrollbar-w);
203
+ .m-select-v2-draggable-list.alternate-collapse .m-select-v2-draggable-list__item.collapsed .m-select-v2-draggable-list__collapse-arrow svg {
204
+ transform: rotate(-90deg);
207
205
  }
208
- .m-select__wrapper ul.m-select__options-contentlist::-webkit-scrollbar-thumb {
209
- background: var(--m-select-scrollbar-color);
206
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.draggable .m-select-v2-draggable-list__itemcontent {
207
+ padding-left: 1.5em;
210
208
  }
211
- .m-select__wrapper ul.m-select__options-contentlist::-webkit-scrollbar-track {
212
- background: var(--m-select-scrollbar-track);
209
+ .m-select-v2-draggable-list.handle-pos-right .m-select-v2-draggable-list__item.draggable .m-select-v2-draggable-list__itemcontent, .m-select-v2-draggable-list.icon-hide .m-select-v2-draggable-list__item.draggable .m-select-v2-draggable-list__itemcontent {
210
+ padding-left: 0.5rem;
213
211
  }
214
- .m-select__wrapper ul.m-select__options-contentlist.dragging {
215
- cursor: grab;
212
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.block.draggable {
213
+ cursor: move;
216
214
  }
217
- .m-select__wrapper ul.m-select__options-contentlist--hide {
218
- overflow: hidden;
219
- height: auto;
215
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.dragging .m-select-v2-draggable-list__itemcontent {
216
+ background: #fff9e6;
217
+ border: 1px dashed #ffd591;
218
+ opacity: 0.8;
219
+ }
220
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.drag-over .m-select-v2-draggable-list__itemcontent {
221
+ background: #fff9e6;
222
+ border: 2px solid #ffd591;
223
+ }
224
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.drag-over-top::before {
225
+ content: "";
226
+ position: absolute;
227
+ top: -3px;
228
+ left: 0;
229
+ right: 0;
230
+ height: 2px;
231
+ background: var(--m-select-v2-draggable-primary-color);
232
+ border-radius: 1px;
233
+ }
234
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.drag-over-bottom::after {
235
+ content: "";
236
+ position: absolute;
237
+ bottom: -3px;
238
+ left: 0;
239
+ right: 0;
240
+ height: 2px;
241
+ background: var(--m-select-v2-draggable-primary-color);
242
+ border-radius: 1px;
243
+ }
244
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__handle {
245
+ color: #999;
246
+ padding: 5px;
247
+ cursor: move;
248
+ transition: color 0.15s ease;
249
+ position: absolute;
250
+ width: 1em;
251
+ height: 1em;
252
+ top: 50%;
253
+ transform: translateY(-50%);
254
+ z-index: 1;
255
+ display: flex;
256
+ align-items: center;
257
+ font-size: 0.75rem;
258
+ }
259
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__handle.left {
260
+ left: 0;
261
+ }
262
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__handle.right {
263
+ right: 1em;
264
+ }
265
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item,
266
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__itemcontent {
267
+ transition: all 0.15s ease;
268
+ }
269
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.editing .m-select-v2-draggable-list__itemcontent, .m-select-v2-draggable-list .m-select-v2-draggable-list__item:hover .m-select-v2-draggable-list__itemcontent {
270
+ background: var(--m-select-v2-draggable-content-diff-bg);
271
+ border-color: var(--m-select-v2-draggable-content-diff-border-color);
272
+ }
273
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__item.block:hover .m-select-v2-draggable-list__handle {
274
+ color: var(--m-select-v2-draggable-primary-color);
275
+ }
276
+ .m-select-v2-draggable-list.handle .m-select-v2-draggable-list__handle:hover {
277
+ color: var(--m-select-v2-draggable-primary-color);
278
+ }
279
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-form {
280
+ display: flex;
281
+ flex: 1;
282
+ gap: 10px;
283
+ align-items: center;
284
+ }
285
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-form input {
286
+ padding: 4px 8px;
287
+ border: 1px solid var(--m-select-v2-draggable-border-color);
288
+ border-radius: var(--m-select-v2-draggable-control-radius);
289
+ font-size: var(--m-select-v2-draggable-control-fs);
290
+ width: var(--m-select-v2-draggable-control-w);
291
+ }
292
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons {
293
+ display: flex;
294
+ gap: 5px;
295
+ }
296
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button {
297
+ padding: 0.2rem 0.5rem;
298
+ border: none;
299
+ font-size: 0.75rem;
300
+ border-radius: var(--m-select-v2-draggable-control-radius);
301
+ cursor: pointer;
302
+ }
303
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button:first-child {
304
+ background: var(--m-select-v2-draggable-btn-confirm-bg);
305
+ color: var(--m-select-v2-draggable-btn-color);
306
+ }
307
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button:last-child {
308
+ background: var(--m-select-v2-draggable-btn-cancel-bg);
309
+ color: var(--m-select-v2-draggable-btn-color);
310
+ }
311
+ .m-select-v2-draggable-list .m-select-v2-draggable-list__edit-buttons button:hover {
312
+ opacity: 0.8;
220
313
  }
@@ -1,6 +1,16 @@
1
1
  import React from 'react';
2
2
  export interface OptionConfig {
3
- [propName: string]: string | number | boolean | Function;
3
+ id: number;
4
+ parentId?: number;
5
+ label: string;
6
+ listItemLabel: string;
7
+ value: string;
8
+ queryString: string;
9
+ depth?: number;
10
+ children?: OptionConfig[];
11
+ disabled?: boolean;
12
+ extendedContent?: React.ReactNode;
13
+ [key: string]: any;
4
14
  }
5
15
  export declare type MultipleSelectProps = {
6
16
  contentRef?: React.ForwardedRef<any>;
@@ -17,11 +27,6 @@ export declare type MultipleSelectProps = {
17
27
  iconAdd?: React.ReactNode | string;
18
28
  iconRemove?: React.ReactNode | string;
19
29
  unattachedSelect?: boolean;
20
- hierarchical?: boolean;
21
- indentation?: string;
22
- doubleIndent?: boolean;
23
- alternateCollapse?: boolean;
24
- arrow?: React.ReactNode;
25
30
  defaultValue?: string;
26
31
  value?: string;
27
32
  label?: React.ReactNode | string;
@@ -29,7 +34,16 @@ export declare type MultipleSelectProps = {
29
34
  options?: OptionConfig[] | string;
30
35
  disabled?: any;
31
36
  required?: any;
32
- appendControl?: React.ReactNode;
37
+ /** DragDrop List */
38
+ draggable?: boolean;
39
+ handleHide?: boolean;
40
+ handleIcon?: string;
41
+ handlePos?: 'left' | 'right';
42
+ dragMode?: 'handle' | 'block';
43
+ indentation?: string;
44
+ doubleIndent?: boolean;
45
+ alternateCollapse?: boolean;
46
+ arrow?: React.ReactNode;
33
47
  /** Whether to use square brackets to save result and initialize default value */
34
48
  extractValueByBrackets?: boolean;
35
49
  /** Incoming data, you can set the third parameter of `onFetch` */
@@ -43,9 +57,9 @@ export declare type MultipleSelectProps = {
43
57
  fetchFuncMethodParams?: any[];
44
58
  fetchCallback?: (data: any) => void;
45
59
  onFetch?: (data: any) => void;
46
- onAddAll?: (e: any, data: any, dataStr: any) => void;
47
- onRemoveAll?: (e: any, data: any, dataStr: any) => void;
48
- onChange?: (e: any, data: any, dataStr: any, currentData: any, type: string) => void;
60
+ onAddAll?: (e: HTMLElement | null, data: any[], dataStr: string, res: any[]) => void;
61
+ onRemoveAll?: (e: HTMLElement | null, data: any[], dataStr: string, res: any[]) => void;
62
+ onChange?: (e: HTMLElement | null, data: any[], dataStr: string, currentData: any, type: string, res: any[]) => void;
49
63
  };
50
64
  declare const MultipleSelect: React.ForwardRefExoticComponent<MultipleSelectProps & React.RefAttributes<unknown>>;
51
65
  export default MultipleSelect;