linkmore-design 1.0.3

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 (239) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +81 -0
  3. package/dist/40b22ad7b4ea2a7e.jpg +0 -0
  4. package/dist/566891e3103ae07a.png +0 -0
  5. package/dist/9f788f660abc173c.png +0 -0
  6. package/dist/f8940d62d6a40f71.png +0 -0
  7. package/dist/index.umd.css +2167 -0
  8. package/dist/index.umd.js +69587 -0
  9. package/dist/index.umd.min.css +1 -0
  10. package/dist/index.umd.min.js +31 -0
  11. package/es/ButtonTags/ButtonTags.js +59 -0
  12. package/es/ButtonTags/index.js +13 -0
  13. package/es/ButtonTags/style/index.js +3 -0
  14. package/es/ButtonTags/style/style.css +221 -0
  15. package/es/CkFilter/baseFilter/filterMenu.js +177 -0
  16. package/es/CkFilter/baseFilter/index.js +91 -0
  17. package/es/CkFilter/baseFilter/moreFilters.js +198 -0
  18. package/es/CkFilter/complexFilter/drawer.js +337 -0
  19. package/es/CkFilter/complexFilter/index.js +69 -0
  20. package/es/CkFilter/components/filterTypes.js +530 -0
  21. package/es/CkFilter/components/modal.js +275 -0
  22. package/es/CkFilter/context.js +152 -0
  23. package/es/CkFilter/customFilter/drawer.js +364 -0
  24. package/es/CkFilter/customFilter/index.js +130 -0
  25. package/es/CkFilter/customFilter/radioGroup.js +65 -0
  26. package/es/CkFilter/filter.js +115 -0
  27. package/es/CkFilter/index.js +13 -0
  28. package/es/CkFilter/style/index.js +3 -0
  29. package/es/CkFilter/style/style.css +586 -0
  30. package/es/CkFilter/utils.js +65 -0
  31. package/es/CustomerService/assets/question01.png +0 -0
  32. package/es/CustomerService/assets/send.png +0 -0
  33. package/es/CustomerService/assets/service.png +0 -0
  34. package/es/CustomerService/assets/shuoming01.png +0 -0
  35. package/es/CustomerService/assets/shuoming02.png +0 -0
  36. package/es/CustomerService/components/question.js +120 -0
  37. package/es/CustomerService/index.js +291 -0
  38. package/es/CustomerService/style/index.js +3 -0
  39. package/es/CustomerService/style/style.css +402 -0
  40. package/es/EditTable/EditTable.js +489 -0
  41. package/es/EditTable/index.js +13 -0
  42. package/es/EditTable/style/index.js +3 -0
  43. package/es/EditTable/style/style.css +165 -0
  44. package/es/EnlargeImg/index.js +109 -0
  45. package/es/EnlargeImg/style/index.js +3 -0
  46. package/es/EnlargeImg/style/style.css +4 -0
  47. package/es/Filter/Popover.js +199 -0
  48. package/es/Filter/baseFilter/Popover.js +214 -0
  49. package/es/Filter/baseFilter/ToggleFilter.js +112 -0
  50. package/es/Filter/baseFilter/index.js +100 -0
  51. package/es/Filter/complex/ComplexFilter.js +149 -0
  52. package/es/Filter/complex/ComplexItem.js +157 -0
  53. package/es/Filter/components/Checkbox.js +94 -0
  54. package/es/Filter/components/Date.js +87 -0
  55. package/es/Filter/components/Input.js +63 -0
  56. package/es/Filter/components/Select.js +89 -0
  57. package/es/Filter/components/Tree.js +64 -0
  58. package/es/Filter/components/header.js +60 -0
  59. package/es/Filter/components/index.js +47 -0
  60. package/es/Filter/context.js +15 -0
  61. package/es/Filter/edit/editFilter.js +277 -0
  62. package/es/Filter/index.js +174 -0
  63. package/es/Filter/popContext.js +15 -0
  64. package/es/Filter/remember.js +137 -0
  65. package/es/Filter/style/index.js +3 -0
  66. package/es/Filter/style/style.css +420 -0
  67. package/es/Icon/index.js +20 -0
  68. package/es/Icon/style/index.js +1 -0
  69. package/es/Icon/style/style.css +0 -0
  70. package/es/IconFont/index.js +15 -0
  71. package/es/IconFont/style/index.js +1 -0
  72. package/es/IconFont/style/style.css +0 -0
  73. package/es/LeftTable/assets/imgTest.jpg +0 -0
  74. package/es/LeftTable/index.js +116 -0
  75. package/es/LeftTable/style/index.js +3 -0
  76. package/es/LeftTable/style/style.css +231 -0
  77. package/es/LoadingPage/index.js +33 -0
  78. package/es/LoadingPage/style/index.js +1 -0
  79. package/es/LoadingPage/style/style.css +0 -0
  80. package/es/Modal/add.js +68 -0
  81. package/es/Modal/confirm.js +88 -0
  82. package/es/Modal/edit.js +44 -0
  83. package/es/Modal/exportModal.js +300 -0
  84. package/es/Modal/index.js +24 -0
  85. package/es/Modal/style/index.js +3 -0
  86. package/es/Modal/style/style.css +119 -0
  87. package/es/PopTable/BseTable.js +113 -0
  88. package/es/PopTable/index.js +151 -0
  89. package/es/PopTable/style/index.js +3 -0
  90. package/es/PopTable/style/style.css +363 -0
  91. package/es/ProTable/ImgList/body.js +111 -0
  92. package/es/ProTable/ImgList/cardCell.js +179 -0
  93. package/es/ProTable/ImgList/context.js +12 -0
  94. package/es/ProTable/ImgList/empty.js +24 -0
  95. package/es/ProTable/ImgList/footer.js +59 -0
  96. package/es/ProTable/ImgList/imgCell.js +181 -0
  97. package/es/ProTable/ImgList/imgTable.js +110 -0
  98. package/es/ProTable/ImgList/index.js +13 -0
  99. package/es/ProTable/Table.js +321 -0
  100. package/es/ProTable/VList.js +594 -0
  101. package/es/ProTable/context.js +12 -0
  102. package/es/ProTable/index.js +16 -0
  103. package/es/ProTable/resetConfig.js +39 -0
  104. package/es/ProTable/style/index.js +3 -0
  105. package/es/ProTable/style/style.css +693 -0
  106. package/es/TableRender/index.js +15 -0
  107. package/es/TableRender/state.js +72 -0
  108. package/es/TableRender/style/index.js +3 -0
  109. package/es/TableRender/style/style.css +0 -0
  110. package/es/UploadOss/index.js +18 -0
  111. package/es/UploadOss/style/index.js +3 -0
  112. package/es/UploadOss/style/style.css +121 -0
  113. package/es/UploadOss/uploadBtn.js +141 -0
  114. package/es/UploadOss/uploadImg.js +282 -0
  115. package/es/VirtualList/index.js +84 -0
  116. package/es/VirtualList/style/index.js +3 -0
  117. package/es/VirtualList/style/style.css +0 -0
  118. package/es/index.js +135 -0
  119. package/es/services/newRequest.js +201 -0
  120. package/es/services/utils.js +72 -0
  121. package/es/styles/icon.css +15 -0
  122. package/es/styles/main.css +149 -0
  123. package/es/styles/resetAntd.css +62 -0
  124. package/es/styles/them.css +0 -0
  125. package/lib/ButtonTags/ButtonTags.js +59 -0
  126. package/lib/ButtonTags/index.js +13 -0
  127. package/lib/ButtonTags/style/index.js +3 -0
  128. package/lib/ButtonTags/style/style.css +221 -0
  129. package/lib/CkFilter/baseFilter/filterMenu.js +177 -0
  130. package/lib/CkFilter/baseFilter/index.js +91 -0
  131. package/lib/CkFilter/baseFilter/moreFilters.js +198 -0
  132. package/lib/CkFilter/complexFilter/drawer.js +337 -0
  133. package/lib/CkFilter/complexFilter/index.js +69 -0
  134. package/lib/CkFilter/components/filterTypes.js +530 -0
  135. package/lib/CkFilter/components/modal.js +275 -0
  136. package/lib/CkFilter/context.js +152 -0
  137. package/lib/CkFilter/customFilter/drawer.js +364 -0
  138. package/lib/CkFilter/customFilter/index.js +130 -0
  139. package/lib/CkFilter/customFilter/radioGroup.js +65 -0
  140. package/lib/CkFilter/filter.js +115 -0
  141. package/lib/CkFilter/index.js +13 -0
  142. package/lib/CkFilter/style/index.js +3 -0
  143. package/lib/CkFilter/style/style.css +586 -0
  144. package/lib/CkFilter/utils.js +65 -0
  145. package/lib/CustomerService/assets/question01.png +0 -0
  146. package/lib/CustomerService/assets/send.png +0 -0
  147. package/lib/CustomerService/assets/service.png +0 -0
  148. package/lib/CustomerService/assets/shuoming01.png +0 -0
  149. package/lib/CustomerService/assets/shuoming02.png +0 -0
  150. package/lib/CustomerService/components/question.js +120 -0
  151. package/lib/CustomerService/index.js +291 -0
  152. package/lib/CustomerService/style/index.js +3 -0
  153. package/lib/CustomerService/style/style.css +402 -0
  154. package/lib/EditTable/EditTable.js +489 -0
  155. package/lib/EditTable/index.js +13 -0
  156. package/lib/EditTable/style/index.js +3 -0
  157. package/lib/EditTable/style/style.css +165 -0
  158. package/lib/EnlargeImg/index.js +109 -0
  159. package/lib/EnlargeImg/style/index.js +3 -0
  160. package/lib/EnlargeImg/style/style.css +4 -0
  161. package/lib/Filter/Popover.js +199 -0
  162. package/lib/Filter/baseFilter/Popover.js +214 -0
  163. package/lib/Filter/baseFilter/ToggleFilter.js +112 -0
  164. package/lib/Filter/baseFilter/index.js +100 -0
  165. package/lib/Filter/complex/ComplexFilter.js +149 -0
  166. package/lib/Filter/complex/ComplexItem.js +157 -0
  167. package/lib/Filter/components/Checkbox.js +94 -0
  168. package/lib/Filter/components/Date.js +87 -0
  169. package/lib/Filter/components/Input.js +63 -0
  170. package/lib/Filter/components/Select.js +89 -0
  171. package/lib/Filter/components/Tree.js +64 -0
  172. package/lib/Filter/components/header.js +60 -0
  173. package/lib/Filter/components/index.js +47 -0
  174. package/lib/Filter/context.js +15 -0
  175. package/lib/Filter/edit/editFilter.js +277 -0
  176. package/lib/Filter/index.js +174 -0
  177. package/lib/Filter/popContext.js +15 -0
  178. package/lib/Filter/remember.js +137 -0
  179. package/lib/Filter/style/index.js +3 -0
  180. package/lib/Filter/style/style.css +420 -0
  181. package/lib/Icon/index.js +20 -0
  182. package/lib/Icon/style/index.js +1 -0
  183. package/lib/Icon/style/style.css +0 -0
  184. package/lib/IconFont/index.js +15 -0
  185. package/lib/IconFont/style/index.js +1 -0
  186. package/lib/IconFont/style/style.css +0 -0
  187. package/lib/LeftTable/assets/imgTest.jpg +0 -0
  188. package/lib/LeftTable/index.js +116 -0
  189. package/lib/LeftTable/style/index.js +3 -0
  190. package/lib/LeftTable/style/style.css +231 -0
  191. package/lib/LoadingPage/index.js +33 -0
  192. package/lib/LoadingPage/style/index.js +1 -0
  193. package/lib/LoadingPage/style/style.css +0 -0
  194. package/lib/Modal/add.js +68 -0
  195. package/lib/Modal/confirm.js +88 -0
  196. package/lib/Modal/edit.js +44 -0
  197. package/lib/Modal/exportModal.js +300 -0
  198. package/lib/Modal/index.js +24 -0
  199. package/lib/Modal/style/index.js +3 -0
  200. package/lib/Modal/style/style.css +119 -0
  201. package/lib/PopTable/BseTable.js +113 -0
  202. package/lib/PopTable/index.js +151 -0
  203. package/lib/PopTable/style/index.js +3 -0
  204. package/lib/PopTable/style/style.css +363 -0
  205. package/lib/ProTable/ImgList/body.js +111 -0
  206. package/lib/ProTable/ImgList/cardCell.js +179 -0
  207. package/lib/ProTable/ImgList/context.js +12 -0
  208. package/lib/ProTable/ImgList/empty.js +24 -0
  209. package/lib/ProTable/ImgList/footer.js +59 -0
  210. package/lib/ProTable/ImgList/imgCell.js +181 -0
  211. package/lib/ProTable/ImgList/imgTable.js +110 -0
  212. package/lib/ProTable/ImgList/index.js +13 -0
  213. package/lib/ProTable/Table.js +321 -0
  214. package/lib/ProTable/VList.js +594 -0
  215. package/lib/ProTable/context.js +12 -0
  216. package/lib/ProTable/index.js +16 -0
  217. package/lib/ProTable/resetConfig.js +39 -0
  218. package/lib/ProTable/style/index.js +3 -0
  219. package/lib/ProTable/style/style.css +693 -0
  220. package/lib/TableRender/index.js +15 -0
  221. package/lib/TableRender/state.js +72 -0
  222. package/lib/TableRender/style/index.js +3 -0
  223. package/lib/TableRender/style/style.css +0 -0
  224. package/lib/UploadOss/index.js +18 -0
  225. package/lib/UploadOss/style/index.js +3 -0
  226. package/lib/UploadOss/style/style.css +121 -0
  227. package/lib/UploadOss/uploadBtn.js +141 -0
  228. package/lib/UploadOss/uploadImg.js +282 -0
  229. package/lib/VirtualList/index.js +84 -0
  230. package/lib/VirtualList/style/index.js +3 -0
  231. package/lib/VirtualList/style/style.css +0 -0
  232. package/lib/index.js +135 -0
  233. package/lib/services/newRequest.js +201 -0
  234. package/lib/services/utils.js +72 -0
  235. package/lib/styles/icon.css +15 -0
  236. package/lib/styles/main.css +149 -0
  237. package/lib/styles/resetAntd.css +62 -0
  238. package/lib/styles/them.css +0 -0
  239. package/package.json +102 -0
@@ -0,0 +1,530 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.default = void 0;
11
+
12
+ require("antd/es/date-picker/style");
13
+
14
+ var _datePicker = _interopRequireDefault(require("antd/es/date-picker"));
15
+
16
+ require("antd/es/radio/style");
17
+
18
+ var _radio = _interopRequireDefault(require("antd/es/radio"));
19
+
20
+ require("antd/es/checkbox/style");
21
+
22
+ var _checkbox = _interopRequireDefault(require("antd/es/checkbox"));
23
+
24
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
25
+
26
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
27
+
28
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
29
+
30
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
31
+
32
+ require("antd/es/input/style");
33
+
34
+ var _input = _interopRequireDefault(require("antd/es/input"));
35
+
36
+ var _classnames = _interopRequireDefault(require("classnames"));
37
+
38
+ var _moment = _interopRequireDefault(require("moment"));
39
+
40
+ var _react = _interopRequireWildcard(require("react"));
41
+
42
+ var _lodash = require("lodash");
43
+
44
+ var _IconFont = _interopRequireDefault(require("../../IconFont"));
45
+
46
+ var _VirtualList = _interopRequireDefault(require("../../VirtualList"));
47
+
48
+ var _utils = require("../utils");
49
+
50
+ var _excluded = ["item"],
51
+ _excluded2 = ["item"],
52
+ _excluded3 = ["item"],
53
+ _excluded4 = ["item"],
54
+ _excluded5 = ["type"];
55
+
56
+ // 输入框过滤器
57
+ var InputFilter = function InputFilter(_ref) {
58
+ var getFilterValue = _ref.getFilterValue,
59
+ setFilterValue = _ref.setFilterValue;
60
+ var inputRef = (0, _react.useRef)(null); // 单选事件
61
+
62
+ var onChange = function onChange(val) {
63
+ return setFilterValue(val);
64
+ };
65
+
66
+ return /*#__PURE__*/_react.default.createElement("div", {
67
+ className: "filter_dropdown"
68
+ }, /*#__PURE__*/_react.default.createElement("div", {
69
+ className: "filter_header"
70
+ }, /*#__PURE__*/_react.default.createElement(_input.default.Search, {
71
+ ref: inputRef,
72
+ defaultValue: getFilterValue,
73
+ allowClear: true,
74
+ size: "small",
75
+ placeholder: "\u8BF7\u8F93\u5165",
76
+ onSearch: onChange
77
+ })));
78
+ }; // 下拉单选过滤器
79
+
80
+
81
+ var SelectFilter = function SelectFilter(_ref2) {
82
+ var filters = _ref2.filters,
83
+ getFilterValue = _ref2.getFilterValue,
84
+ setFilterValue = _ref2.setFilterValue;
85
+ var inputRef = (0, _react.useRef)(null); // 搜索后的筛选项
86
+
87
+ var _useState = (0, _react.useState)(filters),
88
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
89
+ options = _useState2[0],
90
+ setOptions = _useState2[1]; // 是否存在搜索, 当数据大于8时存在搜索
91
+
92
+
93
+ var isSearch = (0, _react.useMemo)(function () {
94
+ return filters.length > 8;
95
+ }, [filters.length]); // 搜索
96
+
97
+ var handleFilter = function handleFilter(val) {
98
+ setOptions(filters.filter(function (v) {
99
+ return v.label.indexOf(val) > -1;
100
+ }));
101
+ }; // 单选事件
102
+
103
+
104
+ var onChange = function onChange(e, item) {
105
+ e.preventDefault();
106
+ setFilterValue(item.value);
107
+ };
108
+
109
+ return /*#__PURE__*/_react.default.createElement("div", {
110
+ className: "filter_dropdown"
111
+ }, isSearch && /*#__PURE__*/_react.default.createElement("div", {
112
+ className: "filter_header"
113
+ }, /*#__PURE__*/_react.default.createElement(_input.default.Search, {
114
+ ref: inputRef,
115
+ allowClear: true,
116
+ size: "small",
117
+ placeholder: "\u8BF7\u8F93\u5165",
118
+ onSearch: handleFilter,
119
+ onChange: (0, _lodash.debounce)(function (e) {
120
+ return handleFilter(e.target.value);
121
+ }, 500)
122
+ })), /*#__PURE__*/_react.default.createElement("div", {
123
+ className: "filter_body"
124
+ }, /*#__PURE__*/_react.default.createElement(_VirtualList.default, {
125
+ options: options,
126
+ className: "filter_list"
127
+ }, function (_ref3) {
128
+ var item = _ref3.item,
129
+ resetProps = (0, _objectWithoutProperties2.default)(_ref3, _excluded);
130
+ return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, resetProps, {
131
+ className: (0, _classnames.default)('filter_item', {
132
+ checked: item.value === getFilterValue
133
+ }),
134
+ onClick: function onClick(e) {
135
+ return onChange(e, item);
136
+ }
137
+ }), /*#__PURE__*/_react.default.createElement("div", {
138
+ className: "filter_item-content"
139
+ }, item.label));
140
+ }), !options.length && /*#__PURE__*/_react.default.createElement("div", {
141
+ className: "filter_empty"
142
+ }, "\u6682\u65E0\u6570\u636E")));
143
+ }; // 自定义筛选下拉选过滤器
144
+
145
+
146
+ var CustomFilter = function CustomFilter(_ref4) {
147
+ var filters = _ref4.filters,
148
+ getFilterValue = _ref4.getFilterValue,
149
+ setFilterValue = _ref4.setFilterValue;
150
+
151
+ // 单选事件
152
+ var onChange = function onChange(e, item) {
153
+ e.preventDefault();
154
+ setFilterValue(item);
155
+ };
156
+
157
+ var handleAdd = function handleAdd(e) {
158
+ e.preventDefault();
159
+ setFilterValue('', 'add');
160
+ };
161
+
162
+ var handleEdit = function handleEdit(e, item) {
163
+ e.stopPropagation();
164
+ setFilterValue(item, 'edit');
165
+ };
166
+
167
+ return /*#__PURE__*/_react.default.createElement("div", {
168
+ className: "filter_dropdown"
169
+ }, /*#__PURE__*/_react.default.createElement("div", {
170
+ className: "filter_body"
171
+ }, /*#__PURE__*/_react.default.createElement(_VirtualList.default, {
172
+ options: filters,
173
+ className: "filter_list"
174
+ }, function (_ref5) {
175
+ var item = _ref5.item,
176
+ resetProps = (0, _objectWithoutProperties2.default)(_ref5, _excluded2);
177
+ return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, resetProps, {
178
+ className: (0, _classnames.default)('filter_item', {
179
+ checked: item.value === getFilterValue
180
+ }),
181
+ onClick: function onClick(e) {
182
+ return onChange(e, item);
183
+ }
184
+ }), /*#__PURE__*/_react.default.createElement("div", {
185
+ className: "filter_item-content"
186
+ }, item.label), /*#__PURE__*/_react.default.createElement("div", {
187
+ className: "filter_item_operate"
188
+ }, item.default ? '默认' : /*#__PURE__*/_react.default.createElement(_IconFont.default, {
189
+ type: "lmweb-edit",
190
+ className: "hover_show icon_top",
191
+ onClick: function onClick(e) {
192
+ return handleEdit(e, item);
193
+ }
194
+ })));
195
+ }), /*#__PURE__*/_react.default.createElement("div", {
196
+ className: "filter_item add_more",
197
+ onClick: function onClick(e) {
198
+ return handleAdd(e);
199
+ }
200
+ }, /*#__PURE__*/_react.default.createElement("div", {
201
+ className: "filter_item-content"
202
+ }, /*#__PURE__*/_react.default.createElement(_IconFont.default, {
203
+ type: "lmweb-plus"
204
+ }), "\u65B0\u589E\u81EA\u5B9A\u4E49\u67E5\u8BE2")), !filters.length && /*#__PURE__*/_react.default.createElement("div", {
205
+ className: "filter_empty"
206
+ }, "\u6682\u65E0\u6570\u636E")));
207
+ }; // 下拉多选过滤器: 要过滤的数据, 当前选中项, 触发过滤, 过滤前的数据
208
+
209
+
210
+ var CheckboxFilter = function CheckboxFilter(_ref6) {
211
+ var filters = _ref6.filters,
212
+ getFilterValue = _ref6.getFilterValue,
213
+ setFilterValue = _ref6.setFilterValue;
214
+ var inputRef = (0, _react.useRef)(null);
215
+
216
+ var _useState3 = (0, _react.useState)(getFilterValue || []),
217
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
218
+ checkedValues = _useState4[0],
219
+ setCheckedValues = _useState4[1]; // 搜索后的筛选项
220
+
221
+
222
+ var _useState5 = (0, _react.useState)(filters),
223
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
224
+ options = _useState6[0],
225
+ setOptions = _useState6[1]; // 是否存在搜索, 当数据大于8时存在搜索
226
+
227
+
228
+ var isSearch = (0, _react.useMemo)(function () {
229
+ return filters.length > 8;
230
+ }, [filters.length]); // 是否半选
231
+
232
+ var indeterminate = (0, _react.useMemo)(function () {
233
+ return checkedValues.length && checkedValues.length < filters.length;
234
+ }, [checkedValues.length, filters.length]); // 是否全选
235
+
236
+ var checkAll = (0, _react.useMemo)(function () {
237
+ return checkedValues.length === filters.length;
238
+ }, [checkedValues.length, filters.length]); // 全选事件
239
+
240
+ var onCheckAllChange = function onCheckAllChange() {
241
+ var nValue = checkAll ? [] : filters.map(function (v) {
242
+ return v.value;
243
+ });
244
+ setCheckedValues(nValue);
245
+ }; // 搜索
246
+
247
+
248
+ var handleFilter = function handleFilter(val) {
249
+ setOptions(filters.filter(function (v) {
250
+ return v.label.indexOf(val) > -1;
251
+ }));
252
+ }; // 确定
253
+
254
+
255
+ var handleSure = function handleSure() {
256
+ setFilterValue(checkedValues);
257
+ }; // 清空
258
+
259
+
260
+ var handleReset = function handleReset() {
261
+ inputRef.current.state.value = '';
262
+ setFilterValue(undefined);
263
+ }; // 单选事件
264
+ // const onChange = (values) => setCheckedValues(values || undefined);
265
+
266
+
267
+ var onChange = function onChange(e, item) {
268
+ e.preventDefault();
269
+ var arr = checkedValues.includes(item.value) ? checkedValues.filter(function (v) {
270
+ return v !== item.value;
271
+ }) : [].concat((0, _toConsumableArray2.default)(checkedValues), [item.value]);
272
+ setCheckedValues(arr || undefined);
273
+ !isSearch && setFilterValue(arr, 'single');
274
+ };
275
+
276
+ return /*#__PURE__*/_react.default.createElement("div", {
277
+ className: "filter_dropdown"
278
+ }, isSearch && /*#__PURE__*/_react.default.createElement("div", {
279
+ className: "filter_header"
280
+ }, /*#__PURE__*/_react.default.createElement(_input.default.Search, {
281
+ ref: inputRef,
282
+ allowClear: true,
283
+ size: "small",
284
+ placeholder: "\u8BF7\u8F93\u5165",
285
+ onSearch: handleFilter,
286
+ onChange: (0, _lodash.debounce)(function (e) {
287
+ return handleFilter(e.target.value);
288
+ }, 500)
289
+ }), /*#__PURE__*/_react.default.createElement("div", {
290
+ className: "filter_header_operate"
291
+ }, /*#__PURE__*/_react.default.createElement(_checkbox.default, {
292
+ indeterminate: indeterminate,
293
+ onChange: onCheckAllChange,
294
+ checked: checkAll,
295
+ className: "filter_tip"
296
+ }, "\u5168\u90E8"), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("span", {
297
+ className: "filter_tip"
298
+ }, "\u5DF2\u9009: ", checkedValues.length)))), /*#__PURE__*/_react.default.createElement(_checkbox.default.Group, {
299
+ value: checkedValues,
300
+ className: "filter_body"
301
+ }, /*#__PURE__*/_react.default.createElement(_VirtualList.default, {
302
+ options: options,
303
+ className: "filter_list"
304
+ }, function (_ref7) {
305
+ var item = _ref7.item,
306
+ resetProps = (0, _objectWithoutProperties2.default)(_ref7, _excluded3);
307
+ return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, resetProps, {
308
+ className: (0, _classnames.default)('filter_item', {
309
+ checked: checkedValues.includes(item.value)
310
+ }),
311
+ onClick: function onClick(e) {
312
+ return onChange(e, item);
313
+ }
314
+ }), /*#__PURE__*/_react.default.createElement(_checkbox.default, {
315
+ value: item.value,
316
+ className: "filter_item-content"
317
+ }, item.label));
318
+ }), !options.length && /*#__PURE__*/_react.default.createElement("div", {
319
+ className: "filter_empty"
320
+ }, "\u6682\u65E0\u6570\u636E")), isSearch && /*#__PURE__*/_react.default.createElement("div", {
321
+ className: "filter_footer"
322
+ }, /*#__PURE__*/_react.default.createElement("div", {
323
+ className: "footer_save",
324
+ onClick: handleSure
325
+ }, "\u786E\u5B9A"), /*#__PURE__*/_react.default.createElement("div", {
326
+ className: "footer_clear",
327
+ onClick: handleReset
328
+ }, "\u6E05\u7A7A")));
329
+ }; // 更多筛选
330
+
331
+
332
+ var MoreFilter = function MoreFilter(_ref8) {
333
+ var filters = _ref8.filters,
334
+ getFilterValue = _ref8.getFilterValue,
335
+ setFilterValue = _ref8.setFilterValue;
336
+ // 选中的数据
337
+ var checkedValues = (0, _react.useMemo)(function () {
338
+ return getFilterValue;
339
+ }, [getFilterValue]); // 排序后的数组
340
+
341
+ var options = (0, _react.useMemo)(function () {
342
+ return filters;
343
+ }, [filters]); // 是否可置顶, 第一项无置顶操作, 所以这里的index > 0
344
+
345
+ var isTop = (0, _react.useCallback)(function (item) {
346
+ return checkedValues.includes(item.field) && filters.findIndex(function (v) {
347
+ return v.field === item.field;
348
+ }) > 0;
349
+ }, [checkedValues, filters]); // 是否半选
350
+
351
+ var indeterminate = (0, _react.useMemo)(function () {
352
+ return checkedValues.length && checkedValues.length < options.length;
353
+ }, [checkedValues.length, options.length]); // 是否全选
354
+
355
+ var checkAll = (0, _react.useMemo)(function () {
356
+ return checkedValues.length === options.length;
357
+ }, [checkedValues.length, options.length]); // 全选事件
358
+
359
+ var onCheckAllChange = function onCheckAllChange() {
360
+ // const nValue = checkAll ? [] : options.map(v => v.field);
361
+ // setCheckedValues(nValue);
362
+ setFilterValue(options, checkAll ? 'hidden' : 'show');
363
+ }; // 重置
364
+
365
+
366
+ var handleReset = function handleReset() {
367
+ return setFilterValue(null, 'reset');
368
+ }; // 置顶操作, 防止频繁操作, 建议加上节流
369
+
370
+
371
+ var handleTop = function handleTop(e, item) {
372
+ e.stopPropagation();
373
+ setFilterValue(item, 'top');
374
+ }; // 单选事件
375
+
376
+
377
+ var onChange = function onChange(e, item) {
378
+ e.preventDefault();
379
+ setFilterValue(item);
380
+ };
381
+
382
+ return /*#__PURE__*/_react.default.createElement("div", {
383
+ className: "filter_dropdown"
384
+ }, /*#__PURE__*/_react.default.createElement("div", {
385
+ className: "filter_header"
386
+ }, /*#__PURE__*/_react.default.createElement("div", {
387
+ className: "filter_header_operate"
388
+ }, /*#__PURE__*/_react.default.createElement(_checkbox.default, {
389
+ indeterminate: indeterminate,
390
+ onChange: onCheckAllChange,
391
+ checked: checkAll
392
+ }, "\u5168\u90E8"), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("span", {
393
+ className: "filter_reset",
394
+ onClick: handleReset
395
+ }, "\u91CD\u7F6E")))), /*#__PURE__*/_react.default.createElement(_checkbox.default.Group, {
396
+ value: checkedValues,
397
+ className: "filter_body"
398
+ }, /*#__PURE__*/_react.default.createElement(_VirtualList.default, {
399
+ options: options,
400
+ className: "filter_list"
401
+ }, function (_ref9) {
402
+ var item = _ref9.item,
403
+ resetProps = (0, _objectWithoutProperties2.default)(_ref9, _excluded4);
404
+ return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, resetProps, {
405
+ className: "filter_item",
406
+ onClick: function onClick(e) {
407
+ return onChange(e, item);
408
+ }
409
+ }), /*#__PURE__*/_react.default.createElement(_checkbox.default, {
410
+ value: item.field,
411
+ className: "filter_item-content"
412
+ }, item.title), /*#__PURE__*/_react.default.createElement("div", {
413
+ className: "filter_item_operate"
414
+ }, isTop(item) && /*#__PURE__*/_react.default.createElement(_IconFont.default, {
415
+ type: "lmweb-vertical-align-top",
416
+ className: "hover_show icon_top",
417
+ onClick: function onClick(e) {
418
+ return handleTop(e, item);
419
+ }
420
+ })));
421
+ })));
422
+ }; // 日期范围选择器
423
+
424
+
425
+ var DatePickerFilter = function DatePickerFilter(_ref10) {
426
+ var getFilterValue = _ref10.getFilterValue,
427
+ setFilterValue = _ref10.setFilterValue,
428
+ props = _ref10.props;
429
+ // 对日期格式的转换, 日期组件仅接收moment格式
430
+ var value = (0, _react.useMemo)(function () {
431
+ var nValue;
432
+
433
+ if (getFilterValue) {
434
+ nValue = [(0, _moment.default)(getFilterValue[0]), (0, _moment.default)(getFilterValue[1])];
435
+ }
436
+
437
+ return nValue;
438
+ }, [getFilterValue]); // 最近的时间段, 值为JSON转换后的字符串
439
+
440
+ var ranges = (0, _react.useMemo)(function () {
441
+ return Object.entries((0, _utils.getRanges)()).map(function (item, i) {
442
+ return {
443
+ id: i,
444
+ label: item[0],
445
+ value: JSON.stringify(item[1])
446
+ };
447
+ });
448
+ }, []); // 选中时间段的触发
449
+
450
+ var onChange = function onChange(dates, dateStrings) {
451
+ setFilterValue((0, _utils.getIsHas)(dateStrings.filter(function (v) {
452
+ return !!v;
453
+ })) ? dateStrings : null);
454
+ }; // 最近的时间触发事件
455
+
456
+
457
+ var handleLastDateOnChange = function handleLastDateOnChange(e) {
458
+ var nValue = JSON.parse(e.target.value);
459
+ setFilterValue(nValue);
460
+ };
461
+
462
+ var panelRender = function panelRender(panelNode) {
463
+ return /*#__PURE__*/_react.default.createElement("div", {
464
+ className: "filter_picker_box"
465
+ }, /*#__PURE__*/_react.default.createElement("div", {
466
+ className: "filter_picker_main"
467
+ }, /*#__PURE__*/_react.default.createElement("div", {
468
+ className: "filter_picker_header"
469
+ }, /*#__PURE__*/_react.default.createElement("div", {
470
+ className: "filter_picker_header_tip"
471
+ }, getFilterValue && "".concat(getFilterValue[0], " - ").concat(getFilterValue[1])), /*#__PURE__*/_react.default.createElement("div", {
472
+ className: "filter_picker_header_operate"
473
+ }, /*#__PURE__*/_react.default.createElement(_radio.default.Group, {
474
+ value: JSON.stringify(getFilterValue),
475
+ onChange: handleLastDateOnChange,
476
+ size: "small"
477
+ }, ranges.map(function (v) {
478
+ return /*#__PURE__*/_react.default.createElement(_radio.default.Button, {
479
+ key: v.label,
480
+ value: v.value
481
+ }, v.label);
482
+ })))), panelNode));
483
+ };
484
+
485
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_datePicker.default.RangePicker, (0, _extends2.default)({
486
+ value: value,
487
+ onChange: onChange,
488
+ panelRender: panelRender,
489
+ dropdownClassName: "lm_filter_dropdown_picker",
490
+ bordered: false,
491
+ picker: "date",
492
+ size: "small",
493
+ separator: "\u81F3",
494
+ placeholder: ['开始日期', '结束日期'],
495
+ style: {
496
+ width: 200
497
+ }
498
+ }, props)));
499
+ };
500
+
501
+ var FilterComp = function FilterComp(props) {
502
+ var type = props.type,
503
+ resetProps = (0, _objectWithoutProperties2.default)(props, _excluded5);
504
+
505
+ switch (type) {
506
+ case 'input':
507
+ return /*#__PURE__*/_react.default.createElement(InputFilter, resetProps);
508
+
509
+ case 'select':
510
+ return /*#__PURE__*/_react.default.createElement(SelectFilter, resetProps);
511
+
512
+ case 'checkbox':
513
+ return /*#__PURE__*/_react.default.createElement(CheckboxFilter, resetProps);
514
+
515
+ case 'datePicker':
516
+ return /*#__PURE__*/_react.default.createElement(DatePickerFilter, resetProps);
517
+
518
+ case 'custom':
519
+ return /*#__PURE__*/_react.default.createElement(CustomFilter, resetProps);
520
+
521
+ case 'more':
522
+ return /*#__PURE__*/_react.default.createElement(MoreFilter, resetProps);
523
+
524
+ default:
525
+ return /*#__PURE__*/_react.default.createElement(CheckboxFilter, resetProps);
526
+ }
527
+ };
528
+
529
+ var _default = FilterComp;
530
+ exports.default = _default;