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.
- package/lib/RootRenderer.js +10 -2
- package/lib/RootRenderer.js.map +2 -2
- package/lib/Schema.d.ts +3 -2
- package/lib/Schema.js.map +1 -1
- package/lib/SchemaRenderer.js +6 -9
- package/lib/SchemaRenderer.js.map +2 -2
- package/lib/actions/CmptAction.js +4 -4
- package/lib/actions/CmptAction.js.map +2 -2
- package/lib/components/Button.d.ts +11 -10
- package/lib/components/Button.js +2 -2
- package/lib/components/Button.js.map +2 -2
- package/lib/components/CalendarMobile.d.ts +40 -40
- package/lib/components/Checkbox.js +1 -1
- package/lib/components/Checkbox.js.map +2 -2
- package/lib/components/ContextMenu.d.ts +4 -0
- package/lib/components/ContextMenu.js +23 -7
- package/lib/components/ContextMenu.js.map +2 -2
- package/lib/components/DatePicker.d.ts +40 -40
- package/lib/components/DateRangePicker.d.ts +40 -40
- package/lib/components/Form.d.ts +22 -0
- package/lib/components/Form.js +44 -0
- package/lib/components/Form.js.map +13 -0
- package/lib/components/FormField.d.ts +65 -0
- package/lib/components/FormField.js +48 -0
- package/lib/components/FormField.js.map +13 -0
- package/lib/components/InputBox.d.ts +10 -10
- package/lib/components/InputBox.js +4 -3
- package/lib/components/InputBox.js.map +2 -2
- package/lib/components/InputBoxWithSuggestion.d.ts +280 -0
- package/lib/components/InputBoxWithSuggestion.js +65 -0
- package/lib/components/InputBoxWithSuggestion.js.map +13 -0
- package/lib/components/ListGroup.d.ts +10 -10
- package/lib/components/PickerContainer.d.ts +4 -2
- package/lib/components/PickerContainer.js +28 -5
- package/lib/components/PickerContainer.js.map +2 -2
- package/lib/components/Radios.d.ts +10 -10
- package/lib/components/ResultBox.d.ts +40 -40
- package/lib/components/Select.d.ts +195 -202
- package/lib/components/Select.js +7 -3
- package/lib/components/Select.js.map +2 -2
- package/lib/components/Textarea.d.ts +568 -2
- package/lib/components/Textarea.js +129 -1
- package/lib/components/Textarea.js.map +2 -2
- package/lib/components/Toast.js +11 -9
- package/lib/components/Toast.js.map +2 -2
- package/lib/components/UserSelect.d.ts +500 -0
- package/lib/components/UserSelect.js +559 -0
- package/lib/components/UserSelect.js.map +13 -0
- package/lib/components/UserTabSelect.d.ts +320 -0
- package/lib/components/UserTabSelect.js +163 -0
- package/lib/components/UserTabSelect.js.map +13 -0
- package/lib/components/WithRemoteConfig.d.ts +7 -0
- package/lib/components/WithRemoteConfig.js +22 -13
- package/lib/components/WithRemoteConfig.js.map +2 -2
- package/lib/components/calendar/DaysView.d.ts +26 -1
- package/lib/components/calendar/DaysView.js +60 -19
- package/lib/components/calendar/DaysView.js.map +2 -2
- package/lib/components/calendar/TimeView.d.ts +1 -1
- package/lib/components/calendar/TimeView.js +10 -3
- package/lib/components/calendar/TimeView.js.map +2 -2
- package/lib/components/formula/Picker.js +4 -4
- package/lib/components/formula/Picker.js.map +2 -2
- package/lib/components/icons.d.ts +7 -1
- package/lib/components/icons.js +17 -1
- package/lib/components/icons.js.map +2 -2
- package/lib/components/index.d.ts +2 -1
- package/lib/components/index.js +3 -1
- package/lib/components/index.js.map +2 -2
- package/lib/components/json-schema/Array.d.ts +3 -0
- package/lib/components/json-schema/Array.js +125 -0
- package/lib/components/json-schema/Array.js.map +13 -0
- package/lib/components/json-schema/Item.d.ts +3 -0
- package/lib/components/json-schema/Item.js +34 -0
- package/lib/components/json-schema/Item.js.map +13 -0
- package/lib/components/json-schema/Object.d.ts +3 -0
- package/lib/components/json-schema/Object.js +178 -0
- package/lib/components/json-schema/Object.js.map +13 -0
- package/lib/components/json-schema/index.d.ts +279 -0
- package/lib/components/json-schema/index.js +16 -0
- package/lib/components/json-schema/index.js.map +13 -0
- package/lib/components/schema-editor/Array.js +2 -2
- package/lib/components/schema-editor/Array.js.map +2 -2
- package/lib/components/schema-editor/Common.d.ts +2 -0
- package/lib/components/schema-editor/Common.js +39 -3
- package/lib/components/schema-editor/Common.js.map +2 -2
- package/lib/components/schema-editor/Object.js +2 -2
- package/lib/components/schema-editor/Object.js.map +2 -2
- package/lib/components/schema-editor/index.d.ts +45 -41
- package/lib/components/schema-editor/index.js +5 -5
- package/lib/components/schema-editor/index.js.map +2 -2
- package/lib/components/table/ItemActionsWrapper.d.ts +10 -0
- package/lib/components/table/ItemActionsWrapper.js +25 -0
- package/lib/components/table/ItemActionsWrapper.js.map +13 -0
- package/lib/components/table/index.d.ts +48 -41
- package/lib/components/table/index.js +46 -18
- package/lib/components/table/index.js.map +2 -2
- package/lib/helper.css +125 -124
- package/lib/helper.css.map +1 -1
- package/lib/hooks/use-validation-resolver.d.ts +1 -0
- package/lib/hooks/use-validation-resolver.js +49 -0
- package/lib/hooks/use-validation-resolver.js.map +13 -0
- package/lib/icons/department.js +17 -0
- package/lib/icons/menu.js +9 -0
- package/lib/icons/post.js +15 -0
- package/lib/icons/role.js +14 -0
- package/lib/icons/user-remove.js +12 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +3 -1
- package/lib/index.js.map +2 -2
- package/lib/locale/de-DE.js +11 -1
- package/lib/locale/de-DE.js.map +2 -2
- package/lib/locale/en-US.js +12 -1
- package/lib/locale/en-US.js.map +2 -2
- package/lib/locale/zh-CN.js +14 -3
- package/lib/locale/zh-CN.js.map +2 -2
- package/lib/renderers/Action.js +25 -11
- package/lib/renderers/Action.js.map +2 -2
- package/lib/renderers/CRUD.js +5 -1
- package/lib/renderers/CRUD.js.map +2 -2
- package/lib/renderers/Dialog.js +9 -3
- package/lib/renderers/Dialog.js.map +2 -2
- package/lib/renderers/Drawer.js +5 -1
- package/lib/renderers/Drawer.js.map +2 -2
- package/lib/renderers/Form/InputDate.d.ts +2 -2
- package/lib/renderers/Form/InputDate.js.map +2 -2
- package/lib/renderers/Form/JSONSchema.d.ts +23 -0
- package/lib/renderers/Form/JSONSchema.js +44 -0
- package/lib/renderers/Form/JSONSchema.js.map +13 -0
- package/lib/renderers/Form/JSONSchemaEditor.d.ts +2 -3
- package/lib/renderers/Form/JSONSchemaEditor.js +9 -24
- package/lib/renderers/Form/JSONSchemaEditor.js.map +2 -2
- package/lib/renderers/Form/Options.js +11 -5
- package/lib/renderers/Form/Options.js.map +2 -2
- package/lib/renderers/Form/Textarea.d.ts +1 -8
- package/lib/renderers/Form/Textarea.js +11 -75
- package/lib/renderers/Form/Textarea.js.map +2 -2
- package/lib/renderers/Form/UserSelect.d.ts +54 -0
- package/lib/renderers/Form/UserSelect.js +197 -0
- package/lib/renderers/Form/UserSelect.js.map +13 -0
- package/lib/renderers/Form/index.d.ts +1 -1
- package/lib/renderers/Form/index.js +88 -42
- package/lib/renderers/Form/index.js.map +2 -2
- package/lib/renderers/Form/wrapControl.js.map +2 -2
- package/lib/renderers/Log.d.ts +28 -0
- package/lib/renderers/Log.js +110 -20
- package/lib/renderers/Log.js.map +2 -2
- package/lib/renderers/Page.js +5 -1
- package/lib/renderers/Page.js.map +2 -2
- package/lib/renderers/Service.js +5 -1
- package/lib/renderers/Service.js.map +2 -2
- package/lib/renderers/Table-v2/index.d.ts +14 -2
- package/lib/renderers/Table-v2/index.js +33 -3
- package/lib/renderers/Table-v2/index.js.map +2 -2
- package/lib/renderers/Wizard.js +37 -14
- package/lib/renderers/Wizard.js.map +2 -2
- package/lib/store/form.js +65 -45
- package/lib/store/form.js.map +2 -2
- package/lib/themes/ang-ie11.css +576 -24
- package/lib/themes/ang.css +553 -12
- package/lib/themes/ang.css.map +1 -1
- package/lib/themes/antd-ie11.css +576 -24
- package/lib/themes/antd.css +553 -12
- package/lib/themes/antd.css.map +1 -1
- package/lib/themes/cxd-ie11.css +576 -24
- package/lib/themes/cxd.css +553 -12
- package/lib/themes/cxd.css.map +1 -1
- package/lib/themes/dark-ie11.css +576 -24
- package/lib/themes/dark.css +553 -12
- package/lib/themes/dark.css.map +1 -1
- package/lib/themes/default-ie11.css +576 -24
- package/lib/themes/default.css +553 -12
- package/lib/themes/default.css.map +1 -1
- package/lib/utils/api.js +1 -1
- package/lib/utils/api.js.map +2 -2
- package/lib/utils/renderer-event.js.map +2 -2
- package/package.json +2 -1
- package/schema.json +552 -5
- package/scss/_properties.scss +20 -8
- package/scss/components/_input-box.scss +22 -1
- package/scss/components/_json-schema.scss +124 -0
- package/scss/components/_log.scss +37 -5
- package/scss/components/form/_date-range.scss +1 -0
- package/scss/components/form/_select.scss +9 -0
- package/scss/components/form/_transfer.scss +19 -3
- package/scss/components/form/_user-select.scss +422 -0
- package/scss/helper/background/_background-color.scss +125 -124
- package/scss/themes/_common.scss +2 -0
- package/sdk/ang-ie11.css +670 -24
- package/sdk/ang.css +647 -12
- package/sdk/antd-ie11.css +670 -24
- package/sdk/antd.css +647 -12
- package/sdk/barcode.js +51 -51
- package/sdk/charts.js +14 -14
- package/sdk/codemirror.js +7 -7
- package/sdk/color-picker.js +65 -65
- package/sdk/cropperjs.js +2 -2
- package/sdk/cxd-ie11.css +670 -24
- package/sdk/cxd.css +647 -12
- package/sdk/dark-ie11.css +670 -24
- package/sdk/dark.css +647 -12
- package/sdk/exceljs.js +1 -1
- package/sdk/helper.css +125 -124
- package/sdk/helper.css.map +1 -1
- package/sdk/locale/de-DE.js +11 -1
- package/sdk/markdown.js +69 -69
- package/sdk/papaparse.js +1 -1
- package/sdk/renderers/Form/CityDB.js +1 -1
- package/sdk/rest.js +16 -16
- package/sdk/rich-text.js +62 -62
- package/sdk/sdk-ie11.css +670 -24
- package/sdk/sdk.css +647 -12
- package/sdk/sdk.js +1653 -1637
- package/sdk/thirds/hls.js/hls.js +1 -1
- package/sdk/thirds/mpegts.js/mpegts.js +1 -1
- package/sdk/tinymce.js +57 -57
- package/src/RootRenderer.tsx +27 -15
- package/src/Schema.ts +5 -1
- package/src/SchemaRenderer.tsx +1 -4
- package/src/actions/CmptAction.ts +4 -4
- package/src/components/Button.tsx +3 -0
- package/src/components/Checkbox.tsx +2 -1
- package/src/components/ContextMenu.tsx +25 -7
- package/src/components/Form.tsx +70 -0
- package/src/components/FormField.tsx +127 -0
- package/src/components/InputBox.tsx +4 -1
- package/src/components/InputBoxWithSuggestion.tsx +113 -0
- package/src/components/PickerContainer.tsx +20 -5
- package/src/components/Select.tsx +18 -10
- package/src/components/Textarea.tsx +234 -2
- package/src/components/Toast.tsx +19 -18
- package/src/components/UserSelect.tsx +850 -0
- package/src/components/UserTabSelect.tsx +261 -0
- package/src/components/WithRemoteConfig.tsx +35 -11
- package/src/components/calendar/DaysView.tsx +117 -49
- package/src/components/calendar/TimeView.tsx +11 -6
- package/src/components/formula/Picker.tsx +2 -1
- package/src/components/icons.tsx +17 -1
- package/src/components/index.tsx +3 -1
- package/src/components/json-schema/Array.tsx +216 -0
- package/src/components/json-schema/Item.tsx +47 -0
- package/src/components/json-schema/Object.tsx +339 -0
- package/src/components/json-schema/index.tsx +44 -0
- package/src/components/schema-editor/Array.tsx +3 -1
- package/src/components/schema-editor/Common.tsx +61 -4
- package/src/components/schema-editor/Object.tsx +3 -1
- package/src/components/schema-editor/index.tsx +12 -5
- package/src/components/table/ItemActionsWrapper.tsx +32 -0
- package/src/components/table/index.tsx +115 -58
- package/src/hooks/use-validation-resolver.ts +45 -0
- package/src/icons/department.svg +17 -0
- package/src/icons/menu.svg +2 -0
- package/src/icons/post.svg +15 -0
- package/src/icons/role.svg +14 -0
- package/src/icons/user-remove.svg +12 -0
- package/src/index.tsx +2 -0
- package/src/locale/de-DE.ts +11 -1
- package/src/locale/en-US.ts +12 -1
- package/src/locale/zh-CN.ts +14 -3
- package/src/renderers/Action.tsx +10 -9
- package/src/renderers/CRUD.tsx +5 -1
- package/src/renderers/Dialog.tsx +9 -3
- package/src/renderers/Drawer.tsx +5 -1
- package/src/renderers/Form/InputDate.tsx +9 -4
- package/src/renderers/Form/JSONSchema.tsx +56 -0
- package/src/renderers/Form/JSONSchemaEditor.tsx +8 -27
- package/src/renderers/Form/Options.tsx +17 -7
- package/src/renderers/Form/Textarea.tsx +7 -117
- package/src/renderers/Form/UserSelect.tsx +263 -0
- package/src/renderers/Form/index.tsx +28 -18
- package/src/renderers/Form/wrapControl.tsx +0 -1
- package/src/renderers/Log.tsx +213 -19
- package/src/renderers/Page.tsx +6 -1
- package/src/renderers/Service.tsx +5 -1
- package/src/renderers/Table-v2/index.tsx +65 -2
- package/src/renderers/Wizard.tsx +24 -10
- package/src/store/form.ts +24 -17
- package/src/utils/api.ts +1 -1
- 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?:
|
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
|
-
|
1108
|
-
|
1109
|
-
|
1110
|
-
|
1111
|
-
|
1112
|
-
|
1113
|
-
|
1114
|
-
|
1115
|
-
|
1116
|
-
|
1117
|
-
|
1118
|
-
|
1119
|
-
|
1120
|
-
|
1121
|
-
|
1122
|
-
|
1123
|
-
|
1124
|
-
|
1125
|
-
|
1126
|
-
|
1127
|
-
|
1128
|
-
|
1129
|
-
|
1130
|
-
|
1131
|
-
|
1132
|
-
|
1133
|
-
|
1134
|
-
|
1135
|
-
|
1136
|
-
|
1137
|
-
|
1138
|
-
|
1139
|
-
|
1140
|
-
|
1141
|
-
|
1142
|
-
|
1143
|
-
|
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
|
1186
|
-
|
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
|
1210
|
-
|
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={
|
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
|
-
|
1428
|
-
|
1429
|
-
|
1430
|
-
|
1431
|
-
|
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 {
|
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
|
1852
|
-
|
1853
|
-
|
1854
|
-
|
1855
|
-
|
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';
|
package/src/locale/de-DE.ts
CHANGED
@@ -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.
|
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'
|
package/src/locale/en-US.ts
CHANGED
@@ -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.
|
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'
|
package/src/locale/zh-CN.ts
CHANGED
@@ -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
|
-
'
|
308
|
-
'
|
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.
|
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': '添加属性',
|
package/src/renderers/Action.tsx
CHANGED
@@ -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
|
-
|
879
|
-
|
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
|
|
package/src/renderers/CRUD.tsx
CHANGED
@@ -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')
|
package/src/renderers/Dialog.tsx
CHANGED
@@ -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,
|
package/src/renderers/Drawer.tsx
CHANGED
@@ -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,
|