@sheinx/base 3.2.0-beta.1 → 3.2.0-beta.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.
- package/cjs/date-picker/time.d.ts.map +1 -1
- package/cjs/date-picker/time.js +9 -2
- package/cjs/icons/config.d.ts +1 -0
- package/cjs/icons/config.d.ts.map +1 -1
- package/cjs/icons/config.js +2 -1
- package/cjs/input/input.type.d.ts +4 -0
- package/cjs/input/input.type.d.ts.map +1 -1
- package/cjs/menu/index.d.ts +2 -0
- package/cjs/menu/index.d.ts.map +1 -1
- package/cjs/menu/index.js +7 -0
- package/cjs/menu/item.d.ts.map +1 -1
- package/cjs/menu/item.js +91 -61
- package/cjs/menu/menu.d.ts.map +1 -1
- package/cjs/menu/menu.js +45 -22
- package/cjs/menu/menu.type.d.ts +25 -16
- package/cjs/menu/menu.type.d.ts.map +1 -1
- package/cjs/menu/search.d.ts +5 -0
- package/cjs/menu/search.d.ts.map +1 -0
- package/cjs/menu/search.js +53 -0
- package/cjs/menu/search.type.d.ts +33 -0
- package/cjs/menu/search.type.d.ts.map +1 -0
- package/cjs/menu/search.type.js +5 -0
- package/cjs/modal/modal-content.js +3 -4
- package/cjs/modal/modal-func.d.ts +1 -1
- package/cjs/modal/modal-func.d.ts.map +1 -1
- package/cjs/modal/modal-func.js +1 -0
- package/cjs/popover/popover.d.ts.map +1 -1
- package/cjs/popover/popover.js +8 -5
- package/cjs/popover/popover.type.d.ts +18 -0
- package/cjs/popover/popover.type.d.ts.map +1 -1
- package/cjs/select/result-input.d.ts.map +1 -1
- package/cjs/select/result-input.js +1 -0
- package/cjs/select/result-input.type.d.ts +1 -0
- package/cjs/select/result-input.type.d.ts.map +1 -1
- package/cjs/select/result-more.d.ts.map +1 -1
- package/cjs/select/result-more.js +19 -12
- package/cjs/select/result.d.ts.map +1 -1
- package/cjs/select/result.js +2 -1
- package/esm/date-picker/time.d.ts.map +1 -1
- package/esm/date-picker/time.js +9 -2
- package/esm/icons/config.d.ts +1 -0
- package/esm/icons/config.d.ts.map +1 -1
- package/esm/icons/config.js +2 -1
- package/esm/input/input.type.d.ts +4 -0
- package/esm/input/input.type.d.ts.map +1 -1
- package/esm/menu/index.d.ts +2 -0
- package/esm/menu/index.d.ts.map +1 -1
- package/esm/menu/index.js +2 -1
- package/esm/menu/item.d.ts.map +1 -1
- package/esm/menu/item.js +94 -63
- package/esm/menu/menu.d.ts.map +1 -1
- package/esm/menu/menu.js +46 -23
- package/esm/menu/menu.type.d.ts +25 -16
- package/esm/menu/menu.type.d.ts.map +1 -1
- package/esm/menu/search.d.ts +5 -0
- package/esm/menu/search.d.ts.map +1 -0
- package/esm/menu/search.js +46 -0
- package/esm/menu/search.type.d.ts +33 -0
- package/esm/menu/search.type.d.ts.map +1 -0
- package/esm/menu/search.type.js +1 -0
- package/esm/modal/modal-content.js +3 -4
- package/esm/modal/modal-func.d.ts +1 -1
- package/esm/modal/modal-func.d.ts.map +1 -1
- package/esm/modal/modal-func.js +1 -0
- package/esm/popover/popover.d.ts.map +1 -1
- package/esm/popover/popover.js +8 -5
- package/esm/popover/popover.type.d.ts +18 -0
- package/esm/popover/popover.type.d.ts.map +1 -1
- package/esm/select/result-input.d.ts.map +1 -1
- package/esm/select/result-input.js +1 -0
- package/esm/select/result-input.type.d.ts +1 -0
- package/esm/select/result-input.type.d.ts.map +1 -1
- package/esm/select/result-more.d.ts.map +1 -1
- package/esm/select/result-more.js +20 -14
- package/esm/select/result.d.ts.map +1 -1
- package/esm/select/result.js +2 -1
- package/package.json +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"time.d.ts","sourceRoot":"","sources":["time.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"time.d.ts","sourceRoot":"","sources":["time.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AA6GxC,QAAA,MAAM,IAAI,UAAW,SAAS,gBA6E7B,CAAC;AAEF,eAAe,IAAI,CAAC"}
|
package/cjs/date-picker/time.js
CHANGED
|
@@ -26,7 +26,8 @@ var TimeScroll = function TimeScroll(props) {
|
|
|
26
26
|
var elRef = (0, _react.useRef)(null);
|
|
27
27
|
var _useRef = (0, _react.useRef)({
|
|
28
28
|
timer: null,
|
|
29
|
-
changeTimer: null
|
|
29
|
+
changeTimer: null,
|
|
30
|
+
controlScroll: false
|
|
30
31
|
}),
|
|
31
32
|
context = _useRef.current;
|
|
32
33
|
var _useResize = (0, _hooks.useResize)({
|
|
@@ -39,11 +40,12 @@ var TimeScroll = function TimeScroll(props) {
|
|
|
39
40
|
var el = elRef.current;
|
|
40
41
|
if (!el) return;
|
|
41
42
|
var lineHeight = el.childNodes[0].clientHeight;
|
|
43
|
+
context.controlScroll = true;
|
|
42
44
|
el.scrollTop = lineHeight * index;
|
|
43
45
|
}, immudiate ? 0 : 30);
|
|
44
46
|
};
|
|
45
47
|
var changeToIndex = function changeToIndex(index) {
|
|
46
|
-
if (!times[index] || times[index].disabled || index === currentIndex) {
|
|
48
|
+
if (!times[index] || times[index].disabled || index === currentIndex && !props.isEmpty) {
|
|
47
49
|
return;
|
|
48
50
|
}
|
|
49
51
|
onChange(times[index].date);
|
|
@@ -51,6 +53,10 @@ var TimeScroll = function TimeScroll(props) {
|
|
|
51
53
|
var handleScroll = function handleScroll(e) {
|
|
52
54
|
if (context.changeTimer) clearTimeout(context.changeTimer);
|
|
53
55
|
var el = e.currentTarget;
|
|
56
|
+
if (context.controlScroll) {
|
|
57
|
+
context.controlScroll = false;
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
54
60
|
context.changeTimer = setTimeout(function () {
|
|
55
61
|
if (!el) return;
|
|
56
62
|
var lineHeight = el.childNodes[0].clientHeight;
|
|
@@ -151,6 +157,7 @@ var Time = function Time(props) {
|
|
|
151
157
|
jssStyle: props.jssStyle,
|
|
152
158
|
times: item.times,
|
|
153
159
|
currentIndex: item.currentIndex,
|
|
160
|
+
isEmpty: props.value === null || props.value === undefined,
|
|
154
161
|
onChange: func.handleChange
|
|
155
162
|
}, item.mode);
|
|
156
163
|
})
|
package/cjs/icons/config.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["config.tsx"],"names":[],"mappings":";AACA,QAAA,MAAM,MAAM
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["config.tsx"],"names":[],"mappings":";AACA,QAAA,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwIX,CAAC;AAEF,KAAK,WAAW,CAAC,CAAC,IAAI;KACnB,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CAC/B,CAAC;AACF,KAAK,cAAc,GAAG,WAAW,CAAC,OAAO,MAAM,CAAC,CAAC;AAGjD,eAAO,MAAM,QAAQ,cAAe,cAAc,SAYjD,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
package/cjs/icons/config.js
CHANGED
|
@@ -73,7 +73,8 @@ var config = {
|
|
|
73
73
|
},
|
|
74
74
|
menu: {
|
|
75
75
|
CollapseArrow: _icons.default.ArrowDown,
|
|
76
|
-
FrontSolidArrowDown: _icons.default.PcArrowFillDown
|
|
76
|
+
FrontSolidArrowDown: _icons.default.PcArrowFillDown,
|
|
77
|
+
Search: _icons.default.Search
|
|
77
78
|
},
|
|
78
79
|
modal: {
|
|
79
80
|
Close: _icons.default === null || _icons.default === void 0 ? void 0 : _icons.default.Close
|
|
@@ -144,6 +144,10 @@ export interface InputCommonProps<V> extends BaseTipProps, Pick<CommonType, 'cla
|
|
|
144
144
|
* @override string
|
|
145
145
|
*/
|
|
146
146
|
defaultValue?: V;
|
|
147
|
+
/**
|
|
148
|
+
* @en The callback before the value is changed, when the return value is not empty, it will be used as the new value of the component
|
|
149
|
+
* @cn 值改变前的回调,当返回值不为空时将作为组件的新值
|
|
150
|
+
*/
|
|
147
151
|
beforeChange?: (value: V) => void | V;
|
|
148
152
|
/**
|
|
149
153
|
* @en Remove content of the input when clicking the clear icon, clear event function
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"input.type.d.ts","sourceRoot":"","sources":["input.type.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"input.type.d.ts","sourceRoot":"","sources":["input.type.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,MAAM,WAAW,YAAY;IAC3B;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,YAAY,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,eAAe,EAAE,MAAM,CAAC;IACxB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,uBAAuB,EAAE,MAAM,CAAC;IAChC,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,eAAe,EAAE,MAAM,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAElB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IAEnB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IAGnB,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,UAAU;IACzB,KAAK,CAAC,EAAE,MAAM,YAAY,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,iBAAiB,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,cAAc,CAAC;CAChC;AAED,MAAM,WAAW,gBACf,SAAQ,cAAc,EACpB,IAAI,CAAC,UAAU,EAAE,QAAQ,GAAG,OAAO,GAAG,WAAW,GAAG,MAAM,CAAC;IAC7D,QAAQ,CAAC,EAAE,UAAU,CAAC;IACtB;;;OAGG;IACH,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC5B;;;OAGG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB;;;OAGG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB;;;;OAIG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB;;;;OAIG;IACH,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB;;;OAGG;IACH,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,CAAC,aAAa,KAAK,IAAI,CAAC;IAC/D;;;OAGG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,WAAW,CAAC,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,YAAY,KAAK,KAAK,CAAC,YAAY,CAAC;IAClE,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,WAAW,gBAAgB,CAAC,CAAC,CAAE,SAAQ,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,WAAW,GAAG,OAAO,CAAC;IAChG,MAAM,CAAC,EAAE,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IACpC;;;OAGG;IACH,GAAG,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB;;;OAGG;IACH,UAAU,CAAC,EAAE,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAC1C;;OAEG;IACH,YAAY,CAAC,EAAE,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAC5C,IAAI,CAAC,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAChC,QAAQ,CAAC,EAAE,gBAAgB,CAAC,UAAU,CAAC,CAAC;IACxC;;;OAGG;IACH,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC7B;;;OAGG;IACH,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC7B;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;;OAGG;IACH,KAAK,CAAC,EAAE,CAAC,CAAC;IACV;;;;OAIG;IACH,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC;IAC9B;;;;OAIG;IACH,YAAY,CAAC,EAAE,CAAC,CAAC;IAChB;;;MAGE;IACH,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC;IACtC;;;;OAIG;IACH,SAAS,CAAC,EAAE,OAAO,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC;IACnC;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB;;;;OAIG;IACH,IAAI,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,GAAG,SAAS,KAAK,MAAM,CAAC,CAAC;IACnD;;;;OAIG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;OAGG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,iBAAiB,CAAC;IACjC,MAAM,CAAC,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;CAC/B;AAED,MAAM,MAAM,cAAc,CAAC,KAAK,EAAE,CAAC,IAAI,IAAI,CACzC,KAAK,EACH,OAAO,GACP,UAAU,GACV,cAAc,GACd,WAAW,GACX,SAAS,GACT,MAAM,GACN,MAAM,GACN,KAAK,GACL,KAAK,GACL,SAAS,GACT,UAAU,GACV,WAAW,GACX,aAAa,GACb,QAAQ,GACR,WAAW,GACX,iBAAiB,GACjB,WAAW,CACd,GACC,gBAAgB,CAAC,CAAC,CAAC,CAAC;AAEtB,MAAM,WAAW,UACf,SAAQ,cAAc,CAAC,gBAAgB,EAAE,MAAM,GAAG,SAAS,CAAC,EAC1D,IAAI,CAAC,gBAAgB,EAAE,OAAO,GAAG,UAAU,GAAG,kBAAkB,CAAC;CAAG"}
|
package/cjs/menu/index.d.ts
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
1
|
export { default, default as Menu } from './menu';
|
|
2
2
|
export type { MenuProps, MenuClasses } from './menu.type';
|
|
3
|
+
export { default as MenuSearch } from './search';
|
|
4
|
+
export type { MenuSearchProps, MenuSearchClasses } from './search.type';
|
|
3
5
|
//# sourceMappingURL=index.d.ts.map
|
package/cjs/menu/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AAClD,YAAY,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AAClD,YAAY,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1D,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,UAAU,CAAC;AACjD,YAAY,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC"}
|
package/cjs/menu/index.js
CHANGED
|
@@ -10,6 +10,12 @@ Object.defineProperty(exports, "Menu", {
|
|
|
10
10
|
return _menu.default;
|
|
11
11
|
}
|
|
12
12
|
});
|
|
13
|
+
Object.defineProperty(exports, "MenuSearch", {
|
|
14
|
+
enumerable: true,
|
|
15
|
+
get: function get() {
|
|
16
|
+
return _search.default;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
13
19
|
Object.defineProperty(exports, "default", {
|
|
14
20
|
enumerable: true,
|
|
15
21
|
get: function get() {
|
|
@@ -17,4 +23,5 @@ Object.defineProperty(exports, "default", {
|
|
|
17
23
|
}
|
|
18
24
|
});
|
|
19
25
|
var _menu = _interopRequireDefault(require("./menu"));
|
|
26
|
+
var _search = _interopRequireDefault(require("./search"));
|
|
20
27
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
package/cjs/menu/item.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"item.d.ts","sourceRoot":"","sources":["item.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"item.d.ts","sourceRoot":"","sources":["item.tsx"],"names":[],"mappings":";AAOA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEjD,QAAA,MAAM,QAAQ,UAAW,mBAAmB,aAAa,CAAC,gBA+NzD,CAAC;AAEF,eAAe,QAAQ,CAAC"}
|
package/cjs/menu/item.js
CHANGED
|
@@ -9,6 +9,7 @@ var _classnames = _interopRequireDefault(require("classnames"));
|
|
|
9
9
|
var _hooks = require("@sheinx/hooks");
|
|
10
10
|
var _icons = _interopRequireDefault(require("../icons"));
|
|
11
11
|
var _config = require("../config");
|
|
12
|
+
var _popover = _interopRequireDefault(require("../../src/popover"));
|
|
12
13
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
13
14
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
14
15
|
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); }
|
|
@@ -21,14 +22,17 @@ var MenuItem = function MenuItem(props) {
|
|
|
21
22
|
var _props$jssStyle, _props$jssStyle$menu;
|
|
22
23
|
var classes = (_props$jssStyle = props.jssStyle) === null || _props$jssStyle === void 0 || (_props$jssStyle$menu = _props$jssStyle.menu) === null || _props$jssStyle$menu === void 0 ? void 0 : _props$jssStyle$menu.call(_props$jssStyle);
|
|
23
24
|
var children = props.dataItem.children || [];
|
|
24
|
-
var itemContentRef = (0, _react.useRef)(null);
|
|
25
|
-
var timer = (0, _react.useRef)(null);
|
|
26
25
|
var _props$inlineIndent = props.inlineIndent,
|
|
27
26
|
inlineIndent = _props$inlineIndent === void 0 ? 24 : _props$inlineIndent,
|
|
28
27
|
_props$frontCaretType = props.frontCaretType,
|
|
29
28
|
frontCaretType = _props$frontCaretType === void 0 ? 'solid' : _props$frontCaretType,
|
|
30
|
-
|
|
29
|
+
mode = props.mode,
|
|
30
|
+
_props$toggleDuration = props.toggleDuration,
|
|
31
|
+
toggleDuration = _props$toggleDuration === void 0 ? 200 : _props$toggleDuration;
|
|
31
32
|
var config = (0, _config.useConfig)();
|
|
33
|
+
var shoudPop = mode === 'vertical' || mode === 'vertical-auto' || mode === 'horizontal';
|
|
34
|
+
var isVertical = mode === 'vertical' || mode === 'vertical-auto';
|
|
35
|
+
var isSubHorizontal = mode === 'horizontal' && props.level > 0;
|
|
32
36
|
var hasExpandAbleChildren = children.some(function (item) {
|
|
33
37
|
return item && item.children && (props.looseChildren || item.children.length);
|
|
34
38
|
});
|
|
@@ -44,7 +48,6 @@ var MenuItem = function MenuItem(props) {
|
|
|
44
48
|
parentId: props.parentId,
|
|
45
49
|
looseChildren: props.looseChildren,
|
|
46
50
|
parentSelectable: props.parentSelectable,
|
|
47
|
-
toggleDuration: props.toggleDuration,
|
|
48
51
|
disabled: props.disabled,
|
|
49
52
|
mode: props.mode,
|
|
50
53
|
scrollRef: props.scrollRef
|
|
@@ -60,41 +63,107 @@ var MenuItem = function MenuItem(props) {
|
|
|
60
63
|
handleItemClick = _useMenuItem.handleItemClick,
|
|
61
64
|
handleMouseEnter = _useMenuItem.handleMouseEnter,
|
|
62
65
|
handleMouseLeave = _useMenuItem.handleMouseLeave;
|
|
66
|
+
var renderChildren = function renderChildren() {
|
|
67
|
+
var _items;
|
|
68
|
+
var items = children;
|
|
69
|
+
var isTitle = false;
|
|
70
|
+
if (!((_items = items) !== null && _items !== void 0 && _items.length)) {
|
|
71
|
+
if (props.level === 0 && props.collapse && shoudPop) {
|
|
72
|
+
items = [props.dataItem];
|
|
73
|
+
isTitle = true;
|
|
74
|
+
} else {
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
var content = function content(close) {
|
|
79
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)("ul", {
|
|
80
|
+
className: (0, _classnames.default)(shoudPop && (classes === null || classes === void 0 ? void 0 : classes.childrenShow), classes === null || classes === void 0 ? void 0 : classes.children, isUp && (classes === null || classes === void 0 ? void 0 : classes.childrenUp), hasExpandAbleChildren && (classes === null || classes === void 0 ? void 0 : classes.childrenHasExpand))
|
|
81
|
+
// 子菜单点击弹出
|
|
82
|
+
,
|
|
83
|
+
onClick: close,
|
|
84
|
+
dir: config.direction,
|
|
85
|
+
children: items.map(function (item, index) {
|
|
86
|
+
var key = _hooks.util.getKey(props.keygen, item, index);
|
|
87
|
+
return /*#__PURE__*/(0, _react.createElement)(MenuItem, _objectSpread(_objectSpread({}, props), {}, {
|
|
88
|
+
mode: mode,
|
|
89
|
+
parentId: id,
|
|
90
|
+
dataItem: item,
|
|
91
|
+
key: key,
|
|
92
|
+
index: index,
|
|
93
|
+
keyResult: key,
|
|
94
|
+
level: props.level + 1,
|
|
95
|
+
renderIcon: isTitle ? undefined : props.renderIcon
|
|
96
|
+
}));
|
|
97
|
+
})
|
|
98
|
+
});
|
|
99
|
+
};
|
|
100
|
+
if (shoudPop) {
|
|
101
|
+
var position = isVertical || isSubHorizontal ? isUp ? 'right-bottom' : 'right-top' : 'bottom';
|
|
102
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_popover.default, {
|
|
103
|
+
mouseLeaveDelay: toggleDuration,
|
|
104
|
+
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.popover),
|
|
105
|
+
attributes: _hooks.util.getDataAttribute({
|
|
106
|
+
theme: props.theme || 'light',
|
|
107
|
+
mode: isVertical ? 'vertical' : mode
|
|
108
|
+
}),
|
|
109
|
+
jssStyle: props.jssStyle,
|
|
110
|
+
arrowClass: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.popArrow, props.theme === 'dark' && (classes === null || classes === void 0 ? void 0 : classes.popArrowDark)),
|
|
111
|
+
position: position,
|
|
112
|
+
lazy: false,
|
|
113
|
+
children: function children(close) {
|
|
114
|
+
return content(close);
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
return content();
|
|
119
|
+
};
|
|
63
120
|
var renderItem = function renderItem() {
|
|
121
|
+
var icon = _hooks.util.isFunc(props.renderIcon) ? props.renderIcon(props.dataItem) : null;
|
|
122
|
+
var iconEl = icon ? /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
123
|
+
className: classes === null || classes === void 0 ? void 0 : classes.titleIcon,
|
|
124
|
+
children: icon
|
|
125
|
+
}) : null;
|
|
126
|
+
var indent = props.mode === 'inline' && props.level ? /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
127
|
+
style: {
|
|
128
|
+
width: props.level * inlineIndent,
|
|
129
|
+
flexShrink: 0
|
|
130
|
+
}
|
|
131
|
+
}) : null;
|
|
64
132
|
var item = _hooks.util.render(props.renderItem, props.dataItem, props.index);
|
|
65
133
|
var link = props.linkKey ? _hooks.util.getKey(props.linkKey, props.dataItem, props.index) : undefined;
|
|
66
134
|
var title = null;
|
|
67
135
|
if (_hooks.util.isLink(item)) {
|
|
68
136
|
var mergeClass = (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.title, item.props && item.props.className);
|
|
69
137
|
title = /*#__PURE__*/(0, _react.cloneElement)(item, {
|
|
70
|
-
className: mergeClass
|
|
138
|
+
className: mergeClass,
|
|
139
|
+
children: /*#__PURE__*/(0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
140
|
+
children: [indent, iconEl, /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
141
|
+
className: classes === null || classes === void 0 ? void 0 : classes.titleContent,
|
|
142
|
+
children: item.props.children
|
|
143
|
+
})]
|
|
144
|
+
})
|
|
71
145
|
});
|
|
72
146
|
} else {
|
|
73
147
|
var linkProps = {
|
|
74
148
|
className: classes === null || classes === void 0 ? void 0 : classes.title,
|
|
75
149
|
href: link
|
|
76
150
|
};
|
|
77
|
-
title = /*#__PURE__*/(0, _jsxRuntime.
|
|
78
|
-
children:
|
|
151
|
+
title = /*#__PURE__*/(0, _jsxRuntime.jsxs)("a", _objectSpread(_objectSpread({}, linkProps), {}, {
|
|
152
|
+
children: [indent, iconEl, /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
153
|
+
className: classes === null || classes === void 0 ? void 0 : classes.titleContent,
|
|
154
|
+
children: _hooks.util.wrapSpan(item)
|
|
155
|
+
})]
|
|
79
156
|
}));
|
|
80
157
|
}
|
|
81
|
-
var indent = props.mode === 'inline' && props.level ? /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
82
|
-
style: {
|
|
83
|
-
width: props.level * inlineIndent,
|
|
84
|
-
flexShrink: 0
|
|
85
|
-
}
|
|
86
|
-
}) : null;
|
|
87
|
-
var isFirstCollapseItem = collapse && props.level === 0;
|
|
88
158
|
if (props.frontCaret) {
|
|
89
159
|
return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
|
|
90
|
-
|
|
91
|
-
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.itemContent, classes === null || classes === void 0 ? void 0 : classes.itemContentFront, isFirstCollapseItem && (classes === null || classes === void 0 ? void 0 : classes.itemContentHide)),
|
|
160
|
+
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.itemContent, classes === null || classes === void 0 ? void 0 : classes.itemContentFront),
|
|
92
161
|
onClick: handleItemClick,
|
|
93
|
-
children: [
|
|
162
|
+
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
94
163
|
style: {
|
|
95
164
|
color: props.caretColor
|
|
96
165
|
},
|
|
97
|
-
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.expand, classes === null || classes === void 0 ? void 0 : classes.expandFront, props.parentSelectable && (classes === null || classes === void 0 ? void 0 : classes.expandHover)),
|
|
166
|
+
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.expand, classes === null || classes === void 0 ? void 0 : classes.expandFront, (isVertical || isSubHorizontal) && (classes === null || classes === void 0 ? void 0 : classes.expandVertical), props.parentSelectable && (classes === null || classes === void 0 ? void 0 : classes.expandHover)),
|
|
98
167
|
onClick: handleExpandClick,
|
|
99
168
|
dir: config.direction,
|
|
100
169
|
children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
@@ -105,15 +174,14 @@ var MenuItem = function MenuItem(props) {
|
|
|
105
174
|
});
|
|
106
175
|
} else {
|
|
107
176
|
return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
|
|
108
|
-
|
|
109
|
-
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.itemContent, classes === null || classes === void 0 ? void 0 : classes.itemContentBack, isFirstCollapseItem && (classes === null || classes === void 0 ? void 0 : classes.itemContentHide)),
|
|
177
|
+
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.itemContent, classes === null || classes === void 0 ? void 0 : classes.itemContentBack),
|
|
110
178
|
onClick: handleItemClick,
|
|
111
|
-
children: [
|
|
179
|
+
children: [title, expandAble && /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
112
180
|
onClick: handleExpandClick,
|
|
113
181
|
style: {
|
|
114
182
|
color: props.caretColor
|
|
115
183
|
},
|
|
116
|
-
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.expand, classes === null || classes === void 0 ? void 0 : classes.expandBack, props.parentSelectable && (classes === null || classes === void 0 ? void 0 : classes.expandHover)),
|
|
184
|
+
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.expand, classes === null || classes === void 0 ? void 0 : classes.expandBack, (isVertical || isSubHorizontal) && (classes === null || classes === void 0 ? void 0 : classes.expandVertical), props.parentSelectable && (classes === null || classes === void 0 ? void 0 : classes.expandHover)),
|
|
117
185
|
dir: config.direction,
|
|
118
186
|
children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
119
187
|
className: classes === null || classes === void 0 ? void 0 : classes.icon,
|
|
@@ -123,50 +191,12 @@ var MenuItem = function MenuItem(props) {
|
|
|
123
191
|
});
|
|
124
192
|
}
|
|
125
193
|
};
|
|
126
|
-
var renderCollapseItem = function renderCollapseItem() {
|
|
127
|
-
if (!props.renderCollapse) return null;
|
|
128
|
-
var isFirstCollapseItem = props.level === 0 && collapse;
|
|
129
|
-
return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
130
|
-
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.collapseItem, isInPath && (classes === null || classes === void 0 ? void 0 : classes.collapseItemInPath), !isFirstCollapseItem && (classes === null || classes === void 0 ? void 0 : classes.collapseItemHide)),
|
|
131
|
-
onClick: handleItemClick,
|
|
132
|
-
children: props.renderCollapse(props.dataItem, props.index)
|
|
133
|
-
});
|
|
134
|
-
};
|
|
135
|
-
(0, _react.useEffect)(function () {
|
|
136
|
-
if (!itemContentRef.current) return;
|
|
137
|
-
if (collapse === undefined) return;
|
|
138
|
-
if (timer.current) clearTimeout(timer.current);
|
|
139
|
-
itemContentRef.current.style.overflow = 'hidden';
|
|
140
|
-
itemContentRef.current.style.whiteSpace = 'nowrap';
|
|
141
|
-
timer.current = setTimeout(function () {
|
|
142
|
-
if (!itemContentRef.current) return;
|
|
143
|
-
itemContentRef.current.style.overflow = '';
|
|
144
|
-
itemContentRef.current.style.whiteSpace = '';
|
|
145
|
-
}, 300);
|
|
146
|
-
return function () {
|
|
147
|
-
if (timer.current) clearTimeout(timer.current);
|
|
148
|
-
};
|
|
149
|
-
}, [collapse]);
|
|
150
194
|
return /*#__PURE__*/(0, _jsxRuntime.jsxs)("li", {
|
|
151
195
|
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.item, isDisabled && (classes === null || classes === void 0 ? void 0 : classes.itemDisabled), isInPath && (classes === null || classes === void 0 ? void 0 : classes.itemInPath), isOpen && (classes === null || classes === void 0 ? void 0 : classes.itemOpen), isChecked && (classes === null || classes === void 0 ? void 0 : classes.itemActive), expandAble && (classes === null || classes === void 0 ? void 0 : classes.itemHasChildren)),
|
|
152
196
|
onMouseEnter: handleMouseEnter,
|
|
153
197
|
onMouseLeave: handleMouseLeave,
|
|
154
198
|
dir: config.direction,
|
|
155
|
-
children: [renderItem(),
|
|
156
|
-
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.children, isUp && (classes === null || classes === void 0 ? void 0 : classes.childrenUp), hasExpandAbleChildren && (classes === null || classes === void 0 ? void 0 : classes.childrenHasExpand)),
|
|
157
|
-
dir: config.direction,
|
|
158
|
-
children: children.map(function (item, index) {
|
|
159
|
-
var key = _hooks.util.getKey(props.keygen, item, index);
|
|
160
|
-
return /*#__PURE__*/(0, _react.createElement)(MenuItem, _objectSpread(_objectSpread({}, props), {}, {
|
|
161
|
-
parentId: id,
|
|
162
|
-
dataItem: item,
|
|
163
|
-
key: key,
|
|
164
|
-
index: index,
|
|
165
|
-
keyResult: key,
|
|
166
|
-
level: props.level + 1
|
|
167
|
-
}));
|
|
168
|
-
})
|
|
169
|
-
})]
|
|
199
|
+
children: [renderItem(), renderChildren()]
|
|
170
200
|
});
|
|
171
201
|
};
|
|
172
202
|
var _default = exports.default = MenuItem;
|
package/cjs/menu/menu.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["menu.tsx"],"names":[],"mappings":";AAMA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAGlD,QAAA,MAAM,IAAI,
|
|
1
|
+
{"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["menu.tsx"],"names":[],"mappings":";AAMA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAGlD,QAAA,MAAM,IAAI,sFAqIT,CAAC;AAEF,eAAe,IAAI,CAAC"}
|
package/cjs/menu/menu.js
CHANGED
|
@@ -25,7 +25,7 @@ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" !=
|
|
|
25
25
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
26
26
|
var emptyArray = [];
|
|
27
27
|
var Menu = function Menu(props) {
|
|
28
|
-
var _props$jssStyle, _props$jssStyle$menu
|
|
28
|
+
var _props$jssStyle, _props$jssStyle$menu;
|
|
29
29
|
var _props$data = props.data,
|
|
30
30
|
data = _props$data === void 0 ? emptyArray : _props$data,
|
|
31
31
|
_props$mode = props.mode,
|
|
@@ -33,7 +33,19 @@ var Menu = function Menu(props) {
|
|
|
33
33
|
_props$theme = props.theme,
|
|
34
34
|
theme = _props$theme === void 0 ? 'light' : _props$theme,
|
|
35
35
|
collapse = props.collapse;
|
|
36
|
-
var
|
|
36
|
+
var render = (0, _hooks.useRender)();
|
|
37
|
+
|
|
38
|
+
// const [inTransition, setInTransition] = useState(false);
|
|
39
|
+
var mode = collapse ? 'vertical-auto' : modeProps;
|
|
40
|
+
var _useRef = (0, _react.useRef)({
|
|
41
|
+
inTransition: false,
|
|
42
|
+
lastCollapse: !!props.collapse
|
|
43
|
+
}),
|
|
44
|
+
context = _useRef.current;
|
|
45
|
+
if (props.mode !== 'horizontal' && !!context.lastCollapse !== !!collapse) {
|
|
46
|
+
context.inTransition = true;
|
|
47
|
+
context.lastCollapse = !!props.collapse;
|
|
48
|
+
}
|
|
37
49
|
var classes = (_props$jssStyle = props.jssStyle) === null || _props$jssStyle === void 0 || (_props$jssStyle$menu = _props$jssStyle.menu) === null || _props$jssStyle$menu === void 0 ? void 0 : _props$jssStyle$menu.call(_props$jssStyle);
|
|
38
50
|
var isVertical = mode === 'vertical' || mode === 'vertical-auto';
|
|
39
51
|
var isHorizontal = mode === 'horizontal';
|
|
@@ -41,16 +53,12 @@ var Menu = function Menu(props) {
|
|
|
41
53
|
_useState2 = _slicedToArray(_useState, 2),
|
|
42
54
|
hasOpen = _useState2[0],
|
|
43
55
|
setHasOpen = _useState2[1];
|
|
44
|
-
var _useState3 = (0, _react.useState)([]),
|
|
45
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
46
|
-
collapseOpenKeys = _useState4[0],
|
|
47
|
-
setCollapseOpenKeys = _useState4[1];
|
|
48
56
|
var _useMenu = (0, _hooks.useMenu)({
|
|
49
57
|
data: data,
|
|
50
58
|
active: props.active,
|
|
51
59
|
defaultOpenKeys: props.defaultOpenKeys,
|
|
52
|
-
openKeys: props.
|
|
53
|
-
onOpenChange: props.
|
|
60
|
+
openKeys: props.openKeys,
|
|
61
|
+
onOpenChange: props.onOpenChange
|
|
54
62
|
}),
|
|
55
63
|
openKeys = _useMenu.openKeys,
|
|
56
64
|
onOpenChange = _useMenu.onOpenChange,
|
|
@@ -62,11 +70,16 @@ var Menu = function Menu(props) {
|
|
|
62
70
|
return item && item.children && (props.looseChildren || item.children.length);
|
|
63
71
|
});
|
|
64
72
|
var showScrollBar = isHorizontal || isVertical;
|
|
65
|
-
var
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
73
|
+
var renderHeader = function renderHeader() {
|
|
74
|
+
if (modeProps === 'horizontal') return;
|
|
75
|
+
if (props.header) {
|
|
76
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
77
|
+
className: classes === null || classes === void 0 ? void 0 : classes.header,
|
|
78
|
+
children: props.header
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
return null;
|
|
82
|
+
};
|
|
70
83
|
(0, _react.useEffect)(function () {
|
|
71
84
|
var newOpen = (openKeys || []).filter(function (k) {
|
|
72
85
|
return data.find(function (d, i) {
|
|
@@ -77,24 +90,32 @@ var Menu = function Menu(props) {
|
|
|
77
90
|
setHasOpen(newOpen);
|
|
78
91
|
}
|
|
79
92
|
}, [data, openKeys]);
|
|
80
|
-
return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
|
|
81
|
-
className: (0, _classnames.default)(props.className, classes === null || classes === void 0 ? void 0 : classes.wrapper, mode === 'inline' && (classes === null || classes === void 0 ? void 0 : classes.wrapperInline), (mode === 'vertical' || mode === 'vertical-auto') && (classes === null || classes === void 0 ? void 0 : classes.wrapperVertical), mode === 'horizontal' && (classes === null || classes === void 0 ? void 0 : classes.wrapperHorizontal), hasOpen && (classes === null || classes === void 0 ? void 0 : classes.wrapperHasOpen), theme === 'dark' ? classes === null || classes === void 0 ? void 0 : classes.wrapperDark : classes === null || classes === void 0 ? void 0 : classes.wrapperLight, collapse && (classes === null || classes === void 0 ? void 0 : classes.
|
|
93
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", _objectSpread(_objectSpread({
|
|
94
|
+
className: (0, _classnames.default)(props.className, classes === null || classes === void 0 ? void 0 : classes.wrapper, mode === 'inline' && (classes === null || classes === void 0 ? void 0 : classes.wrapperInline), (mode === 'vertical' || mode === 'vertical-auto') && (classes === null || classes === void 0 ? void 0 : classes.wrapperVertical), mode === 'horizontal' && (classes === null || classes === void 0 ? void 0 : classes.wrapperHorizontal), hasOpen && (classes === null || classes === void 0 ? void 0 : classes.wrapperHasOpen), theme === 'dark' ? classes === null || classes === void 0 ? void 0 : classes.wrapperDark : classes === null || classes === void 0 ? void 0 : classes.wrapperLight, collapse && (classes === null || classes === void 0 ? void 0 : classes.wrapperCollpase), context.inTransition && (classes === null || classes === void 0 ? void 0 : classes.wrapperInTransition))
|
|
95
|
+
}, _hooks.util.getDataAttribute({
|
|
96
|
+
theme: theme,
|
|
97
|
+
mode: isVertical ? 'vertical' : mode
|
|
98
|
+
})), {}, {
|
|
82
99
|
style: _objectSpread({
|
|
83
100
|
height: props.height
|
|
84
|
-
}, style),
|
|
85
|
-
|
|
101
|
+
}, props.style),
|
|
102
|
+
onTransitionEnd: function onTransitionEnd(e) {
|
|
103
|
+
if (e.target === e.currentTarget) {
|
|
104
|
+
context.inTransition = false;
|
|
105
|
+
render();
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
children: [renderHeader(), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
|
86
109
|
className: classes === null || classes === void 0 ? void 0 : classes.scrollbox,
|
|
87
110
|
ref: scrollRef,
|
|
88
111
|
children: /*#__PURE__*/(0, _jsxRuntime.jsx)("ul", {
|
|
89
112
|
className: (0, _classnames.default)(classes === null || classes === void 0 ? void 0 : classes.root, hasExpand && (classes === null || classes === void 0 ? void 0 : classes.childrenHasExpand)),
|
|
90
|
-
style: listStyle,
|
|
91
113
|
children: data.map(function (item, index) {
|
|
92
114
|
var key = _hooks.util.getKey(props.keygen, item, index);
|
|
93
115
|
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_item.default, {
|
|
94
116
|
level: 0,
|
|
95
117
|
index: index,
|
|
96
118
|
parentId: "",
|
|
97
|
-
collapse: collapse,
|
|
98
119
|
dataItem: item,
|
|
99
120
|
keyResult: key,
|
|
100
121
|
openKeys: openKeys,
|
|
@@ -109,7 +130,6 @@ var Menu = function Menu(props) {
|
|
|
109
130
|
toggleDuration: props.toggleDuration,
|
|
110
131
|
disabled: props.disabled,
|
|
111
132
|
renderItem: props.renderItem,
|
|
112
|
-
renderCollapse: props.renderCollapse,
|
|
113
133
|
keygen: props.keygen,
|
|
114
134
|
jssStyle: props.jssStyle,
|
|
115
135
|
linkKey: props.linkKey,
|
|
@@ -117,7 +137,10 @@ var Menu = function Menu(props) {
|
|
|
117
137
|
frontCaretType: props.frontCaretType,
|
|
118
138
|
caretColor: props.caretColor,
|
|
119
139
|
inlineIndent: props.inlineIndent,
|
|
120
|
-
scrollRef: scrollRef
|
|
140
|
+
scrollRef: scrollRef,
|
|
141
|
+
theme: theme,
|
|
142
|
+
renderIcon: props.renderIcon,
|
|
143
|
+
collapse: collapse
|
|
121
144
|
}, key);
|
|
122
145
|
})
|
|
123
146
|
})
|
|
@@ -127,6 +150,6 @@ var Menu = function Menu(props) {
|
|
|
127
150
|
data: data,
|
|
128
151
|
jssStyle: props.jssStyle
|
|
129
152
|
})]
|
|
130
|
-
});
|
|
153
|
+
}));
|
|
131
154
|
};
|
|
132
155
|
var _default = exports.default = Menu;
|
package/cjs/menu/menu.type.d.ts
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
import type { UseMenuItemProps } from '@sheinx/hooks';
|
|
3
3
|
import { KeygenResult, KeygenType, ObjectKey } from '@sheinx/hooks';
|
|
4
4
|
import { CommonType } from '../common/type';
|
|
5
|
+
import { PopoverJssStyle } from '../popover/popover.type';
|
|
5
6
|
export type MenuMode = 'inline' | 'vertical' | 'horizontal' | 'vertical-auto';
|
|
6
7
|
export interface MenuClasses {
|
|
7
8
|
wrapper: string;
|
|
@@ -11,28 +12,30 @@ export interface MenuClasses {
|
|
|
11
12
|
wrapperHasOpen: string;
|
|
12
13
|
wrapperLight: string;
|
|
13
14
|
wrapperDark: string;
|
|
14
|
-
|
|
15
|
+
wrapperCollpase: string;
|
|
16
|
+
wrapperInTransition: string;
|
|
17
|
+
header: string;
|
|
15
18
|
root: string;
|
|
16
19
|
children: string;
|
|
20
|
+
childrenShow: string;
|
|
17
21
|
childrenUp: string;
|
|
18
22
|
item: string;
|
|
19
|
-
collapseItem: string;
|
|
20
|
-
collapseItemInPath: string;
|
|
21
|
-
collapseItemHide: string;
|
|
22
23
|
itemActive: string;
|
|
23
24
|
itemDisabled: string;
|
|
24
25
|
itemOpen: string;
|
|
25
26
|
itemInPath: string;
|
|
26
27
|
itemHasChildren: string;
|
|
27
28
|
itemContent: string;
|
|
28
|
-
itemContentHide: string;
|
|
29
29
|
itemContentFront: string;
|
|
30
30
|
itemContentBack: string;
|
|
31
31
|
title: string;
|
|
32
|
+
titleIcon: string;
|
|
33
|
+
titleContent: string;
|
|
32
34
|
expand: string;
|
|
33
35
|
expandFront: string;
|
|
34
36
|
expandBack: string;
|
|
35
37
|
expandHover: string;
|
|
38
|
+
expandVertical: string;
|
|
36
39
|
scrollbar: string;
|
|
37
40
|
scrollbarX: string;
|
|
38
41
|
scrollbarY: string;
|
|
@@ -41,10 +44,13 @@ export interface MenuClasses {
|
|
|
41
44
|
scrollbox: string;
|
|
42
45
|
icon: string;
|
|
43
46
|
childrenHasExpand: string;
|
|
47
|
+
popover?: string;
|
|
48
|
+
popArrow?: string;
|
|
49
|
+
popArrowDark?: string;
|
|
44
50
|
}
|
|
45
|
-
export
|
|
51
|
+
export interface MenuJssStyle extends PopoverJssStyle {
|
|
46
52
|
menu?: () => MenuClasses;
|
|
47
|
-
}
|
|
53
|
+
}
|
|
48
54
|
/**
|
|
49
55
|
* @title Menu
|
|
50
56
|
*/
|
|
@@ -67,7 +73,7 @@ export interface MenuProps<DataItem, Key extends KeygenResult = KeygenResult> ex
|
|
|
67
73
|
* @en theme of menu
|
|
68
74
|
* @cn 主题
|
|
69
75
|
*/
|
|
70
|
-
theme?: 'dark';
|
|
76
|
+
theme?: 'dark' | 'light';
|
|
71
77
|
/**
|
|
72
78
|
* @en menu height
|
|
73
79
|
* @cn 菜单高度
|
|
@@ -164,22 +170,25 @@ export interface MenuProps<DataItem, Key extends KeygenResult = KeygenResult> ex
|
|
|
164
170
|
*/
|
|
165
171
|
renderItem?: ((data: DataItem, index: number) => React.ReactNode) | ObjectKey<DataItem>;
|
|
166
172
|
/**
|
|
167
|
-
* @
|
|
168
|
-
* @
|
|
173
|
+
* @cn 渲染Icon
|
|
174
|
+
* @en Render Icon
|
|
175
|
+
*/
|
|
176
|
+
renderIcon?: (data: DataItem) => React.ReactNode;
|
|
177
|
+
/**
|
|
178
|
+
* @cn 是否折叠
|
|
179
|
+
* @en Whether to collapse
|
|
169
180
|
* @default false
|
|
170
181
|
*/
|
|
171
182
|
collapse?: boolean;
|
|
172
183
|
/**
|
|
173
|
-
*
|
|
174
|
-
* @cn 折叠时的渲染方式,如果为字符串,则会以对应的值作为显示内容;如果为函数,则以函数返回的结果作为显示内容,函数参数为对应的数据对象
|
|
175
|
-
* @en Element render mode when collapsed. If it is a string, the corresponding value is taken as the display content; If it is a function, the result returned by the function is taken as the display content.
|
|
176
|
-
* @default null
|
|
184
|
+
* @cn 头部内容, 仅在 mode为 'inline' 时生效
|
|
177
185
|
*/
|
|
178
|
-
|
|
186
|
+
header?: React.ReactNode;
|
|
179
187
|
}
|
|
180
|
-
export interface MenuItemProps extends UseMenuItemProps, Pick<MenuProps<any, any>, 'renderItem' | 'keygen' | 'linkKey' | 'frontCaret' | 'frontCaretType' | 'caretColor' | 'jssStyle' | 'inlineIndent' | '
|
|
188
|
+
export interface MenuItemProps extends UseMenuItemProps, Pick<MenuProps<any, any>, 'renderItem' | 'keygen' | 'linkKey' | 'frontCaret' | 'frontCaretType' | 'caretColor' | 'jssStyle' | 'inlineIndent' | 'theme' | 'renderIcon'> {
|
|
181
189
|
index: number;
|
|
182
190
|
level: number;
|
|
183
191
|
scrollRef: React.MutableRefObject<HTMLDivElement | null>;
|
|
192
|
+
collapse?: boolean;
|
|
184
193
|
}
|
|
185
194
|
//# sourceMappingURL=menu.type.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu.type.d.ts","sourceRoot":"","sources":["menu.type.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"menu.type.d.ts","sourceRoot":"","sources":["menu.type.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["search.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAKhD,QAAA,MAAM,MAAM,UAAW,eAAe,gBAmCrC,CAAC;AAEF,eAAe,MAAM,CAAC"}
|