linkmore-design 1.1.4 → 1.1.6

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 (66) hide show
  1. package/dist/ImageViewer/LmImageViewer.d.ts +8 -0
  2. package/dist/ImageViewer/index.d.ts +1 -0
  3. package/dist/LmEditTable/util.d.ts +6 -0
  4. package/dist/LmFilter/filterFns/index.d.ts +1 -0
  5. package/dist/LmUpload/fns/index.d.ts +1 -1
  6. package/dist/index.d.ts +2 -0
  7. package/dist/index.umd.css +93 -93
  8. package/dist/index.umd.js +845 -161
  9. package/dist/index.umd.min.css +1 -1
  10. package/dist/index.umd.min.js +7 -7
  11. package/dist/variables.css +22 -8
  12. package/es/Button/index.js +4 -1
  13. package/es/Button/style/index.css +0 -4
  14. package/es/Button/style/variables.css +0 -4
  15. package/es/CardTable/style/index.css +19 -4
  16. package/es/CardTable/style/variables.css +19 -4
  17. package/es/ImageViewer/LmImageViewer.d.ts +8 -0
  18. package/es/ImageViewer/index.d.ts +1 -0
  19. package/es/ImageViewer/index.js +1 -0
  20. package/es/Input/index.js +3 -3
  21. package/es/LmEditTable/EditTable.js +189 -116
  22. package/es/LmEditTable/style/index.css +3 -0
  23. package/es/LmEditTable/style/variables.css +3 -0
  24. package/es/LmEditTable/util.d.ts +6 -0
  25. package/es/LmEditTable/util.js +29 -1
  26. package/es/LmFilter/clearFilter/index.js +3 -1
  27. package/es/LmFilter/components/EmptyFilter.js +2 -2
  28. package/es/LmFilter/filterFns/index.d.ts +1 -0
  29. package/es/LmFilter/filterFns/index.js +6 -1
  30. package/es/LmFilter/wrapper/FilterRoot.js +1 -1
  31. package/es/LmTable/Table.js +1 -1
  32. package/es/LmUpload/LmUpload.js +1 -0
  33. package/es/LmUpload/fns/index.d.ts +1 -1
  34. package/es/LmUpload/fns/index.js +105 -33
  35. package/es/index.d.ts +2 -0
  36. package/es/index.js +2 -1
  37. package/es/message/index.js +4 -1
  38. package/es/styles/variables.css +22 -8
  39. package/lib/Button/index.js +6 -1
  40. package/lib/Button/style/index.css +0 -4
  41. package/lib/Button/style/variables.css +0 -4
  42. package/lib/CardTable/style/index.css +19 -4
  43. package/lib/CardTable/style/variables.css +19 -4
  44. package/lib/ImageViewer/LmImageViewer.d.ts +8 -0
  45. package/lib/ImageViewer/index.d.ts +1 -0
  46. package/lib/ImageViewer/index.js +14 -2
  47. package/lib/Input/index.js +3 -3
  48. package/lib/LmEditTable/EditTable.js +188 -115
  49. package/lib/LmEditTable/style/index.css +3 -0
  50. package/lib/LmEditTable/style/variables.css +3 -0
  51. package/lib/LmEditTable/util.d.ts +6 -0
  52. package/lib/LmEditTable/util.js +40 -1
  53. package/lib/LmFilter/clearFilter/index.js +3 -1
  54. package/lib/LmFilter/components/EmptyFilter.js +2 -2
  55. package/lib/LmFilter/filterFns/index.d.ts +1 -0
  56. package/lib/LmFilter/filterFns/index.js +6 -1
  57. package/lib/LmFilter/wrapper/FilterRoot.js +1 -1
  58. package/lib/LmTable/Table.js +1 -1
  59. package/lib/LmUpload/LmUpload.js +1 -0
  60. package/lib/LmUpload/fns/index.d.ts +1 -1
  61. package/lib/LmUpload/fns/index.js +105 -31
  62. package/lib/index.d.ts +2 -0
  63. package/lib/index.js +11 -2
  64. package/lib/message/index.js +6 -1
  65. package/lib/styles/variables.css +22 -8
  66. package/package.json +1 -1
package/dist/index.umd.js CHANGED
@@ -12219,7 +12219,8 @@
12219
12219
  messageInstance$1 = null;
12220
12220
  }
12221
12221
  }
12222
- }
12222
+ },
12223
+ antdMessage: api
12223
12224
  };
12224
12225
  function attachTypeApi$1(originalApi, type) {
12225
12226
  originalApi[type] = function (content, duration, onClose) {
@@ -14955,7 +14956,10 @@
14955
14956
  hover = _props$hover === void 0 ? false : _props$hover,
14956
14957
  restProps = _objectWithoutProperties$1(props, _excluded$a);
14957
14958
 
14958
- var size = customizeSize || React__default['default'].useContext(SizeContext$1) || 'middle'; // const { getPrefixCls, autoInsertSpaceInButton, direction } = React.useContext(ConfigContext);
14959
+ var globalSize = customizeSize || React__default['default'].useContext(SizeContext$1) || 'middle';
14960
+ var size = React__default['default'].useMemo(function () {
14961
+ return globalSize === 'default' ? 'middle' : globalSize;
14962
+ }, [globalSize]); // const { getPrefixCls, autoInsertSpaceInButton, direction } = React.useContext(ConfigContext);
14959
14963
 
14960
14964
  var classs = classnames('lm-button', className, {
14961
14965
  'lm-button-icon-only': !children
@@ -89886,13 +89890,13 @@
89886
89890
  })));
89887
89891
  };
89888
89892
 
89889
- var imgEmpty = "";
89893
+ var emptyBase64 = "";
89890
89894
 
89891
89895
  var EmptyFilter = function EmptyFilter() {
89892
89896
  return /*#__PURE__*/React__default['default'].createElement("div", {
89893
89897
  className: "filter_empty"
89894
89898
  }, /*#__PURE__*/React__default['default'].createElement("img", {
89895
- src: imgEmpty,
89899
+ src: emptyBase64,
89896
89900
  alt: "empty",
89897
89901
  width: 81
89898
89902
  }), /*#__PURE__*/React__default['default'].createElement("div", {
@@ -92488,7 +92492,9 @@
92488
92492
 
92489
92493
  var LmFilterClear = /*#__PURE__*/React__default['default'].memo(function (_ref) {
92490
92494
  var instance = _ref.instance;
92491
- var onClearChange = instance.onClearChange;
92495
+ var onClearChange = instance.onClearChange,
92496
+ getHasFilter = instance.getHasFilter;
92497
+ if (!getHasFilter()) return null;
92492
92498
 
92493
92499
  var handleClear = function handleClear() {
92494
92500
  onClearChange();
@@ -92702,7 +92708,11 @@
92702
92708
  searchKey = props.searchKey,
92703
92709
  searchConfig = props.searchConfig,
92704
92710
  customOptions = props.customOptions,
92705
- enableAutoString = props.enableAutoString; // 转换一级查询结构 object => array
92711
+ enableAutoString = props.enableAutoString; // 获取是否存在过滤值
92712
+
92713
+ var getHasFilter = React.useCallback(function () {
92714
+ return getIsHas(state.basicFilter) || getIsHas(state.searchFilter);
92715
+ }, [state.basicFilter, state.searchFilter]); // 转换一级查询结构 object => array
92706
92716
 
92707
92717
  var tranformGlobalQuery = React.useCallback(function (obj) {
92708
92718
  var _Object$keys3;
@@ -93164,6 +93174,7 @@
93164
93174
  },
93165
93175
  getFilterValue: getFilterValue,
93166
93176
  getFilterQuery: getFilterQuery,
93177
+ getHasFilter: getHasFilter,
93167
93178
  setFilterValue: setFilterValue,
93168
93179
  setFilterFieldValue: setFilterFieldValue,
93169
93180
  setLocalization: setLocalization,
@@ -93287,7 +93298,7 @@
93287
93298
  basicFilter = _initLocalization.basicFilter,
93288
93299
  basicQuery = _initLocalization.basicQuery,
93289
93300
  customQuery = _initLocalization.customQuery,
93290
- customFilter = _initLocalization.customFilter; // 字段对应关系 basicQuery => filterQuery; customQuery => globalQuery; searchQuery => fuzzyQuery
93301
+ customFilter = _initLocalization.customFilter; // 字段对应关系 basicQuery => filterQuery; customQuery => globalQuery; searchQuery => fuzzyQuery
93291
93302
 
93292
93303
 
93293
93304
  return {
@@ -181313,6 +181324,8 @@
181313
181324
  onChange = props.onChange,
181314
181325
  type = props.type,
181315
181326
  fileSize = props.fileSize,
181327
+ fileSizeType = props.fileSizeType,
181328
+ fileAreaSize = props.fileAreaSize,
181316
181329
  enabledOss = props.enabledOss,
181317
181330
  enableCrop = props.enableCrop,
181318
181331
  ossConfig = props.ossConfig; // 获取当前的文件列表
@@ -181499,12 +181512,12 @@
181499
181512
  value: getFileList(),
181500
181513
  onChange: uploadSuccess
181501
181514
  });
181502
- }, [props.fileUpload, getFileList, uploadSuccess]); // 上传文件
181515
+ }, [props.fileUpload, getFileList, uploadSuccess]); // 调用上传方法: 执行 uploadOss && customUpload事件
181503
181516
 
181504
181517
  var uploadFile = React.useCallback(function (file) {
181505
181518
  enabledOss && uploadOss(file);
181506
181519
  customUpload(file);
181507
- }, [enabledOss, uploadOss, customUpload]); // 检测完成 file
181520
+ }, [enabledOss, uploadOss, customUpload]); // 检测完成, 执行外部 `beforeUpload` 事件
181508
181521
 
181509
181522
  var checkOver = React.useCallback( /*#__PURE__*/function () {
181510
181523
  var _ref5 = _asyncToGenerator$1( /*#__PURE__*/_regeneratorRuntime$1().mark(function _callee2(file) {
@@ -181570,53 +181583,128 @@
181570
181583
  return function (_x2) {
181571
181584
  return _ref5.apply(this, arguments);
181572
181585
  };
181573
- }(), [props.beforeUpload, getFileList, uploadFile]); // 上传前的检测
181586
+ }(), [props.beforeUpload, getFileList, uploadFile]); // 单个文件异步校验
181574
181587
 
181575
- var beforeUpload = React.useCallback(function (e) {
181576
- var files = e.target.files; // 循环文件检查是否存在不符合要求的文件
181588
+ var fileCheckAsync = React.useCallback(function (file) {
181589
+ return new Promise(function (resolve, reject) {
181590
+ // 文件类型校验是否通过 | 存在通配符或符合规定类型
181591
+ var isCheckType = type.includes('*') || type.includes(file.name.replace(/.*\./, '').toLowerCase()); // 大小校验是否通过
181577
181592
 
181578
- for (var i = 0, len = files.length; i < len; i += 1) {
181579
- var item = files[i];
181593
+ var isCheckSize = file.size / 1024 / (fileSizeType.toLowerCase().includes('m') ? 1024 : 1) <= fileSize;
181580
181594
 
181581
- if (!type.includes(item.name.replace(/.*\./, '').toLowerCase())) {
181595
+ if (!isCheckType) {
181582
181596
  var content = type.join('、');
181583
- return api$2.warning("\u6587\u4EF6\u4E0A\u4F20\u5931\u8D25\uFF01\u4EC5\u652F\u6301".concat(content, "\u7684\u6587\u4EF6\u7C7B\u578B\uFF01"), 1.5);
181597
+ reject(new Error("\u6587\u4EF6\u4E0A\u4F20\u5931\u8D25\uFF01\u4EC5\u652F\u6301".concat(content, "\u7684\u6587\u4EF6\u7C7B\u578B\uFF01")));
181584
181598
  }
181585
181599
 
181586
- if (item.size / 1024 / 1024 > fileSize) {
181587
- return api$2.warning("\u6587\u4EF6\u4E0A\u4F20\u5931\u8D25\uFF01\u9644\u4EF6\u5927\u5C0F\u4E0D\u80FD\u8D85\u8FC7".concat(fileSize, "M\uFF01"), 1.5);
181588
- } // 可剪裁时单独处理文件
181600
+ if (!isCheckSize) {
181601
+ reject(new Error("\u6587\u4EF6\u4E0A\u4F20\u5931\u8D25\uFF01\u9644\u4EF6\u5927\u5C0F\u4E0D\u80FD\u8D85\u8FC7".concat(fileSize).concat(fileSizeType, "\uFF01")));
181602
+ } // 是否需要校验图片宽高
181589
181603
 
181590
181604
 
181591
- if (enableCrop) {
181592
- dispatch({
181593
- type: 'changeCropFile',
181594
- cropFile: item
181595
- });
181605
+ if (fileAreaSize) {
181606
+ var reader = new FileReader();
181607
+ reader.readAsDataURL(file);
181608
+
181609
+ reader.onload = function (evt) {
181610
+ var res = evt.target.result;
181611
+ var imageObj = new Image();
181612
+ imageObj.src = res;
181613
+
181614
+ imageObj.onload = function () {
181615
+ var maxWidth = fileAreaSize.maxWidth,
181616
+ maxHeight = fileAreaSize.maxHeight;
181617
+ var isCheckAreaSizeMaxWidth = !maxWidth || imageObj.width <= maxWidth;
181618
+ var isCheckAreaSizeMaxHeight = !maxHeight || imageObj.height <= maxHeight;
181619
+
181620
+ if (!isCheckAreaSizeMaxWidth || !isCheckAreaSizeMaxHeight) {
181621
+ reject(new Error("\u6587\u4EF6\u4E0A\u4F20\u5931\u8D25\uFF01\u56FE\u7247\u5C3A\u5BF8\u4E0D\u7B26\u5408"));
181622
+ } else {
181623
+ resolve(file);
181624
+ }
181625
+ };
181626
+ };
181596
181627
  } else {
181597
- // 单个文件上传
181598
- checkOver(item);
181628
+ resolve(file);
181599
181629
  }
181600
- }
181630
+ });
181631
+ }, [type, fileSize, fileSizeType, fileAreaSize]); // 文件循环校验,返回校验后的文件数组
181601
181632
 
181602
- return false;
181603
- }, [type, fileSize, enableCrop, checkOver]); // 删除事件
181633
+ var filesLoopCheck = React.useCallback(function (files) {
181634
+ return Promise.all(files.map(fileCheckAsync));
181635
+ }, []);
181636
+ /*
181637
+ * 上传前: 先校验 => 全部校验通过后开始上传
181638
+ * 事件执行顺序:
181639
+ * beforeUpload => filesLoopCheck => checkOver
181640
+ * => uploadFile => uploadOss && customUpload
181641
+ * => uploadProgress => uploadSuccess || uploadError
181642
+ * => Props.onChange && (Props.onSuccess || Props.onError)
181643
+ */
181644
+
181645
+ var beforeUpload = React.useCallback( /*#__PURE__*/function () {
181646
+ var _ref6 = _asyncToGenerator$1( /*#__PURE__*/_regeneratorRuntime$1().mark(function _callee3(e) {
181647
+ var files, res;
181648
+ return _regeneratorRuntime$1().wrap(function _callee3$(_context3) {
181649
+ while (1) {
181650
+ switch (_context3.prev = _context3.next) {
181651
+ case 0:
181652
+ files = Array.from(e.target.files);
181653
+ _context3.prev = 1;
181654
+ _context3.next = 4;
181655
+ return filesLoopCheck(files);
181656
+
181657
+ case 4:
181658
+ res = _context3.sent;
181659
+
181660
+ // 仅单文件上传时可剪裁
181661
+ if (enableCrop) {
181662
+ dispatch({
181663
+ type: 'changeCropFile',
181664
+ cropFile: res[0]
181665
+ });
181666
+ } else {
181667
+ // 校验完成开始执行上传
181668
+ res.forEach(checkOver);
181669
+ }
181670
+
181671
+ _context3.next = 12;
181672
+ break;
181673
+
181674
+ case 8:
181675
+ _context3.prev = 8;
181676
+ _context3.t0 = _context3["catch"](1);
181677
+ console.log('文件校验未通过!', _context3.t0.message);
181678
+ api$2.warning(_context3.t0.message, 1.5);
181679
+
181680
+ case 12:
181681
+ case "end":
181682
+ return _context3.stop();
181683
+ }
181684
+ }
181685
+ }, _callee3, null, [[1, 8]]);
181686
+ }));
181687
+
181688
+ return function (_x3) {
181689
+ return _ref6.apply(this, arguments);
181690
+ };
181691
+ }(), [filesLoopCheck, enableCrop, checkOver]); // 删除事件
181604
181692
 
181605
181693
  var remove = React.useCallback( /*#__PURE__*/function () {
181606
- var _ref6 = _asyncToGenerator$1( /*#__PURE__*/_regeneratorRuntime$1().mark(function _callee3(file) {
181694
+ var _ref7 = _asyncToGenerator$1( /*#__PURE__*/_regeneratorRuntime$1().mark(function _callee4(file) {
181607
181695
  var _props$onRemove;
181608
181696
 
181609
181697
  var res, _getFileList, fileList;
181610
181698
 
181611
- return _regeneratorRuntime$1().wrap(function _callee3$(_context3) {
181699
+ return _regeneratorRuntime$1().wrap(function _callee4$(_context4) {
181612
181700
  while (1) {
181613
- switch (_context3.prev = _context3.next) {
181701
+ switch (_context4.prev = _context4.next) {
181614
181702
  case 0:
181615
- _context3.next = 2;
181703
+ _context4.next = 2;
181616
181704
  return (_props$onRemove = props.onRemove) === null || _props$onRemove === void 0 ? void 0 : _props$onRemove.call(props, file);
181617
181705
 
181618
181706
  case 2:
181619
- res = _context3.sent;
181707
+ res = _context4.sent;
181620
181708
 
181621
181709
  if (res) {
181622
181710
  fileList = (_getFileList = getFileList()) === null || _getFileList === void 0 ? void 0 : _getFileList.filter(function (v) {
@@ -181634,14 +181722,14 @@
181634
181722
 
181635
181723
  case 4:
181636
181724
  case "end":
181637
- return _context3.stop();
181725
+ return _context4.stop();
181638
181726
  }
181639
181727
  }
181640
- }, _callee3);
181728
+ }, _callee4);
181641
181729
  }));
181642
181730
 
181643
- return function (_x3) {
181644
- return _ref6.apply(this, arguments);
181731
+ return function (_x4) {
181732
+ return _ref7.apply(this, arguments);
181645
181733
  };
181646
181734
  }(), [props.onRemove, getFileList, onChange, dispatch, uid]); // 点击文件链接或预览图标时的回调
181647
181735
 
@@ -182226,6 +182314,7 @@
182226
182314
  var defaultProps = _objectSpread({
182227
182315
  size: 100,
182228
182316
  fileSize: 10,
182317
+ fileSizeType: 'M',
182229
182318
  uid: 'uid',
182230
182319
  accept: '',
182231
182320
  type: ['jpg', 'jpeg', 'png'],
@@ -188236,6 +188325,7 @@
188236
188325
  _excluded3$5 = ["allowClear"];
188237
188326
  var LmInput = /*#__PURE__*/React.forwardRef(function (props, ref) {
188238
188327
  var _props$allowClear = props.allowClear,
188328
+ allowClear = _props$allowClear === void 0 ? true : _props$allowClear,
188239
188329
  customizeSize = props.size,
188240
188330
  rest = _objectWithoutProperties$1(props, _excluded$1i);
188241
188331
 
@@ -188245,12 +188335,13 @@
188245
188335
  className: "lm_input",
188246
188336
  size: size
188247
188337
  }, rest), {}, {
188248
- allowClear: true
188338
+ allowClear: allowClear
188249
188339
  }));
188250
188340
  });
188251
188341
  LmInput.Group = Input$3.Group;
188252
188342
  LmInput.Search = /*#__PURE__*/React.forwardRef(function (props, ref) {
188253
188343
  var _props$allowClear2 = props.allowClear,
188344
+ allowClear = _props$allowClear2 === void 0 ? true : _props$allowClear2,
188254
188345
  rest = _objectWithoutProperties$1(props, _excluded2$i);
188255
188346
 
188256
188347
  return /*#__PURE__*/React__default['default'].createElement(Input$3.Search, _objectSpread(_objectSpread({
@@ -188259,7 +188350,7 @@
188259
188350
  })
188260
188351
  }, rest), {}, {
188261
188352
  ref: ref,
188262
- allowClear: true,
188353
+ allowClear: allowClear,
188263
188354
  className: "lm_input_search"
188264
188355
  }));
188265
188356
  });
@@ -188267,6 +188358,7 @@
188267
188358
 
188268
188359
  LmInput.Password = function (props) {
188269
188360
  var _props$allowClear3 = props.allowClear,
188361
+ allowClear = _props$allowClear3 === void 0 ? true : _props$allowClear3,
188270
188362
  rest = _objectWithoutProperties$1(props, _excluded3$5);
188271
188363
 
188272
188364
  return /*#__PURE__*/React__default['default'].createElement(Input$3.Password, _objectSpread(_objectSpread({
@@ -188279,7 +188371,7 @@
188279
188371
  });
188280
188372
  }
188281
188373
  }, rest), {}, {
188282
- allowClear: true
188374
+ allowClear: allowClear
188283
188375
  }));
188284
188376
  };
188285
188377
 
@@ -286326,7 +286418,7 @@
286326
286418
  items_per_page: '/条',
286327
286419
  jump_to: '前往',
286328
286420
  page: '页'
286329
- } : locale.Pagination || {},
286421
+ } : (locale === null || locale === void 0 ? void 0 : locale.Pagination) || {},
286330
286422
  size: 'small'
286331
286423
  }, pagination),
286332
286424
  rowSelection: rowSelection === false ? undefined : _objectSpread({
@@ -286914,13 +287006,13 @@
286914
287006
  _excluded2$x = ["item"],
286915
287007
  _excluded3$8 = ["type"];
286916
287008
 
286917
- var imgEmpty$1 = require('./icon_placeholder.png');
287009
+ var imgEmpty = require('./icon_placeholder.png');
286918
287010
 
286919
287011
  var FilterEmpty = function FilterEmpty() {
286920
287012
  return /*#__PURE__*/React__default['default'].createElement("div", {
286921
287013
  className: "filter_empty"
286922
287014
  }, /*#__PURE__*/React__default['default'].createElement("img", {
286923
- src: imgEmpty$1,
287015
+ src: imgEmpty,
286924
287016
  alt: "empty",
286925
287017
  width: 81
286926
287018
  }), /*#__PURE__*/React__default['default'].createElement("div", {
@@ -287410,13 +287502,13 @@
287410
287502
 
287411
287503
  var _excluded$2b = ["item"];
287412
287504
 
287413
- var imgEmpty$2 = require('./icon_placeholder.png');
287505
+ var imgEmpty$1 = require('./icon_placeholder.png');
287414
287506
 
287415
287507
  var FilterEmpty$1 = function FilterEmpty() {
287416
287508
  return /*#__PURE__*/React__default['default'].createElement("div", {
287417
287509
  className: "filter_empty"
287418
287510
  }, /*#__PURE__*/React__default['default'].createElement("img", {
287419
- src: imgEmpty$2,
287511
+ src: imgEmpty$1,
287420
287512
  alt: "empty",
287421
287513
  width: 81
287422
287514
  }), /*#__PURE__*/React__default['default'].createElement("div", {
@@ -311568,6 +311660,29 @@
311568
311660
 
311569
311661
  return ((_Object$keys = Object.keys(obj || {})) === null || _Object$keys === void 0 ? void 0 : _Object$keys.length) === 0;
311570
311662
  }
311663
+ function deepDataSourcePreKeys(dataSource, rowKey) {
311664
+ var deepDataSource = [];
311665
+
311666
+ var eachChildren = function eachChildren(children, preKeys) {
311667
+ children.forEach(function (item) {
311668
+ deepDataSource.push(_objectSpread(_objectSpread({}, item), {}, {
311669
+ preKeys: [].concat(_toConsumableArray$1(preKeys), [item[rowKey]])
311670
+ }));
311671
+
311672
+ if (item.children) {
311673
+ eachChildren(item.children, [].concat(_toConsumableArray$1(preKeys), [item[rowKey]])); // deepDataSource.push({ ...item, preKeys: [...preKeys, item[rowKey]] })
311674
+ }
311675
+ });
311676
+ };
311677
+
311678
+ eachChildren(dataSource, []);
311679
+ return lodash.keyBy(deepDataSource, rowKey);
311680
+ }
311681
+ function isExpandRow(children) {
311682
+ var _children$, _children$$props, _children$$props$chil, _children$$props$chil2, _children$$props$chil3;
311683
+
311684
+ return ['Collapse row', 'Expand row'].includes(children === null || children === void 0 ? void 0 : (_children$ = children[0]) === null || _children$ === void 0 ? void 0 : (_children$$props = _children$.props) === null || _children$$props === void 0 ? void 0 : (_children$$props$chil = _children$$props.children) === null || _children$$props$chil === void 0 ? void 0 : (_children$$props$chil2 = _children$$props$chil[1]) === null || _children$$props$chil2 === void 0 ? void 0 : (_children$$props$chil3 = _children$$props$chil2.props) === null || _children$$props$chil3 === void 0 ? void 0 : _children$$props$chil3['aria-label']);
311685
+ }
311571
311686
 
311572
311687
  var _excluded$2S = ["index"],
311573
311688
  _excluded2$I = ["index"],
@@ -311948,6 +312063,7 @@
311948
312063
 
311949
312064
  var Control = function Control(con) {
311950
312065
  var resultComponentProps = lodash.isFunction(componentProps) ? componentProps === null || componentProps === void 0 ? void 0 : componentProps(record, col) : componentProps;
312066
+ var clearAttrComponentProps = lodash.omit(resultComponentProps, ['optionOnly', 'isOnlyValue']);
311951
312067
 
311952
312068
  switch (con) {
311953
312069
  case 'input':
@@ -311956,7 +312072,7 @@
311956
312072
  onBlur: handleFormItemChange,
311957
312073
  ref: inputRef,
311958
312074
  placeholder: "\u8BF7\u8F93\u5165"
311959
- }, resultComponentProps), {}, {
312075
+ }, clearAttrComponentProps), {}, {
311960
312076
  addonBefore: resultComponentProps.addonBefore ? /*#__PURE__*/React__default['default'].createElement(Form$4.Item, {
311961
312077
  name: [col.dataIndex, 'addonBeforeValue'],
311962
312078
  noStyle: true
@@ -311996,13 +312112,13 @@
311996
312112
  },
311997
312113
  placeholder: "\u8BF7\u8F93\u5165",
311998
312114
  ref: inputRef
311999
- }, resultComponentProps));
312115
+ }, clearAttrComponentProps));
312000
312116
 
312001
312117
  case 'date':
312002
312118
  // @ts-ignore
312003
312119
  return /*#__PURE__*/React__default['default'].createElement(DatePicker$1, _objectSpread({
312004
312120
  onChange: handleFormItemChange
312005
- }, resultComponentProps));
312121
+ }, clearAttrComponentProps));
312006
312122
 
312007
312123
  case 'select':
312008
312124
  return /*#__PURE__*/React__default['default'].createElement(LMSelect$1, _objectSpread(_objectSpread({
@@ -312015,7 +312131,7 @@
312015
312131
 
312016
312132
  return ((_option$children = option.children) === null || _option$children === void 0 ? void 0 : (_option$children$toLo = _option$children.toLowerCase()) === null || _option$children$toLo === void 0 ? void 0 : _option$children$toLo.indexOf(input.toLowerCase())) >= 0;
312017
312133
  }
312018
- }, resultComponentProps), {}, {
312134
+ }, clearAttrComponentProps), {}, {
312019
312135
  // open={true}
312020
312136
  onChange: handleFormItemChange
312021
312137
  }));
@@ -312034,30 +312150,30 @@
312034
312150
  },
312035
312151
  onChange: handleFormItemChange,
312036
312152
  onDeselect: handleFormItemChange
312037
- }, resultComponentProps));
312153
+ }, clearAttrComponentProps));
312038
312154
 
312039
312155
  case 'checkbox':
312040
312156
  return /*#__PURE__*/React__default['default'].createElement(LMCheckBox.Group, _objectSpread({
312041
312157
  onChange: handleFormItemChange,
312042
312158
  ref: inputRef
312043
- }, resultComponentProps));
312159
+ }, clearAttrComponentProps));
312044
312160
 
312045
312161
  case 'radio':
312046
312162
  return /*#__PURE__*/React__default['default'].createElement(LMRadio, _objectSpread({
312047
312163
  onChange: handleFormItemChange,
312048
312164
  ref: inputRef
312049
- }, resultComponentProps));
312165
+ }, clearAttrComponentProps));
312050
312166
 
312051
312167
  case 'radioGroup':
312052
312168
  return /*#__PURE__*/React__default['default'].createElement(LMRadio.Group, _objectSpread({
312053
312169
  onChange: handleFormItemChange,
312054
312170
  ref: inputRef
312055
- }, resultComponentProps));
312171
+ }, clearAttrComponentProps));
312056
312172
 
312057
312173
  case 'switch':
312058
312174
  return /*#__PURE__*/React__default['default'].createElement(Switch$2, _objectSpread(_objectSpread({
312059
312175
  size: 'small'
312060
- }, resultComponentProps), {}, {
312176
+ }, clearAttrComponentProps), {}, {
312061
312177
  onChange: handleFormItemChange
312062
312178
  }));
312063
312179
 
@@ -312086,7 +312202,7 @@
312086
312202
  var fromData = form.getFieldsValue();
312087
312203
  return render === null || render === void 0 ? void 0 : render(_objectSpread(_objectSpread({}, !isObjEmpty(fromData) ? _objectSpread(_objectSpread({}, record), {}, _defineProperty$1({}, dataIndex, fromData[dataIndex])) : record), {}, {
312088
312204
  onChange: save
312089
- })); // return render?.({ ...(!isObjEmpty(fromData) ? {...record, ...fromData} : record), onChange: save })
312205
+ }));
312090
312206
  }
312091
312207
 
312092
312208
  default:
@@ -312116,7 +312232,7 @@
312116
312232
  onClick: toggleEdit
312117
312233
  }, childNode);
312118
312234
  } else if (isEdit && editable) {
312119
- childNode = /*#__PURE__*/React__default['default'].createElement(Form$4.Item, _objectSpread(_objectSpread({
312235
+ childNode = /*#__PURE__*/React__default['default'].createElement(React__default['default'].Fragment, null, isExpandRow(childNode) && childNode[0], /*#__PURE__*/React__default['default'].createElement(Form$4.Item, _objectSpread(_objectSpread({
312120
312236
  errorPlacement: "right",
312121
312237
  valuePropName: editable === 'switch' ? 'checked' : 'value',
312122
312238
  style: {
@@ -312124,17 +312240,17 @@
312124
312240
  }
312125
312241
  }, formProps), {}, {
312126
312242
  name: dataIndex
312127
- }), Control(editable));
312243
+ }), Control(editable)));
312128
312244
 
312129
312245
  if (editable === 'input' && ((resultComponentProps === null || resultComponentProps === void 0 ? void 0 : resultComponentProps.addonBefore) || (resultComponentProps === null || resultComponentProps === void 0 ? void 0 : resultComponentProps.addonAfter))) {
312130
- childNode = /*#__PURE__*/React__default['default'].createElement(Form$4.Item, _objectSpread(_objectSpread({
312246
+ childNode = /*#__PURE__*/React__default['default'].createElement(React__default['default'].Fragment, null, isExpandRow(childNode) && childNode[0], /*#__PURE__*/React__default['default'].createElement(Form$4.Item, _objectSpread(_objectSpread({
312131
312247
  errorPlacement: "right",
312132
312248
  style: {
312133
312249
  margin: 0
312134
312250
  }
312135
312251
  }, formProps), {}, {
312136
312252
  name: [dataIndex, 'value']
312137
- }), Control(editable));
312253
+ }), Control(editable)));
312138
312254
  }
312139
312255
  } else if (!isEdit && (componentProps === null || componentProps === void 0 ? void 0 : componentProps.options)) {
312140
312256
  var _componentProps$optio, _componentProps$optio2;
@@ -312164,7 +312280,7 @@
312164
312280
  // }
312165
312281
 
312166
312282
  }, [record]);
312167
- return /*#__PURE__*/React__default['default'].createElement("td", _objectSpread(_objectSpread({}, clearProps), {}, {
312283
+ return /*#__PURE__*/React__default['default'].createElement("td", _objectSpread(_objectSpread({}, lodash.omit(clearProps, ['dataIndex'])), {}, {
312168
312284
  className: classnames(clearProps === null || clearProps === void 0 ? void 0 : clearProps.className, 'lm_custom_cell_td'),
312169
312285
  key: "r".concat(rowIndex, "_c").concat(colIndex)
312170
312286
  }), getMemoChildNode);
@@ -312216,9 +312332,17 @@
312216
312332
  _useState12 = _slicedToArray$1(_useState11, 2),
312217
312333
  sortEditTable = _useState12[0],
312218
312334
  setCallBackFalg = _useState12[1];
312335
+ /** 当前展开的列 */
312336
+
312337
+
312338
+ var _useState13 = React.useState([]),
312339
+ _useState14 = _slicedToArray$1(_useState13, 2),
312340
+ expandedRowKeys = _useState14[0],
312341
+ setExpandedRowKeys = _useState14[1];
312219
312342
 
312220
312343
  var dataSourceRef = React.useRef([]);
312221
312344
  var sortDataSorceRef = React.useRef([]);
312345
+ var deepDataSourceRef = React.useRef([]);
312222
312346
 
312223
312347
  var onSortEnd = function onSortEnd(active, over) {
312224
312348
  var cloneArr = _toConsumableArray$1(dataSourceRef.current);
@@ -312311,26 +312435,72 @@
312311
312435
  };
312312
312436
 
312313
312437
  var handleSave = function handleSave(row, options) {
312438
+ var _deepDataSourceRef$cu, _deepDataSourceRef$cu2;
312439
+
312440
+ var preKeys = deepDataSourceRef === null || deepDataSourceRef === void 0 ? void 0 : (_deepDataSourceRef$cu = deepDataSourceRef.current) === null || _deepDataSourceRef$cu === void 0 ? void 0 : (_deepDataSourceRef$cu2 = _deepDataSourceRef$cu[row[_rowKey]]) === null || _deepDataSourceRef$cu2 === void 0 ? void 0 : _deepDataSourceRef$cu2.preKeys;
312314
312441
  var res = fn(dataSourceRef.current, function (draft) {
312315
312442
  if (options === null || options === void 0 ? void 0 : options.only) {
312316
312443
  var _options$only = options === null || options === void 0 ? void 0 : options.only,
312317
312444
  key = _options$only.key,
312318
312445
  value = _options$only.value;
312319
312446
 
312320
- draft.forEach(function (item, index) {
312321
- if (row[_rowKey] === item[_rowKey]) {
312322
- draft[index] = row;
312323
- } else {
312324
- draft[index][key] = value;
312325
- }
312326
- });
312447
+ if ((preKeys === null || preKeys === void 0 ? void 0 : preKeys.length) > 1) {
312448
+ var deeps = function deeps(children) {
312449
+ children.forEach(function (item) {
312450
+ if (preKeys.includes(item[_rowKey])) {
312451
+ if (item[_rowKey] === row[_rowKey]) {
312452
+ var _Object$keys;
312453
+
312454
+ children.forEach(function (c) {
312455
+ c[key] = value;
312456
+ });
312457
+ (_Object$keys = Object.keys(item)) === null || _Object$keys === void 0 ? void 0 : _Object$keys.forEach(function (v) {
312458
+ item[v] = row[v] || item[v];
312459
+ });
312460
+ } else if (item.children) {
312461
+ deeps(item.children);
312462
+ }
312463
+ }
312464
+ });
312465
+ };
312466
+
312467
+ deeps(draft);
312468
+ } else {
312469
+ draft.forEach(function (item, index) {
312470
+ if (row[_rowKey] === item[_rowKey]) {
312471
+ draft[index] = row;
312472
+ } else {
312473
+ draft[index][key] = value;
312474
+ }
312475
+ });
312476
+ }
312327
312477
  } else {
312328
- var index = draft.findIndex(function (item) {
312329
- return row[_rowKey] === item[_rowKey];
312330
- });
312478
+ if ((preKeys === null || preKeys === void 0 ? void 0 : preKeys.length) > 1) {
312479
+ var _deeps = function _deeps(children) {
312480
+ children.forEach(function (item) {
312481
+ if (preKeys.includes(item[_rowKey])) {
312482
+ if (item[_rowKey] === row[_rowKey]) {
312483
+ var _Object$keys2;
312484
+
312485
+ (_Object$keys2 = Object.keys(row)) === null || _Object$keys2 === void 0 ? void 0 : _Object$keys2.forEach(function (v) {
312486
+ item[v] = row[v] || item[v];
312487
+ });
312488
+ } else if (item.children) {
312489
+ _deeps(item.children);
312490
+ }
312491
+ }
312492
+ });
312493
+ };
312331
312494
 
312332
- if (index !== -1) {
312333
- draft[index] = row;
312495
+ _deeps(draft);
312496
+ } else {
312497
+ var index = draft.findIndex(function (item) {
312498
+ return row[_rowKey] === item[_rowKey];
312499
+ });
312500
+
312501
+ if (index !== -1) {
312502
+ draft[index] = row;
312503
+ }
312334
312504
  }
312335
312505
  }
312336
312506
  });
@@ -312352,60 +312522,95 @@
312352
312522
  return item;
312353
312523
  });
312354
312524
  });
312355
- }; // 校验保存
312356
- // const save = async (row) => {
312357
- // try {
312358
- // const values = row || (await form.getFieldsValue())
312359
- // handleSave({ ...record, ...values })
312360
- // await form.validateFields()
312361
- // // 清空异常校验
312362
- // setValid((old) => {
312363
- // const obj = { ...old }
312364
- // delete obj[record[rowKey]]
312365
- // return obj
312366
- // })
312367
- // } catch (errInfo) {
312368
- // // 加入异常校验
312369
- // setValid((old) => ({ ...old, [record[rowKey]]: errInfo.errorFields }))
312370
- // }
312371
- // }
312372
- // @ts-ignore
312525
+ }; // @ts-ignore
312373
312526
 
312374
312527
 
312375
312528
  var handleTableRowDelete = function handleTableRowDelete(key) {
312376
- var _dataSourceRef$curren;
312529
+ var _deepDataSourceRef$cu3, _deepDataSourceRef$cu4;
312377
312530
 
312378
- if (((_dataSourceRef$curren = dataSourceRef.current) === null || _dataSourceRef$curren === void 0 ? void 0 : _dataSourceRef$curren.length) === 1 && !quickOpetateClearAll) {
312379
- return false;
312380
- }
312531
+ var preKeys = deepDataSourceRef === null || deepDataSourceRef === void 0 ? void 0 : (_deepDataSourceRef$cu3 = deepDataSourceRef.current) === null || _deepDataSourceRef$cu3 === void 0 ? void 0 : (_deepDataSourceRef$cu4 = _deepDataSourceRef$cu3[key]) === null || _deepDataSourceRef$cu4 === void 0 ? void 0 : _deepDataSourceRef$cu4.preKeys;
312381
312532
 
312382
- var res = fn(dataSourceRef.current, function (draft) {
312383
- var index = draft.findIndex(function (item) {
312384
- return key === item[_rowKey];
312385
- });
312533
+ if (preKeys.length > 1) {
312534
+ /** 说明删除的是children中的数据 */
312535
+ var filter = function filter(data, key) {
312536
+ var newData = data.filter(function (x) {
312537
+ return x[_rowKey] !== key;
312538
+ });
312539
+ newData.forEach(function (x) {
312540
+ if (x.children) {
312541
+ var c = filter(x.children, key);
312542
+ x.children = c;
312386
312543
 
312387
- if (index !== -1) {
312388
- draft.splice(index, 1);
312389
- }
312390
- });
312544
+ if (!c.length) {
312545
+ delete x.children;
312546
+ }
312547
+ }
312548
+ });
312549
+ return newData;
312550
+ };
312391
312551
 
312392
- if (onChange) {
312393
- onChange === null || onChange === void 0 ? void 0 : onChange(res);
312552
+ var res = filter(dataSource, key);
312553
+
312554
+ if (onChange) {
312555
+ onChange === null || onChange === void 0 ? void 0 : onChange(res);
312556
+ } else {
312557
+ setDataSource(res);
312558
+ }
312394
312559
  } else {
312395
- setDataSource(res);
312396
- } // setDataSource(res)
312397
- // onChange?.(res)
312560
+ var _dataSourceRef$curren;
312561
+
312562
+ if (((_dataSourceRef$curren = dataSourceRef.current) === null || _dataSourceRef$curren === void 0 ? void 0 : _dataSourceRef$curren.length) === 1 && !quickOpetateClearAll) {
312563
+ return false;
312564
+ }
312565
+
312566
+ var _res = fn(dataSourceRef.current, function (draft) {
312567
+ var index = draft.findIndex(function (item) {
312568
+ return key === item[_rowKey];
312569
+ });
312570
+
312571
+ if (index !== -1) {
312572
+ draft.splice(index, 1);
312573
+ }
312574
+ });
312398
312575
 
312576
+ if (onChange) {
312577
+ onChange === null || onChange === void 0 ? void 0 : onChange(_res);
312578
+ } else {
312579
+ setDataSource(_res);
312580
+ }
312581
+ }
312399
312582
  };
312583
+ /** 快捷添加 */
312584
+
312400
312585
 
312401
312586
  var handleTableRowAdd = function handleTableRowAdd(record) {
312587
+ var _deepDataSourceRef$cu5, _deepDataSourceRef$cu6;
312588
+
312589
+ console.log(record, '-rrrrr');
312590
+ var preKeys = deepDataSourceRef === null || deepDataSourceRef === void 0 ? void 0 : (_deepDataSourceRef$cu5 = deepDataSourceRef.current) === null || _deepDataSourceRef$cu5 === void 0 ? void 0 : (_deepDataSourceRef$cu6 = _deepDataSourceRef$cu5[record[_rowKey]]) === null || _deepDataSourceRef$cu6 === void 0 ? void 0 : _deepDataSourceRef$cu6.preKeys;
312402
312591
  var res = fn(dataSourceRef.current, function (draft) {
312403
- var index = draft.findIndex(function (item) {
312404
- return record[_rowKey] === item[_rowKey];
312405
- });
312592
+ if (preKeys.length > 1) {
312593
+ var deeps = function deeps(children) {
312594
+ children.forEach(function (item, index) {
312595
+ if (preKeys.includes(item[_rowKey])) {
312596
+ if (item[_rowKey] === record[_rowKey]) {
312597
+ children.splice(index + 1, 0, _defineProperty$1({}, _rowKey, "".concat(Date.now())));
312598
+ } else if (item.children) {
312599
+ deeps(item.children);
312600
+ }
312601
+ }
312602
+ });
312603
+ };
312406
312604
 
312407
- if (index !== -1) {
312408
- draft.splice(index + 1, 0, _defineProperty$1({}, _rowKey, "".concat(Date.now())));
312605
+ deeps(draft);
312606
+ } else {
312607
+ var index = draft.findIndex(function (item) {
312608
+ return record[_rowKey] === item[_rowKey];
312609
+ });
312610
+
312611
+ if (index !== -1) {
312612
+ draft.splice(index + 1, 0, _defineProperty$1({}, _rowKey, "".concat(Date.now())));
312613
+ }
312409
312614
  }
312410
312615
  });
312411
312616
 
@@ -312586,52 +312791,7 @@
312586
312791
 
312587
312792
  var res = localColumns.map(function (col, index) {
312588
312793
  return mapColumns(col, index);
312589
- }); // const res = localColumns.map((col, index) => {
312590
- // if (!col.editable) {
312591
- // return col
312592
- // }
312593
- // return {
312594
- // ...col,
312595
- // shouldCellUpdate: (record, prevRecord) => {
312596
- // const { dataIndex, editable, relevanceCols } = col
312597
- // if (col?.fixed ||
312598
- // (hasDisableOptions && hasDisableOptions.includes(dataIndex)) ||
312599
- // col.componentProps?.options ||
312600
- // editable === 'render' ||
312601
- // !!relevanceCols || !!shouldUpdate) {
312602
- // return true
312603
- // }
312604
- // return record[dataIndex] !== prevRecord[dataIndex]
312605
- // },
312606
- // onCell: (record, rowIndex) => {
312607
- // return {
312608
- // getLength: dataSource.length,
312609
- // rowKey,
312610
- // record,
312611
- // col,
312612
- // rowIndex,
312613
- // colIndex: index,
312614
- // quickOpetateClearAll,
312615
- // handleTableRowDelete,
312616
- // handleTableRowAdd,
312617
- // editable: col.editable,
312618
- // dataIndex: col.dataIndex,
312619
- // itemProps: col.itemProps,
312620
- // setValid,
312621
- // isEdit,
312622
- // isHoverEdit,
312623
- // handleAdd,
312624
- // handleDelete,
312625
- // handleCopy,
312626
- // editEnum: typeof col.editEnum === 'function' ? col.editEnum(record) : col.editEnum,
312627
- // valueType: typeof col.valueType === 'function' ? col.valueType(record) : col.valueType,
312628
- // handleSave,
312629
- // reWriteOriginSource,
312630
- // }
312631
- // },
312632
- // }
312633
- // })
312634
-
312794
+ });
312635
312795
  return res;
312636
312796
  }, [columns, isAdd, sortOpen, useQuickOpetate, sortEditTable, dataSource, _toConsumableArray$1(memoOptions)]);
312637
312797
  var DraggableContainer = React.useCallback(function (_ref7) {
@@ -312691,9 +312851,32 @@
312691
312851
  }, resetProps);
312692
312852
  }, [resultColumns, dataSource, sortOpen, colSortOpen, size]);
312693
312853
  React.useEffect(function () {
312694
- setDataSource(defaultData === null || defaultData === void 0 ? void 0 : defaultData.map(function (v, idx) {
312854
+ // setDataSource(defaultData?.map((v, idx) => ({ ...v, [rowKey]: v[rowKey] || `v${idx + 1}` })))
312855
+ var addRowKey = function addRowKey(children, pkey) {
312856
+ return children === null || children === void 0 ? void 0 : children.map(function (item, index) {
312857
+ if (item.children) {
312858
+ var _objectSpread6;
312859
+
312860
+ var rchildren = addRowKey(item.children, "".concat(pkey, "_").concat(index + 1));
312861
+ return _objectSpread(_objectSpread({}, item), {}, (_objectSpread6 = {}, _defineProperty$1(_objectSpread6, _rowKey, item[_rowKey] || "".concat(pkey, "_").concat(index + 1)), _defineProperty$1(_objectSpread6, "children", rchildren), _objectSpread6));
312862
+ }
312863
+
312864
+ return _objectSpread(_objectSpread({}, item), {}, _defineProperty$1({}, _rowKey, item[_rowKey] || "".concat(pkey, "_").concat(index + 1)));
312865
+ });
312866
+ };
312867
+
312868
+ var res = defaultData === null || defaultData === void 0 ? void 0 : defaultData.map(function (v, idx) {
312869
+ if (v.children) {
312870
+ var _objectSpread8;
312871
+
312872
+ var rchildren = addRowKey(v.children, v[_rowKey] || "v".concat(idx + 1));
312873
+ return _objectSpread(_objectSpread({}, v), {}, (_objectSpread8 = {}, _defineProperty$1(_objectSpread8, _rowKey, v[_rowKey] || "v".concat(idx + 1)), _defineProperty$1(_objectSpread8, "children", rchildren), _objectSpread8));
312874
+ }
312875
+
312695
312876
  return _objectSpread(_objectSpread({}, v), {}, _defineProperty$1({}, _rowKey, v[_rowKey] || "v".concat(idx + 1)));
312696
- }));
312877
+ });
312878
+ deepDataSourceRef.current = deepDataSourcePreKeys(res, _rowKey);
312879
+ setDataSource(res);
312697
312880
  }, [defaultData]);
312698
312881
  React.useImperativeHandle(ref, function () {
312699
312882
  return {
@@ -312757,6 +312940,13 @@
312757
312940
  bordered: true,
312758
312941
  pagination: false,
312759
312942
  // components={tableComponents}
312943
+ expandable: (resetProps === null || resetProps === void 0 ? void 0 : resetProps.expandable) || {
312944
+ expandedRowKeys: expandedRowKeys,
312945
+ fixed: true,
312946
+ onExpandedRowsChange: function onExpandedRowsChange(expandedRows) {
312947
+ return setExpandedRowKeys(expandedRows);
312948
+ }
312949
+ },
312760
312950
  rowSelection: !rowSelection ? undefined : {
312761
312951
  fixed: true,
312762
312952
  type: 'checkbox',
@@ -323187,6 +323377,499 @@
323187
323377
  }, defaultProps));
323188
323378
  });
323189
323379
 
323380
+ // 初始化状态值
323381
+ var defaultState$2 = {
323382
+ currentIndex: 0,
323383
+ currentUrl: '',
323384
+ transform: {
323385
+ scale: 1,
323386
+ rotateZ: 0 // Z轴旋转方向
323387
+
323388
+ } // 当前选中的图片变换
323389
+
323390
+ }; // 状态管理操作
323391
+
323392
+ var reducer$7 = function reducer(state, action) {
323393
+ var transform = action.transform,
323394
+ current = action.current,
323395
+ visible = action.visible;
323396
+
323397
+ switch (action.type) {
323398
+ case 'changeVisible':
323399
+ // 控制显示隐藏
323400
+ return _objectSpread(_objectSpread({}, state), {}, {
323401
+ visible: visible
323402
+ });
323403
+
323404
+ case 'changeTransform':
323405
+ // 改变转换
323406
+ return _objectSpread(_objectSpread({}, state), {}, {
323407
+ transform: _objectSpread(_objectSpread({}, state.transform), transform)
323408
+ });
323409
+
323410
+ case 'changeCurrent':
323411
+ // 改变当前选中的图片
323412
+ return _objectSpread(_objectSpread(_objectSpread({}, state), current), {}, {
323413
+ transform: defaultState$2.transform
323414
+ });
323415
+
323416
+ case 'init':
323417
+ // 改变当前选中的图片
323418
+ return _objectSpread(_objectSpread({}, state), defaultState$2);
323419
+
323420
+ default:
323421
+ throw new Error();
323422
+ }
323423
+ }; // 仅在初始化时触发一次
323424
+
323425
+ var initialState$5 = function initialState(props) {
323426
+ var initialIndex = props.initialIndex;
323427
+ return _objectSpread(_objectSpread({}, defaultState$2), {}, {
323428
+ currentIndex: initialIndex
323429
+ });
323430
+ };
323431
+
323432
+ var useCoreOptions$4 = function useCoreOptions(_ref) {
323433
+ var state = _ref.state,
323434
+ dispatch = _ref.dispatch,
323435
+ props = _ref.props,
323436
+ previewRef = _ref.previewRef;
323437
+ // 获取显示状态
323438
+ var getVisible = React.useCallback(function () {
323439
+ return typeof props.visible === 'boolean' ? props.visible : state.visible;
323440
+ }, [props.visible, state.visible]); // 获取是否为视频格式
323441
+
323442
+ var getIsVideo = React.useCallback(function (url) {
323443
+ var fileExtension = url.replace(/.*\./, '').toLowerCase();
323444
+ return ['mp4', 'm2v', 'mkv', 'ogm', 'webm'].includes(fileExtension);
323445
+ }, []); // 关闭事件
323446
+
323447
+ var onClose = React.useCallback(function () {
323448
+ var _props$close;
323449
+
323450
+ (_props$close = props.close) === null || _props$close === void 0 ? void 0 : _props$close.call(props);
323451
+ dispatch({
323452
+ type: 'init'
323453
+ });
323454
+ dispatch({
323455
+ type: 'changeVisible',
323456
+ visible: false
323457
+ });
323458
+ }, []);
323459
+ var setTransform = React.useCallback(function (type) {
323460
+ var scale = state.transform.scale * 100;
323461
+ var rotateZ = state.transform.rotateZ;
323462
+
323463
+ switch (type) {
323464
+ case 'zoomIn':
323465
+ scale += 25;
323466
+ break;
323467
+
323468
+ case 'zoomOut':
323469
+ scale < 30 ? scale : scale -= 25;
323470
+ break;
323471
+
323472
+ case 'rotateLeft':
323473
+ rotateZ -= 90;
323474
+ break;
323475
+
323476
+ case 'rotateRight':
323477
+ rotateZ += 90;
323478
+ break;
323479
+ }
323480
+
323481
+ dispatch({
323482
+ type: 'changeTransform',
323483
+ transform: {
323484
+ rotateZ: rotateZ,
323485
+ scale: scale / 100
323486
+ }
323487
+ });
323488
+ }, [state.transform]); // 切换轮播前的回调
323489
+
323490
+ var beforeChange = React.useCallback(function (from, currentIndex) {
323491
+ dispatch({
323492
+ type: 'changeCurrent',
323493
+ current: {
323494
+ currentIndex: currentIndex
323495
+ }
323496
+ });
323497
+ }, []); // 切换轮播后的回调
323498
+
323499
+ var afterChange = React.useCallback(function (currentIndex) {
323500
+ dispatch({
323501
+ type: 'changeCurrent',
323502
+ current: {
323503
+ currentIndex: currentIndex
323504
+ }
323505
+ });
323506
+ }, []); // 转到指定的轮播图, 直接跳转, 不展示动画
323507
+
323508
+ var slickGoTo = React.useCallback(function (currentIndex) {
323509
+ previewRef.current.goTo(currentIndex, true);
323510
+ }, []); // 转到下一张轮播图
323511
+
323512
+ var slickNext = React.useCallback(function () {
323513
+ previewRef.current.next();
323514
+ }, []); // 转到上一张轮播图
323515
+
323516
+ var slickPrev = React.useCallback(function () {
323517
+ previewRef.current.prev();
323518
+ }, []);
323519
+ React.useEffect(function () {
323520
+ if (getVisible()) {
323521
+ slickGoTo(props.initialIndex);
323522
+ dispatch({
323523
+ type: 'changeCurrent',
323524
+ current: {
323525
+ currentIndex: props.initialIndex
323526
+ }
323527
+ });
323528
+ }
323529
+ }, [getVisible, props.initialIndex, slickGoTo]);
323530
+ var CoreMethods = {
323531
+ getVisible: getVisible,
323532
+ getIsVideo: getIsVideo,
323533
+ onClose: onClose,
323534
+ setTransform: setTransform,
323535
+ beforeChange: beforeChange,
323536
+ afterChange: afterChange,
323537
+ slickGoTo: slickGoTo,
323538
+ slickNext: slickNext,
323539
+ slickPrev: slickPrev
323540
+ };
323541
+ var RefMethods = {
323542
+ getState: function getState() {
323543
+ return state;
323544
+ }
323545
+ };
323546
+ return {
323547
+ CoreMethods: CoreMethods,
323548
+ RefMethods: RefMethods
323549
+ };
323550
+ };
323551
+
323552
+ var ListItem$3 = function ListItem(_ref) {
323553
+ var key = _ref.key,
323554
+ index = _ref.index,
323555
+ item = _ref.item,
323556
+ instance = _ref.instance;
323557
+ var state = instance.state,
323558
+ getIsVideo = instance.getIsVideo;
323559
+ var transformProps = React.useMemo(function () {
323560
+ if (index !== state.currentIndex) return {};
323561
+ var _state$transform = state.transform,
323562
+ scale = _state$transform.scale,
323563
+ rotateZ = _state$transform.rotateZ;
323564
+ return {
323565
+ transform: "scale(".concat(scale, ") rotateZ(").concat(rotateZ, "deg)")
323566
+ };
323567
+ }, [state.currentIndex, state.transform]);
323568
+ return /*#__PURE__*/React__default['default'].createElement("div", {
323569
+ className: "preview_item",
323570
+ key: key
323571
+ }, getIsVideo(item) ?
323572
+ /*#__PURE__*/
323573
+ // @ts-ignore
323574
+ // eslint-disable-next-line jsx-a11y/media-has-caption
323575
+ React__default['default'].createElement("video", {
323576
+ width: "100%",
323577
+ height: "100%",
323578
+ controls: "controls"
323579
+ }, /*#__PURE__*/React__default['default'].createElement("source", {
323580
+ src: item,
323581
+ type: "video/mp4"
323582
+ }), /*#__PURE__*/React__default['default'].createElement("source", {
323583
+ src: item,
323584
+ type: "video/webm"
323585
+ }), /*#__PURE__*/React__default['default'].createElement("source", {
323586
+ src: item,
323587
+ type: "video/ogg"
323588
+ }), "\u89C6\u9891\u64AD\u653E\u5931\u8D25\uFF01") : /*#__PURE__*/React__default['default'].createElement("img", {
323589
+ src: item,
323590
+ alt: "",
323591
+ style: transformProps
323592
+ }));
323593
+ };
323594
+
323595
+ var BigImg$1 = function BigImg(_ref2) {
323596
+ var instance = _ref2.instance;
323597
+ var urlList = instance.urlList,
323598
+ previewRef = instance.previewRef,
323599
+ infinite = instance.infinite,
323600
+ setTransform = instance.setTransform,
323601
+ beforeChange = instance.beforeChange;
323602
+ var onWheel = React.useCallback(function (e) {
323603
+ // e?.preventDefault()
323604
+ // e.stopPropagation()
323605
+ if ((e === null || e === void 0 ? void 0 : e.deltaY) <= 0) {
323606
+ setTransform('zoomIn');
323607
+ } else {
323608
+ setTransform('zoomOut');
323609
+ }
323610
+ }, [setTransform]);
323611
+ var config = {
323612
+ dots: false,
323613
+ infinite: infinite,
323614
+ // lazyLoad: true, // 懒加载
323615
+ adaptiveHeight: false,
323616
+ beforeChange: beforeChange // customPaging: (i) => <img src={urlList[i]} alt="" />,
323617
+
323618
+ };
323619
+ return /*#__PURE__*/React__default['default'].createElement("div", {
323620
+ className: "preview_list",
323621
+ onClick: function onClick(e) {
323622
+ return e.stopPropagation();
323623
+ },
323624
+ onWheel: onWheel
323625
+ }, /*#__PURE__*/React__default['default'].createElement(Carousel, _objectSpread({
323626
+ ref: previewRef
323627
+ }, config), urlList.map(function (v, idx) {
323628
+ return /*#__PURE__*/React__default['default'].createElement(ListItem$3, {
323629
+ key: idx || v,
323630
+ index: idx,
323631
+ item: v,
323632
+ instance: instance
323633
+ });
323634
+ })));
323635
+ };
323636
+
323637
+ var ThumbItem$1 = function ThumbItem(_ref) {
323638
+ var item = _ref.item,
323639
+ instance = _ref.instance;
323640
+ var getIsVideo = instance.getIsVideo;
323641
+
323642
+ if (getIsVideo(item)) {
323643
+ return /*#__PURE__*/React__default['default'].createElement(IconFont, {
323644
+ type: "lmweb-video",
323645
+ className: "thumb_item_icon"
323646
+ });
323647
+ }
323648
+
323649
+ return /*#__PURE__*/React__default['default'].createElement("img", {
323650
+ src: item,
323651
+ alt: ""
323652
+ });
323653
+ };
323654
+
323655
+ var Thumb$2 = function Thumb(_ref2) {
323656
+ var instance = _ref2.instance;
323657
+ var state = instance.state,
323658
+ urlList = instance.urlList,
323659
+ slickGoTo = instance.slickGoTo;
323660
+ var activeIndex = React.useMemo(function () {
323661
+ return state.currentIndex;
323662
+ }, [state.currentIndex]);
323663
+
323664
+ var handleGoTo = function handleGoTo(e, number) {
323665
+ e.preventDefault();
323666
+ slickGoTo(number);
323667
+ };
323668
+
323669
+ return /*#__PURE__*/React__default['default'].createElement("div", {
323670
+ className: "thumb_list",
323671
+ onClick: function onClick(e) {
323672
+ return e.stopPropagation();
323673
+ }
323674
+ }, urlList.map(function (v, idx) {
323675
+ return /*#__PURE__*/React__default['default'].createElement("div", {
323676
+ className: classnames('thumb_item', activeIndex === idx && 'active'),
323677
+ key: idx || v,
323678
+ onClick: function onClick(e) {
323679
+ return handleGoTo(e, idx);
323680
+ }
323681
+ }, /*#__PURE__*/React__default['default'].createElement(ThumbItem$1, {
323682
+ item: v,
323683
+ instance: instance
323684
+ }));
323685
+ }));
323686
+ };
323687
+
323688
+ var Operate$2 = function Operate(_ref) {
323689
+ var instance = _ref.instance;
323690
+ var setTransform = instance.setTransform;
323691
+
323692
+ var handleTranform = function handleTranform(e, type) {
323693
+ setTransform(type);
323694
+ };
323695
+
323696
+ return /*#__PURE__*/React__default['default'].createElement("div", {
323697
+ className: "image_viewer_action",
323698
+ onClick: function onClick(e) {
323699
+ return e.stopPropagation();
323700
+ }
323701
+ }, /*#__PURE__*/React__default['default'].createElement(IconFont, {
323702
+ type: "lmweb-zoomin",
323703
+ onClick: function onClick(e) {
323704
+ return handleTranform(e, 'zoomIn');
323705
+ }
323706
+ }), /*#__PURE__*/React__default['default'].createElement(IconFont, {
323707
+ type: "lmweb-a-icon_m_search1",
323708
+ onClick: function onClick(e) {
323709
+ return handleTranform(e, 'zoomOut');
323710
+ }
323711
+ }), /*#__PURE__*/React__default['default'].createElement(IconFont, {
323712
+ type: "lmweb-undo",
323713
+ onClick: function onClick(e) {
323714
+ return handleTranform(e, 'rotateLeft');
323715
+ }
323716
+ }), /*#__PURE__*/React__default['default'].createElement(IconFont, {
323717
+ type: "lmweb-redo",
323718
+ onClick: function onClick(e) {
323719
+ return handleTranform(e, 'rotateRight');
323720
+ }
323721
+ }));
323722
+ };
323723
+
323724
+ var Arrows = function Arrows(_ref) {
323725
+ var instance = _ref.instance;
323726
+ var slickNext = instance.slickNext,
323727
+ slickPrev = instance.slickPrev;
323728
+
323729
+ var handlePreNext = function handlePreNext(e, type) {
323730
+ e.stopPropagation();
323731
+
323732
+ if (type === 'next') {
323733
+ slickNext();
323734
+ }
323735
+
323736
+ if (type === 'prev') {
323737
+ slickPrev();
323738
+ }
323739
+ };
323740
+
323741
+ return /*#__PURE__*/React__default['default'].createElement(React__default['default'].Fragment, null, /*#__PURE__*/React__default['default'].createElement("div", {
323742
+ className: "arrow arrow_left",
323743
+ onClick: function onClick(e) {
323744
+ return handlePreNext(e, 'prev');
323745
+ }
323746
+ }, /*#__PURE__*/React__default['default'].createElement(IconFont, {
323747
+ type: "lmweb-left"
323748
+ })), /*#__PURE__*/React__default['default'].createElement("div", {
323749
+ className: "arrow arrow_right",
323750
+ onClick: function onClick(e) {
323751
+ return handlePreNext(e, 'next');
323752
+ }
323753
+ }, /*#__PURE__*/React__default['default'].createElement(IconFont, {
323754
+ type: "lmweb-right"
323755
+ })));
323756
+ };
323757
+
323758
+ // 根文件 => 参数聚合
323759
+
323760
+ var LmImageViewerContainer = function LmImageViewerContainer(_ref) {
323761
+ var instance = _ref.instance;
323762
+ var onClose = instance.onClose,
323763
+ hideOnClickModal = instance.hideOnClickModal;
323764
+
323765
+ var handleClose = function handleClose() {
323766
+ hideOnClickModal && onClose();
323767
+ };
323768
+
323769
+ return /*#__PURE__*/React__default['default'].createElement(React__default['default'].Fragment, null, /*#__PURE__*/React__default['default'].createElement("div", {
323770
+ className: "lm_image_viewer_container",
323771
+ onClick: handleClose
323772
+ }, /*#__PURE__*/React__default['default'].createElement(BigImg$1, {
323773
+ instance: instance
323774
+ }), /*#__PURE__*/React__default['default'].createElement(Thumb$2, {
323775
+ instance: instance
323776
+ }), /*#__PURE__*/React__default['default'].createElement(Operate$2, {
323777
+ instance: instance
323778
+ }), /*#__PURE__*/React__default['default'].createElement(Arrows, {
323779
+ instance: instance
323780
+ })));
323781
+ };
323782
+
323783
+ var LmImageViewerContainer$1 = /*#__PURE__*/React__default['default'].memo(LmImageViewerContainer);
323784
+
323785
+ // 根文件 => 参数聚合
323786
+
323787
+ var LmImageViewerWrapper = function LmImageViewerWrapper(_ref) {
323788
+ var instance = _ref.instance;
323789
+ var getVisible = instance.getVisible,
323790
+ zIndex = instance.zIndex;
323791
+
323792
+ var handleClose = function handleClose() {
323793
+ console.log('handleClose');
323794
+ };
323795
+
323796
+ if (!getVisible()) return null;
323797
+ return /*#__PURE__*/React__default['default'].createElement("div", {
323798
+ className: "lm_image_viewer_wrapper",
323799
+ style: {
323800
+ zIndex: zIndex
323801
+ }
323802
+ }, /*#__PURE__*/React__default['default'].createElement("div", {
323803
+ className: "lm_image_viewer_mask",
323804
+ onClick: handleClose
323805
+ }), /*#__PURE__*/React__default['default'].createElement(LmImageViewerContainer$1, {
323806
+ instance: instance
323807
+ }));
323808
+ };
323809
+
323810
+ var LmImageViewerWrapper$1 = /*#__PURE__*/React__default['default'].memo(LmImageViewerWrapper);
323811
+
323812
+ var LmImageViewerRoot = function LmImageViewerRoot(props, ref) {
323813
+ var previewRef = React.useRef(null);
323814
+ var initialState = React.useMemo(function () {
323815
+ return initialState$5(props);
323816
+ }, []);
323817
+
323818
+ var _useReducer = React.useReducer(reducer$7, initialState),
323819
+ _useReducer2 = _slicedToArray$1(_useReducer, 2),
323820
+ state = _useReducer2[0],
323821
+ dispatch = _useReducer2[1]; // 获取核心Methods
323822
+
323823
+
323824
+ var _useCoreOptions = useCoreOptions$4({
323825
+ state: state,
323826
+ dispatch: dispatch,
323827
+ props: props,
323828
+ previewRef: previewRef
323829
+ }),
323830
+ CoreMethods = _useCoreOptions.CoreMethods,
323831
+ RefMethods = _useCoreOptions.RefMethods; // 组件实例
323832
+
323833
+
323834
+ var instance = _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, props), CoreMethods), RefMethods), {}, {
323835
+ previewRef: previewRef,
323836
+ state: state,
323837
+ dispatch: dispatch
323838
+ }); // 向外暴露出的方法
323839
+
323840
+
323841
+ React.useImperativeHandle(ref, function () {
323842
+ return {};
323843
+ });
323844
+ return /*#__PURE__*/React__default['default'].createElement(LmImageViewerWrapper$1, {
323845
+ instance: instance
323846
+ });
323847
+ };
323848
+
323849
+ var LmImageViewerRoot$1 = /*#__PURE__*/React.forwardRef(LmImageViewerRoot);
323850
+
323851
+ var LmImageViewer = function LmImageViewer(_ref, ref) {
323852
+ var resetProps = _extends$2({}, _ref);
323853
+
323854
+ var defaultRef = React.useRef(null);
323855
+
323856
+ var defaultConfig = _objectSpread({
323857
+ visible: null,
323858
+ urlList: [],
323859
+ zIndex: 2001,
323860
+ initialIndex: 0,
323861
+ infinite: false,
323862
+ hideOnClickModal: true,
323863
+ close: function close() {}
323864
+ }, resetProps);
323865
+
323866
+ return /*#__PURE__*/React__default['default'].createElement(LmImageViewerRoot$1, _objectSpread({
323867
+ ref: ref || defaultRef
323868
+ }, defaultConfig));
323869
+ };
323870
+
323871
+ var LmImageViewer$1 = /*#__PURE__*/React.forwardRef(LmImageViewer);
323872
+
323190
323873
  exports.Alert = Alert$1;
323191
323874
  exports.Approval = LMApproval;
323192
323875
  exports.AutoComplete = RefAutoComplete$1;
@@ -323222,6 +323905,7 @@
323222
323905
  exports.IconFont = IconFont;
323223
323906
  exports.IconSelect = IconSelect;
323224
323907
  exports.Image = Image$1;
323908
+ exports.ImageViewer = LmImageViewer$1;
323225
323909
  exports.Input = LmInput;
323226
323910
  exports.InputNumber = CInputNumber;
323227
323911
  exports.LMQuickMenu = LMQuickMenu;