hc-busin-components 1.0.4 → 1.0.7

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 (77) hide show
  1. package/README.md +31 -0
  2. package/dist/Actions/index.css +36 -0
  3. package/dist/Actions/index.js +46 -87
  4. package/dist/Actions/index.less +33 -0
  5. package/dist/CascaderCluster/index.css +127 -0
  6. package/dist/ComponentUninstalled/index.css +106 -0
  7. package/dist/DataCountPopover/index.css +58 -0
  8. package/dist/DateRangePicker/index.css +180 -0
  9. package/dist/DeleteConfirm/index.css +44 -0
  10. package/dist/DeleteConfirm/index.js +4 -3
  11. package/dist/DeleteConfirm/index.less +8 -0
  12. package/dist/HCCascader/assets/loading-black.gif +0 -0
  13. package/dist/HCCascader/assets/loading-blue.gif +0 -0
  14. package/dist/HCCascader/assets/loading-re.gif +0 -0
  15. package/dist/HCCascader/components/CascaderPanel.d.ts +29 -0
  16. package/dist/HCCascader/components/CascaderPanel.js +236 -0
  17. package/dist/HCCascader/components/InfinityLoading.css +14 -0
  18. package/dist/HCCascader/components/InfinityLoading.d.ts +12 -0
  19. package/dist/HCCascader/components/InfinityLoading.js +39 -0
  20. package/dist/HCCascader/components/InfinityLoading.less +15 -0
  21. package/dist/HCCascader/index.css +6 -0
  22. package/dist/HCCascader/index.d.ts +6 -0
  23. package/dist/HCCascader/index.js +325 -0
  24. package/dist/HCCascader/index.less +12 -0
  25. package/dist/HCCascader/style/index.d.ts +32 -0
  26. package/dist/HCCascader/style/index.js +46 -0
  27. package/dist/HCCascader/types.d.ts +56 -0
  28. package/dist/HCCascader/types.js +1 -0
  29. package/dist/HCCascader/utils.d.ts +22 -0
  30. package/dist/HCCascader/utils.js +229 -0
  31. package/dist/HCDrawer/index.css +23 -0
  32. package/dist/HCModal/index.css +22 -0
  33. package/dist/Icon/index.css +10 -0
  34. package/dist/IconPopTips/index.css +25 -0
  35. package/dist/IconText/index.css +30 -0
  36. package/dist/LogCenter/index.css +434 -0
  37. package/dist/LogCenter/select-with-all.css +72 -0
  38. package/dist/LogicalResourceFilter/index.css +102 -0
  39. package/dist/MetadataCount/index.css +40 -0
  40. package/dist/MetadataForm/index.css +94 -0
  41. package/dist/MetadataPopoverList/index.css +68 -0
  42. package/dist/MetadataTags/index.css +23 -0
  43. package/dist/PageHeader/index.css +78 -0
  44. package/dist/PageHeader/index.less +1 -1
  45. package/dist/ResourceProgress/index.css +73 -0
  46. package/dist/Terminal/index.css +33 -0
  47. package/dist/TextCopy/index.css +35 -0
  48. package/dist/TextEllipsis/index.css +3 -0
  49. package/dist/ThemeForm/index.css +9 -0
  50. package/dist/ThemeSubmit/index.css +21 -0
  51. package/dist/UsageCycle/index.css +47 -0
  52. package/dist/Yaml/index.css +158 -0
  53. package/dist/index.d.ts +5 -0
  54. package/dist/index.js +3 -0
  55. package/dist/umd/index.css +1 -0
  56. package/dist/umd/index.js +329667 -0
  57. package/dist/umd/index.min.css +1 -0
  58. package/dist/umd/index.min.js +1 -0
  59. package/dist/umd/static/back.bc428fe0.png +0 -0
  60. package/dist/umd/static/comp-unintall-bg.3e8d54bb.png +0 -0
  61. package/dist/umd/static/excel.e65df84a.png +0 -0
  62. package/dist/umd/static/folder.ce6450d2.png +0 -0
  63. package/dist/umd/static/jpeg.5bbd1a0a.png +0 -0
  64. package/dist/umd/static/jpg.94ce866e.png +0 -0
  65. package/dist/umd/static/loading-black.95f34d48.gif +0 -0
  66. package/dist/umd/static/loading-blue.dab47538.gif +0 -0
  67. package/dist/umd/static/loading-re.d56cdf97.gif +0 -0
  68. package/dist/umd/static/normal.12136b30.png +0 -0
  69. package/dist/umd/static/png.659e267b.png +0 -0
  70. package/dist/umd/static/tar.5c4ce847.png +0 -0
  71. package/dist/umd/static/text.edd65df9.png +0 -0
  72. package/dist/umd/static/zip.4ebb6070.png +0 -0
  73. package/dist/utils/storage/index.d.ts +11 -0
  74. package/dist/utils/storage/index.js +67 -0
  75. package/dist/utils/tree/index.d.ts +59 -0
  76. package/dist/utils/tree/index.js +375 -0
  77. package/package.json +13 -2
@@ -0,0 +1,180 @@
1
+ .hc-date-range-picker-wrapper {
2
+ position: relative;
3
+ display: inline-block;
4
+ }
5
+ .hc-date-range-picker-wrapper .hc-date-range-picker-input {
6
+ cursor: pointer;
7
+ }
8
+ .hc-date-range-picker-wrapper .hc-date-range-picker-input .ant-input[disabled] {
9
+ color: rgba(0, 0, 0, 0.25);
10
+ background-color: #f5f5f5;
11
+ cursor: not-allowed;
12
+ }
13
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat {
14
+ display: block;
15
+ }
16
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-content {
17
+ display: flex;
18
+ gap: 8px;
19
+ align-items: center;
20
+ }
21
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented {
22
+ position: relative;
23
+ display: inline-flex;
24
+ flex-wrap: nowrap;
25
+ margin: 0;
26
+ border: none;
27
+ border-radius: 4px;
28
+ box-shadow: none;
29
+ }
30
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented::before {
31
+ position: absolute;
32
+ top: var(--hc-date-range-picker-flat-segmented-thumb-top, 3px);
33
+ left: var(--hc-date-range-picker-flat-segmented-thumb-left, 3px);
34
+ z-index: 0;
35
+ width: var(--hc-date-range-picker-flat-segmented-thumb-width, 0);
36
+ height: var(--hc-date-range-picker-flat-segmented-thumb-height, 26px);
37
+ background: var(--ant-color-bg-elevated, #fff);
38
+ border-radius: var(--ant-border-radius-sm, 4px);
39
+ box-shadow: var(--ant-box-shadow-tertiary, 0 1px 10px #00000014);
40
+ opacity: var(--hc-date-range-picker-flat-segmented-thumb-opacity, 0);
41
+ transition: left 0.2s ease, top 0.2s ease, width 0.2s ease, height 0.2s ease, opacity 0.2s ease;
42
+ pointer-events: none;
43
+ content: '';
44
+ }
45
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented .ant-segmented-group {
46
+ position: relative;
47
+ z-index: 1;
48
+ gap: 3px;
49
+ }
50
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented .ant-segmented-item {
51
+ height: 26px;
52
+ padding: 0;
53
+ background: transparent;
54
+ box-shadow: none;
55
+ border-radius: 4px;
56
+ }
57
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented .ant-segmented-item-label {
58
+ min-height: 26px;
59
+ padding: 0 12px;
60
+ line-height: 26px;
61
+ border-radius: 4px;
62
+ }
63
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented .ant-segmented-thumb {
64
+ pointer-events: none;
65
+ opacity: 0;
66
+ }
67
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented .ant-segmented-item-selected,
68
+ .hc-date-range-picker-wrapper.hc-date-range-picker-flat .hc-date-range-picker-flat-segmented .ant-segmented-item-selected:hover {
69
+ background: transparent;
70
+ box-shadow: none;
71
+ }
72
+ .hc-date-range-picker-popover .ant-popover-inner-content {
73
+ padding: 0;
74
+ }
75
+ .hc-date-range-picker-popover .hc-date-range-picker-content {
76
+ min-width: 424px;
77
+ background: #fff;
78
+ }
79
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-header {
80
+ display: flex;
81
+ align-items: center;
82
+ justify-content: space-between;
83
+ height: 55px;
84
+ padding: 0 16px;
85
+ border-bottom: 1px solid #d9d9d9;
86
+ }
87
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-header .hc-date-range-picker-switch {
88
+ display: flex;
89
+ align-items: center;
90
+ font-size: 14px;
91
+ }
92
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-header .hc-date-range-picker-switch span {
93
+ transition: color 0.3s;
94
+ }
95
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-header .hc-date-range-picker-close {
96
+ color: rgba(0, 0, 0, 0.45);
97
+ font-size: 14px;
98
+ cursor: pointer;
99
+ transition: color 0.3s;
100
+ }
101
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-header .hc-date-range-picker-close:hover {
102
+ color: rgba(0, 0, 0, 0.75);
103
+ }
104
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body {
105
+ padding: 0;
106
+ }
107
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body .hc-date-range-picker-recent {
108
+ padding: 16px;
109
+ }
110
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body .hc-date-range-picker-recent .ant-slider {
111
+ margin: 10px 20px 45px;
112
+ }
113
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body .hc-date-range-picker-recent .hc-date-range-picker-footer {
114
+ display: flex;
115
+ justify-content: flex-end;
116
+ margin-top: 16px;
117
+ }
118
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body .hc-date-range-picker-custom .hc-date-range-picker-range {
119
+ width: 100%;
120
+ }
121
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body .hc-date-range-picker-custom .hc-date-range-picker-tip {
122
+ margin-top: 8px;
123
+ color: #ff4d4f;
124
+ font-size: 12px;
125
+ }
126
+ .hc-date-range-picker-popover .hc-date-range-picker-content .hc-date-range-picker-body .hc-date-range-picker-custom .hc-date-range-picker-footer {
127
+ display: flex;
128
+ justify-content: flex-end;
129
+ margin-top: 16px;
130
+ }
131
+ .hc-date-range-picker-custom .rc-calendar {
132
+ border: none;
133
+ box-shadow: none;
134
+ }
135
+ .hc-date-range-picker-custom .rc-calendar-range {
136
+ width: fit-content;
137
+ }
138
+ .hc-date-range-picker-custom .rc-calendar-input-wrap {
139
+ border-top: 1px solid #d9d9d9;
140
+ }
141
+ .hc-date-range-picker-custom .rc-calendar-footer {
142
+ display: flex;
143
+ align-items: center;
144
+ justify-content: flex-end;
145
+ }
146
+ .hc-date-range-picker-custom .rc-calendar-footer .rc-calendar-footer-btn {
147
+ display: flex;
148
+ align-items: center;
149
+ }
150
+ .hc-date-range-picker-custom .rc-calendar-footer .rc-calendar-footer-btn .rc-calendar-ok-btn {
151
+ line-height: 24px;
152
+ text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.12);
153
+ background-color: var(--ant-color-primary, #2869f6);
154
+ border-color: var(--ant-color-primary, #2869f6);
155
+ border-radius: 4px;
156
+ box-shadow: 0 2px 0 rgba(0, 0, 0, 0.045);
157
+ }
158
+ .hc-date-range-picker-custom .rc-calendar-footer .rc-calendar-footer-btn .rc-calendar-ok-btn:hover {
159
+ background: #528eff;
160
+ border-color: #528eff;
161
+ }
162
+ .hc-date-range-picker-custom .rc-calendar-ok-btn {
163
+ height: 24px;
164
+ padding: 0 15px;
165
+ color: #fff;
166
+ font-size: 12px;
167
+ background-color: #1890ff;
168
+ border-color: #1890ff;
169
+ border-radius: 2px;
170
+ }
171
+ .hc-date-range-picker-custom .rc-calendar-ok-btn:hover {
172
+ background-color: #40a9ff;
173
+ border-color: #40a9ff;
174
+ }
175
+ .hc-date-range-picker-custom .rc-calendar-today-btn {
176
+ color: #1890ff;
177
+ }
178
+ .hc-date-range-picker-custom .rc-calendar-today-btn:hover {
179
+ color: #40a9ff;
180
+ }
@@ -0,0 +1,44 @@
1
+ .delete-confirm-popover.ant-popover {
2
+ max-width: 480px;
3
+ }
4
+ .delete-confirm-popover.ant-popover .content {
5
+ display: flex;
6
+ align-items: flex-start;
7
+ margin-bottom: 16px;
8
+ }
9
+ .delete-confirm-popover.ant-popover .content dl,
10
+ .delete-confirm-popover.ant-popover .content dt,
11
+ .delete-confirm-popover.ant-popover .content dd {
12
+ margin: 0;
13
+ padding: 0;
14
+ }
15
+ .delete-confirm-popover.ant-popover .content dl {
16
+ width: calc(100% - 20px);
17
+ }
18
+ .delete-confirm-popover.ant-popover .content dl dt {
19
+ margin-bottom: 8px;
20
+ font-weight: 500;
21
+ }
22
+ .delete-confirm-popover.ant-popover .content .anticon {
23
+ margin: 2px 6px 0 0;
24
+ color: #faad14;
25
+ font-size: 14px;
26
+ }
27
+ .delete-confirm-popover.ant-popover .footer {
28
+ text-align: right;
29
+ }
30
+ .delete-confirm-popover.ant-popover .footer button {
31
+ min-width: 58px;
32
+ margin-left: 12px;
33
+ }
34
+ .delete-confirm-popover.ant-popover .footer button.ant-btn.ant-btn-sm {
35
+ padding: 1.6px 7px;
36
+ }
37
+ .hc-delete-icon-btn .hc-icon {
38
+ font-size: 16px;
39
+ }
40
+ .hc-delete-link-btn.ant-btn.ant-btn-link {
41
+ height: auto;
42
+ padding-inline: 0;
43
+ padding-block: 0;
44
+ }
@@ -47,6 +47,7 @@ var DeleteConfirm = function DeleteConfirm(props) {
47
47
  var common = _objectSpread(_objectSpread({}, deleteConfirmLocaleZhCN.common), antdLocale === null || antdLocale === void 0 ? void 0 : antdLocale.common);
48
48
  var deleteLabel = deleteText !== null && deleteText !== void 0 ? deleteText : common.delete;
49
49
  var cancelLabel = common.cancel;
50
+ var triggerClassName = [type === 'link' ? 'hc-delete-link-btn' : '', isIcon && isDelete ? 'hc-delete-icon-btn' : '', className].filter(Boolean).join(' ');
50
51
  if (disabled) {
51
52
  return /*#__PURE__*/React.createElement(Popover, {
52
53
  placement: placement,
@@ -58,7 +59,7 @@ var DeleteConfirm = function DeleteConfirm(props) {
58
59
  }, /*#__PURE__*/React.createElement(Button, {
59
60
  type: type,
60
61
  danger: danger,
61
- className: className,
62
+ className: triggerClassName,
62
63
  disabled: true
63
64
  }, deleteLabel));
64
65
  }
@@ -93,7 +94,7 @@ var DeleteConfirm = function DeleteConfirm(props) {
93
94
  danger: danger,
94
95
  size: size,
95
96
  ghost: ghost,
96
- className: ['hc-delete-icon-btn', className].filter(Boolean).join(' '),
97
+ className: triggerClassName,
97
98
  icon: /*#__PURE__*/React.createElement(Icon, {
98
99
  name: "v35_TrashCan"
99
100
  })
@@ -102,7 +103,7 @@ var DeleteConfirm = function DeleteConfirm(props) {
102
103
  danger: danger,
103
104
  size: size,
104
105
  ghost: ghost,
105
- className: className
106
+ className: triggerClassName
106
107
  }, deleteLabel));
107
108
  };
108
109
  export { deleteConfirmLocaleZhCN } from "./locale";
@@ -42,3 +42,11 @@
42
42
  font-size: 16px;
43
43
  }
44
44
  }
45
+
46
+ .hc-delete-link-btn {
47
+ &.ant-btn.ant-btn-link {
48
+ height: auto;
49
+ padding-inline: 0;
50
+ padding-block: 0;
51
+ }
52
+ }
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import type { HCCascaderFieldNames, HCCascaderOption, HCCascaderShowSearch } from '../types';
3
+ export interface CascaderPanelProps {
4
+ options: HCCascaderOption[];
5
+ dataLoading: boolean;
6
+ initLoading: boolean;
7
+ loadingPathKey: string | null;
8
+ fieldNames: Required<HCCascaderFieldNames>;
9
+ activeValues: (string | number)[];
10
+ /** 搜索模式下仅用于展开列,不参与高亮 */
11
+ searchExpandValues?: (string | number)[];
12
+ selectedValues: (string | number)[];
13
+ expandTrigger: 'click' | 'hover';
14
+ changeOnSelect?: boolean;
15
+ showSearch?: HCCascaderShowSearch | false;
16
+ searchValue: string;
17
+ onSearchChange: (value: string) => void;
18
+ searchData?: (keyword: string) => Promise<HCCascaderOption[]>;
19
+ onSearchDataLoad?: (options: HCCascaderOption[]) => void;
20
+ onSearchClear?: () => void;
21
+ notFoundContent?: React.ReactNode;
22
+ loadData?: (selectedOptions: HCCascaderOption[]) => Promise<void>;
23
+ onActiveChange: (values: (string | number)[], selectedOptions: HCCascaderOption[]) => void;
24
+ onSelect: (values: (string | number)[], selectedOptions: HCCascaderOption[]) => void;
25
+ dropdownClassName?: string;
26
+ dropdownStyle?: React.CSSProperties;
27
+ }
28
+ declare const CascaderPanel: React.FC<CascaderPanelProps>;
29
+ export default CascaderPanel;
@@ -0,0 +1,236 @@
1
+ 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); }
2
+ 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; }
3
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
4
+ 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); }
5
+ 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 e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
6
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
7
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
8
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
9
+ 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."); }
10
+ 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); }
11
+ 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; }
12
+ 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; } }
13
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
14
+ import { SearchOutlined } from '@ant-design/icons';
15
+ import { Input } from 'antd';
16
+ import classNames from 'classnames';
17
+ import React, { useEffect, useMemo, useRef, useState } from 'react';
18
+ import Icon from "../../Icon";
19
+ import { useHCCascaderStyles } from "../style";
20
+ import { getLoadPathKey, getMenuColumns, getOptionChildren, getOptionId, getOptionLabel, getOptionValue, isLeafOption, ROOT_LOAD_KEY } from "../utils";
21
+ import InfinityLoading from "./InfinityLoading";
22
+ var SEARCH_DEBOUNCE_MS = 300;
23
+ var CascaderPanel = function CascaderPanel(_ref) {
24
+ var _columns$;
25
+ var options = _ref.options,
26
+ dataLoading = _ref.dataLoading,
27
+ initLoading = _ref.initLoading,
28
+ loadingPathKey = _ref.loadingPathKey,
29
+ fieldNames = _ref.fieldNames,
30
+ activeValues = _ref.activeValues,
31
+ _ref$searchExpandValu = _ref.searchExpandValues,
32
+ searchExpandValues = _ref$searchExpandValu === void 0 ? [] : _ref$searchExpandValu,
33
+ selectedValues = _ref.selectedValues,
34
+ expandTrigger = _ref.expandTrigger,
35
+ changeOnSelect = _ref.changeOnSelect,
36
+ showSearch = _ref.showSearch,
37
+ searchValue = _ref.searchValue,
38
+ onSearchChange = _ref.onSearchChange,
39
+ searchData = _ref.searchData,
40
+ onSearchDataLoad = _ref.onSearchDataLoad,
41
+ onSearchClear = _ref.onSearchClear,
42
+ notFoundContent = _ref.notFoundContent,
43
+ loadData = _ref.loadData,
44
+ onActiveChange = _ref.onActiveChange,
45
+ onSelect = _ref.onSelect,
46
+ dropdownClassName = _ref.dropdownClassName,
47
+ dropdownStyle = _ref.dropdownStyle;
48
+ var _useHCCascaderStyles = useHCCascaderStyles({
49
+ size: 'middle'
50
+ }),
51
+ styles = _useHCCascaderStyles.styles;
52
+ var _useState = useState(false),
53
+ _useState2 = _slicedToArray(_useState, 2),
54
+ searchLoading = _useState2[0],
55
+ setSearchLoading = _useState2[1];
56
+ var searchRequestIdRef = useRef(0);
57
+ var searchTimerRef = useRef();
58
+ var hasSearchKeyword = Boolean(showSearch && searchValue.trim());
59
+ var isRemoteSearch = Boolean(searchData && hasSearchKeyword);
60
+ var columnExpandValues = hasSearchKeyword ? searchExpandValues : activeValues;
61
+ var columns = useMemo(function () {
62
+ return getMenuColumns(options, columnExpandValues, fieldNames);
63
+ }, [options, columnExpandValues, fieldNames]);
64
+ useEffect(function () {
65
+ if (!searchData || !showSearch) {
66
+ return undefined;
67
+ }
68
+ clearTimeout(searchTimerRef.current);
69
+ var keyword = searchValue.trim();
70
+ if (!keyword) {
71
+ setSearchLoading(false);
72
+ onSearchClear === null || onSearchClear === void 0 || onSearchClear();
73
+ return undefined;
74
+ }
75
+ searchTimerRef.current = setTimeout(function () {
76
+ var requestId = searchRequestIdRef.current + 1;
77
+ searchRequestIdRef.current = requestId;
78
+ setSearchLoading(true);
79
+ searchData(keyword).then(function (tree) {
80
+ if (searchRequestIdRef.current === requestId) {
81
+ onSearchDataLoad === null || onSearchDataLoad === void 0 || onSearchDataLoad(tree);
82
+ }
83
+ }).finally(function () {
84
+ if (searchRequestIdRef.current === requestId) {
85
+ setSearchLoading(false);
86
+ }
87
+ });
88
+ }, SEARCH_DEBOUNCE_MS);
89
+ return function () {
90
+ clearTimeout(searchTimerRef.current);
91
+ };
92
+ }, [searchValue, searchData, showSearch, onSearchDataLoad, onSearchClear]);
93
+ var getPathOptions = function getPathOptions(columnIndex, option) {
94
+ var pathOptions = [];
95
+ var _loop = function _loop() {
96
+ var column = columns[i];
97
+ var value = columnExpandValues[i];
98
+ var found = column.find(function (item) {
99
+ return String(getOptionValue(item, fieldNames)) === String(value);
100
+ });
101
+ if (found) {
102
+ pathOptions.push(found);
103
+ }
104
+ };
105
+ for (var i = 0; i < columnIndex; i += 1) {
106
+ _loop();
107
+ }
108
+ pathOptions.push(option);
109
+ return pathOptions;
110
+ };
111
+ var handleExpand = /*#__PURE__*/function () {
112
+ var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(columnIndex, option) {
113
+ var pathOptions, pathValues, children;
114
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
115
+ while (1) switch (_context.prev = _context.next) {
116
+ case 0:
117
+ pathOptions = getPathOptions(columnIndex, option);
118
+ pathValues = pathOptions.map(function (item) {
119
+ return getOptionValue(item, fieldNames);
120
+ }).filter(function (item) {
121
+ return item !== undefined;
122
+ });
123
+ onActiveChange(pathValues, pathOptions);
124
+ children = getOptionChildren(option, fieldNames);
125
+ if (!(loadData && !(children !== null && children !== void 0 && children.length) && !option.isLeaf && !option.disabled)) {
126
+ _context.next = 7;
127
+ break;
128
+ }
129
+ _context.next = 7;
130
+ return loadData(pathOptions);
131
+ case 7:
132
+ case "end":
133
+ return _context.stop();
134
+ }
135
+ }, _callee);
136
+ }));
137
+ return function handleExpand(_x, _x2) {
138
+ return _ref2.apply(this, arguments);
139
+ };
140
+ }();
141
+ var handleSelect = function handleSelect(columnIndex, option) {
142
+ var pathOptions = getPathOptions(columnIndex, option);
143
+ var pathValues = pathOptions.map(function (item) {
144
+ return getOptionValue(item, fieldNames);
145
+ }).filter(function (item) {
146
+ return item !== undefined;
147
+ });
148
+ var children = getOptionChildren(option, fieldNames);
149
+ var leaf = isLeafOption(option, fieldNames);
150
+ if (leaf || changeOnSelect) {
151
+ onSelect(pathValues, pathOptions);
152
+ if (!leaf && changeOnSelect) {
153
+ onActiveChange(pathValues, pathOptions);
154
+ }
155
+ return;
156
+ }
157
+ handleExpand(columnIndex, option);
158
+ };
159
+ var renderMenuItem = function renderMenuItem(columnIndex, option) {
160
+ var _ref3;
161
+ var value = getOptionValue(option, fieldNames);
162
+ var label = getOptionLabel(option, fieldNames);
163
+ var optionId = getOptionId(option);
164
+ var children = getOptionChildren(option, fieldNames);
165
+ var hasChildren = Boolean(children === null || children === void 0 ? void 0 : children.length) || loadData && !option.isLeaf;
166
+ var pathOptions = getPathOptions(columnIndex, option);
167
+ var pathKey = getLoadPathKey(pathOptions, fieldNames);
168
+ var isLoadingTarget = dataLoading && loadingPathKey !== null && loadingPathKey !== ROOT_LOAD_KEY && loadingPathKey === pathKey;
169
+ var isInSelectedPath = value !== undefined && columnIndex < selectedValues.length && String(selectedValues[columnIndex]) === String(value);
170
+ var isExpandedActive = !hasSearchKeyword && value !== undefined && String(activeValues[columnIndex]) === String(value);
171
+ return /*#__PURE__*/React.createElement("li", {
172
+ key: String((_ref3 = optionId !== null && optionId !== void 0 ? optionId : value) !== null && _ref3 !== void 0 ? _ref3 : label),
173
+ className: classNames(styles.menuItem, _defineProperty(_defineProperty({}, styles.menuItemActive, isInSelectedPath || isExpandedActive), styles.menuItemDisabled, option.disabled)),
174
+ onClick: function onClick() {
175
+ if (option.disabled) {
176
+ return;
177
+ }
178
+ if (expandTrigger === 'click' && hasChildren && !changeOnSelect) {
179
+ handleExpand(columnIndex, option);
180
+ return;
181
+ }
182
+ handleSelect(columnIndex, option);
183
+ },
184
+ onMouseEnter: function onMouseEnter() {
185
+ if (option.disabled || expandTrigger !== 'hover') {
186
+ return;
187
+ }
188
+ if (hasChildren) {
189
+ handleExpand(columnIndex, option);
190
+ }
191
+ }
192
+ }, /*#__PURE__*/React.createElement("span", null, label), hasChildren ? isLoadingTarget ? /*#__PURE__*/React.createElement(InfinityLoading, {
193
+ size: 12,
194
+ color: "black",
195
+ className: styles.menuItemExpandIcon
196
+ }) : /*#__PURE__*/React.createElement(Icon, {
197
+ name: "v35_ArrowRight",
198
+ className: styles.menuItemExpandIcon
199
+ }) : null);
200
+ };
201
+ var showMenus = columns.length > 0 && ((_columns$ = columns[0]) === null || _columns$ === void 0 ? void 0 : _columns$.length) > 0;
202
+ return /*#__PURE__*/React.createElement("div", {
203
+ className: classNames(styles.dropdown, dropdownClassName),
204
+ style: dropdownStyle
205
+ }, showSearch ? /*#__PURE__*/React.createElement("div", {
206
+ className: styles.search
207
+ }, /*#__PURE__*/React.createElement(Input, {
208
+ variant: "filled",
209
+ prefix: /*#__PURE__*/React.createElement(SearchOutlined, null),
210
+ allowClear: true,
211
+ value: searchValue,
212
+ placeholder: "\u641C\u7D22",
213
+ onChange: function onChange(event) {
214
+ return onSearchChange(event.target.value);
215
+ }
216
+ })) : null, isRemoteSearch && searchLoading || initLoading || dataLoading && loadingPathKey === ROOT_LOAD_KEY ? /*#__PURE__*/React.createElement("div", {
217
+ className: styles.empty
218
+ }, /*#__PURE__*/React.createElement(InfinityLoading, {
219
+ size: 12,
220
+ color: "blue"
221
+ }), /*#__PURE__*/React.createElement("p", {
222
+ className: styles.loadingText
223
+ }, "\u6570\u636E\u52A0\u8F7D\u4E2D...")) : showMenus ? /*#__PURE__*/React.createElement("div", {
224
+ className: styles.menus
225
+ }, columns.map(function (column, columnIndex) {
226
+ return /*#__PURE__*/React.createElement("ul", {
227
+ key: columnIndex,
228
+ className: styles.menu
229
+ }, column.map(function (option) {
230
+ return renderMenuItem(columnIndex, option);
231
+ }));
232
+ })) : /*#__PURE__*/React.createElement("div", {
233
+ className: styles.empty
234
+ }, hasSearchKeyword ? '无匹配数据' : notFoundContent !== null && notFoundContent !== void 0 ? notFoundContent : '暂无数据'));
235
+ };
236
+ export default CascaderPanel;
@@ -0,0 +1,14 @@
1
+ .hc-infinity-loading {
2
+ display: inline-flex;
3
+ flex-shrink: 0;
4
+ align-items: center;
5
+ justify-content: center;
6
+ line-height: 0;
7
+ vertical-align: middle;
8
+ }
9
+ .hc-infinity-loading img {
10
+ display: block;
11
+ width: 100%;
12
+ height: 100%;
13
+ object-fit: contain;
14
+ }
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import './InfinityLoading.less';
3
+ export type InfinityLoadingColor = 'blue' | 'black' | 'red';
4
+ export interface InfinityLoadingProps {
5
+ /** 动画高度,宽度按 2:1 */
6
+ size?: number;
7
+ className?: string;
8
+ style?: React.CSSProperties;
9
+ color?: InfinityLoadingColor;
10
+ }
11
+ declare const InfinityLoading: React.FC<InfinityLoadingProps>;
12
+ export default InfinityLoading;
@@ -0,0 +1,39 @@
1
+ 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); }
2
+ 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; }
3
+ 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; }
4
+ 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; }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
6
+ 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); }
7
+ import classNames from 'classnames';
8
+ import React from 'react';
9
+ import loadingBlueGif from "../assets/loading-blue.gif";
10
+ import loadingBlackGif from "../assets/loading-black.gif";
11
+ import loadingRedGif from "../assets/loading-re.gif";
12
+ import "./InfinityLoading.less";
13
+ var LOADING_GIF = {
14
+ blue: loadingBlueGif,
15
+ black: loadingBlackGif,
16
+ red: loadingRedGif
17
+ };
18
+ var InfinityLoading = function InfinityLoading(_ref) {
19
+ var _ref$size = _ref.size,
20
+ size = _ref$size === void 0 ? 20 : _ref$size,
21
+ className = _ref.className,
22
+ style = _ref.style,
23
+ _ref$color = _ref.color,
24
+ color = _ref$color === void 0 ? 'blue' : _ref$color;
25
+ return /*#__PURE__*/React.createElement("span", {
26
+ className: classNames('hc-infinity-loading', className),
27
+ style: _objectSpread({
28
+ width: size * 2,
29
+ height: size
30
+ }, style),
31
+ "aria-hidden": true,
32
+ role: "presentation"
33
+ }, /*#__PURE__*/React.createElement("img", {
34
+ src: LOADING_GIF[color],
35
+ alt: "",
36
+ draggable: false
37
+ }));
38
+ };
39
+ export default InfinityLoading;
@@ -0,0 +1,15 @@
1
+ .hc-infinity-loading {
2
+ display: inline-flex;
3
+ flex-shrink: 0;
4
+ align-items: center;
5
+ justify-content: center;
6
+ line-height: 0;
7
+ vertical-align: middle;
8
+
9
+ img {
10
+ display: block;
11
+ width: 100%;
12
+ height: 100%;
13
+ object-fit: contain;
14
+ }
15
+ }
@@ -0,0 +1,6 @@
1
+ .hc-cascader-popover .ant-popover-inner {
2
+ padding: 0;
3
+ }
4
+ .hc-cascader {
5
+ width: 100%;
6
+ }
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import './index.less';
3
+ import type { HCCascaderProps } from './types';
4
+ export type { HCCascaderProps, HCCascaderOption, HCCascaderFieldNames } from './types';
5
+ declare const HCCascader: React.FC<HCCascaderProps>;
6
+ export default HCCascader;