amis 2.0.0-rc.10 → 2.0.0-rc.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (209) hide show
  1. package/lib/Schema.d.ts +3 -2
  2. package/lib/compat.js +1 -1
  3. package/lib/index.d.ts +1 -0
  4. package/lib/index.js +2 -1
  5. package/lib/preset.js +1 -1
  6. package/lib/renderers/Action.js +1 -1
  7. package/lib/renderers/Alert.js +1 -1
  8. package/lib/renderers/AnchorNav.js +1 -1
  9. package/lib/renderers/App.js +1 -1
  10. package/lib/renderers/Audio.js +1 -1
  11. package/lib/renderers/Avatar.js +1 -1
  12. package/lib/renderers/BarCode.js +1 -1
  13. package/lib/renderers/Breadcrumb.js +1 -1
  14. package/lib/renderers/ButtonGroup.d.ts +2 -2
  15. package/lib/renderers/ButtonGroup.js +1 -1
  16. package/lib/renderers/CRUD.js +3 -3
  17. package/lib/renderers/CRUD2.d.ts +213 -0
  18. package/lib/renderers/CRUD2.js +722 -0
  19. package/lib/renderers/Calendar.js +1 -1
  20. package/lib/renderers/Card.js +1 -1
  21. package/lib/renderers/Card2.d.ts +1 -1
  22. package/lib/renderers/Card2.js +3 -3
  23. package/lib/renderers/Cards.d.ts +4 -0
  24. package/lib/renderers/Cards.js +50 -6
  25. package/lib/renderers/Carousel.js +1 -1
  26. package/lib/renderers/Chart.js +19 -3
  27. package/lib/renderers/Code.js +1 -1
  28. package/lib/renderers/Collapse.js +1 -1
  29. package/lib/renderers/CollapseGroup.js +1 -1
  30. package/lib/renderers/Color.js +1 -1
  31. package/lib/renderers/Container.js +1 -1
  32. package/lib/renderers/Copyable.js +1 -1
  33. package/lib/renderers/Custom.js +1 -1
  34. package/lib/renderers/Date.js +1 -1
  35. package/lib/renderers/Dialog.d.ts +40 -40
  36. package/lib/renderers/Dialog.js +1 -1
  37. package/lib/renderers/Divider.js +1 -1
  38. package/lib/renderers/Drawer.js +1 -1
  39. package/lib/renderers/DropDownButton.js +1 -1
  40. package/lib/renderers/Each.js +1 -1
  41. package/lib/renderers/Flex.js +1 -1
  42. package/lib/renderers/Form/ButtonGroupSelect.js +1 -1
  43. package/lib/renderers/Form/ButtonToolbar.js +1 -1
  44. package/lib/renderers/Form/ChainedSelect.js +2 -2
  45. package/lib/renderers/Form/ChartRadios.js +1 -1
  46. package/lib/renderers/Form/Checkbox.js +1 -1
  47. package/lib/renderers/Form/Checkboxes.js +1 -1
  48. package/lib/renderers/Form/Combo.js +1 -1
  49. package/lib/renderers/Form/ConditionBuilder.d.ts +10 -0
  50. package/lib/renderers/Form/ConditionBuilder.js +7 -3
  51. package/lib/renderers/Form/Control.js +1 -1
  52. package/lib/renderers/Form/DiffEditor.d.ts +68 -22
  53. package/lib/renderers/Form/DiffEditor.js +1 -1
  54. package/lib/renderers/Form/Editor.d.ts +68 -22
  55. package/lib/renderers/Form/Editor.js +1 -1
  56. package/lib/renderers/Form/FieldSet.js +1 -1
  57. package/lib/renderers/Form/Formula.js +1 -1
  58. package/lib/renderers/Form/Group.js +1 -1
  59. package/lib/renderers/Form/Hidden.js +1 -1
  60. package/lib/renderers/Form/IconPicker.js +1 -1
  61. package/lib/renderers/Form/IconPickerIcons.js +1 -1
  62. package/lib/renderers/Form/InputArray.js +1 -1
  63. package/lib/renderers/Form/InputCity.d.ts +40 -40
  64. package/lib/renderers/Form/InputCity.js +1 -1
  65. package/lib/renderers/Form/InputColor.d.ts +40 -40
  66. package/lib/renderers/Form/InputColor.js +1 -1
  67. package/lib/renderers/Form/InputDate.js +1 -1
  68. package/lib/renderers/Form/InputDateRange.js +1 -1
  69. package/lib/renderers/Form/InputExcel.js +1 -1
  70. package/lib/renderers/Form/InputFile.js +2 -2
  71. package/lib/renderers/Form/InputFormula.js +1 -1
  72. package/lib/renderers/Form/InputGroup.js +1 -1
  73. package/lib/renderers/Form/InputImage.js +1 -1
  74. package/lib/renderers/Form/InputMonthRange.js +1 -1
  75. package/lib/renderers/Form/InputNumber.js +1 -1
  76. package/lib/renderers/Form/InputQuarterRange.js +1 -1
  77. package/lib/renderers/Form/InputRange.js +1 -1
  78. package/lib/renderers/Form/InputRating.js +1 -1
  79. package/lib/renderers/Form/InputRepeat.js +1 -1
  80. package/lib/renderers/Form/InputRichText.js +1 -1
  81. package/lib/renderers/Form/InputSubForm.js +1 -1
  82. package/lib/renderers/Form/InputTable.js +2 -2
  83. package/lib/renderers/Form/InputTag.js +1 -1
  84. package/lib/renderers/Form/InputText.js +1 -1
  85. package/lib/renderers/Form/InputTree.js +1 -1
  86. package/lib/renderers/Form/InputYearRange.js +1 -1
  87. package/lib/renderers/Form/JSONSchema.js +1 -1
  88. package/lib/renderers/Form/JSONSchemaEditor.js +1 -1
  89. package/lib/renderers/Form/ListSelect.js +1 -1
  90. package/lib/renderers/Form/LocationPicker.js +1 -1
  91. package/lib/renderers/Form/MatrixCheckboxes.js +1 -1
  92. package/lib/renderers/Form/NestedSelect.js +1 -1
  93. package/lib/renderers/Form/Picker.js +1 -1
  94. package/lib/renderers/Form/Radios.js +1 -1
  95. package/lib/renderers/Form/Select.js +1 -1
  96. package/lib/renderers/Form/Static.js +1 -1
  97. package/lib/renderers/Form/Switch.js +1 -1
  98. package/lib/renderers/Form/TabsTransfer.js +1 -1
  99. package/lib/renderers/Form/TabsTransferPicker.js +1 -1
  100. package/lib/renderers/Form/Textarea.d.ts +2 -1
  101. package/lib/renderers/Form/Textarea.js +13 -2
  102. package/lib/renderers/Form/Transfer.js +1 -1
  103. package/lib/renderers/Form/TransferPicker.js +1 -1
  104. package/lib/renderers/Form/TreeSelect.js +1 -1
  105. package/lib/renderers/Form/UUID.js +1 -1
  106. package/lib/renderers/Form/UserSelect.js +3 -3
  107. package/lib/renderers/Grid.js +1 -1
  108. package/lib/renderers/Grid2D.js +1 -1
  109. package/lib/renderers/GridNav.js +1 -1
  110. package/lib/renderers/HBox.js +1 -1
  111. package/lib/renderers/IFrame.js +1 -1
  112. package/lib/renderers/Icon.d.ts +1 -1
  113. package/lib/renderers/Icon.js +11 -6
  114. package/lib/renderers/Image.js +1 -1
  115. package/lib/renderers/Images.js +1 -1
  116. package/lib/renderers/Json.js +1 -1
  117. package/lib/renderers/Link.js +1 -1
  118. package/lib/renderers/List.js +1 -1
  119. package/lib/renderers/Log.js +1 -1
  120. package/lib/renderers/Mapping.js +1 -1
  121. package/lib/renderers/Markdown.js +1 -1
  122. package/lib/renderers/Nav.d.ts +10 -10
  123. package/lib/renderers/Nav.js +1 -1
  124. package/lib/renderers/Operation.js +1 -1
  125. package/lib/renderers/Page.js +1 -1
  126. package/lib/renderers/Pagination.js +1 -1
  127. package/lib/renderers/PaginationWrapper.js +1 -1
  128. package/lib/renderers/Panel.js +1 -1
  129. package/lib/renderers/Plain.js +1 -1
  130. package/lib/renderers/PopOver.js +1 -1
  131. package/lib/renderers/Portlet.js +1 -1
  132. package/lib/renderers/Progress.js +1 -1
  133. package/lib/renderers/Property.js +1 -1
  134. package/lib/renderers/QRCode.js +1 -1
  135. package/lib/renderers/QuickEdit.js +1 -1
  136. package/lib/renderers/Remark.d.ts +1 -1
  137. package/lib/renderers/Remark.js +1 -1
  138. package/lib/renderers/SearchBox.js +1 -1
  139. package/lib/renderers/Service.js +1 -1
  140. package/lib/renderers/SparkLine.js +1 -1
  141. package/lib/renderers/Spinner.js +1 -1
  142. package/lib/renderers/Status.js +1 -1
  143. package/lib/renderers/Steps.js +3 -2
  144. package/lib/renderers/Table/ColumnToggler.js +1 -1
  145. package/lib/renderers/Table/HeadCellFilterDropdown.js +1 -1
  146. package/lib/renderers/Table/HeadCellSearchDropdown.js +1 -1
  147. package/lib/renderers/Table/ItemActionsWrapper.js +1 -1
  148. package/lib/renderers/Table/TableBody.js +1 -1
  149. package/lib/renderers/Table/TableCell.js +1 -1
  150. package/lib/renderers/Table/TableContent.js +1 -1
  151. package/lib/renderers/Table/TableRow.js +1 -1
  152. package/lib/renderers/Table/exportExcel.js +2 -2
  153. package/lib/renderers/Table/index.d.ts +1 -0
  154. package/lib/renderers/Table/index.js +15 -1
  155. package/lib/renderers/Table-v2/ColumnToggler.js +1 -1
  156. package/lib/renderers/Table-v2/HeadCellSearchDropdown.js +1 -1
  157. package/lib/renderers/Table-v2/TableCell.js +1 -1
  158. package/lib/renderers/Table-v2/index.d.ts +8 -5
  159. package/lib/renderers/Table-v2/index.js +81 -54
  160. package/lib/renderers/TableView.js +1 -1
  161. package/lib/renderers/Tabs.js +1 -1
  162. package/lib/renderers/Tag.js +1 -1
  163. package/lib/renderers/Tasks.js +1 -1
  164. package/lib/renderers/Timeline.js +1 -1
  165. package/lib/renderers/TooltipWrapper.js +1 -1
  166. package/lib/renderers/Tpl.js +1 -1
  167. package/lib/renderers/VBox.js +1 -1
  168. package/lib/renderers/Video.js +1 -1
  169. package/lib/renderers/WebComponent.js +1 -1
  170. package/lib/renderers/Wizard.js +1 -1
  171. package/lib/renderers/Wrapper.js +1 -1
  172. package/lib/schemaExtend.js +1 -1
  173. package/lib/themes/ang-ie11.css +190 -36
  174. package/lib/themes/ang.css +193 -38
  175. package/lib/themes/antd-ie11.css +190 -36
  176. package/lib/themes/antd.css +193 -38
  177. package/lib/themes/cxd-ie11.css +199 -45
  178. package/lib/themes/cxd.css +196 -40
  179. package/lib/themes/dark-ie11.css +190 -36
  180. package/lib/themes/dark.css +193 -38
  181. package/lib/themes/default-ie11.css +199 -45
  182. package/lib/themes/default.css +196 -40
  183. package/lib/types.d.ts +1 -1
  184. package/package.json +2 -2
  185. package/schema.json +1191 -26
  186. package/sdk/ang-ie11.css +223 -37
  187. package/sdk/ang.css +226 -39
  188. package/sdk/antd-ie11.css +223 -37
  189. package/sdk/antd.css +226 -39
  190. package/sdk/barcode.js +50 -50
  191. package/sdk/charts.js +14 -14
  192. package/sdk/codemirror.js +7 -7
  193. package/sdk/color-picker.js +65 -65
  194. package/sdk/cropperjs.js +2 -2
  195. package/sdk/cxd-ie11.css +232 -46
  196. package/sdk/cxd.css +229 -41
  197. package/sdk/dark-ie11.css +223 -37
  198. package/sdk/dark.css +226 -39
  199. package/sdk/exceljs.js +1 -1
  200. package/sdk/markdown.js +68 -68
  201. package/sdk/papaparse.js +1 -1
  202. package/sdk/rest.js +24 -24
  203. package/sdk/rich-text.js +62 -62
  204. package/sdk/sdk-ie11.css +232 -46
  205. package/sdk/sdk.css +229 -41
  206. package/sdk/sdk.js +1359 -1357
  207. package/sdk/thirds/hls.js/hls.js +1 -1
  208. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  209. package/sdk/tinymce.js +57 -57
@@ -0,0 +1,722 @@
1
+ /**
2
+ * amis v2.0.0-rc.14
3
+ * Copyright 2018-2022 baidu
4
+ */
5
+
6
+ 'use strict';
7
+
8
+ Object.defineProperty(exports, '__esModule', { value: true });
9
+
10
+ var tslib = require('tslib');
11
+ var React = require('react');
12
+ var amisCore = require('amis-core');
13
+ var pick = require('lodash/pick');
14
+ var ReactDOM = require('react-dom');
15
+ var findIndex = require('lodash/findIndex');
16
+ var amisUi = require('amis-ui');
17
+ var lodash = require('lodash');
18
+
19
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
20
+
21
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
22
+ var pick__default = /*#__PURE__*/_interopDefaultLegacy(pick);
23
+ var findIndex__default = /*#__PURE__*/_interopDefaultLegacy(findIndex);
24
+
25
+ var CRUD2 = /** @class */ (function (_super) {
26
+ tslib.__extends(CRUD2, _super);
27
+ function CRUD2(props) {
28
+ var _this = _super.call(this, props) || this;
29
+ _this.stopingAutoRefresh = false;
30
+ var location = props.location, store = props.store, syncLocation = props.syncLocation, pageField = props.pageField, perPageField = props.perPageField;
31
+ _this.mounted = true;
32
+ if (syncLocation && location && (location.query || location.search)) {
33
+ store.updateQuery(amisCore.qsparse(location.search.substring(1)), undefined, pageField, perPageField);
34
+ }
35
+ else if (syncLocation && !location && window.location.search) {
36
+ store.updateQuery(amisCore.qsparse(window.location.search.substring(1)), undefined, pageField, perPageField);
37
+ }
38
+ // 如果有 api,data 里面先写个 空数组,面得继承外层的 items
39
+ // 比如 crud 打开一个弹框,里面也是个 crud,默认一开始其实显示
40
+ // 的是外层 crud 的数据,等接口回来后就会变成新的。
41
+ // 加上这个就是为了解决这种情况
42
+ if (_this.props.api) {
43
+ _this.props.store.updateData({
44
+ items: []
45
+ });
46
+ }
47
+ return _this;
48
+ }
49
+ CRUD2.prototype.componentDidMount = function () {
50
+ var _a = this.props, store = _a.store, pickerMode = _a.pickerMode, loadType = _a.loadType, loadDataOnce = _a.loadDataOnce, perPage = _a.perPage;
51
+ // 初始化分页
52
+ var pagination = loadType && !!loadDataOnce;
53
+ if (pagination) {
54
+ store.changePage(store.page, perPage);
55
+ }
56
+ // 初始化筛选条件
57
+ this.initQuery({});
58
+ if (pickerMode) {
59
+ // 解析picker组件默认值
60
+ var val = amisCore.getPropValue(this.props);
61
+ val && store.setSelectedItems(val);
62
+ }
63
+ };
64
+ CRUD2.prototype.componentDidUpdate = function (prevProps) {
65
+ var props = this.props;
66
+ var store = prevProps.store;
67
+ // picker外部引起的值变化处理
68
+ var val;
69
+ if (this.props.pickerMode &&
70
+ amisCore.isArrayChildrenModified((val = amisCore.getPropValue(this.props)), amisCore.getPropValue(prevProps))) {
71
+ store.setSelectedItems(val);
72
+ }
73
+ var dataInvalid = false;
74
+ if (prevProps.syncLocation &&
75
+ prevProps.location &&
76
+ prevProps.location.search !== props.location.search) {
77
+ // 同步地址栏,那么直接检测 query 是否变了,变了就重新拉数据
78
+ store.updateQuery(amisCore.qsparse(props.location.search.substring(1)), undefined, props.pageField, props.perPageField);
79
+ dataInvalid = !!(props.api && amisCore.isObjectShallowModified(store.query, this.lastQuery, false));
80
+ }
81
+ if (dataInvalid) ;
82
+ else if (prevProps.api &&
83
+ props.api &&
84
+ amisCore.isApiOutdated(prevProps.api, props.api, store.fetchCtxOf(prevProps.data, {
85
+ pageField: prevProps.pageField,
86
+ perPageField: prevProps.perPageField
87
+ }), store.fetchCtxOf(props.data, {
88
+ pageField: props.pageField,
89
+ perPageField: props.perPageField
90
+ }))) {
91
+ dataInvalid = true;
92
+ }
93
+ else if (!props.api && amisCore.isPureVariable(props.source)) {
94
+ var next = amisCore.resolveVariableAndFilter(props.source, props.data, '| raw');
95
+ if (!this.lastData || this.lastData !== next) {
96
+ store.initFromScope(props.data, props.source);
97
+ this.lastData = next;
98
+ }
99
+ }
100
+ if (dataInvalid) {
101
+ this.getData();
102
+ }
103
+ };
104
+ CRUD2.prototype.componentWillUnmount = function () {
105
+ this.mounted = false;
106
+ clearTimeout(this.timer);
107
+ };
108
+ CRUD2.prototype.controlRef = function (control) {
109
+ // 因为 control 有可能被 n 层 hoc 包裹。
110
+ while (control && control.getWrappedInstance) {
111
+ control = control.getWrappedInstance();
112
+ }
113
+ this.control = control;
114
+ };
115
+ CRUD2.prototype.initQuery = function (values) {
116
+ var _a = this.props, store = _a.store, orderBy = _a.orderBy, orderDir = _a.orderDir;
117
+ var params = {};
118
+ if (orderBy) {
119
+ params['orderBy'] = orderBy;
120
+ params['orderDir'] = orderDir || 'asc';
121
+ }
122
+ this.handleSearch({
123
+ query: tslib.__assign(tslib.__assign(tslib.__assign({}, params), values), store.query),
124
+ replaceQuery: this.props.initFetch !== false
125
+ });
126
+ // 保留一次用于重置查询条件
127
+ store.setPristineQuery();
128
+ };
129
+ /**
130
+ * 加载更多动作处理器
131
+ */
132
+ CRUD2.prototype.handleLoadMore = function () {
133
+ this.getData(undefined, undefined, undefined, true);
134
+ };
135
+ /**
136
+ * 发起一次新的查询,查询条件不同,需要从第一页数据加载
137
+ */
138
+ CRUD2.prototype.handleSearch = function (data) {
139
+ var _a = this.props, store = _a.store, syncLocation = _a.syncLocation, env = _a.env, pageField = _a.pageField, perPageField = _a.perPageField;
140
+ var query = data.query, resetQuery = data.resetQuery, replaceQuery = data.replaceQuery;
141
+ query = syncLocation ? amisCore.qsparse(amisCore.qsstringify(query, undefined, true)) : query;
142
+ store.updateQuery(resetQuery ? this.props.store.pristineQuery : query, syncLocation && env && env.updateLocation
143
+ ? function (location) { return env.updateLocation(location, true); }
144
+ : undefined, pageField, perPageField, replaceQuery);
145
+ this.lastQuery = store.query;
146
+ this.getData(undefined, undefined, undefined);
147
+ };
148
+ CRUD2.prototype.handleStopAutoRefresh = function () {
149
+ this.timer && clearTimeout(this.timer);
150
+ this.stopingAutoRefresh = true;
151
+ };
152
+ CRUD2.prototype.handleStartAutoRefresh = function () {
153
+ this.stopingAutoRefresh = false;
154
+ this.reload();
155
+ };
156
+ CRUD2.prototype.reloadTarget = function (target, data) {
157
+ // implement this.
158
+ };
159
+ CRUD2.prototype.closeTarget = function (target) {
160
+ // implement this.
161
+ };
162
+ CRUD2.prototype.updateQuery = function (newQuery) {
163
+ this.props.store;
164
+ };
165
+ /**
166
+ * 更新列表数据
167
+ */
168
+ CRUD2.prototype.getData = function (
169
+ /** 静默更新,不显示加载状态 */
170
+ silent,
171
+ /** 清空已选择数据 */
172
+ clearSelection,
173
+ /** 强制重新加载 */
174
+ forceReload,
175
+ /** 加载更多数据,默认模式取props中的配置,只有事件动作需要直接触发 */
176
+ loadMore) {
177
+ var _this = this;
178
+ var _a;
179
+ if (forceReload === void 0) { forceReload = false; }
180
+ var _b = this.props, store = _b.store, api = _b.api, messages = _b.messages, pageField = _b.pageField, perPageField = _b.perPageField, interval = _b.interval, stopAutoRefreshWhen = _b.stopAutoRefreshWhen, silentPolling = _b.silentPolling; _b.syncLocation; var syncResponse2Query = _b.syncResponse2Query, keepItemSelectionOnPageChange = _b.keepItemSelectionOnPageChange, stopAutoRefreshWhenModalIsOpen = _b.stopAutoRefreshWhenModalIsOpen, pickerMode = _b.pickerMode; _b.env; var loadType = _b.loadType, loadDataOnce = _b.loadDataOnce, loadDataOnceFetchOnFilter = _b.loadDataOnceFetchOnFilter, source = _b.source, columns = _b.columns;
181
+ // reload 需要清空用户选择
182
+ if (!loadMore &&
183
+ keepItemSelectionOnPageChange &&
184
+ clearSelection &&
185
+ !pickerMode) {
186
+ store.setSelectedItems([]);
187
+ store.setUnSelectedItems([]);
188
+ }
189
+ clearTimeout(this.timer);
190
+ this.lastQuery = store.query;
191
+ var loadDataMode = loadMore !== null && loadMore !== void 0 ? loadMore : loadType === 'more';
192
+ var data = amisCore.createObject(store.data, store.query);
193
+ amisCore.isEffectiveApi(api, data)
194
+ ? store
195
+ .fetchInitData(api, data, {
196
+ successMessage: messages && messages.fetchSuccess,
197
+ errorMessage: messages && messages.fetchFailed,
198
+ autoAppend: true,
199
+ forceReload: forceReload,
200
+ loadDataOnce: loadDataOnce,
201
+ loadDataOnceFetchOnFilter: loadDataOnceFetchOnFilter,
202
+ source: source,
203
+ silent: silent,
204
+ pageField: pageField,
205
+ perPageField: perPageField,
206
+ loadDataMode: loadDataMode,
207
+ syncResponse2Query: syncResponse2Query,
208
+ columns: (_a = store.columns) !== null && _a !== void 0 ? _a : columns
209
+ })
210
+ .then(function (value) {
211
+ interval &&
212
+ !_this.stopingAutoRefresh &&
213
+ _this.mounted &&
214
+ (!stopAutoRefreshWhen ||
215
+ !(stopAutoRefreshWhen &&
216
+ amisCore.evalExpression(stopAutoRefreshWhen, amisCore.createObject(store.data, store.query)))) &&
217
+ // 弹窗期间不进行刷新
218
+ (!stopAutoRefreshWhenModalIsOpen || !store.dialogOpen) &&
219
+ (_this.timer = setTimeout(_this.getData.bind(_this, silentPolling, undefined, true), Math.max(interval, 1000)));
220
+ return value;
221
+ })
222
+ : source && store.initFromScope(data, source);
223
+ };
224
+ CRUD2.prototype.handleChangePage = function (page, perPage) {
225
+ var _a;
226
+ var _b;
227
+ var _c = this.props, store = _c.store, syncLocation = _c.syncLocation, env = _c.env, pageField = _c.pageField, perPageField = _c.perPageField, autoJumpToTopOnPagerChange = _c.autoJumpToTopOnPagerChange, affixOffsetTop = _c.affixOffsetTop;
228
+ var query = (_a = {},
229
+ _a[pageField || 'page'] = page,
230
+ _a);
231
+ if (perPage) {
232
+ query[perPageField || 'perPage'] = perPage;
233
+ }
234
+ store.updateQuery(query, syncLocation && (env === null || env === void 0 ? void 0 : env.updateLocation) ? env.updateLocation : undefined, pageField, perPageField);
235
+ this.getData();
236
+ if (autoJumpToTopOnPagerChange && this.control) {
237
+ ReactDOM.findDOMNode(this.control).scrollIntoView();
238
+ var scrolledY = window.scrollY;
239
+ var offsetTop = (_b = affixOffsetTop !== null && affixOffsetTop !== void 0 ? affixOffsetTop : env === null || env === void 0 ? void 0 : env.affixOffsetTop) !== null && _b !== void 0 ? _b : 0;
240
+ scrolledY && window.scroll(0, scrolledY - offsetTop);
241
+ }
242
+ };
243
+ CRUD2.prototype.handleSave = function (rows, diff, indexes, unModifiedItems, rowsOrigin, resetOnFailed) {
244
+ var _this = this;
245
+ var _a = this.props, store = _a.store, quickSaveApi = _a.quickSaveApi, quickSaveItemApi = _a.quickSaveItemApi, primaryField = _a.primaryField, env = _a.env, messages = _a.messages, reload = _a.reload;
246
+ if (Array.isArray(rows)) {
247
+ if (!amisCore.isEffectiveApi(quickSaveApi)) {
248
+ env && env.alert('CRUD quickSaveApi is required');
249
+ return;
250
+ }
251
+ var data_1 = amisCore.createObject(store.data, {
252
+ rows: rows,
253
+ rowsDiff: diff,
254
+ indexes: indexes,
255
+ rowsOrigin: rowsOrigin
256
+ });
257
+ if (rows.length && rows[0].hasOwnProperty(primaryField || 'id')) {
258
+ data_1.ids = rows
259
+ .map(function (item) { return item[primaryField || 'id']; })
260
+ .join(',');
261
+ }
262
+ if (unModifiedItems) {
263
+ data_1.unModifiedItems = unModifiedItems;
264
+ }
265
+ store
266
+ .saveRemote(quickSaveApi, data_1, {
267
+ successMessage: messages && messages.saveFailed,
268
+ errorMessage: messages && messages.saveSuccess
269
+ })
270
+ .then(function () {
271
+ reload && _this.reloadTarget(reload, data_1);
272
+ _this.getData(undefined, undefined, true, true);
273
+ })
274
+ .catch(function () { });
275
+ }
276
+ else {
277
+ if (!amisCore.isEffectiveApi(quickSaveItemApi)) {
278
+ env && env.alert('CRUD quickSaveItemApi is required!');
279
+ return;
280
+ }
281
+ var data_2 = amisCore.createObject(store.data, {
282
+ item: rows,
283
+ modified: diff,
284
+ origin: rowsOrigin
285
+ });
286
+ var sendData = amisCore.createObject(data_2, rows);
287
+ store
288
+ .saveRemote(quickSaveItemApi, sendData)
289
+ .then(function () {
290
+ reload && _this.reloadTarget(reload, data_2);
291
+ _this.getData(undefined, undefined, true, true);
292
+ })
293
+ .catch(function () {
294
+ resetOnFailed && _this.control.reset();
295
+ });
296
+ }
297
+ };
298
+ CRUD2.prototype.handleSaveOrder = function (moved, rows) {
299
+ var _this = this;
300
+ var _a = this.props, store = _a.store, saveOrderApi = _a.saveOrderApi, orderField = _a.orderField, primaryField = _a.primaryField, env = _a.env, reload = _a.reload;
301
+ if (!saveOrderApi) {
302
+ env && env.alert('CRUD saveOrderApi is required!');
303
+ return;
304
+ }
305
+ var model = amisCore.createObject(store.data);
306
+ var insertAfter;
307
+ var insertBefore;
308
+ var holding = [];
309
+ var hasIdField = primaryField &&
310
+ rows[0] &&
311
+ rows[0].hasOwnProperty(primaryField);
312
+ hasIdField || (model.idMap = {});
313
+ model.insertAfter = {};
314
+ rows.forEach(function (item) {
315
+ if (~moved.indexOf(item)) {
316
+ if (insertAfter) {
317
+ var insertAfterId = hasIdField
318
+ ? insertAfter[primaryField]
319
+ : rows.indexOf(insertAfter);
320
+ model.insertAfter[insertAfterId] =
321
+ model.insertAfter[insertAfterId] || [];
322
+ hasIdField || (model.idMap[insertAfterId] = insertAfter);
323
+ model.insertAfter[insertAfterId].push(hasIdField ? item[primaryField] : item);
324
+ }
325
+ else {
326
+ holding.push(item);
327
+ }
328
+ }
329
+ else {
330
+ insertAfter = item;
331
+ insertBefore = insertBefore || item;
332
+ }
333
+ });
334
+ if (insertBefore && holding.length) {
335
+ var insertBeforeId = hasIdField
336
+ ? insertBefore[primaryField]
337
+ : rows.indexOf(insertBefore);
338
+ hasIdField || (model.idMap[insertBeforeId] = insertBefore);
339
+ model.insertBefore = {};
340
+ model.insertBefore[insertBeforeId] = holding.map(function (item) {
341
+ return hasIdField ? item[primaryField] : item;
342
+ });
343
+ }
344
+ else if (holding.length) {
345
+ var first = holding[0];
346
+ var firstId = hasIdField
347
+ ? first[primaryField]
348
+ : rows.indexOf(first);
349
+ hasIdField || (model.idMap[firstId] = first);
350
+ model.insertAfter[firstId] = holding
351
+ .slice(1)
352
+ .map(function (item) { return (hasIdField ? item[primaryField] : item); });
353
+ }
354
+ if (orderField) {
355
+ var start_1 = (store.page - 1) * store.perPage || 0;
356
+ rows = rows.map(function (item, key) {
357
+ var _a;
358
+ return amisCore.extendObject(item, (_a = {},
359
+ _a[orderField] = start_1 + key + 1,
360
+ _a));
361
+ });
362
+ }
363
+ model.rows = rows.concat();
364
+ hasIdField &&
365
+ (model.ids = rows
366
+ .map(function (item) { return item[primaryField]; })
367
+ .join(','));
368
+ hasIdField &&
369
+ orderField &&
370
+ (model.order = rows.map(function (item) {
371
+ return pick__default["default"](item, [primaryField, orderField]);
372
+ }));
373
+ amisCore.isEffectiveApi(saveOrderApi, model) &&
374
+ store
375
+ .saveRemote(saveOrderApi, model)
376
+ .then(function () {
377
+ reload && _this.reloadTarget(reload, model);
378
+ _this.getData(undefined, undefined, true, true);
379
+ })
380
+ .catch(function () { });
381
+ };
382
+ CRUD2.prototype.handleSelect = function (items, unSelectedItems) {
383
+ var _a = this.props, store = _a.store, keepItemSelectionOnPageChange = _a.keepItemSelectionOnPageChange, primaryField = _a.primaryField, multiple = _a.multiple, pickerMode = _a.pickerMode, onSelect = _a.onSelect;
384
+ var newItems = items;
385
+ var newUnSelectedItems = unSelectedItems;
386
+ // cards等组件初始化的时候也会抛出来,感觉不太合理,但是只能用这个先暂时规避一下了
387
+ if (!amisCore.isArrayChildrenModified(store.selectedItemsAsArray, newItems)) {
388
+ return;
389
+ }
390
+ if (keepItemSelectionOnPageChange && store.selectedItems.length) {
391
+ var oldItems_1 = store.selectedItems.concat();
392
+ var oldUnselectedItems_1 = store.unSelectedItems.concat();
393
+ items.forEach(function (item) {
394
+ var idx = findIndex__default["default"](oldItems_1, function (a) {
395
+ return a === item ||
396
+ (a[primaryField || 'id'] &&
397
+ a[primaryField || 'id'] == item[primaryField || 'id']);
398
+ });
399
+ if (~idx) {
400
+ oldItems_1[idx] = item;
401
+ }
402
+ else {
403
+ oldItems_1.push(item);
404
+ }
405
+ var idx2 = findIndex__default["default"](oldUnselectedItems_1, function (a) {
406
+ return a === item ||
407
+ (a[primaryField || 'id'] &&
408
+ a[primaryField || 'id'] == item[primaryField || 'id']);
409
+ });
410
+ if (~idx2) {
411
+ oldUnselectedItems_1.splice(idx2, 1);
412
+ }
413
+ });
414
+ unSelectedItems.forEach(function (item) {
415
+ var idx = findIndex__default["default"](oldUnselectedItems_1, function (a) {
416
+ return a === item ||
417
+ (a[primaryField || 'id'] &&
418
+ a[primaryField || 'id'] == item[primaryField || 'id']);
419
+ });
420
+ var idx2 = findIndex__default["default"](oldItems_1, function (a) {
421
+ return a === item ||
422
+ (a[primaryField || 'id'] &&
423
+ a[primaryField || 'id'] == item[primaryField || 'id']);
424
+ });
425
+ if (~idx) {
426
+ oldUnselectedItems_1[idx] = item;
427
+ }
428
+ else {
429
+ oldUnselectedItems_1.push(item);
430
+ }
431
+ ~idx2 && oldItems_1.splice(idx2, 1);
432
+ });
433
+ newItems = oldItems_1;
434
+ newUnSelectedItems = oldUnselectedItems_1;
435
+ // const thisBatch = items.concat(unSelectedItems);
436
+ // let notInThisBatch = (item: any) =>
437
+ // !find(
438
+ // thisBatch,
439
+ // a => a[primaryField || 'id'] == item[primaryField || 'id']
440
+ // );
441
+ // newItems = store.selectedItems.filter(notInThisBatch);
442
+ // newUnSelectedItems = store.unSelectedItems.filter(notInThisBatch);
443
+ // newItems.push(...items);
444
+ // newUnSelectedItems.push(...unSelectedItems);
445
+ }
446
+ if (pickerMode && multiple === false && newItems.length > 1) {
447
+ newUnSelectedItems.push.apply(newUnSelectedItems, newItems.splice(0, newItems.length - 1));
448
+ }
449
+ store.updateSelectData(newItems, newUnSelectedItems);
450
+ onSelect && onSelect(newItems);
451
+ };
452
+ /**
453
+ * 表格列上的筛选触发
454
+ */
455
+ CRUD2.prototype.handleTableQuery = function (values, forceReload) {
456
+ var _a;
457
+ if (forceReload === void 0) { forceReload = false; }
458
+ var _b = this.props, store = _b.store, syncLocation = _b.syncLocation, env = _b.env, pageField = _b.pageField, perPageField = _b.perPageField;
459
+ store.updateQuery(tslib.__assign(tslib.__assign({}, values), (_a = {}, _a[pageField || 'page'] = 1, _a)), syncLocation && env && env.updateLocation
460
+ ? env.updateLocation
461
+ : undefined, pageField, perPageField);
462
+ this.getData(undefined, undefined, undefined, forceReload);
463
+ };
464
+ CRUD2.prototype.reload = function (subpath, query) {
465
+ if (query) {
466
+ return this.receive(query);
467
+ }
468
+ else {
469
+ this.getData(undefined, undefined, true, true);
470
+ }
471
+ };
472
+ CRUD2.prototype.receive = function (values) {
473
+ this.handleTableQuery(values, true);
474
+ };
475
+ CRUD2.prototype.doAction = function (action, data, throwErrors) {
476
+ if (action.actionType &&
477
+ ~['stopAutoRefresh', 'reload', 'search', 'startAutoRefresh'].includes(action.actionType)) {
478
+ // @ts-ignore
479
+ return this["handle".concat(lodash.upperFirst(action.actionType))](data);
480
+ }
481
+ // const {onAction, data: ctx} = this.props;
482
+ // return this.props.onAction?.(
483
+ // undefined,
484
+ // action,
485
+ // ctx,
486
+ // throwErrors,
487
+ // undefined
488
+ // );
489
+ };
490
+ CRUD2.prototype.unSelectItem = function (item, index) {
491
+ var store = this.props.store;
492
+ var selected = store.selectedItems.concat();
493
+ var unSelected = store.unSelectedItems.concat();
494
+ var idx = selected.indexOf(item);
495
+ ~idx && unSelected.push.apply(unSelected, selected.splice(idx, 1));
496
+ store.setSelectedItems(selected);
497
+ store.setUnSelectedItems(unSelected);
498
+ };
499
+ CRUD2.prototype.clearSelection = function () {
500
+ var store = this.props.store;
501
+ var selected = store.selectedItems.concat();
502
+ var unSelected = store.unSelectedItems.concat();
503
+ store.setSelectedItems([]);
504
+ store.setUnSelectedItems(unSelected.concat(selected));
505
+ };
506
+ CRUD2.prototype.renderChild = function (region, schema, props) {
507
+ if (props === void 0) { props = {}; }
508
+ var _a = this.props, render = _a.render, store = _a.store;
509
+ // 覆盖所有分页组件
510
+ var childProps = {
511
+ activePage: store.page,
512
+ lastPage: store.lastPage,
513
+ perPage: store.perPage,
514
+ total: store.total,
515
+ onPageChange: this.handleChangePage
516
+ // onAction: onAction
517
+ };
518
+ return render(region, schema, tslib.__assign(tslib.__assign(tslib.__assign({}, props), {
519
+ // 包两层,主要是为了处理以下 case
520
+ // 里面放了个 form,form 提交过来的时候不希望把 items 这些发送过来。
521
+ // 因为会把数据呈现在地址栏上。
522
+ data: amisCore.createObject(amisCore.createObject(store.filterData, store.getData(this.props.data)), {}), render: this.renderChild }), childProps));
523
+ };
524
+ CRUD2.prototype.renderToolbar = function (region, toolbar) {
525
+ var _this = this;
526
+ if (!toolbar) {
527
+ return null;
528
+ }
529
+ toolbar = [].concat(toolbar);
530
+ return toolbar.map(function (item, index) {
531
+ return _this.renderChild("".concat(region, "/").concat(index), item, {
532
+ key: index + ''
533
+ });
534
+ });
535
+ };
536
+ CRUD2.prototype.renderFilter = function (filter) {
537
+ var _this = this;
538
+ if (!filter || filter.length === 0) {
539
+ return null;
540
+ }
541
+ return filter.map(function (item, index) {
542
+ return _this.renderChild("filter/".concat(index), item, {
543
+ key: index + '',
544
+ onSubmit: function (data) { return _this.handleSearch({ query: data }); }
545
+ });
546
+ });
547
+ };
548
+ CRUD2.prototype.renderSelection = function () {
549
+ var _this = this;
550
+ var _a = this.props, store = _a.store, cx = _a.classnames, labelField = _a.labelField, labelTpl = _a.labelTpl, primaryField = _a.primaryField, __ = _a.translate;
551
+ if (!store.selectedItems.length) {
552
+ return null;
553
+ }
554
+ return (React__default["default"].createElement("div", { className: cx('Crud-selection') },
555
+ React__default["default"].createElement("div", { className: cx('Crud-selectionLabel') }, __('CRUD.selected', { total: store.selectedItems.length })),
556
+ store.selectedItems.map(function (item, index) { return (React__default["default"].createElement("div", { key: index, className: cx("Crud-value") },
557
+ React__default["default"].createElement("span", { "data-tooltip": __('delete'), "data-position": "bottom", className: cx('Crud-valueIcon'), onClick: _this.unSelectItem.bind(_this, item, index) }, "\u00D7"),
558
+ React__default["default"].createElement("span", { className: cx('Crud-valueLabel') }, labelTpl ? (React__default["default"].createElement(amisUi.Html, { html: amisCore.filter(labelTpl, item) })) : (amisCore.getVariable(item, labelField || 'label') ||
559
+ amisCore.getVariable(item, primaryField || 'id'))))); }),
560
+ React__default["default"].createElement("a", { onClick: this.clearSelection, className: cx('Crud-selectionClear') }, __('clear'))));
561
+ };
562
+ CRUD2.prototype.render = function () {
563
+ var _a = this.props, columns = _a.columns, className = _a.className, bodyClassName = _a.bodyClassName, filter = _a.filter, render = _a.render, store = _a.store, _b = _a.mode, mode = _b === void 0 ? 'table-v2' : _b; _a.syncLocation; _a.children; _a.bulkActions; var pickerMode = _a.pickerMode, selectable = _a.selectable, multiple = _a.multiple, valueField = _a.valueField, primaryField = _a.primaryField; _a.value; _a.hideQuickSaveBtn; var itemActions = _a.itemActions, cx = _a.classnames, keepItemSelectionOnPageChange = _a.keepItemSelectionOnPageChange, maxKeepItemSelectionLength = _a.maxKeepItemSelectionLength; _a.onAction; var popOverContainer = _a.popOverContainer; _a.translate; _a.onQuery; var autoGenerateFilter = _a.autoGenerateFilter; _a.onSelect; var autoFillHeight = _a.autoFillHeight, showSelection = _a.showSelection, headerToolbar = _a.headerToolbar, footerToolbar = _a.footerToolbar, rest = tslib.__rest(_a, ["columns", "className", "bodyClassName", "filter", "render", "store", "mode", "syncLocation", "children", "bulkActions", "pickerMode", "selectable", "multiple", "valueField", "primaryField", "value", "hideQuickSaveBtn", "itemActions", "classnames", "keepItemSelectionOnPageChange", "maxKeepItemSelectionLength", "onAction", "popOverContainer", "translate", "onQuery", "autoGenerateFilter", "onSelect", "autoFillHeight", "showSelection", "headerToolbar", "footerToolbar"]);
564
+ return (React__default["default"].createElement("div", { className: cx('Crud2', className, {
565
+ 'is-loading': store.loading
566
+ }) },
567
+ React__default["default"].createElement("div", { className: cx('Crud2-filter') }, this.renderFilter(filter)),
568
+ React__default["default"].createElement("div", { className: cx('Crud2-toolbar') }, this.renderToolbar('headerToolbar', headerToolbar)),
569
+ showSelection && keepItemSelectionOnPageChange && multiple !== false
570
+ ? this.renderSelection()
571
+ : null,
572
+ render('body', tslib.__assign(tslib.__assign({}, rest), { type: mode, columns: mode.startsWith('table')
573
+ ? store.columns || columns
574
+ : undefined }), {
575
+ key: 'body',
576
+ className: cx('Crud2-body', bodyClassName),
577
+ ref: this.controlRef,
578
+ autoGenerateFilter: !filter && autoGenerateFilter,
579
+ autoFillHeight: autoFillHeight,
580
+ checkAll: false,
581
+ selectable: !!(selectable !== null && selectable !== void 0 ? selectable : pickerMode),
582
+ itemActions: itemActions,
583
+ multiple: multiple,
584
+ selected: pickerMode || keepItemSelectionOnPageChange
585
+ ? store.selectedItemsAsArray
586
+ : undefined,
587
+ keepItemSelectionOnPageChange: keepItemSelectionOnPageChange,
588
+ maxKeepItemSelectionLength: maxKeepItemSelectionLength,
589
+ valueField: valueField || primaryField,
590
+ primaryField: primaryField,
591
+ items: store.data.items,
592
+ query: store.query,
593
+ orderBy: store.query.orderBy,
594
+ orderDir: store.query.orderDir,
595
+ popOverContainer: popOverContainer,
596
+ onSave: this.handleSave,
597
+ onSaveOrder: this.handleSaveOrder,
598
+ onQuery: this.handleTableQuery,
599
+ onSelect: this.handleSelect,
600
+ data: store.mergedData
601
+ }),
602
+ React__default["default"].createElement(amisUi.Spinner, { overlay: true, size: "lg", key: "info", show: store.loading }),
603
+ React__default["default"].createElement("div", { className: cx('Crud2-toolbar') }, this.renderToolbar('footerToolbar', footerToolbar))));
604
+ };
605
+ CRUD2.propsList = [
606
+ 'mode',
607
+ 'syncLocation',
608
+ 'value',
609
+ 'multiple',
610
+ 'valueField',
611
+ 'pageField',
612
+ 'perPageField',
613
+ 'hideQuickSaveBtn',
614
+ 'autoJumpToTopOnPagerChange',
615
+ 'interval',
616
+ 'silentPolling',
617
+ 'stopAutoRefreshWhen',
618
+ 'stopAutoRefreshWhenModalIsOpen',
619
+ 'api',
620
+ 'headerToolbar',
621
+ 'footerToolbar',
622
+ 'autoGenerateFilter',
623
+ 'syncResponse2Query',
624
+ 'keepItemSelectionOnPageChange',
625
+ 'source',
626
+ 'onChange',
627
+ 'onInit',
628
+ 'onSaved',
629
+ 'onQuery',
630
+ 'autoFillHeight',
631
+ 'showSelection'
632
+ ];
633
+ CRUD2.defaultProps = {
634
+ toolbarInline: true,
635
+ syncLocation: true,
636
+ hideQuickSaveBtn: false,
637
+ autoJumpToTopOnPagerChange: true,
638
+ silentPolling: false,
639
+ autoFillHeight: false,
640
+ showSelection: true,
641
+ perPage: 10
642
+ };
643
+ tslib.__decorate([
644
+ amisCore.autobind,
645
+ tslib.__metadata("design:type", Function),
646
+ tslib.__metadata("design:paramtypes", [Object]),
647
+ tslib.__metadata("design:returntype", void 0)
648
+ ], CRUD2.prototype, "controlRef", null);
649
+ tslib.__decorate([
650
+ amisCore.autobind,
651
+ tslib.__metadata("design:type", Function),
652
+ tslib.__metadata("design:paramtypes", [Number, Number]),
653
+ tslib.__metadata("design:returntype", void 0)
654
+ ], CRUD2.prototype, "handleChangePage", null);
655
+ tslib.__decorate([
656
+ amisCore.autobind,
657
+ tslib.__metadata("design:type", Function),
658
+ tslib.__metadata("design:paramtypes", [Array, Array]),
659
+ tslib.__metadata("design:returntype", void 0)
660
+ ], CRUD2.prototype, "handleSelect", null);
661
+ tslib.__decorate([
662
+ amisCore.autobind,
663
+ tslib.__metadata("design:type", Function),
664
+ tslib.__metadata("design:paramtypes", [Object, Object, Boolean]),
665
+ tslib.__metadata("design:returntype", void 0)
666
+ ], CRUD2.prototype, "doAction", null);
667
+ tslib.__decorate([
668
+ amisCore.autobind,
669
+ tslib.__metadata("design:type", Function),
670
+ tslib.__metadata("design:paramtypes", [String, Object, Object]),
671
+ tslib.__metadata("design:returntype", void 0)
672
+ ], CRUD2.prototype, "renderChild", null);
673
+ return CRUD2;
674
+ }(React__default["default"].Component));
675
+ /** @class */ ((function (_super) {
676
+ tslib.__extends(CRUD2Renderer, _super);
677
+ function CRUD2Renderer(props, context) {
678
+ var _this = _super.call(this, props) || this;
679
+ var scoped = context;
680
+ scoped.registerComponent(_this);
681
+ return _this;
682
+ }
683
+ CRUD2Renderer.prototype.componentWillUnmount = function () {
684
+ _super.prototype.componentWillUnmount.call(this);
685
+ var scoped = this.context;
686
+ scoped.unRegisterComponent(this);
687
+ };
688
+ CRUD2Renderer.prototype.reload = function (subpath, query, ctx) {
689
+ var scoped = this.context;
690
+ if (subpath) {
691
+ return scoped.reload(query ? "".concat(subpath, "?").concat(amisCore.qsstringify(query)) : subpath, ctx);
692
+ }
693
+ return _super.prototype.reload.call(this, subpath, query);
694
+ };
695
+ CRUD2Renderer.prototype.receive = function (values, subPath) {
696
+ var scoped = this.context;
697
+ if (subPath) {
698
+ return scoped.send(subPath, values);
699
+ }
700
+ return _super.prototype.receive.call(this, values);
701
+ };
702
+ CRUD2Renderer.prototype.reloadTarget = function (target, data) {
703
+ var scoped = this.context;
704
+ scoped.reload(target, data);
705
+ };
706
+ CRUD2Renderer.prototype.closeTarget = function (target) {
707
+ var scoped = this.context;
708
+ scoped.close(target);
709
+ };
710
+ CRUD2Renderer.contextType = amisCore.ScopedContext;
711
+ CRUD2Renderer = tslib.__decorate([
712
+ amisCore.Renderer({
713
+ type: 'crud2',
714
+ storeType: amisCore.CRUDStore.name,
715
+ isolateScope: true
716
+ }),
717
+ tslib.__metadata("design:paramtypes", [Object, Object])
718
+ ], CRUD2Renderer);
719
+ return CRUD2Renderer;
720
+ })(CRUD2));
721
+
722
+ exports["default"] = CRUD2;