amis 1.9.1-beta.0 → 1.9.1-beta.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (278) hide show
  1. package/lib/RootRenderer.js +10 -2
  2. package/lib/RootRenderer.js.map +2 -2
  3. package/lib/Schema.d.ts +3 -2
  4. package/lib/Schema.js.map +1 -1
  5. package/lib/SchemaRenderer.js +6 -9
  6. package/lib/SchemaRenderer.js.map +2 -2
  7. package/lib/actions/CmptAction.js +4 -4
  8. package/lib/actions/CmptAction.js.map +2 -2
  9. package/lib/components/Button.d.ts +11 -10
  10. package/lib/components/Button.js +2 -2
  11. package/lib/components/Button.js.map +2 -2
  12. package/lib/components/CalendarMobile.d.ts +40 -40
  13. package/lib/components/Checkbox.js +1 -1
  14. package/lib/components/Checkbox.js.map +2 -2
  15. package/lib/components/ContextMenu.d.ts +4 -0
  16. package/lib/components/ContextMenu.js +23 -7
  17. package/lib/components/ContextMenu.js.map +2 -2
  18. package/lib/components/DatePicker.d.ts +40 -40
  19. package/lib/components/DateRangePicker.d.ts +40 -40
  20. package/lib/components/Form.d.ts +22 -0
  21. package/lib/components/Form.js +44 -0
  22. package/lib/components/Form.js.map +13 -0
  23. package/lib/components/FormField.d.ts +65 -0
  24. package/lib/components/FormField.js +48 -0
  25. package/lib/components/FormField.js.map +13 -0
  26. package/lib/components/InputBox.d.ts +10 -10
  27. package/lib/components/InputBox.js +4 -3
  28. package/lib/components/InputBox.js.map +2 -2
  29. package/lib/components/InputBoxWithSuggestion.d.ts +280 -0
  30. package/lib/components/InputBoxWithSuggestion.js +65 -0
  31. package/lib/components/InputBoxWithSuggestion.js.map +13 -0
  32. package/lib/components/ListGroup.d.ts +10 -10
  33. package/lib/components/PickerContainer.d.ts +4 -2
  34. package/lib/components/PickerContainer.js +28 -5
  35. package/lib/components/PickerContainer.js.map +2 -2
  36. package/lib/components/Radios.d.ts +10 -10
  37. package/lib/components/ResultBox.d.ts +40 -40
  38. package/lib/components/Select.d.ts +195 -202
  39. package/lib/components/Select.js +7 -3
  40. package/lib/components/Select.js.map +2 -2
  41. package/lib/components/Textarea.d.ts +568 -2
  42. package/lib/components/Textarea.js +129 -1
  43. package/lib/components/Textarea.js.map +2 -2
  44. package/lib/components/Toast.js +11 -9
  45. package/lib/components/Toast.js.map +2 -2
  46. package/lib/components/UserSelect.d.ts +500 -0
  47. package/lib/components/UserSelect.js +559 -0
  48. package/lib/components/UserSelect.js.map +13 -0
  49. package/lib/components/UserTabSelect.d.ts +320 -0
  50. package/lib/components/UserTabSelect.js +163 -0
  51. package/lib/components/UserTabSelect.js.map +13 -0
  52. package/lib/components/WithRemoteConfig.d.ts +7 -0
  53. package/lib/components/WithRemoteConfig.js +22 -13
  54. package/lib/components/WithRemoteConfig.js.map +2 -2
  55. package/lib/components/calendar/DaysView.d.ts +26 -1
  56. package/lib/components/calendar/DaysView.js +60 -19
  57. package/lib/components/calendar/DaysView.js.map +2 -2
  58. package/lib/components/calendar/TimeView.d.ts +1 -1
  59. package/lib/components/calendar/TimeView.js +10 -3
  60. package/lib/components/calendar/TimeView.js.map +2 -2
  61. package/lib/components/formula/Picker.js +4 -4
  62. package/lib/components/formula/Picker.js.map +2 -2
  63. package/lib/components/icons.d.ts +7 -1
  64. package/lib/components/icons.js +17 -1
  65. package/lib/components/icons.js.map +2 -2
  66. package/lib/components/index.d.ts +2 -1
  67. package/lib/components/index.js +3 -1
  68. package/lib/components/index.js.map +2 -2
  69. package/lib/components/json-schema/Array.d.ts +3 -0
  70. package/lib/components/json-schema/Array.js +125 -0
  71. package/lib/components/json-schema/Array.js.map +13 -0
  72. package/lib/components/json-schema/Item.d.ts +3 -0
  73. package/lib/components/json-schema/Item.js +34 -0
  74. package/lib/components/json-schema/Item.js.map +13 -0
  75. package/lib/components/json-schema/Object.d.ts +3 -0
  76. package/lib/components/json-schema/Object.js +178 -0
  77. package/lib/components/json-schema/Object.js.map +13 -0
  78. package/lib/components/json-schema/index.d.ts +279 -0
  79. package/lib/components/json-schema/index.js +16 -0
  80. package/lib/components/json-schema/index.js.map +13 -0
  81. package/lib/components/schema-editor/Array.js +2 -2
  82. package/lib/components/schema-editor/Array.js.map +2 -2
  83. package/lib/components/schema-editor/Common.d.ts +2 -0
  84. package/lib/components/schema-editor/Common.js +39 -3
  85. package/lib/components/schema-editor/Common.js.map +2 -2
  86. package/lib/components/schema-editor/Object.js +2 -2
  87. package/lib/components/schema-editor/Object.js.map +2 -2
  88. package/lib/components/schema-editor/index.d.ts +45 -41
  89. package/lib/components/schema-editor/index.js +5 -5
  90. package/lib/components/schema-editor/index.js.map +2 -2
  91. package/lib/components/table/ItemActionsWrapper.d.ts +10 -0
  92. package/lib/components/table/ItemActionsWrapper.js +25 -0
  93. package/lib/components/table/ItemActionsWrapper.js.map +13 -0
  94. package/lib/components/table/index.d.ts +48 -41
  95. package/lib/components/table/index.js +46 -18
  96. package/lib/components/table/index.js.map +2 -2
  97. package/lib/helper.css +125 -124
  98. package/lib/helper.css.map +1 -1
  99. package/lib/hooks/use-validation-resolver.d.ts +1 -0
  100. package/lib/hooks/use-validation-resolver.js +49 -0
  101. package/lib/hooks/use-validation-resolver.js.map +13 -0
  102. package/lib/icons/department.js +17 -0
  103. package/lib/icons/menu.js +9 -0
  104. package/lib/icons/post.js +15 -0
  105. package/lib/icons/role.js +14 -0
  106. package/lib/icons/user-remove.js +12 -0
  107. package/lib/index.d.ts +2 -0
  108. package/lib/index.js +3 -1
  109. package/lib/index.js.map +2 -2
  110. package/lib/locale/de-DE.js +11 -1
  111. package/lib/locale/de-DE.js.map +2 -2
  112. package/lib/locale/en-US.js +12 -1
  113. package/lib/locale/en-US.js.map +2 -2
  114. package/lib/locale/zh-CN.js +14 -3
  115. package/lib/locale/zh-CN.js.map +2 -2
  116. package/lib/renderers/Action.js +25 -11
  117. package/lib/renderers/Action.js.map +2 -2
  118. package/lib/renderers/CRUD.js +5 -1
  119. package/lib/renderers/CRUD.js.map +2 -2
  120. package/lib/renderers/Dialog.js +9 -3
  121. package/lib/renderers/Dialog.js.map +2 -2
  122. package/lib/renderers/Drawer.js +5 -1
  123. package/lib/renderers/Drawer.js.map +2 -2
  124. package/lib/renderers/Form/InputDate.d.ts +2 -2
  125. package/lib/renderers/Form/InputDate.js.map +2 -2
  126. package/lib/renderers/Form/JSONSchema.d.ts +23 -0
  127. package/lib/renderers/Form/JSONSchema.js +44 -0
  128. package/lib/renderers/Form/JSONSchema.js.map +13 -0
  129. package/lib/renderers/Form/JSONSchemaEditor.d.ts +2 -3
  130. package/lib/renderers/Form/JSONSchemaEditor.js +9 -24
  131. package/lib/renderers/Form/JSONSchemaEditor.js.map +2 -2
  132. package/lib/renderers/Form/Options.js +11 -5
  133. package/lib/renderers/Form/Options.js.map +2 -2
  134. package/lib/renderers/Form/Textarea.d.ts +1 -8
  135. package/lib/renderers/Form/Textarea.js +11 -75
  136. package/lib/renderers/Form/Textarea.js.map +2 -2
  137. package/lib/renderers/Form/UserSelect.d.ts +54 -0
  138. package/lib/renderers/Form/UserSelect.js +197 -0
  139. package/lib/renderers/Form/UserSelect.js.map +13 -0
  140. package/lib/renderers/Form/index.d.ts +1 -1
  141. package/lib/renderers/Form/index.js +88 -42
  142. package/lib/renderers/Form/index.js.map +2 -2
  143. package/lib/renderers/Form/wrapControl.js.map +2 -2
  144. package/lib/renderers/Log.d.ts +28 -0
  145. package/lib/renderers/Log.js +110 -20
  146. package/lib/renderers/Log.js.map +2 -2
  147. package/lib/renderers/Page.js +5 -1
  148. package/lib/renderers/Page.js.map +2 -2
  149. package/lib/renderers/Service.js +5 -1
  150. package/lib/renderers/Service.js.map +2 -2
  151. package/lib/renderers/Table-v2/index.d.ts +14 -2
  152. package/lib/renderers/Table-v2/index.js +33 -3
  153. package/lib/renderers/Table-v2/index.js.map +2 -2
  154. package/lib/renderers/Wizard.js +37 -14
  155. package/lib/renderers/Wizard.js.map +2 -2
  156. package/lib/store/form.js +65 -45
  157. package/lib/store/form.js.map +2 -2
  158. package/lib/themes/ang-ie11.css +576 -24
  159. package/lib/themes/ang.css +553 -12
  160. package/lib/themes/ang.css.map +1 -1
  161. package/lib/themes/antd-ie11.css +576 -24
  162. package/lib/themes/antd.css +553 -12
  163. package/lib/themes/antd.css.map +1 -1
  164. package/lib/themes/cxd-ie11.css +576 -24
  165. package/lib/themes/cxd.css +553 -12
  166. package/lib/themes/cxd.css.map +1 -1
  167. package/lib/themes/dark-ie11.css +576 -24
  168. package/lib/themes/dark.css +553 -12
  169. package/lib/themes/dark.css.map +1 -1
  170. package/lib/themes/default-ie11.css +576 -24
  171. package/lib/themes/default.css +553 -12
  172. package/lib/themes/default.css.map +1 -1
  173. package/lib/utils/api.js +1 -1
  174. package/lib/utils/api.js.map +2 -2
  175. package/lib/utils/renderer-event.js.map +2 -2
  176. package/package.json +2 -1
  177. package/schema.json +552 -5
  178. package/scss/_properties.scss +20 -8
  179. package/scss/components/_input-box.scss +22 -1
  180. package/scss/components/_json-schema.scss +124 -0
  181. package/scss/components/_log.scss +37 -5
  182. package/scss/components/form/_date-range.scss +1 -0
  183. package/scss/components/form/_select.scss +9 -0
  184. package/scss/components/form/_transfer.scss +19 -3
  185. package/scss/components/form/_user-select.scss +422 -0
  186. package/scss/helper/background/_background-color.scss +125 -124
  187. package/scss/themes/_common.scss +2 -0
  188. package/sdk/ang-ie11.css +670 -24
  189. package/sdk/ang.css +647 -12
  190. package/sdk/antd-ie11.css +670 -24
  191. package/sdk/antd.css +647 -12
  192. package/sdk/barcode.js +51 -51
  193. package/sdk/charts.js +14 -14
  194. package/sdk/codemirror.js +7 -7
  195. package/sdk/color-picker.js +65 -65
  196. package/sdk/cropperjs.js +2 -2
  197. package/sdk/cxd-ie11.css +670 -24
  198. package/sdk/cxd.css +647 -12
  199. package/sdk/dark-ie11.css +670 -24
  200. package/sdk/dark.css +647 -12
  201. package/sdk/exceljs.js +1 -1
  202. package/sdk/helper.css +125 -124
  203. package/sdk/helper.css.map +1 -1
  204. package/sdk/locale/de-DE.js +11 -1
  205. package/sdk/markdown.js +69 -69
  206. package/sdk/papaparse.js +1 -1
  207. package/sdk/renderers/Form/CityDB.js +1 -1
  208. package/sdk/rest.js +16 -16
  209. package/sdk/rich-text.js +62 -62
  210. package/sdk/sdk-ie11.css +670 -24
  211. package/sdk/sdk.css +647 -12
  212. package/sdk/sdk.js +1653 -1637
  213. package/sdk/thirds/hls.js/hls.js +1 -1
  214. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  215. package/sdk/tinymce.js +57 -57
  216. package/src/RootRenderer.tsx +27 -15
  217. package/src/Schema.ts +5 -1
  218. package/src/SchemaRenderer.tsx +1 -4
  219. package/src/actions/CmptAction.ts +4 -4
  220. package/src/components/Button.tsx +3 -0
  221. package/src/components/Checkbox.tsx +2 -1
  222. package/src/components/ContextMenu.tsx +25 -7
  223. package/src/components/Form.tsx +70 -0
  224. package/src/components/FormField.tsx +127 -0
  225. package/src/components/InputBox.tsx +4 -1
  226. package/src/components/InputBoxWithSuggestion.tsx +113 -0
  227. package/src/components/PickerContainer.tsx +20 -5
  228. package/src/components/Select.tsx +18 -10
  229. package/src/components/Textarea.tsx +234 -2
  230. package/src/components/Toast.tsx +19 -18
  231. package/src/components/UserSelect.tsx +850 -0
  232. package/src/components/UserTabSelect.tsx +261 -0
  233. package/src/components/WithRemoteConfig.tsx +35 -11
  234. package/src/components/calendar/DaysView.tsx +117 -49
  235. package/src/components/calendar/TimeView.tsx +11 -6
  236. package/src/components/formula/Picker.tsx +2 -1
  237. package/src/components/icons.tsx +17 -1
  238. package/src/components/index.tsx +3 -1
  239. package/src/components/json-schema/Array.tsx +216 -0
  240. package/src/components/json-schema/Item.tsx +47 -0
  241. package/src/components/json-schema/Object.tsx +339 -0
  242. package/src/components/json-schema/index.tsx +44 -0
  243. package/src/components/schema-editor/Array.tsx +3 -1
  244. package/src/components/schema-editor/Common.tsx +61 -4
  245. package/src/components/schema-editor/Object.tsx +3 -1
  246. package/src/components/schema-editor/index.tsx +12 -5
  247. package/src/components/table/ItemActionsWrapper.tsx +32 -0
  248. package/src/components/table/index.tsx +115 -58
  249. package/src/hooks/use-validation-resolver.ts +45 -0
  250. package/src/icons/department.svg +17 -0
  251. package/src/icons/menu.svg +2 -0
  252. package/src/icons/post.svg +15 -0
  253. package/src/icons/role.svg +14 -0
  254. package/src/icons/user-remove.svg +12 -0
  255. package/src/index.tsx +2 -0
  256. package/src/locale/de-DE.ts +11 -1
  257. package/src/locale/en-US.ts +12 -1
  258. package/src/locale/zh-CN.ts +14 -3
  259. package/src/renderers/Action.tsx +10 -9
  260. package/src/renderers/CRUD.tsx +5 -1
  261. package/src/renderers/Dialog.tsx +9 -3
  262. package/src/renderers/Drawer.tsx +5 -1
  263. package/src/renderers/Form/InputDate.tsx +9 -4
  264. package/src/renderers/Form/JSONSchema.tsx +56 -0
  265. package/src/renderers/Form/JSONSchemaEditor.tsx +8 -27
  266. package/src/renderers/Form/Options.tsx +17 -7
  267. package/src/renderers/Form/Textarea.tsx +7 -117
  268. package/src/renderers/Form/UserSelect.tsx +263 -0
  269. package/src/renderers/Form/index.tsx +28 -18
  270. package/src/renderers/Form/wrapControl.tsx +0 -1
  271. package/src/renderers/Log.tsx +213 -19
  272. package/src/renderers/Page.tsx +6 -1
  273. package/src/renderers/Service.tsx +5 -1
  274. package/src/renderers/Table-v2/index.tsx +65 -2
  275. package/src/renderers/Wizard.tsx +24 -10
  276. package/src/store/form.ts +24 -17
  277. package/src/utils/api.ts +1 -1
  278. package/src/utils/renderer-event.ts +0 -2
@@ -23,12 +23,13 @@ import Spinner from '../Spinner';
23
23
  import HeadCellSort from './HeadCellSort';
24
24
  import HeadCellFilter from './HeadCellFilter';
25
25
  import HeadCellSelect from './HeadCellSelect';
26
+ import ItemActionsWrapper from './ItemActionsWrapper';
26
27
  import Cell from './Cell';
27
28
 
28
29
  export interface ColumnProps {
29
30
  title: string | React.ReactNode | Function;
30
31
  key: string;
31
- className?: string;
32
+ className?: Function;
32
33
  children?: Array<ColumnProps>;
33
34
  render: Function;
34
35
  fixed?: boolean | string;
@@ -144,6 +145,7 @@ export interface TableProps extends ThemeProps, LocaleProps {
144
145
  showHeader?: boolean; // 是否展示表头
145
146
  onSelect?: Function;
146
147
  onSelectAll?: Function;
148
+ itemActions?: Function;
147
149
  }
148
150
 
149
151
  export interface ScrollProps {
@@ -156,6 +158,11 @@ export interface TableState {
156
158
  dataSource: Array<any>;
157
159
  expandedRowKeys: Array<string | number>;
158
160
  colWidths: Array<number>;
161
+ hoverRow: {
162
+ rowIndex?: number,
163
+ record: any,
164
+ target: HTMLTableRowElement
165
+ } | null;
159
166
  }
160
167
 
161
168
  function getMaxLevelThRowSpan(columns: Array<ColumnProps>) {
@@ -336,7 +343,8 @@ export class Table extends React.PureComponent<TableProps, TableState> {
336
343
  ? props.expandable.defaultExpandedRowKeys || []
337
344
  : [])
338
345
  ],
339
- colWidths: []
346
+ colWidths: [],
347
+ hoverRow: null
340
348
  };
341
349
 
342
350
  this.onTableContentScroll = this.onTableContentScroll.bind(this);
@@ -1104,43 +1112,43 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1104
1112
  );
1105
1113
  }
1106
1114
 
1107
- const children = (
1108
- <span>
1109
- {sort}
1110
- {filter}
1111
- {resizable ? (
1112
- <i
1113
- className={cx('Table-thead-resizable')}
1114
- onMouseDown={e => this.onResizeMouseDown(e, item.key)}
1115
- ></i>
1116
- ) : null}
1117
- </span>
1118
- );
1119
-
1120
- return (
1121
- <Cell
1122
- wrapperComponent="th"
1123
- rowSpan={item.rowSpan}
1124
- colSpan={item.colSpan}
1125
- key={'cell' + (item.key || i)}
1126
- fixed={item.fixed === true ? 'left' : item.fixed}
1127
- className={cx({
1128
- 'Table-cell-last':
1129
- i === maxCount - 1 && i === data.length - 1
1130
- })}
1131
- groupId={item.groupId}
1132
- depth={item.depth}
1133
- >
1134
- {typeof item.title === 'function'
1135
- ? item.title(children)
1136
- : item.title}
1137
- </Cell>
1138
- );
1139
- })}
1140
- </tr>
1141
- );
1142
- })}
1143
- </thead>
1115
+ const children = (
1116
+ <span>
1117
+ {sort}
1118
+ {filter}
1119
+ {resizable ? (
1120
+ <i
1121
+ className={cx('Table-thead-resizable')}
1122
+ onMouseDown={e => this.onResizeMouseDown(e, item.key)}
1123
+ ></i>
1124
+ ) : null}
1125
+ </span>
1126
+ );
1127
+
1128
+ return (
1129
+ <Cell
1130
+ wrapperComponent="th"
1131
+ rowSpan={item.rowSpan}
1132
+ colSpan={item.colSpan}
1133
+ key={`cell-${i}`}
1134
+ fixed={item.fixed === true ? 'left' : item.fixed}
1135
+ className={cx({
1136
+ 'Table-cell-last':
1137
+ i === maxCount - 1 && i === data.length - 1
1138
+ })}
1139
+ groupId={item.groupId}
1140
+ depth={item.depth}
1141
+ >
1142
+ {typeof item.title === 'function'
1143
+ ? item.title(children)
1144
+ : item.title}
1145
+ </Cell>
1146
+ );
1147
+ })}
1148
+ </tr>
1149
+ );
1150
+ })}
1151
+ </thead>
1144
1152
  );
1145
1153
  }
1146
1154
 
@@ -1182,8 +1190,17 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1182
1190
  }
1183
1191
  }
1184
1192
 
1185
- if (record && onRow) {
1186
- onRow.onRowMouseEnter && onRow.onRowMouseEnter(event, record, rowIndex);
1193
+ if (record) {
1194
+ let target = event.target;
1195
+ if (target.tagName !== 'TR') {
1196
+ target = target.closest('tr');
1197
+ }
1198
+
1199
+ this.setState({hoverRow: {target, rowIndex, record}}, () => {
1200
+ if (onRow) {
1201
+ onRow.onRowMouseEnter && onRow.onRowMouseEnter(event, record, rowIndex);
1202
+ }
1203
+ });
1187
1204
  }
1188
1205
  }
1189
1206
 
@@ -1206,11 +1223,17 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1206
1223
  }
1207
1224
  }
1208
1225
 
1209
- if (record && onRow) {
1210
- onRow.onRowMouseLeave && onRow.onRowMouseLeave(event, record, rowIndex);
1226
+ if (record) {
1227
+ if (onRow) {
1228
+ onRow.onRowMouseLeave && onRow.onRowMouseLeave(event, record, rowIndex);
1229
+ }
1211
1230
  }
1212
1231
  }
1213
1232
 
1233
+ onMouseLeave(event: React.ChangeEvent<any>) {
1234
+ this.setState({hoverRow: null});
1235
+ }
1236
+
1214
1237
  onExpandRow(data: any) {
1215
1238
  const {expandedRowKeys} = this.state;
1216
1239
  const {expandable} = this.props;
@@ -1396,7 +1419,8 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1396
1419
  levels.length > 0 ? (
1397
1420
  <span
1398
1421
  className={cx('Table-row-indent', `indent-level-${levels.length}`)}
1399
- style={{paddingLeft: indentSize * levels.length + 'px'}}
1422
+ style={levels.length > 0
1423
+ ? {paddingLeft: (indentSize * levels.length) + 'px'} : {}}
1400
1424
  ></span>
1401
1425
  ) : null;
1402
1426
 
@@ -1415,6 +1439,9 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1415
1439
  props.rowSpan === 1;
1416
1440
  }
1417
1441
  }
1442
+
1443
+ const className = typeof item.className === 'function'
1444
+ ? item.className(data, rowIndex) : ''
1418
1445
  return props.rowSpan === 0 || props.colSpan === 0 ? null : (
1419
1446
  <Cell
1420
1447
  key={i}
@@ -1422,15 +1449,16 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1422
1449
  fixed={item.fixed === true ? 'left' : item.fixed}
1423
1450
  column={item}
1424
1451
  groupId={item.groupId}
1452
+ className={cx({
1453
+ [`${className}`]: !!className
1454
+ })}
1425
1455
  >
1426
- <div
1427
- className={cx('Table-cell-wrapper', {
1428
- [cx('Table-cell-wrapper-prefix')]:
1429
- i === 0 &&
1430
- (!!indentDom || (levels.length === 0 && hasChildrenRow)),
1431
- [cx(`Table-cell-height-${lineHeight}`)]: !!lineHeight
1432
- })}
1433
- >
1456
+ <div className={cx('Table-cell-wrapper', {
1457
+ [cx('Table-cell-wrapper-prefix')]:
1458
+ i === 0 &&
1459
+ (!!indentDom || levels.length === 0 && hasChildrenRow),
1460
+ [cx(`Table-cell-height-${lineHeight}`)]: !!lineHeight
1461
+ })}>
1434
1462
  {i === 0 && levels.length > 0 ? indentDom : null}
1435
1463
  {i === 0 && hasChildrenRow
1436
1464
  ? this.getExpandedIcons(isExpanded, data)
@@ -1759,18 +1787,28 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1759
1787
  footSummary,
1760
1788
  loading,
1761
1789
  showHeader,
1790
+ itemActions,
1762
1791
  classnames: cx
1763
1792
  } = this.props;
1764
1793
 
1765
1794
  // 设置了横向滚动轴 则table的table-layout为fixed
1766
1795
  const hasScrollX = scroll && scroll.x;
1796
+ const hoverRow = this.state.hoverRow;
1767
1797
 
1768
1798
  return (
1769
1799
  <div
1770
1800
  ref={this.contentDom}
1771
1801
  className={cx('Table-content')}
1772
1802
  style={hasScrollX ? {overflow: 'auto hidden'} : {}}
1803
+ onMouseLeave={this.onMouseLeave.bind(this)}
1773
1804
  >
1805
+ {itemActions && hoverRow
1806
+ ? <ItemActionsWrapper
1807
+ dom={hoverRow.target}
1808
+ classnames={cx}>
1809
+ {typeof itemActions === 'function'
1810
+ ? itemActions(hoverRow.record, hoverRow.rowIndex) : null}
1811
+ </ItemActionsWrapper> : null}
1774
1812
  <table
1775
1813
  style={
1776
1814
  hasScrollX
@@ -1831,7 +1869,11 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1831
1869
  }
1832
1870
 
1833
1871
  renderScrollTableBody() {
1834
- const {scroll, classnames: cx} = this.props;
1872
+ const {
1873
+ scroll,
1874
+ itemActions,
1875
+ classnames: cx
1876
+ } = this.props;
1835
1877
 
1836
1878
  const style = {};
1837
1879
  const tableStyle = {};
@@ -1847,12 +1889,27 @@ export class Table extends React.PureComponent<TableProps, TableState> {
1847
1889
  });
1848
1890
  }
1849
1891
 
1892
+ const hoverRow = this.state.hoverRow;
1893
+
1850
1894
  return (
1851
- <div ref={this.bodyDom} className={cx('Table-body')} style={style}>
1852
- <table className={cx('Table-table')} style={tableStyle}>
1853
- {this.renderColGroup()}
1854
- {this.renderTBody()}
1855
- </table>
1895
+ <div
1896
+ ref={this.bodyDom}
1897
+ className={cx('Table-body')}
1898
+ style={style}
1899
+ onMouseLeave={this.onMouseLeave.bind(this)}>
1900
+ {itemActions && hoverRow
1901
+ ? <ItemActionsWrapper
1902
+ dom={hoverRow.target}
1903
+ classnames={cx}>
1904
+ {typeof itemActions === 'function'
1905
+ ? itemActions(hoverRow.record, hoverRow.rowIndex) : null}
1906
+ </ItemActionsWrapper> : null}
1907
+ <table
1908
+ className={cx('Table-table')}
1909
+ style={tableStyle}>
1910
+ {this.renderColGroup()}
1911
+ {this.renderTBody()}
1912
+ </table>
1856
1913
  </div>
1857
1914
  );
1858
1915
  }
@@ -0,0 +1,45 @@
1
+ /**
2
+ * @file 用 amis 内置的验证来验证 react-hook-form 里面的表单数据
3
+ */
4
+ import pick from 'lodash/pick';
5
+ import React from 'react';
6
+ import {validateObject, validations} from '../utils/validations';
7
+
8
+ function formatErrors(errors: any) {
9
+ const formated: any = {};
10
+ Object.keys(errors).forEach(key => {
11
+ const origin = errors[key][0];
12
+ if (origin) {
13
+ formated[key] = {
14
+ type: origin.rule,
15
+ message: origin.msg
16
+ };
17
+ }
18
+ });
19
+ return formated;
20
+ }
21
+
22
+ export function useValidationResolver(__ = (str: string) => str) {
23
+ return React.useCallback<any>(
24
+ async (values: any, context: any, config: any) => {
25
+ const rules: any = {};
26
+ const ruleKeys = Object.keys(validations);
27
+ for (let key of Object.keys(config.fields)) {
28
+ const field = config.fields[key];
29
+ rules[key] = pick(field, ruleKeys);
30
+
31
+ if (field.required) {
32
+ rules[key].isRequired = true;
33
+ }
34
+ }
35
+
36
+ const errors = validateObject(values, rules, undefined, __);
37
+
38
+ return {
39
+ values,
40
+ errors: formatErrors(errors)
41
+ };
42
+ },
43
+ [__]
44
+ );
45
+ }
@@ -0,0 +1,17 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>部门</title>
4
+ <g id="PC-流程属性、找人找部门+公式化编辑器+字段权限" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g transform="translate(-3271.000000, -1246.000000)" id="部门">
6
+ <g transform="translate(3271.000000, 1246.000000)">
7
+ <rect id="矩形" fill-opacity="0.01" fill="#FFFFFF" fill-rule="nonzero" x="0" y="0" width="16" height="16"></rect>
8
+ <circle id="椭圆形" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round" cx="4.66666667" cy="9.66666667" r="1.66666667"></circle>
9
+ <circle id="椭圆形" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round" cx="11.3333333" cy="9.66666667" r="1.66666667"></circle>
10
+ <circle id="椭圆形" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round" cx="8" cy="3" r="1.66666667"></circle>
11
+ <path d="M8,14.6666667 C8,12.8257333 6.5076,11.3333333 4.66666667,11.3333333 C2.82571667,11.3333333 1.33333333,12.8257333 1.33333333,14.6666667" id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
12
+ <path d="M14.6666667,14.6666667 C14.6666667,12.8257333 13.1742667,11.3333333 11.3333333,11.3333333 C9.4924,11.3333333 8,12.8257333 8,14.6666667" id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
13
+ <path d="M11.3333333,8 C11.3333333,6.15906667 9.84093333,4.66666667 8,4.66666667 C6.15906667,4.66666667 4.66666667,6.15906667 4.66666667,8" id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
14
+ </g>
15
+ </g>
16
+ </g>
17
+ </svg>
@@ -0,0 +1,2 @@
1
+ <?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1649759681558" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1191" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><defs><style type="text/css">@font-face { font-family: feedback-iconfont; src: url("//at.alicdn.com/t/font_1031158_u69w8yhxdu.woff2?t=1630033759944") format("woff2"), url("//at.alicdn.com/t/font_1031158_u69w8yhxdu.woff?t=1630033759944") format("woff"), url("//at.alicdn.com/t/font_1031158_u69w8yhxdu.ttf?t=1630033759944") format("truetype"); }
2
+ </style></defs><path d="M549.624242 214.626263H113.648485c-18.10101 0-32.840404-14.739394-32.840404-32.840404 0-18.10101 14.739394-32.840404 32.840404-32.840404h436.10505c18.10101 0 32.840404 14.739394 32.840404 32.840404-0.129293 18.10101-14.868687 32.840404-32.969697 32.840404z m0 0M549.624242 545.616162H113.648485c-18.10101 0-32.840404-14.739394-32.840404-32.840404 0-18.10101 14.739394-32.840404 32.840404-32.840404h436.10505c18.10101 0 32.840404 14.739394 32.840404 32.840404-0.129293 18.10101-14.868687 32.840404-32.969697 32.840404z m0 0M549.624242 876.088889H113.648485c-18.10101 0-32.840404-14.739394-32.840404-32.840404s14.739394-32.840404 32.840404-32.840404h436.10505c18.10101 0 32.840404 14.739394 32.840404 32.840404s-14.868687 32.840404-32.969697 32.840404z m0 0M932.589899 659.006061c-12.8-12.8-33.616162-12.8-46.416162 0l-104.727272 104.727272V182.044444c0-18.10101-14.739394-32.840404-32.840404-32.840404-18.10101 0-32.840404 14.739394-32.840404 32.840404v661.462627c0 18.10101 14.739394 32.840404 32.840404 32.840404 8.016162 0 15.385859-2.844444 21.074747-7.628283 0.905051-0.775758 162.779798-163.167677 162.779798-163.167677 12.929293-12.8 12.929293-33.745455 0.129293-46.545454z m0 0" fill="" p-id="1192"></path></svg>
@@ -0,0 +1,15 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>岗位</title>
4
+ <g id="选人选部门" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g id="补充icon及颜色" transform="translate(-95.000000, -12.000000)">
6
+ <g id="岗位" transform="translate(95.000000, 12.000000)">
7
+ <rect id="矩形" fill-opacity="0.01" fill="#FFFFFF" fill-rule="nonzero" x="0" y="0" width="16" height="16"></rect>
8
+ <path d="M6.33333333,6.66666667 C7.622,6.66666667 8.66666667,5.622 8.66666667,4.33333333 C8.66666667,3.04467 7.622,2 6.33333333,2 C5.04466667,2 4,3.04467 4,4.33333333 C4,5.622 5.04466667,6.66666667 6.33333333,6.66666667 Z" id="路径" stroke="#FFFFFF" fill="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
9
+ <path d="M10.8692333,2.33333333 C11.5468333,2.74163333 12.0000333,3.48456667 12.0000333,4.33333333 C12.0000333,5.1821 11.5468333,5.92503333 10.8692333,6.33333333" id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
10
+ <path d="M1.33333333,13.6 L1.33333333,14 L11.3333333,14 L11.3333333,13.6 C11.3333333,12.1065333 11.3333333,11.3598 11.0427,10.7893667 C10.7870333,10.2876 10.3790667,9.87963333 9.8773,9.62396667 C9.30686667,9.33333333 8.56013333,9.33333333 7.06666667,9.33333333 L5.6,9.33333333 C4.10653333,9.33333333 3.3598,9.33333333 2.78936,9.62396667 C2.28759333,9.87963333 1.87964333,10.2876 1.62398333,10.7893667 C1.33333333,11.3598 1.33333333,12.1065333 1.33333333,13.6 Z" id="路径" stroke="#FFFFFF" fill="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
11
+ <path d="M14.6666333,14 L14.6666333,13.6 C14.6666333,12.1065333 14.6666333,11.3598 14.376,10.7893667 C14.1203333,10.2876 13.7123667,9.87963333 13.2106,9.62396667" id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
12
+ </g>
13
+ </g>
14
+ </g>
15
+ </svg>
@@ -0,0 +1,14 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>角色</title>
4
+ <g id="PC-流程属性、找人找部门+公式化编辑器+字段权限" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g transform="translate(-3426.000000, -1246.000000)" id="角色">
6
+ <g transform="translate(3426.000000, 1246.000000)">
7
+ <rect id="矩形" fill-opacity="0.01" fill="#FFFFFF" fill-rule="nonzero" x="0" y="0" width="16" height="16"></rect>
8
+ <circle id="椭圆形" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round" cx="8" cy="4" r="2.66666667"></circle>
9
+ <path d="M14,14.6666667 C14,11.3529667 11.3137,8.66666667 8,8.66666667 C4.6863,8.66666667 2,11.3529667 2,14.6666667" id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round"></path>
10
+ <polygon id="路径" stroke="#FFFFFF" stroke-linecap="round" stroke-linejoin="round" points="8 14.6666667 9.33333333 13 8 8.66666667 6.66666667 13"></polygon>
11
+ </g>
12
+ </g>
13
+ </g>
14
+ </svg>
@@ -0,0 +1,12 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>应用中心</title>
4
+ <g id="控件" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <g id="排序删除部门" transform="translate(-16.000000, -16.000000)">
6
+ <g id="编组-39" transform="translate(16.000000, 16.000000)">
7
+ <circle id="椭圆形" fill="#F6654D" cx="8" cy="8" r="8"></circle>
8
+ <rect id="矩形" fill="#FFFFFF" x="4" y="7" width="8" height="2" rx="0.5"></rect>
9
+ </g>
10
+ </g>
11
+ </g>
12
+ </svg>
package/src/index.tsx CHANGED
@@ -87,6 +87,7 @@ import './renderers/Form/ChartRadios';
87
87
  import './renderers/Form/InputRating';
88
88
  import './renderers/Form/Switch';
89
89
  import './renderers/Form/Radios';
90
+ import './renderers/Form/JSONSchema';
90
91
  import './renderers/Form/JSONSchemaEditor';
91
92
  import './renderers/Form/ListSelect';
92
93
  import './renderers/Form/LocationPicker';
@@ -128,6 +129,7 @@ import './renderers/Form/TabsTransfer';
128
129
  import './renderers/Form/TabsTransferPicker';
129
130
  import './renderers/Form/Group';
130
131
  import './renderers/Form/InputGroup';
132
+ import './renderers/Form/UserSelect';
131
133
  import './renderers/Grid';
132
134
  import './renderers/Grid2D';
133
135
  import './renderers/HBox';
@@ -153,6 +153,10 @@ register('de-DE', {
153
153
  'Image.width': 'Weite: {{width}} Pixel',
154
154
  'Image.zoomIn': 'Vergrößern',
155
155
  'Log.mustHaveSource': 'Quelle muss in der Konfiguration vorhanden sein',
156
+ 'Log.showLineNumber': 'Zeilennummer anzeigen',
157
+ 'Log.notShowLineNumber': 'Zeilennummer ausblenden',
158
+ 'Log.expand': 'Erweitern',
159
+ 'Log.collapse': 'Zusammenbruch',
156
160
  'link': 'Link',
157
161
  'loading': 'Wird geladen...',
158
162
  'LocationPicker.placeholder': 'Wählen Sie einen Ort',
@@ -307,15 +311,21 @@ register('de-DE', {
307
311
  'pullRefresh.loadingText': 'Laden...',
308
312
  'pullRefresh.successText': 'Laden erfolgreich',
309
313
  'Picker.placeholder': 'Klicken Sie rechts auf das Symbol',
314
+ 'UserSelect.edit': 'bearbeiten',
315
+ 'UserSelect.save': 'Konservierung',
316
+ 'UserSelect.resultSort': 'Ergebnissortierung auswählen',
317
+ 'UserSelect.selected': 'Ausgewählt',
318
+ 'UserSelect.clear': 'leer',
310
319
  'SchemaType.string': 'String',
311
320
  'SchemaType.number': 'Number',
312
- 'SchemaType.interger': 'Interger',
321
+ 'SchemaType.integer': 'integer',
313
322
  'SchemaType.object': 'Object',
314
323
  'SchemaType.array': 'Array',
315
324
  'SchemaType.boolean': 'Boolean',
316
325
  'SchemaType.null': 'Null',
317
326
  'SchemaType.any': 'Any',
318
327
  'JSONSchema.title': 'Title',
328
+ 'JSONSchema.default': 'Default',
319
329
  'JSONSchema.description': 'Description',
320
330
  'JSONSchema.key': 'Key',
321
331
  'JSONSchema.array_items': 'Items'
@@ -155,6 +155,10 @@ register('en-US', {
155
155
  'Image.width': 'width: {{width}}px',
156
156
  'Image.zoomIn': 'Zoom In',
157
157
  'Log.mustHaveSource': 'Must have source in config',
158
+ 'Log.showLineNumber': 'Display line number',
159
+ 'Log.notShowLineNumber': 'Hide line number',
160
+ 'Log.expand': 'Expand Operation',
161
+ 'Log.collapse': 'Collapse Operation',
158
162
  'link': 'Link',
159
163
  'loading': 'Loading',
160
164
  'LocationPicker.placeholder': 'Pick location',
@@ -188,6 +192,7 @@ register('en-US', {
188
192
  'Select.placeholder': 'Select',
189
193
  'Select.searchPromptText': 'Input to search',
190
194
  'sort': 'Sort',
195
+ 'stop': 'Stop',
191
196
  'SubForm.button': 'Config',
192
197
  'SubForm.editDetail': 'Edit Detail',
193
198
  'System.error': 'System error',
@@ -309,15 +314,21 @@ register('en-US', {
309
314
  'pullRefresh.loadingText': 'Loading...',
310
315
  'pullRefresh.successText': 'Loading success',
311
316
  'Picker.placeholder': 'Click icon on the right',
317
+ 'UserSelect.edit': 'edit',
318
+ 'UserSelect.save': 'preservation',
319
+ 'UserSelect.resultSort': 'Select result sort',
320
+ 'UserSelect.selected': 'Selected',
321
+ 'UserSelect.clear': 'empty',
312
322
  'SchemaType.string': 'String',
313
323
  'SchemaType.number': 'Number',
314
- 'SchemaType.interger': 'Interger',
324
+ 'SchemaType.integer': 'integer',
315
325
  'SchemaType.object': 'Object',
316
326
  'SchemaType.array': 'Array',
317
327
  'SchemaType.boolean': 'Boolean',
318
328
  'SchemaType.any': 'Any',
319
329
  'SchemaType.null': 'Null',
320
330
  'JSONSchema.title': 'Title',
331
+ 'JSONSchema.default': 'Default',
321
332
  'JSONSchema.description': 'Description',
322
333
  'JSONSchema.key': 'Key',
323
334
  'JSONSchema.array_items': 'Items'
@@ -162,6 +162,10 @@ register('zh-CN', {
162
162
  'Image.limitMax': '上传图片大于{{info}},请检查图片尺寸',
163
163
  'Image.limitMin': '上传图片小于{{info}},请检查图片尺寸',
164
164
  'Log.mustHaveSource': '需要配置 Source',
165
+ 'Log.showLineNumber': '显示行数',
166
+ 'Log.notShowLineNumber': '不现实行数',
167
+ 'Log.expand': '展开工具栏',
168
+ 'Log.collapse': '收起工具栏',
165
169
  'link': '链接',
166
170
  'loading': '加载中',
167
171
  'LocationPicker.placeholder': '请选择位置',
@@ -187,6 +191,7 @@ register('zh-CN', {
187
191
  'saveSuccess': '保存成功',
188
192
  'search': '搜索',
189
193
  'searchResult': '搜索结果',
194
+ 'stop': '停止',
190
195
  'Checkboxes.selectAll': '全选/不选',
191
196
  'Select.checkAll': '全选',
192
197
  'Select.clear': '移除',
@@ -304,8 +309,8 @@ register('zh-CN', {
304
309
  'Condition.formula_placeholder': '请输入公式',
305
310
  'Condition.fun_error': '方法未定义',
306
311
  'InputTable.uniqueError': '列`{{label}}`没有通过唯一验证',
307
- 'Timeline.collapseText': '展开',
308
- 'Timeline.expandText': '折叠',
312
+ 'collapse': '展开',
313
+ 'expand': '折叠',
309
314
  'FormulaEditor.btnLabel': '公式编辑',
310
315
  'FormulaEditor.title': '公式编辑器',
311
316
  'FormulaEditor.variable': '变量',
@@ -316,15 +321,21 @@ register('zh-CN', {
316
321
  'pullRefresh.loadingText': '加载中...',
317
322
  'pullRefresh.successText': '加载成功',
318
323
  'Picker.placeholder': '请点击右侧的图标',
324
+ 'UserSelect.edit': '编辑',
325
+ 'UserSelect.save': '保存',
326
+ 'UserSelect.resultSort': '选择结果排序',
327
+ 'UserSelect.selected': '已选',
328
+ 'UserSelect.clear': '清空',
319
329
  'SchemaType.string': '文本',
320
330
  'SchemaType.number': '数字',
321
- 'SchemaType.interger': '整数',
331
+ 'SchemaType.integer': '整数',
322
332
  'SchemaType.object': '对象',
323
333
  'SchemaType.array': '数组',
324
334
  'SchemaType.boolean': '布尔',
325
335
  'SchemaType.null': 'Null',
326
336
  'SchemaType.any': '任意',
327
337
  'JSONSchema.title': '名称',
338
+ 'JSONSchema.default': '默认值',
328
339
  'JSONSchema.key': '字段名',
329
340
  'JSONSchema.description': '描述',
330
341
  'JSONSchema.add_prop': '添加属性',
@@ -398,7 +398,8 @@ const ActionProps = [
398
398
  'copy',
399
399
  'copyFormat',
400
400
  'payload',
401
- 'requireSelected'
401
+ 'requireSelected',
402
+ 'countDown'
402
403
  ];
403
404
  import {filterContents} from './Remark';
404
405
  import {ClassNamesFn, themeable, ThemeProps} from '../theme';
@@ -659,8 +660,7 @@ export class Action extends React.Component<ActionProps, ActionState> {
659
660
  (action as AjaxActionSchema).api = api;
660
661
  }
661
662
 
662
- onAction(e, action);
663
-
663
+ await onAction(e, action);
664
664
  if (countDown) {
665
665
  const countDownEnd = Date.now() + countDown * 1000;
666
666
  this.setState({
@@ -668,9 +668,7 @@ export class Action extends React.Component<ActionProps, ActionState> {
668
668
  inCountDown: true,
669
669
  timeLeft: countDown
670
670
  });
671
-
672
671
  localStorage.setItem(this.localStorageKey, String(countDownEnd));
673
-
674
672
  setTimeout(() => {
675
673
  this.handleCountDown();
676
674
  }, 1000);
@@ -874,11 +872,14 @@ export class ActionRenderer extends React.Component<
874
872
  }
875
873
 
876
874
  if (!ignoreConfirm && action.confirmText && env.confirm) {
877
- env
878
- .confirm(filter(action.confirmText, data))
879
- .then((confirmed: boolean) => confirmed && onAction(e, action, data));
875
+ let confirmed = await env.confirm(filter(action.confirmText, data));
876
+ if (confirmed) {
877
+ await onAction(e, action, data);
878
+ } else if (action.countDown) {
879
+ throw new Error('cancel');
880
+ }
880
881
  } else {
881
- onAction(e, action, data);
882
+ await onAction(e, action, data);
882
883
  }
883
884
  }
884
885
 
@@ -665,7 +665,11 @@ export default class CRUD extends React.Component<CRUDProps, any> {
665
665
  : this.search(undefined, undefined, true, true);
666
666
  action.close && this.closeTarget(action.close);
667
667
  })
668
- .catch(() => {});
668
+ .catch((e) => {
669
+ if (throwErrors || action.countDown) {
670
+ throw e;
671
+ }
672
+ });
669
673
  } else if (
670
674
  pickerMode &&
671
675
  (action.actionType === 'confirm' || action.actionType === 'submit')
@@ -538,7 +538,8 @@ export default class Dialog extends React.Component<DialogProps> {
538
538
  </a>
539
539
  ) : null}
540
540
  {render('title', title, {
541
- data: store.formData
541
+ data: store.formData,
542
+ onAction: this.handleAction
542
543
  })}
543
544
  </div>
544
545
  ) : showCloseButton !== false && !store.loading ? (
@@ -553,7 +554,8 @@ export default class Dialog extends React.Component<DialogProps> {
553
554
 
554
555
  {header
555
556
  ? render('header', header, {
556
- data: store.formData
557
+ data: store.formData,
558
+ onAction: this.handleAction
557
559
  })
558
560
  : null}
559
561
 
@@ -827,7 +829,11 @@ export class DialogRenderer extends Dialog {
827
829
  this.closeTarget(action.close);
828
830
  }
829
831
  })
830
- .catch(() => {});
832
+ .catch(e => {
833
+ if (throwErrors || action.countDown) {
834
+ throw e;
835
+ }
836
+ });
831
837
  } else if (onAction) {
832
838
  let ret = onAction(
833
839
  e,
@@ -821,7 +821,11 @@ export class DrawerRenderer extends Drawer {
821
821
  this.closeTarget(action.close);
822
822
  }
823
823
  })
824
- .catch(() => {});
824
+ .catch((e) => {
825
+ if (throwErrors || action.countDown) {
826
+ throw e;
827
+ }
828
+ });
825
829
  } else if (onAction) {
826
830
  let ret = onAction(
827
831
  e,