@kdcloudjs/kdesign 1.7.15 → 1.7.17

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 (80) hide show
  1. package/CHANGELOG.md +54 -0
  2. package/dist/kdesign-complete.less +27 -3
  3. package/dist/kdesign.css +21 -3
  4. package/dist/kdesign.css.map +1 -1
  5. package/dist/kdesign.js +137 -95
  6. package/dist/kdesign.js.map +1 -1
  7. package/dist/kdesign.min.css +3 -3
  8. package/dist/kdesign.min.js +3 -3
  9. package/dist/kdesign.min.js.map +1 -1
  10. package/es/button/group.d.ts +1 -0
  11. package/es/button/group.js +6 -3
  12. package/es/card/card.d.ts +1 -0
  13. package/es/card/card.js +30 -19
  14. package/es/carousel/carousel.js +3 -2
  15. package/es/carousel/slideList.d.ts +1 -0
  16. package/es/carousel/slideList.js +5 -2
  17. package/es/color-picker/color-picker-panel.js +4 -4
  18. package/es/color-picker/color-picker.js +4 -2
  19. package/es/color-picker/interface.d.ts +1 -0
  20. package/es/color-picker/style/index.css +4 -1
  21. package/es/color-picker/style/index.less +5 -1
  22. package/es/config-provider/compDefaultProps.d.ts +1 -0
  23. package/es/config-provider/compDefaultProps.js +1 -0
  24. package/es/dropdown/dropdown.js +7 -4
  25. package/es/dropdown/style/index.css +3 -0
  26. package/es/dropdown/style/index.less +4 -0
  27. package/es/filter/scheme.js +2 -1
  28. package/es/filter/style/index.css +2 -1
  29. package/es/filter/style/index.less +3 -2
  30. package/es/form/Field.js +1 -1
  31. package/es/input-number/inputNumber.js +1 -1
  32. package/es/locale/locale.d.ts +3 -4
  33. package/es/locale/zh-CN.js +8 -8
  34. package/es/notification/index.js +2 -1
  35. package/es/notification-base/index.js +11 -8
  36. package/es/select/select.js +8 -8
  37. package/es/select/style/index.css +7 -0
  38. package/es/select/style/index.less +11 -0
  39. package/es/tree-select/interface.d.ts +1 -0
  40. package/es/tree-select/tree-select.js +4 -3
  41. package/es/upload/interface.d.ts +1 -0
  42. package/es/upload/style/index.css +4 -0
  43. package/es/upload/style/index.less +4 -0
  44. package/es/upload/upload.js +16 -6
  45. package/lib/button/group.d.ts +1 -0
  46. package/lib/button/group.js +6 -3
  47. package/lib/card/card.d.ts +1 -0
  48. package/lib/card/card.js +30 -19
  49. package/lib/carousel/carousel.js +3 -2
  50. package/lib/carousel/slideList.d.ts +1 -0
  51. package/lib/carousel/slideList.js +5 -2
  52. package/lib/color-picker/color-picker-panel.js +4 -4
  53. package/lib/color-picker/color-picker.js +4 -2
  54. package/lib/color-picker/interface.d.ts +1 -0
  55. package/lib/color-picker/style/index.css +4 -1
  56. package/lib/color-picker/style/index.less +5 -1
  57. package/lib/config-provider/compDefaultProps.d.ts +1 -0
  58. package/lib/config-provider/compDefaultProps.js +1 -0
  59. package/lib/dropdown/dropdown.js +7 -4
  60. package/lib/dropdown/style/index.css +3 -0
  61. package/lib/dropdown/style/index.less +4 -0
  62. package/lib/filter/scheme.js +2 -1
  63. package/lib/filter/style/index.css +2 -1
  64. package/lib/filter/style/index.less +3 -2
  65. package/lib/form/Field.js +1 -1
  66. package/lib/input-number/inputNumber.js +1 -1
  67. package/lib/locale/locale.d.ts +3 -4
  68. package/lib/locale/zh-CN.js +8 -8
  69. package/lib/notification/index.js +2 -1
  70. package/lib/notification-base/index.js +11 -8
  71. package/lib/select/select.js +8 -8
  72. package/lib/select/style/index.css +7 -0
  73. package/lib/select/style/index.less +11 -0
  74. package/lib/tree-select/interface.d.ts +1 -0
  75. package/lib/tree-select/tree-select.js +4 -3
  76. package/lib/upload/interface.d.ts +1 -0
  77. package/lib/upload/style/index.css +4 -0
  78. package/lib/upload/style/index.less +4 -0
  79. package/lib/upload/upload.js +16 -6
  80. package/package.json +1 -1
@@ -21,15 +21,15 @@ var locale = (0, _extends2.default)((0, _extends2.default)({
21
21
  'Progress.success': '加载成功',
22
22
  'Pagination.prevPage': '上一页',
23
23
  'Pagination.nextPage': '下一页',
24
- 'Pagination.total': '共{page}页{row}条',
25
- 'Pagination.page': '共{page}页',
26
- 'Pagination.row': '共{row}条',
24
+ 'Pagination.total': '共 {page} {row}条',
25
+ 'Pagination.page': '共 {page} 页',
26
+ 'Pagination.row': '共 {row} 条',
27
27
  'Pagination.first': '第一页',
28
28
  'Pagination.last': '最后一页',
29
- 'Pagination.perPage': '{size}条/页',
30
- 'Pagination.order': '第{order}页',
31
- 'Pagination.forward': '向前5页',
32
- 'Pagination.backward': '向后5页',
29
+ 'Pagination.perPage': '{size} 条/页',
30
+ 'Pagination.order': '第 {order} 页',
31
+ 'Pagination.forward': '向前 5 页',
32
+ 'Pagination.backward': '向后 5 页',
33
33
  'Transfer.selectAll': '全选',
34
34
  'Transfer.searchPlaceholder': ['请输入需要搜索的内容', '请输入需要搜索的内容'],
35
35
  'Transfer.leftTitle': '可选列表',
@@ -49,7 +49,7 @@ var locale = (0, _extends2.default)((0, _extends2.default)({
49
49
  'CityPicker.internation': '国际',
50
50
  'CityPicker.common': '常用',
51
51
  'CityPicker.noData': '暂无数据',
52
- 'ColorPicker.followFunctionalColor': '跟随主题色',
52
+ 'ColorPicker.followFunctionalColor': '跟随功能色',
53
53
  'Search.placeholder': '请输入需要搜索的内容',
54
54
  'Search.desc': ['空格代表"或",回车代表"且"'],
55
55
  'Search.nplDesc': '智能搜索',
@@ -136,7 +136,8 @@ var Notification = {
136
136
  },
137
137
  destroy: function destroy(key) {
138
138
  _notificationBase.default.destroy(key);
139
- }
139
+ },
140
+ displayName: 'Notification'
140
141
  };
141
142
  var _default = Notification;
142
143
  exports.default = _default;
@@ -55,14 +55,17 @@ var NotificationApi = {
55
55
  destroy: function destroy(key) {
56
56
  if (key) {
57
57
  (0, _keys.default)(notificationInstance).forEach(function (placement) {
58
- var instance = notificationInstance[placement].instance;
59
- var notices = instance.notices;
60
- if (Array.isArray(notices) && notices.length) {
61
- var flag = notices.some(function (notice) {
62
- return notice.key === key;
63
- });
64
- if (flag) {
65
- instance.remove(key);
58
+ var _a;
59
+ var instance = (_a = notificationInstance[placement]) === null || _a === void 0 ? void 0 : _a.instance;
60
+ if (instance) {
61
+ var notices = instance.notices;
62
+ if (Array.isArray(notices) && notices.length) {
63
+ var flag = notices.some(function (notice) {
64
+ return notice.key === key;
65
+ });
66
+ if (flag) {
67
+ instance.remove(key);
68
+ }
66
69
  }
67
70
  }
68
71
  });
@@ -120,6 +120,9 @@ var InternalSelect = function InternalSelect(props, ref) {
120
120
  _useState12 = (0, _slicedToArray2.default)(_useState11, 2),
121
121
  focusd = _useState12[0],
122
122
  setFocusd = _useState12[1];
123
+ var isShowSearch = (0, _react.useMemo)(function () {
124
+ return (0, _isBoolean.default)(showSearch) ? showSearch : isMultiple;
125
+ }, [isMultiple, showSearch]);
123
126
  var selectPrefixCls = getPrefixCls(prefixCls, 'select', customPrefixcls);
124
127
  // 选择器样式
125
128
  var selectCls = (0, _classnames.default)(selectPrefixCls, className, (0, _defineProperty2.default)({}, "".concat(selectPrefixCls, "-visible"), optionShow));
@@ -131,7 +134,7 @@ var InternalSelect = function InternalSelect(props, ref) {
131
134
  // 多选底部样式
132
135
  var multipleFooterCls = (0, _classnames.default)((0, _defineProperty2.default)({}, "".concat(selectPrefixCls, "-multiple-footer"), true));
133
136
  // 多选,单选公共样式
134
- var commCls = (0, _classnames.default)((_classNames6 = {}, (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-bordered"), borderType === 'bordered'), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-underline"), borderType === 'underline'), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-borderless"), borderType === 'none'), (0, _defineProperty2.default)(_classNames6, (0, _concat.default)(_context = "".concat(selectPrefixCls, "-size-")).call(_context, size), size), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-wrapper"), true), _classNames6));
137
+ var commCls = (0, _classnames.default)((_classNames6 = {}, (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-bordered"), borderType === 'bordered'), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-underline"), borderType === 'underline'), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-borderless"), borderType === 'none'), (0, _defineProperty2.default)(_classNames6, (0, _concat.default)(_context = "".concat(selectPrefixCls, "-size-")).call(_context, size), size), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-wrapper"), true), (0, _defineProperty2.default)(_classNames6, "".concat(selectPrefixCls, "-show-search"), isShowSearch), _classNames6));
135
138
  (0, _react.useEffect)(function () {
136
139
  if (typeof props.visible !== 'undefined') {
137
140
  setOptionShow(props.visible);
@@ -319,7 +322,7 @@ var InternalSelect = function InternalSelect(props, ref) {
319
322
  }
320
323
  } else {
321
324
  props.visible === undefined && setOptionShow(false);
322
- onChange && onChange(labelInValue ? {
325
+ initValue !== key && onChange && onChange(labelInValue ? {
323
326
  value: key,
324
327
  label: label
325
328
  } : key, (0, _extends2.default)((0, _extends2.default)({}, optionsObj), {
@@ -335,7 +338,7 @@ var InternalSelect = function InternalSelect(props, ref) {
335
338
  multipleRef.current.selectedVal = key;
336
339
  setInitValue(key);
337
340
  props.visible === undefined && setOptionShow(false);
338
- onChange && onChange(labelInValue ? {
341
+ initValue !== key && onChange && onChange(labelInValue ? {
339
342
  value: key,
340
343
  label: label
341
344
  } : key, (0, _extends2.default)((0, _extends2.default)({}, optionsObj), {
@@ -512,9 +515,6 @@ var InternalSelect = function InternalSelect(props, ref) {
512
515
  className: emptyListCls
513
516
  }, emptyContent);
514
517
  };
515
- var isShowSearch = (0, _react.useMemo)(function () {
516
- return (0, _isBoolean.default)(showSearch) ? showSearch : isMultiple;
517
- }, [isMultiple, showSearch]);
518
518
  (0, _react.useEffect)(function () {
519
519
  var _a;
520
520
  if (isShowSearch && autoFocus && !disabled) {
@@ -570,7 +570,7 @@ var InternalSelect = function InternalSelect(props, ref) {
570
570
  className: dropDownCls,
571
571
  style: dropDownStyle,
572
572
  ref: dropDownRef
573
- }, !dropdownRender && childrenToRender.length > 0 && dropRender(eleOptionList, heightStyle), renderNotContent(), /*#__PURE__*/_react.default.createElement("div", null, dropdownRender && dropdownRender(dropRender(childrenToRender, heightStyle))), isMultiple && /*#__PURE__*/_react.default.createElement("div", {
573
+ }, !dropdownRender && childrenToRender.length > 0 && dropRender(eleOptionList, heightStyle), renderNotContent(), /*#__PURE__*/_react.default.createElement("div", null, dropdownRender && dropdownRender(dropRender(childrenToRender, heightStyle))), isMultiple && realChildren.length > 0 && /*#__PURE__*/_react.default.createElement("div", {
574
574
  className: multipleFooterCls
575
575
  }, /*#__PURE__*/_react.default.createElement(_index.Checkbox, {
576
576
  style: checkboxStyle,
@@ -579,7 +579,7 @@ var InternalSelect = function InternalSelect(props, ref) {
579
579
  onChange: handleSelectAll
580
580
  }, "\u5168\u9009"), /*#__PURE__*/_react.default.createElement("span", {
581
581
  className: "".concat(selectPrefixCls, "-multiple-footer-hadSelected")
582
- }, "\u5DF2\u9009", /*#__PURE__*/_react.default.createElement("span", null, isMultiple ? selectedVal.length : 0), "\u9879"))));
582
+ }, "\u5DF2\u9009", /*#__PURE__*/_react.default.createElement("span", null, selectedVal.length), "\u9879"))));
583
583
  };
584
584
  // 处理多选tag
585
585
  var handleMaxTagHolder = (0, _react.useCallback)(function () {
@@ -350,6 +350,12 @@
350
350
  overflow-x: hidden;
351
351
  position: relative;
352
352
  }
353
+ .kd-select-show-search {
354
+ cursor: text;
355
+ }
356
+ .kd-select-show-search.kd-select-single .kd-select-selection-search .kd-select-selection-search-input {
357
+ cursor: text;
358
+ }
353
359
  .kd-select-dropdown {
354
360
  display: block;
355
361
  left: 0;
@@ -471,6 +477,7 @@
471
477
  background: transparent;
472
478
  height: 100%;
473
479
  width: 100%;
480
+ cursor: pointer;
474
481
  }
475
482
  .kd-select .kd-select-single .kd-select-selection-item {
476
483
  display: inline-block;
@@ -120,6 +120,16 @@
120
120
  position: relative;
121
121
  }
122
122
 
123
+ &-show-search {
124
+ cursor: text;
125
+
126
+ &.@{select-prefix-cls}-single .@{select-prefix-cls}-selection-search {
127
+ .@{select-prefix-cls}-selection-search-input {
128
+ cursor: text;
129
+ }
130
+ }
131
+ }
132
+
123
133
  &-dropdown {
124
134
  display: block;
125
135
  left: 0;
@@ -232,6 +242,7 @@
232
242
  background: transparent;
233
243
  height: 100%;
234
244
  width: 100%;
245
+ cursor: pointer;
235
246
  }
236
247
  }
237
248
  &-item {
@@ -55,6 +55,7 @@ export interface ITreeSelectProps<T extends TreeSelectValue> extends AbstractSel
55
55
  defaultValue?: T;
56
56
  mode?: Mode;
57
57
  autoFocus?: boolean;
58
+ onlyExpandOnClickIcon?: boolean;
58
59
  onChange?: (value: T, treeNode: TreeNodeData) => void;
59
60
  onSelect?: (value: T extends (infer I)[] ? I : T, { checked, node, event }: any) => void;
60
61
  onBlur?: (value?: T) => void;
@@ -107,7 +107,8 @@ var InternalTreeSelect = function InternalTreeSelect(props, ref) {
107
107
  onTreeExpand = treeSelectProps.onTreeExpand,
108
108
  onSelect = treeSelectProps.onSelect,
109
109
  onCheck = treeSelectProps.onCheck,
110
- dropdownRender = treeSelectProps.dropdownRender;
110
+ dropdownRender = treeSelectProps.dropdownRender,
111
+ onlyExpandOnClickIcon = treeSelectProps.onlyExpandOnClickIcon;
111
112
  var isMultiple = mode === 'multiple'; // 是否多选
112
113
  var _useMergedState = (0, _hooks.useMergedState)(isMultiple ? [] : undefined, {
113
114
  value: value,
@@ -322,7 +323,7 @@ var InternalTreeSelect = function InternalTreeSelect(props, ref) {
322
323
  icon: treeIcon,
323
324
  showIcon: showTreeIcon,
324
325
  switcherIcon: switcherIcon,
325
- onlyExpandOnClickIcon: true,
326
+ onlyExpandOnClickIcon: onlyExpandOnClickIcon,
326
327
  notFoundContent: renderNotContent(),
327
328
  filterTreeNode: defFilterTreeNode,
328
329
  onSelect: handleSelect,
@@ -506,7 +507,7 @@ var InternalTreeSelect = function InternalTreeSelect(props, ref) {
506
507
  }
507
508
  };
508
509
  var popperProps = (0, _extends2.default)((0, _extends2.default)({}, treeSelectProps), {
509
- prefixCls: selectPrefixCls,
510
+ prefixCls: "".concat(selectPrefixCls, "-panel"),
510
511
  placement: 'bottomLeft',
511
512
  popperStyle: catchStyle(),
512
513
  defaultVisible: optionShow,
@@ -146,6 +146,7 @@ export interface IFileItem {
146
146
  prefixCls: string;
147
147
  listType: string;
148
148
  disabled: boolean;
149
+ onPreview?: (file: UploadFile) => void;
149
150
  handleReUpload: (file: UploadFile, e: React.MouseEvent) => void;
150
151
  handleRemove: (file: UploadFile, e: React.MouseEvent) => void;
151
152
  }
@@ -217,6 +217,10 @@
217
217
  .kd-upload .kd-upload-text-list-item-icon > i {
218
218
  font-size: var(--kd-c-upload-font-size, var(--kd-g-font-size-middle, 14px));
219
219
  }
220
+ .kd-upload .kd-upload-text-list-item-name,
221
+ .kd-upload .kd-upload-text-list-item-icon {
222
+ cursor: pointer;
223
+ }
220
224
  .kd-upload .kd-upload-text-list-item-name {
221
225
  display: inline-block;
222
226
  margin: 0 var(--kd-c-upload-text-list-item-name-padding-right, 8px) 0 var(--kd-c-upload-text-list-item-name-padding-left, 4px);
@@ -94,6 +94,10 @@
94
94
  font-size: @upload-font-size;
95
95
  }
96
96
 
97
+ &-name,&-icon {
98
+ cursor: pointer;
99
+ }
100
+
97
101
  &-name {
98
102
  display: inline-block;
99
103
  margin: 0 @upload-text-list-item-name-padding-right 0 @upload-text-list-item-name-padding-left;
@@ -104,7 +104,8 @@ var InternalUpload = function InternalUpload(props, ref) {
104
104
  className = allProps.className,
105
105
  itemRender = allProps.itemRender,
106
106
  showUploadList = allProps.showUploadList,
107
- customPrefixcls = allProps.prefixCls;
107
+ customPrefixcls = allProps.prefixCls,
108
+ onPreview = allProps.onPreview;
108
109
  var _React$useState = _react.default.useState(props.fileList || props.defaultFileList || []),
109
110
  _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
110
111
  fileList = _React$useState2[0],
@@ -411,7 +412,8 @@ var InternalUpload = function InternalUpload(props, ref) {
411
412
  listType: listType,
412
413
  handleReUpload: handleReUpload,
413
414
  handleRemove: handleRemove,
414
- disabled: disabled
415
+ disabled: disabled,
416
+ onPreview: onPreview
415
417
  })), file, setFileList) : /*#__PURE__*/_react.default.createElement(Item, (0, _extends2.default)({
416
418
  key: file.uid
417
419
  }, {
@@ -420,7 +422,8 @@ var InternalUpload = function InternalUpload(props, ref) {
420
422
  listType: listType,
421
423
  handleReUpload: handleReUpload,
422
424
  handleRemove: handleRemove,
423
- disabled: disabled
425
+ disabled: disabled,
426
+ onPreview: onPreview
424
427
  }));
425
428
  })));
426
429
  };
@@ -431,7 +434,8 @@ var Item = function Item(_ref3) {
431
434
  listType = _ref3.listType,
432
435
  handleReUpload = _ref3.handleReUpload,
433
436
  handleRemove = _ref3.handleRemove,
434
- disabled = _ref3.disabled;
437
+ disabled = _ref3.disabled,
438
+ onPreview = _ref3.onPreview;
435
439
  var mapStatus = {
436
440
  uploading: 'loadding',
437
441
  error: 'warning-solid',
@@ -439,18 +443,23 @@ var Item = function Item(_ref3) {
439
443
  success: 'attachment',
440
444
  notStart: 'attachment'
441
445
  };
446
+ var handlePreview = function handlePreview() {
447
+ onPreview && onPreview(file);
448
+ };
442
449
  return /*#__PURE__*/_react.default.createElement("li", {
443
450
  className: (0, _classnames.default)((0, _concat.default)(_context8 = "".concat(prefixCls, "-")).call(_context8, listType, "-list-item"), {
444
451
  error: file.status === 'error'
445
452
  })
446
453
  }, listType === 'text' ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
447
- className: (0, _concat.default)(_context9 = "".concat(prefixCls, "-")).call(_context9, listType, "-list-item-icon")
454
+ className: (0, _concat.default)(_context9 = "".concat(prefixCls, "-")).call(_context9, listType, "-list-item-icon"),
455
+ onClick: handlePreview
448
456
  }, /*#__PURE__*/_react.default.createElement(_icon.default, {
449
457
  spin: file.status === 'uploading',
450
458
  type: mapStatus[file.status]
451
459
  })), /*#__PURE__*/_react.default.createElement("span", {
452
460
  className: (0, _concat.default)(_context10 = "".concat(prefixCls, "-")).call(_context10, listType, "-list-item-name"),
453
- title: file.name
461
+ title: file.name,
462
+ onClick: handlePreview
454
463
  }, file.name), /*#__PURE__*/_react.default.createElement("span", {
455
464
  className: (0, _concat.default)(_context11 = "".concat(prefixCls, "-")).call(_context11, listType, "-list-item-size")
456
465
  }, "(", (0, _utils2.getFileSize)(file.size), ")"), /*#__PURE__*/_react.default.createElement("div", {
@@ -489,6 +498,7 @@ var Item = function Item(_ref3) {
489
498
  className: (0, _concat.default)(_context20 = "".concat(prefixCls, "-")).call(_context20, listType, "-list-item-delete"),
490
499
  onClick: handleRemove.bind(_this, file)
491
500
  }, "\u5220\u9664"))) : /*#__PURE__*/_react.default.createElement(_image.default, {
501
+ onClick: handlePreview,
492
502
  previewType: "upload",
493
503
  name: file.name,
494
504
  size: (0, _utils2.getFileSize)(file.size),
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kdcloudjs/kdesign",
3
- "version": "1.7.15",
3
+ "version": "1.7.17",
4
4
  "description": "KDesign 金蝶前端react 组件库",
5
5
  "title": "kdesign",
6
6
  "keywords": [