@ai-table/grid 0.0.73 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/angular-konva/components/container.component.d.ts.map +1 -1
- package/angular-konva/components/shape.component.d.ts.map +1 -1
- package/angular-konva/components/stage.component.d.ts.map +1 -1
- package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
- package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
- package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -1
- package/components/cell-editors/link/link-editor.component.d.ts.map +1 -1
- package/components/cell-editors/number/number-editor.component.d.ts.map +1 -1
- package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
- package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
- package/components/cell-views/select/option.component.d.ts.map +1 -1
- package/components/context-menu/context-menu.component.d.ts.map +1 -1
- package/components/drag/drag.component.d.ts.map +1 -1
- package/components/field-menu/field-menu.component.d.ts.map +1 -1
- package/components/field-setting/field-setting.component.d.ts.map +1 -1
- package/core/context.d.ts +2 -0
- package/core/context.d.ts.map +1 -1
- package/core/types/ai-table.d.ts.map +1 -1
- package/core/utils/field.d.ts.map +1 -1
- package/core/utils/queries.d.ts.map +1 -1
- package/core/utils/short-id.d.ts.map +1 -1
- package/dom-grid.component.d.ts.map +1 -1
- package/fesm2022/ai-table-grid.mjs +322 -310
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +3 -1
- package/grid-base.component.d.ts.map +1 -1
- package/grid.component.d.ts +1 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +3 -5
- package/pipes/grid.pipe.d.ts.map +1 -1
- package/renderer/components/action-icon.component.d.ts.map +1 -1
- package/renderer/components/add-field-column.component.d.ts.map +1 -1
- package/renderer/components/cells/attachment.component.d.ts.map +1 -1
- package/renderer/components/cells/link.component.d.ts.map +1 -1
- package/renderer/components/cells/progress.component.d.ts.map +1 -1
- package/renderer/components/cells/rate.component.d.ts.map +1 -1
- package/renderer/components/cells/rich-text.component.d.ts.map +1 -1
- package/renderer/components/cells.component.d.ts.map +1 -1
- package/renderer/components/field-head.component.d.ts +2 -2
- package/renderer/components/field-head.component.d.ts.map +1 -1
- package/renderer/components/field-icon.component.d.ts.map +1 -1
- package/renderer/components/frozen-cells.component.d.ts.map +1 -1
- package/renderer/components/frozen-heads.component.d.ts +1 -1
- package/renderer/components/frozen-heads.component.d.ts.map +1 -1
- package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -1
- package/renderer/components/heads.component.d.ts +1 -1
- package/renderer/components/heads.component.d.ts.map +1 -1
- package/renderer/components/hover-cell.component.d.ts.map +1 -1
- package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
- package/renderer/components/icon.component.d.ts.map +1 -1
- package/renderer/components/other-rows.component.d.ts.map +1 -1
- package/renderer/components/placeholder-cells.component.d.ts.map +1 -1
- package/renderer/components/text.component.d.ts.map +1 -1
- package/renderer/creations/create-active-cell-border.d.ts.map +1 -1
- package/renderer/creations/create-cells.d.ts.map +1 -1
- package/renderer/creations/create-heads.d.ts.map +1 -1
- package/renderer/drawers/add-row-layout-drawer.d.ts +1 -1
- package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/renderer/drawers/drawer.d.ts +1 -1
- package/renderer/renderer.component.d.ts +5 -4
- package/renderer/renderer.component.d.ts.map +1 -1
- package/types/cell.d.ts +2 -0
- package/types/cell.d.ts.map +1 -1
- package/types/component-config.d.ts +2 -0
- package/types/component-config.d.ts.map +1 -1
- package/types/grid.d.ts +4 -0
- package/types/grid.d.ts.map +1 -1
- package/types/row.d.ts +1 -0
- package/types/row.d.ts.map +1 -1
- package/utils/build.d.ts.map +1 -1
- package/utils/clipboard/clipboard.d.ts.map +1 -1
- package/utils/clipboard/copy.d.ts.map +1 -1
- package/utils/clipboard/paste.d.ts +5 -1
- package/utils/clipboard/paste.d.ts.map +1 -1
- package/utils/common.d.ts.map +1 -1
- package/utils/field/model/date.d.ts.map +1 -1
- package/utils/field/model/link.d.ts.map +1 -1
- package/utils/field/model/progress.d.ts.map +1 -1
- package/utils/field/model/text.d.ts.map +1 -1
- package/utils/get-text-width.d.ts.map +1 -1
- package/utils/i18n.d.ts +2 -0
- package/utils/i18n.d.ts.map +1 -1
- package/utils/match-keywords.d.ts.map +1 -1
- package/utils/position.d.ts.map +1 -1
- package/utils/style.d.ts.map +1 -1
- package/utils/text-measure.d.ts.map +1 -1
- package/utils/visible-range.d.ts.map +1 -1
- package/esm2022/ai-table-grid.mjs +0 -5
- package/esm2022/angular-konva/components/container.component.mjs +0 -29
- package/esm2022/angular-konva/components/container.token.mjs +0 -3
- package/esm2022/angular-konva/components/index.mjs +0 -4
- package/esm2022/angular-konva/components/shape.component.mjs +0 -142
- package/esm2022/angular-konva/components/stage.component.mjs +0 -123
- package/esm2022/angular-konva/index.mjs +0 -5
- package/esm2022/angular-konva/interfaces/component.mjs +0 -4
- package/esm2022/angular-konva/interfaces/config.mjs +0 -2
- package/esm2022/angular-konva/interfaces/event-object.mjs +0 -2
- package/esm2022/angular-konva/interfaces/index.mjs +0 -5
- package/esm2022/angular-konva/interfaces/shape.mjs +0 -42
- package/esm2022/angular-konva/utils/apply-node-props.mjs +0 -67
- package/esm2022/angular-konva/utils/common.mjs +0 -48
- package/esm2022/angular-konva/utils/index.mjs +0 -5
- package/esm2022/angular-konva/utils/types.mjs +0 -2
- package/esm2022/angular-konva/utils/update-picture.mjs +0 -7
- package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +0 -56
- package/esm2022/components/cell-editors/date/date-editor.component.mjs +0 -87
- package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +0 -81
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +0 -122
- package/esm2022/components/cell-editors/number/number-editor.component.mjs +0 -41
- package/esm2022/components/cell-editors/select/select-editor.component.mjs +0 -74
- package/esm2022/components/cell-editors/text/text-editor.component.mjs +0 -76
- package/esm2022/components/cell-views/select/option.component.mjs +0 -28
- package/esm2022/components/context-menu/context-menu.component.mjs +0 -42
- package/esm2022/components/drag/drag.component.mjs +0 -300
- package/esm2022/components/field-menu/field-menu.component.mjs +0 -47
- package/esm2022/components/field-setting/field-setting.component.mjs +0 -142
- package/esm2022/components/index.mjs +0 -10
- package/esm2022/constants/colors.mjs +0 -19
- package/esm2022/constants/editor.mjs +0 -11
- package/esm2022/constants/file-icon.mjs +0 -342
- package/esm2022/constants/grid.mjs +0 -35
- package/esm2022/constants/icon.mjs +0 -30
- package/esm2022/constants/index.mjs +0 -7
- package/esm2022/constants/table.mjs +0 -78
- package/esm2022/constants/text.mjs +0 -23
- package/esm2022/core/constants/field.mjs +0 -107
- package/esm2022/core/context.mjs +0 -29
- package/esm2022/core/coordinate.mjs +0 -222
- package/esm2022/core/index.mjs +0 -6
- package/esm2022/core/types/ai-table.mjs +0 -57
- package/esm2022/core/types/core.mjs +0 -2
- package/esm2022/core/types/index.mjs +0 -3
- package/esm2022/core/utils/common.mjs +0 -45
- package/esm2022/core/utils/field.mjs +0 -64
- package/esm2022/core/utils/id-creator.mjs +0 -21
- package/esm2022/core/utils/index.mjs +0 -5
- package/esm2022/core/utils/queries.mjs +0 -80
- package/esm2022/core/utils/short-id.mjs +0 -53
- package/esm2022/dom-grid.component.mjs +0 -80
- package/esm2022/grid-base.component.mjs +0 -145
- package/esm2022/grid.component.mjs +0 -649
- package/esm2022/index.mjs +0 -2
- package/esm2022/pipes/grid.pipe.mjs +0 -110
- package/esm2022/pipes/index.mjs +0 -2
- package/esm2022/public-api.mjs +0 -12
- package/esm2022/renderer/components/action-icon.component.mjs +0 -117
- package/esm2022/renderer/components/add-field-column.component.mjs +0 -88
- package/esm2022/renderer/components/cells/attachment.component.mjs +0 -107
- package/esm2022/renderer/components/cells/cells.mjs +0 -6
- package/esm2022/renderer/components/cells/index.mjs +0 -7
- package/esm2022/renderer/components/cells/link.component.mjs +0 -89
- package/esm2022/renderer/components/cells/progress.component.mjs +0 -268
- package/esm2022/renderer/components/cells/rate.component.mjs +0 -153
- package/esm2022/renderer/components/cells/rich-text.component.mjs +0 -95
- package/esm2022/renderer/components/cells.component.mjs +0 -35
- package/esm2022/renderer/components/field-head.component.mjs +0 -146
- package/esm2022/renderer/components/field-icon.component.mjs +0 -72
- package/esm2022/renderer/components/frozen-cells.component.mjs +0 -36
- package/esm2022/renderer/components/frozen-heads.component.mjs +0 -214
- package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +0 -38
- package/esm2022/renderer/components/heads.component.mjs +0 -38
- package/esm2022/renderer/components/hover-cell.component.mjs +0 -104
- package/esm2022/renderer/components/hover-row-heads.component.mjs +0 -132
- package/esm2022/renderer/components/icon.component.mjs +0 -84
- package/esm2022/renderer/components/index.mjs +0 -15
- package/esm2022/renderer/components/other-rows.component.mjs +0 -68
- package/esm2022/renderer/components/placeholder-cells.component.mjs +0 -33
- package/esm2022/renderer/components/text.component.mjs +0 -67
- package/esm2022/renderer/creations/create-active-cell-border.mjs +0 -70
- package/esm2022/renderer/creations/create-cells.mjs +0 -190
- package/esm2022/renderer/creations/create-heads.mjs +0 -51
- package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +0 -98
- package/esm2022/renderer/drawers/cell-drawer.mjs +0 -673
- package/esm2022/renderer/drawers/drawer.mjs +0 -947
- package/esm2022/renderer/drawers/layout-drawer.mjs +0 -64
- package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +0 -131
- package/esm2022/renderer/index.mjs +0 -4
- package/esm2022/renderer/interfaces/hover-cell.mjs +0 -4
- package/esm2022/renderer/interfaces/index.mjs +0 -2
- package/esm2022/renderer/renderer.component.mjs +0 -197
- package/esm2022/services/event.service.mjs +0 -241
- package/esm2022/services/field.service.mjs +0 -56
- package/esm2022/services/index.mjs +0 -4
- package/esm2022/services/selection.service.mjs +0 -151
- package/esm2022/types/avatar.mjs +0 -27
- package/esm2022/types/canvas.mjs +0 -2
- package/esm2022/types/cell.mjs +0 -2
- package/esm2022/types/clipboard.mjs +0 -2
- package/esm2022/types/component-config.mjs +0 -7
- package/esm2022/types/field.mjs +0 -2
- package/esm2022/types/grid.mjs +0 -17
- package/esm2022/types/index.mjs +0 -10
- package/esm2022/types/layout.mjs +0 -2
- package/esm2022/types/row.mjs +0 -6
- package/esm2022/utils/build.mjs +0 -39
- package/esm2022/utils/cell.mjs +0 -80
- package/esm2022/utils/clear-cells.mjs +0 -23
- package/esm2022/utils/clipboard/clipboard.mjs +0 -88
- package/esm2022/utils/clipboard/copy.mjs +0 -99
- package/esm2022/utils/clipboard/extract.mjs +0 -38
- package/esm2022/utils/clipboard/index.mjs +0 -5
- package/esm2022/utils/clipboard/paste.mjs +0 -188
- package/esm2022/utils/common.mjs +0 -50
- package/esm2022/utils/field/field-operable.mjs +0 -2
- package/esm2022/utils/field/field.mjs +0 -20
- package/esm2022/utils/field/index.mjs +0 -4
- package/esm2022/utils/field/model/attachment.mjs +0 -56
- package/esm2022/utils/field/model/date.mjs +0 -141
- package/esm2022/utils/field/model/index.mjs +0 -12
- package/esm2022/utils/field/model/link.mjs +0 -56
- package/esm2022/utils/field/model/member.mjs +0 -81
- package/esm2022/utils/field/model/number.mjs +0 -59
- package/esm2022/utils/field/model/progress.mjs +0 -69
- package/esm2022/utils/field/model/rate.mjs +0 -58
- package/esm2022/utils/field/model/rich-text.mjs +0 -39
- package/esm2022/utils/field/model/select.mjs +0 -131
- package/esm2022/utils/field/model/text.mjs +0 -32
- package/esm2022/utils/field/operate.mjs +0 -73
- package/esm2022/utils/file.mjs +0 -116
- package/esm2022/utils/get-placeholder-cells.mjs +0 -66
- package/esm2022/utils/get-text-width.mjs +0 -30
- package/esm2022/utils/hover-cell.mjs +0 -25
- package/esm2022/utils/i18n.mjs +0 -87
- package/esm2022/utils/image-cache.mjs +0 -57
- package/esm2022/utils/index.mjs +0 -19
- package/esm2022/utils/match-keywords.mjs +0 -15
- package/esm2022/utils/os.mjs +0 -16
- package/esm2022/utils/position.mjs +0 -48
- package/esm2022/utils/style.mjs +0 -37
- package/esm2022/utils/text-measure.mjs +0 -122
- package/esm2022/utils/visible-range.mjs +0 -42
@@ -1,56 +0,0 @@
|
|
1
|
-
import { isNil } from 'lodash';
|
2
|
-
import { AITableFieldType, LinkFieldBase, AITableFilterOperation, isEmpty } from '@ai-table/utils';
|
3
|
-
import { extractText, extractLinkUrl } from '../../clipboard';
|
4
|
-
import { compareString, isMeetFilter, stringInclude } from '../operate';
|
5
|
-
export class LinkField extends LinkFieldBase {
|
6
|
-
isMeetFilter(condition, cellValue) {
|
7
|
-
if (cellValue === null) {
|
8
|
-
if (condition.operation === AITableFilterOperation.empty) {
|
9
|
-
return true;
|
10
|
-
}
|
11
|
-
else {
|
12
|
-
return false;
|
13
|
-
}
|
14
|
-
}
|
15
|
-
const cellTextValue = cellValue?.text;
|
16
|
-
switch (condition.operation) {
|
17
|
-
case AITableFilterOperation.empty:
|
18
|
-
return isEmpty(cellTextValue);
|
19
|
-
case AITableFilterOperation.exists:
|
20
|
-
return !isEmpty(cellTextValue);
|
21
|
-
case AITableFilterOperation.contain:
|
22
|
-
return !isNil(cellTextValue) && stringInclude(cellTextValue, condition.value);
|
23
|
-
default:
|
24
|
-
return isMeetFilter(condition, cellTextValue);
|
25
|
-
}
|
26
|
-
}
|
27
|
-
compare(cellValue1, cellValue2) {
|
28
|
-
return compareString(cellValueToSortValue(cellValue1), cellValueToSortValue(cellValue2));
|
29
|
-
}
|
30
|
-
toFieldValue(plainText, targetField, originData) {
|
31
|
-
return toLinkFieldValue(plainText, targetField, originData);
|
32
|
-
}
|
33
|
-
}
|
34
|
-
export function toLinkFieldValue(plainText, targetField, originData) {
|
35
|
-
if (originData) {
|
36
|
-
const { field, cellValue } = originData;
|
37
|
-
if (field.type === AITableFieldType.link) {
|
38
|
-
return cellValue;
|
39
|
-
}
|
40
|
-
}
|
41
|
-
else {
|
42
|
-
const url = extractLinkUrl(plainText);
|
43
|
-
const text = extractText(plainText);
|
44
|
-
if (url && text) {
|
45
|
-
return {
|
46
|
-
url,
|
47
|
-
text
|
48
|
-
};
|
49
|
-
}
|
50
|
-
}
|
51
|
-
return null;
|
52
|
-
}
|
53
|
-
function cellValueToSortValue(cellValue) {
|
54
|
-
return (cellValue && cellValue.text && cellValue.text.trim()) || null;
|
55
|
-
}
|
56
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3V0aWxzL2ZpZWxkL21vZGVsL2xpbmsudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUMvQixPQUFPLEVBRUgsZ0JBQWdCLEVBR2hCLGFBQWEsRUFFYixzQkFBc0IsRUFDdEIsT0FBTyxFQUNWLE1BQU0saUJBQWlCLENBQUM7QUFDekIsT0FBTyxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFHeEUsTUFBTSxPQUFPLFNBQVUsU0FBUSxhQUFhO0lBQ3hDLFlBQVksQ0FBQyxTQUF5QyxFQUFFLFNBQXlCO1FBQzdFLElBQUksU0FBUyxLQUFLLElBQUksRUFBRSxDQUFDO1lBQ3JCLElBQUksU0FBUyxDQUFDLFNBQVMsS0FBSyxzQkFBc0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztnQkFDdkQsT0FBTyxJQUFJLENBQUM7WUFDaEIsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLE9BQU8sS0FBSyxDQUFDO1lBQ2pCLENBQUM7UUFDTCxDQUFDO1FBQ0QsTUFBTSxhQUFhLEdBQUcsU0FBUyxFQUFFLElBQUksQ0FBQztRQUN0QyxRQUFRLFNBQVMsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMxQixLQUFLLHNCQUFzQixDQUFDLEtBQUs7Z0JBQzdCLE9BQU8sT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBQ2xDLEtBQUssc0JBQXNCLENBQUMsTUFBTTtnQkFDOUIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUNuQyxLQUFLLHNCQUFzQixDQUFDLE9BQU87Z0JBQy9CLE9BQU8sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLElBQUksYUFBYSxDQUFDLGFBQWEsRUFBRSxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbEY7Z0JBQ0ksT0FBTyxZQUFZLENBQUMsU0FBUyxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ3RELENBQUM7SUFDTCxDQUFDO0lBRUQsT0FBTyxDQUFDLFVBQTBCLEVBQUUsVUFBMEI7UUFDMUQsT0FBTyxhQUFhLENBQUMsb0JBQW9CLENBQUMsVUFBVSxDQUFDLEVBQUUsb0JBQW9CLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztJQUM3RixDQUFDO0lBRUQsWUFBWSxDQUNSLFNBQWlCLEVBQ2pCLFdBQXlCLEVBQ3pCLFVBQWtFO1FBRWxFLE9BQU8sZ0JBQWdCLENBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUNoRSxDQUFDO0NBQ0o7QUFFRCxNQUFNLFVBQVUsZ0JBQWdCLENBQzVCLFNBQWlCLEVBQ2pCLFdBQXlCLEVBQ3pCLFVBQWtFO0lBRWxFLElBQUksVUFBVSxFQUFFLENBQUM7UUFDYixNQUFNLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLFVBQVUsQ0FBQztRQUN4QyxJQUFJLEtBQUssQ0FBQyxJQUFJLEtBQUssZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDdkMsT0FBTyxTQUFTLENBQUM7UUFDckIsQ0FBQztJQUNMLENBQUM7U0FBTSxDQUFDO1FBQ0osTUFBTSxHQUFHLEdBQUcsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3RDLE1BQU0sSUFBSSxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNwQyxJQUFJLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNkLE9BQU87Z0JBQ0gsR0FBRztnQkFDSCxJQUFJO2FBQ1AsQ0FBQztRQUNOLENBQUM7SUFDTCxDQUFDO0lBQ0QsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQztBQUVELFNBQVMsb0JBQW9CLENBQUMsU0FBeUI7SUFDbkQsT0FBTyxDQUFDLFNBQVMsSUFBSSxTQUFTLENBQUMsSUFBSSxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUM7QUFDMUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzTmlsIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7XG4gICAgQUlUYWJsZUZpZWxkLFxuICAgIEFJVGFibGVGaWVsZFR5cGUsXG4gICAgRmllbGRWYWx1ZSxcbiAgICBMaW5rRmllbGRWYWx1ZSxcbiAgICBMaW5rRmllbGRCYXNlLFxuICAgIEFJVGFibGVGaWx0ZXJDb25kaXRpb24sXG4gICAgQUlUYWJsZUZpbHRlck9wZXJhdGlvbixcbiAgICBpc0VtcHR5XG59IGZyb20gJ0BhaS10YWJsZS91dGlscyc7XG5pbXBvcnQgeyBleHRyYWN0VGV4dCwgZXh0cmFjdExpbmtVcmwgfSBmcm9tICcuLi8uLi9jbGlwYm9hcmQnO1xuaW1wb3J0IHsgY29tcGFyZVN0cmluZywgaXNNZWV0RmlsdGVyLCBzdHJpbmdJbmNsdWRlIH0gZnJvbSAnLi4vb3BlcmF0ZSc7XG5pbXBvcnQgeyBGaWVsZE9wZXJhYmxlIH0gZnJvbSAnLi4vZmllbGQtb3BlcmFibGUnO1xuXG5leHBvcnQgY2xhc3MgTGlua0ZpZWxkIGV4dGVuZHMgTGlua0ZpZWxkQmFzZSBpbXBsZW1lbnRzIEZpZWxkT3BlcmFibGU8c3RyaW5nLCBMaW5rRmllbGRWYWx1ZT4ge1xuICAgIGlzTWVldEZpbHRlcihjb25kaXRpb246IEFJVGFibGVGaWx0ZXJDb25kaXRpb248c3RyaW5nPiwgY2VsbFZhbHVlOiBMaW5rRmllbGRWYWx1ZSkge1xuICAgICAgICBpZiAoY2VsbFZhbHVlID09PSBudWxsKSB7XG4gICAgICAgICAgICBpZiAoY29uZGl0aW9uLm9wZXJhdGlvbiA9PT0gQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5lbXB0eSkge1xuICAgICAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgY2VsbFRleHRWYWx1ZSA9IGNlbGxWYWx1ZT8udGV4dDtcbiAgICAgICAgc3dpdGNoIChjb25kaXRpb24ub3BlcmF0aW9uKSB7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uZW1wdHk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzRW1wdHkoY2VsbFRleHRWYWx1ZSk7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uZXhpc3RzOlxuICAgICAgICAgICAgICAgIHJldHVybiAhaXNFbXB0eShjZWxsVGV4dFZhbHVlKTtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5jb250YWluOlxuICAgICAgICAgICAgICAgIHJldHVybiAhaXNOaWwoY2VsbFRleHRWYWx1ZSkgJiYgc3RyaW5nSW5jbHVkZShjZWxsVGV4dFZhbHVlLCBjb25kaXRpb24udmFsdWUpO1xuICAgICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgICAgICByZXR1cm4gaXNNZWV0RmlsdGVyKGNvbmRpdGlvbiwgY2VsbFRleHRWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBjb21wYXJlKGNlbGxWYWx1ZTE6IExpbmtGaWVsZFZhbHVlLCBjZWxsVmFsdWUyOiBMaW5rRmllbGRWYWx1ZSk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiBjb21wYXJlU3RyaW5nKGNlbGxWYWx1ZVRvU29ydFZhbHVlKGNlbGxWYWx1ZTEpLCBjZWxsVmFsdWVUb1NvcnRWYWx1ZShjZWxsVmFsdWUyKSk7XG4gICAgfVxuXG4gICAgdG9GaWVsZFZhbHVlKFxuICAgICAgICBwbGFpblRleHQ6IHN0cmluZyxcbiAgICAgICAgdGFyZ2V0RmllbGQ6IEFJVGFibGVGaWVsZCxcbiAgICAgICAgb3JpZ2luRGF0YT86IHsgZmllbGQ6IEFJVGFibGVGaWVsZDsgY2VsbFZhbHVlOiBGaWVsZFZhbHVlIH0gfCBudWxsXG4gICAgKTogRmllbGRWYWx1ZSB8IG51bGwge1xuICAgICAgICByZXR1cm4gdG9MaW5rRmllbGRWYWx1ZShwbGFpblRleHQsIHRhcmdldEZpZWxkLCBvcmlnaW5EYXRhKTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b0xpbmtGaWVsZFZhbHVlKFxuICAgIHBsYWluVGV4dDogc3RyaW5nLFxuICAgIHRhcmdldEZpZWxkOiBBSVRhYmxlRmllbGQsXG4gICAgb3JpZ2luRGF0YT86IHsgZmllbGQ6IEFJVGFibGVGaWVsZDsgY2VsbFZhbHVlOiBGaWVsZFZhbHVlIH0gfCBudWxsXG4pOiBGaWVsZFZhbHVlIHwgbnVsbCB7XG4gICAgaWYgKG9yaWdpbkRhdGEpIHtcbiAgICAgICAgY29uc3QgeyBmaWVsZCwgY2VsbFZhbHVlIH0gPSBvcmlnaW5EYXRhO1xuICAgICAgICBpZiAoZmllbGQudHlwZSA9PT0gQUlUYWJsZUZpZWxkVHlwZS5saW5rKSB7XG4gICAgICAgICAgICByZXR1cm4gY2VsbFZhbHVlO1xuICAgICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgdXJsID0gZXh0cmFjdExpbmtVcmwocGxhaW5UZXh0KTtcbiAgICAgICAgY29uc3QgdGV4dCA9IGV4dHJhY3RUZXh0KHBsYWluVGV4dCk7XG4gICAgICAgIGlmICh1cmwgJiYgdGV4dCkge1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICB1cmwsXG4gICAgICAgICAgICAgICAgdGV4dFxuICAgICAgICAgICAgfTtcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbn1cblxuZnVuY3Rpb24gY2VsbFZhbHVlVG9Tb3J0VmFsdWUoY2VsbFZhbHVlOiBMaW5rRmllbGRWYWx1ZSk6IHN0cmluZyB8IG51bGwge1xuICAgIHJldHVybiAoY2VsbFZhbHVlICYmIGNlbGxWYWx1ZS50ZXh0ICYmIGNlbGxWYWx1ZS50ZXh0LnRyaW0oKSkgfHwgbnVsbDtcbn1cbiJdfQ==
|
@@ -1,81 +0,0 @@
|
|
1
|
-
import { compareString, hasIntersect, isMeetFilter } from '../operate';
|
2
|
-
import { MemberFieldBase, AITableFieldType, AITableFilterOperation, isEmpty } from '@ai-table/utils';
|
3
|
-
export class MemberField extends MemberFieldBase {
|
4
|
-
isMeetFilter(condition, cellValue) {
|
5
|
-
switch (condition.operation) {
|
6
|
-
case AITableFilterOperation.empty:
|
7
|
-
return isEmpty(cellValue);
|
8
|
-
case AITableFilterOperation.exists:
|
9
|
-
return !isEmpty(cellValue);
|
10
|
-
case AITableFilterOperation.in:
|
11
|
-
return Array.isArray(condition.value) && hasIntersect(cellValue, condition.value);
|
12
|
-
case AITableFilterOperation.nin:
|
13
|
-
return Array.isArray(condition.value) && !hasIntersect(cellValue, condition.value);
|
14
|
-
default:
|
15
|
-
return isMeetFilter(condition, cellValue);
|
16
|
-
}
|
17
|
-
}
|
18
|
-
compare(cellValue1, cellValue2, references, sortKey, options) {
|
19
|
-
const value1 = cellValueToSortValue(cellValue1, options.field, references, sortKey);
|
20
|
-
const value2 = cellValueToSortValue(cellValue2, options.field, references, sortKey);
|
21
|
-
return compareString(value1, value2);
|
22
|
-
}
|
23
|
-
toFieldValue(plainText, targetField, originData, references) {
|
24
|
-
return toMemberFieldValue(plainText, targetField, originData, references);
|
25
|
-
}
|
26
|
-
}
|
27
|
-
export function toMemberFieldValue(plainText, targetField, originData, references) {
|
28
|
-
if (targetField.type == AITableFieldType.createdBy || targetField.type == AITableFieldType.updatedBy) {
|
29
|
-
return null;
|
30
|
-
}
|
31
|
-
const isMultiple = targetField.settings?.is_multiple;
|
32
|
-
if (originData) {
|
33
|
-
const { field, cellValue } = originData;
|
34
|
-
switch (field.type) {
|
35
|
-
case AITableFieldType.member:
|
36
|
-
if (Array.isArray(cellValue) && cellValue.length) {
|
37
|
-
return isMultiple ? cellValue : [cellValue[0]];
|
38
|
-
}
|
39
|
-
break;
|
40
|
-
default:
|
41
|
-
break;
|
42
|
-
}
|
43
|
-
}
|
44
|
-
plainText = plainText.trim();
|
45
|
-
const hasMemberInfo = references && references.members && Object.keys(references.members).length;
|
46
|
-
if (plainText && hasMemberInfo) {
|
47
|
-
const memberNames = plainText
|
48
|
-
.split(',')
|
49
|
-
.map((id) => id.trim())
|
50
|
-
.filter((id) => !!id);
|
51
|
-
const memberInfos = Object.values(references.members);
|
52
|
-
let validMemberIds = [];
|
53
|
-
memberNames.forEach((memberName) => {
|
54
|
-
const memberInfo = memberInfos.find((member) => member.display_name === memberName);
|
55
|
-
if (memberInfo) {
|
56
|
-
validMemberIds.push(memberInfo.uid);
|
57
|
-
}
|
58
|
-
});
|
59
|
-
if (validMemberIds.length) {
|
60
|
-
return isMultiple ? validMemberIds : [validMemberIds[0]];
|
61
|
-
}
|
62
|
-
}
|
63
|
-
return null;
|
64
|
-
}
|
65
|
-
function cellValueToSortValue(cellValue, field, references, sortKey = 'display_name') {
|
66
|
-
let values = [];
|
67
|
-
if (cellValue?.length && references) {
|
68
|
-
for (let index = 0; index < cellValue.length; index++) {
|
69
|
-
const userInfo = references?.members[cellValue[index]];
|
70
|
-
if (!userInfo) {
|
71
|
-
continue;
|
72
|
-
}
|
73
|
-
const value = userInfo[sortKey];
|
74
|
-
if (value) {
|
75
|
-
values.push(value);
|
76
|
-
}
|
77
|
-
}
|
78
|
-
}
|
79
|
-
return values && values.length ? values.join(', ') : null;
|
80
|
-
}
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"member.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/member.ts"],"names":[],"mappings":"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","sourcesContent":["import { compareString, hasIntersect, isMeetFilter } from '../operate';\nimport {\n    AITableFilterCondition,\n    MemberFieldBase,\n    AITableField,\n    AITableFieldType,\n    AITableReferences,\n    FieldValue,\n    MemberFieldValue,\n    MemberSettings,\n    AITableFilterOperation,\n    Id,\n    isEmpty\n} from '@ai-table/utils';\nimport { FieldOperable } from '../field-operable';\nimport { AITable } from '../../../core';\n\nexport class MemberField extends MemberFieldBase implements FieldOperable<string, MemberFieldValue> {\n    isMeetFilter(condition: AITableFilterCondition<string>, cellValue: MemberFieldValue) {\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue);\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue);\n            case AITableFilterOperation.in:\n                return Array.isArray(condition.value) && hasIntersect(cellValue, condition.value);\n            case AITableFilterOperation.nin:\n                return Array.isArray(condition.value) && !hasIntersect(cellValue, condition.value);\n            default:\n                return isMeetFilter(condition, cellValue);\n        }\n    }\n\n    compare(\n        cellValue1: MemberFieldValue,\n        cellValue2: MemberFieldValue,\n        references: AITableReferences,\n        sortKey: string,\n        options: {\n            aiTable: AITable;\n            field: AITableField;\n        }\n    ): number {\n        const value1 = cellValueToSortValue(cellValue1, options.field, references, sortKey);\n        const value2 = cellValueToSortValue(cellValue2, options.field, references, sortKey);\n        return compareString(value1, value2);\n    }\n\n    toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue },\n        references?: AITableReferences\n    ): FieldValue | null {\n        return toMemberFieldValue(plainText, targetField, originData, references);\n    }\n}\n\nexport function toMemberFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue },\n    references?: AITableReferences\n): FieldValue | null {\n    if (targetField.type == AITableFieldType.createdBy || targetField.type == AITableFieldType.updatedBy) {\n        return null;\n    }\n\n    const isMultiple = (targetField.settings as MemberSettings)?.is_multiple;\n    if (originData) {\n        const { field, cellValue } = originData;\n        switch (field.type) {\n            case AITableFieldType.member:\n                if (Array.isArray(cellValue) && cellValue.length) {\n                    return isMultiple ? cellValue : [cellValue[0]];\n                }\n                break;\n            default:\n                break;\n        }\n    }\n\n    plainText = plainText.trim();\n    const hasMemberInfo = references && references.members && Object.keys(references.members).length;\n    if (plainText && hasMemberInfo) {\n        const memberNames = plainText\n            .split(',')\n            .map((id) => id.trim())\n            .filter((id) => !!id);\n        const memberInfos = Object.values(references.members);\n        let validMemberIds: MemberFieldValue = [];\n        memberNames.forEach((memberName) => {\n            const memberInfo = memberInfos.find((member) => member.display_name === memberName);\n            if (memberInfo) {\n                validMemberIds.push(memberInfo.uid as Id);\n            }\n        });\n        if (validMemberIds.length) {\n            return isMultiple ? validMemberIds : [validMemberIds[0]];\n        }\n    }\n\n    return null;\n}\n\nfunction cellValueToSortValue(\n    cellValue: MemberFieldValue,\n    field: AITableField,\n    references: AITableReferences,\n    sortKey = 'display_name'\n): string | null {\n    let values: string[] = [];\n    if (cellValue?.length && references) {\n        for (let index = 0; index < cellValue.length; index++) {\n            const userInfo = references?.members[cellValue[index]];\n            if (!userInfo) {\n                continue;\n            }\n\n            const value = userInfo[sortKey];\n            if (value) {\n                values.push(value);\n            }\n        }\n    }\n    return values && values.length ? values.join(', ') : null;\n}\n"]}
|
@@ -1,59 +0,0 @@
|
|
1
|
-
import { helpers } from 'ngx-tethys/util';
|
2
|
-
import { AITableFieldType, AITableFilterOperation, NumberFieldBase, isEmpty } from '@ai-table/utils';
|
3
|
-
import { compareNumber, isMeetFilter } from '../operate';
|
4
|
-
export class NumberField extends NumberFieldBase {
|
5
|
-
isMeetFilter(condition, cellValue) {
|
6
|
-
switch (condition.operation) {
|
7
|
-
case AITableFilterOperation.empty:
|
8
|
-
return isEmpty(cellValue);
|
9
|
-
case AITableFilterOperation.exists:
|
10
|
-
return !isEmpty(cellValue);
|
11
|
-
case AITableFilterOperation.eq:
|
12
|
-
return !Number.isNaN(condition.value) && cellValue != null && condition.value === cellValue;
|
13
|
-
case AITableFilterOperation.gte:
|
14
|
-
return cellValue != null && cellValue >= condition.value;
|
15
|
-
case AITableFilterOperation.lte:
|
16
|
-
return cellValue != null && cellValue <= condition.value;
|
17
|
-
case AITableFilterOperation.gt:
|
18
|
-
return cellValue != null && cellValue > condition.value;
|
19
|
-
case AITableFilterOperation.lt:
|
20
|
-
return cellValue != null && cellValue < condition.value;
|
21
|
-
case AITableFilterOperation.ne:
|
22
|
-
return cellValue == null || Number.isNaN(condition.value) || cellValue !== condition.value;
|
23
|
-
default:
|
24
|
-
return isMeetFilter(condition, cellValue);
|
25
|
-
}
|
26
|
-
}
|
27
|
-
compare(cellValue1, cellValue2) {
|
28
|
-
return compareNumber(cellValue1, cellValue2);
|
29
|
-
}
|
30
|
-
toFieldValue(plainText, targetField, originData) {
|
31
|
-
return toNumberFieldValue(plainText, targetField, originData);
|
32
|
-
}
|
33
|
-
}
|
34
|
-
export function toNumberFieldValue(plainText, targetField, originData) {
|
35
|
-
let text = plainText.trim();
|
36
|
-
if (originData) {
|
37
|
-
const { field, cellValue } = originData;
|
38
|
-
const fieldType = field.type;
|
39
|
-
switch (fieldType) {
|
40
|
-
case AITableFieldType.number:
|
41
|
-
case AITableFieldType.rate:
|
42
|
-
case AITableFieldType.progress:
|
43
|
-
return cellValue;
|
44
|
-
case AITableFieldType.select:
|
45
|
-
if (cellValue && Array.isArray(cellValue) && cellValue.length) {
|
46
|
-
const optionsMap = helpers.keyBy(field.settings.options || [], '_id');
|
47
|
-
text = optionsMap[cellValue[0]]?.text;
|
48
|
-
}
|
49
|
-
break;
|
50
|
-
default:
|
51
|
-
break;
|
52
|
-
}
|
53
|
-
}
|
54
|
-
if (text && !isEmpty(text) && !Number.isNaN(Number(text))) {
|
55
|
-
return Number(text);
|
56
|
-
}
|
57
|
-
return null;
|
58
|
-
}
|
59
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvdXRpbHMvZmllbGQvbW9kZWwvbnVtYmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxPQUFPLEVBRUgsZ0JBQWdCLEVBRWhCLHNCQUFzQixFQUl0QixlQUFlLEVBQ2YsT0FBTyxFQUNWLE1BQU0saUJBQWlCLENBQUM7QUFDekIsT0FBTyxFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFHekQsTUFBTSxPQUFPLFdBQVksU0FBUSxlQUFlO0lBQzVDLFlBQVksQ0FBQyxTQUF5QyxFQUFFLFNBQTJCO1FBQy9FLFFBQVEsU0FBUyxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQzFCLEtBQUssc0JBQXNCLENBQUMsS0FBSztnQkFDN0IsT0FBTyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDOUIsS0FBSyxzQkFBc0IsQ0FBQyxNQUFNO2dCQUM5QixPQUFPLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQy9CLEtBQUssc0JBQXNCLENBQUMsRUFBRTtnQkFDMUIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLFNBQVMsSUFBSSxJQUFJLElBQUksU0FBUyxDQUFDLEtBQUssS0FBSyxTQUFTLENBQUM7WUFDaEcsS0FBSyxzQkFBc0IsQ0FBQyxHQUFHO2dCQUMzQixPQUFPLFNBQVMsSUFBSSxJQUFJLElBQUksU0FBUyxJQUFJLFNBQVMsQ0FBQyxLQUFLLENBQUM7WUFDN0QsS0FBSyxzQkFBc0IsQ0FBQyxHQUFHO2dCQUMzQixPQUFPLFNBQVMsSUFBSSxJQUFJLElBQUksU0FBUyxJQUFJLFNBQVMsQ0FBQyxLQUFLLENBQUM7WUFDN0QsS0FBSyxzQkFBc0IsQ0FBQyxFQUFFO2dCQUMxQixPQUFPLFNBQVMsSUFBSSxJQUFJLElBQUksU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUM7WUFDNUQsS0FBSyxzQkFBc0IsQ0FBQyxFQUFFO2dCQUMxQixPQUFPLFNBQVMsSUFBSSxJQUFJLElBQUksU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUM7WUFDNUQsS0FBSyxzQkFBc0IsQ0FBQyxFQUFFO2dCQUMxQixPQUFPLFNBQVMsSUFBSSxJQUFJLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksU0FBUyxLQUFLLFNBQVMsQ0FBQyxLQUFLLENBQUM7WUFDL0Y7Z0JBQ0ksT0FBTyxZQUFZLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ2xELENBQUM7SUFDTCxDQUFDO0lBRUQsT0FBTyxDQUFDLFVBQTRCLEVBQUUsVUFBNEI7UUFDOUQsT0FBTyxhQUFhLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFRCxZQUFZLENBQ1IsU0FBaUIsRUFDakIsV0FBeUIsRUFDekIsVUFBMkQ7UUFFM0QsT0FBTyxrQkFBa0IsQ0FBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7Q0FDSjtBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FDOUIsU0FBaUIsRUFDakIsV0FBeUIsRUFDekIsVUFBMkQ7SUFFM0QsSUFBSSxJQUFJLEdBQUcsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBRTVCLElBQUksVUFBVSxFQUFFLENBQUM7UUFDYixNQUFNLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLFVBQVUsQ0FBQztRQUN4QyxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDO1FBRTdCLFFBQVEsU0FBUyxFQUFFLENBQUM7WUFDaEIsS0FBSyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUM7WUFDN0IsS0FBSyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUM7WUFDM0IsS0FBSyxnQkFBZ0IsQ0FBQyxRQUFRO2dCQUMxQixPQUFPLFNBQVMsQ0FBQztZQUNyQixLQUFLLGdCQUFnQixDQUFDLE1BQU07Z0JBQ3hCLElBQUksU0FBUyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDO29CQUM1RCxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFFLEtBQUssQ0FBQyxRQUEyQixDQUFDLE9BQU8sSUFBSSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7b0JBQzFGLElBQUksR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDO2dCQUMxQyxDQUFDO2dCQUNELE1BQU07WUFDVjtnQkFDSSxNQUFNO1FBQ2QsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUN4RCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixDQUFDO0lBQ0QsT0FBTyxJQUFJLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGhlbHBlcnMgfSBmcm9tICduZ3gtdGV0aHlzL3V0aWwnO1xuaW1wb3J0IHtcbiAgICBBSVRhYmxlRmllbGQsXG4gICAgQUlUYWJsZUZpZWxkVHlwZSxcbiAgICBBSVRhYmxlRmlsdGVyQ29uZGl0aW9uLFxuICAgIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24sXG4gICAgRmllbGRWYWx1ZSxcbiAgICBOdW1iZXJGaWVsZFZhbHVlLFxuICAgIFNlbGVjdFNldHRpbmdzLFxuICAgIE51bWJlckZpZWxkQmFzZSxcbiAgICBpc0VtcHR5XG59IGZyb20gJ0BhaS10YWJsZS91dGlscyc7XG5pbXBvcnQgeyBjb21wYXJlTnVtYmVyLCBpc01lZXRGaWx0ZXIgfSBmcm9tICcuLi9vcGVyYXRlJztcbmltcG9ydCB7IEZpZWxkT3BlcmFibGUgfSBmcm9tICcuLi9maWVsZC1vcGVyYWJsZSc7XG5cbmV4cG9ydCBjbGFzcyBOdW1iZXJGaWVsZCBleHRlbmRzIE51bWJlckZpZWxkQmFzZSBpbXBsZW1lbnRzIEZpZWxkT3BlcmFibGU8bnVtYmVyLCBOdW1iZXJGaWVsZFZhbHVlPiB7XG4gICAgaXNNZWV0RmlsdGVyKGNvbmRpdGlvbjogQUlUYWJsZUZpbHRlckNvbmRpdGlvbjxudW1iZXI+LCBjZWxsVmFsdWU6IE51bWJlckZpZWxkVmFsdWUpIHtcbiAgICAgICAgc3dpdGNoIChjb25kaXRpb24ub3BlcmF0aW9uKSB7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uZW1wdHk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzRW1wdHkoY2VsbFZhbHVlKTtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5leGlzdHM6XG4gICAgICAgICAgICAgICAgcmV0dXJuICFpc0VtcHR5KGNlbGxWYWx1ZSk7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uZXE6XG4gICAgICAgICAgICAgICAgcmV0dXJuICFOdW1iZXIuaXNOYU4oY29uZGl0aW9uLnZhbHVlKSAmJiBjZWxsVmFsdWUgIT0gbnVsbCAmJiBjb25kaXRpb24udmFsdWUgPT09IGNlbGxWYWx1ZTtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5ndGU6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGNlbGxWYWx1ZSAhPSBudWxsICYmIGNlbGxWYWx1ZSA+PSBjb25kaXRpb24udmFsdWU7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24ubHRlOlxuICAgICAgICAgICAgICAgIHJldHVybiBjZWxsVmFsdWUgIT0gbnVsbCAmJiBjZWxsVmFsdWUgPD0gY29uZGl0aW9uLnZhbHVlO1xuICAgICAgICAgICAgY2FzZSBBSVRhYmxlRmlsdGVyT3BlcmF0aW9uLmd0OlxuICAgICAgICAgICAgICAgIHJldHVybiBjZWxsVmFsdWUgIT0gbnVsbCAmJiBjZWxsVmFsdWUgPiBjb25kaXRpb24udmFsdWU7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24ubHQ6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGNlbGxWYWx1ZSAhPSBudWxsICYmIGNlbGxWYWx1ZSA8IGNvbmRpdGlvbi52YWx1ZTtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5uZTpcbiAgICAgICAgICAgICAgICByZXR1cm4gY2VsbFZhbHVlID09IG51bGwgfHwgTnVtYmVyLmlzTmFOKGNvbmRpdGlvbi52YWx1ZSkgfHwgY2VsbFZhbHVlICE9PSBjb25kaXRpb24udmFsdWU7XG4gICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgIHJldHVybiBpc01lZXRGaWx0ZXIoY29uZGl0aW9uLCBjZWxsVmFsdWUpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgY29tcGFyZShjZWxsVmFsdWUxOiBOdW1iZXJGaWVsZFZhbHVlLCBjZWxsVmFsdWUyOiBOdW1iZXJGaWVsZFZhbHVlKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIGNvbXBhcmVOdW1iZXIoY2VsbFZhbHVlMSwgY2VsbFZhbHVlMik7XG4gICAgfVxuXG4gICAgdG9GaWVsZFZhbHVlKFxuICAgICAgICBwbGFpblRleHQ6IHN0cmluZyxcbiAgICAgICAgdGFyZ2V0RmllbGQ6IEFJVGFibGVGaWVsZCxcbiAgICAgICAgb3JpZ2luRGF0YT86IHsgZmllbGQ6IEFJVGFibGVGaWVsZDsgY2VsbFZhbHVlOiBGaWVsZFZhbHVlIH1cbiAgICApOiBGaWVsZFZhbHVlIHwgbnVsbCB7XG4gICAgICAgIHJldHVybiB0b051bWJlckZpZWxkVmFsdWUocGxhaW5UZXh0LCB0YXJnZXRGaWVsZCwgb3JpZ2luRGF0YSk7XG4gICAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9OdW1iZXJGaWVsZFZhbHVlKFxuICAgIHBsYWluVGV4dDogc3RyaW5nLFxuICAgIHRhcmdldEZpZWxkOiBBSVRhYmxlRmllbGQsXG4gICAgb3JpZ2luRGF0YT86IHsgZmllbGQ6IEFJVGFibGVGaWVsZDsgY2VsbFZhbHVlOiBGaWVsZFZhbHVlIH1cbik6IE51bWJlckZpZWxkVmFsdWUgfCBudWxsIHtcbiAgICBsZXQgdGV4dCA9IHBsYWluVGV4dC50cmltKCk7XG5cbiAgICBpZiAob3JpZ2luRGF0YSkge1xuICAgICAgICBjb25zdCB7IGZpZWxkLCBjZWxsVmFsdWUgfSA9IG9yaWdpbkRhdGE7XG4gICAgICAgIGNvbnN0IGZpZWxkVHlwZSA9IGZpZWxkLnR5cGU7XG5cbiAgICAgICAgc3dpdGNoIChmaWVsZFR5cGUpIHtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpZWxkVHlwZS5udW1iZXI6XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWVsZFR5cGUucmF0ZTpcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpZWxkVHlwZS5wcm9ncmVzczpcbiAgICAgICAgICAgICAgICByZXR1cm4gY2VsbFZhbHVlO1xuICAgICAgICAgICAgY2FzZSBBSVRhYmxlRmllbGRUeXBlLnNlbGVjdDpcbiAgICAgICAgICAgICAgICBpZiAoY2VsbFZhbHVlICYmIEFycmF5LmlzQXJyYXkoY2VsbFZhbHVlKSAmJiBjZWxsVmFsdWUubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IG9wdGlvbnNNYXAgPSBoZWxwZXJzLmtleUJ5KChmaWVsZC5zZXR0aW5ncyBhcyBTZWxlY3RTZXR0aW5ncykub3B0aW9ucyB8fCBbXSwgJ19pZCcpO1xuICAgICAgICAgICAgICAgICAgICB0ZXh0ID0gb3B0aW9uc01hcFtjZWxsVmFsdWVbMF1dPy50ZXh0O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAodGV4dCAmJiAhaXNFbXB0eSh0ZXh0KSAmJiAhTnVtYmVyLmlzTmFOKE51bWJlcih0ZXh0KSkpIHtcbiAgICAgICAgcmV0dXJuIE51bWJlcih0ZXh0KTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG59XG4iXX0=
|
@@ -1,69 +0,0 @@
|
|
1
|
-
import { helpers, isEmpty } from 'ngx-tethys/util';
|
2
|
-
import { AITableFieldType, AITableFilterOperation, ProgressFieldBase } from '@ai-table/utils';
|
3
|
-
import { compareNumber, isMeetFilter } from '../operate';
|
4
|
-
export class ProgressField extends ProgressFieldBase {
|
5
|
-
isMeetFilter(condition, cellValue) {
|
6
|
-
switch (condition.operation) {
|
7
|
-
case AITableFilterOperation.empty:
|
8
|
-
return isEmpty(cellValue);
|
9
|
-
case AITableFilterOperation.exists:
|
10
|
-
return !isEmpty(cellValue);
|
11
|
-
case AITableFilterOperation.eq:
|
12
|
-
return !Number.isNaN(condition.value) && cellValue != null && condition.value === cellValue;
|
13
|
-
case AITableFilterOperation.gte:
|
14
|
-
return cellValue != null && cellValue >= condition.value;
|
15
|
-
case AITableFilterOperation.lte:
|
16
|
-
return cellValue != null && cellValue <= condition.value;
|
17
|
-
case AITableFilterOperation.gt:
|
18
|
-
return cellValue != null && cellValue > condition.value;
|
19
|
-
case AITableFilterOperation.lt:
|
20
|
-
return cellValue != null && cellValue < condition.value;
|
21
|
-
case AITableFilterOperation.ne:
|
22
|
-
return cellValue == null || Number.isNaN(condition.value) || cellValue !== condition.value;
|
23
|
-
default:
|
24
|
-
return isMeetFilter(condition, cellValue);
|
25
|
-
}
|
26
|
-
}
|
27
|
-
compare(cellValue1, cellValue2) {
|
28
|
-
return compareNumber(cellValue1, cellValue2);
|
29
|
-
}
|
30
|
-
toFieldValue(plainText, targetField, originData) {
|
31
|
-
return toProgressFieldValue(plainText, targetField, originData);
|
32
|
-
}
|
33
|
-
}
|
34
|
-
export function toProgressFieldValue(plainText, targetField, originData) {
|
35
|
-
let value = plainText.trim();
|
36
|
-
if (originData) {
|
37
|
-
const { field, cellValue } = originData;
|
38
|
-
switch (field.type) {
|
39
|
-
case AITableFieldType.progress:
|
40
|
-
case AITableFieldType.rate:
|
41
|
-
case AITableFieldType.number:
|
42
|
-
value = cellValue;
|
43
|
-
break;
|
44
|
-
case AITableFieldType.select:
|
45
|
-
if (cellValue && Array.isArray(cellValue) && cellValue.length) {
|
46
|
-
const optionsMap = helpers.keyBy(field.settings.options || [], '_id');
|
47
|
-
value = optionsMap[cellValue[0]]?.text;
|
48
|
-
}
|
49
|
-
break;
|
50
|
-
default:
|
51
|
-
break;
|
52
|
-
}
|
53
|
-
}
|
54
|
-
const progressRegex = /^(?:100|[1-9]?\d(?:\.\d+)?)\s*%$/;
|
55
|
-
if (progressRegex.test(value)) {
|
56
|
-
value = parseFloat(value);
|
57
|
-
}
|
58
|
-
if (!isEmpty(value)) {
|
59
|
-
let progressValue = Number(value);
|
60
|
-
if (!Number.isNaN(progressValue)) {
|
61
|
-
progressValue = Math.round(progressValue);
|
62
|
-
if (progressValue >= 0 && progressValue <= 100) {
|
63
|
-
return progressValue;
|
64
|
-
}
|
65
|
-
}
|
66
|
-
}
|
67
|
-
return null;
|
68
|
-
}
|
69
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/progress.ts"],"names":[],"mappings":"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","sourcesContent":["import { helpers, isEmpty } from 'ngx-tethys/util';\nimport {\n    AITableField,\n    AITableFieldType,\n    AITableFilterCondition,\n    AITableFilterOperation,\n    FieldValue,\n    ProgressFieldValue,\n    SelectSettings,\n    ProgressFieldBase\n} from '@ai-table/utils';\nimport { compareNumber, isMeetFilter } from '../operate';\nimport { FieldOperable } from '../field-operable';\n\nexport class ProgressField extends ProgressFieldBase implements FieldOperable<number, ProgressFieldValue> {\n    isMeetFilter(condition: AITableFilterCondition<number>, cellValue: ProgressFieldValue) {\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue);\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue);\n            case AITableFilterOperation.eq:\n                return !Number.isNaN(condition.value) && cellValue != null && condition.value === cellValue;\n            case AITableFilterOperation.gte:\n                return cellValue != null && cellValue >= condition.value;\n            case AITableFilterOperation.lte:\n                return cellValue != null && cellValue <= condition.value;\n            case AITableFilterOperation.gt:\n                return cellValue != null && cellValue > condition.value;\n            case AITableFilterOperation.lt:\n                return cellValue != null && cellValue < condition.value;\n            case AITableFilterOperation.ne:\n                return cellValue == null || Number.isNaN(condition.value) || cellValue !== condition.value;\n            default:\n                return isMeetFilter(condition, cellValue);\n        }\n    }\n\n    compare(cellValue1: ProgressFieldValue, cellValue2: ProgressFieldValue): number {\n        return compareNumber(cellValue1, cellValue2);\n    }\n\n    toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue }\n    ): FieldValue | null {\n        return toProgressFieldValue(plainText, targetField, originData);\n    }\n}\n\nexport function toProgressFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue }\n): FieldValue | null {\n    let value: any = plainText.trim();\n    if (originData) {\n        const { field, cellValue } = originData;\n        switch (field.type) {\n            case AITableFieldType.progress:\n            case AITableFieldType.rate:\n            case AITableFieldType.number:\n                value = cellValue;\n                break;\n            case AITableFieldType.select:\n                if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n                    const optionsMap = helpers.keyBy((field.settings as SelectSettings).options || [], '_id');\n                    value = optionsMap[cellValue[0]]?.text;\n                }\n                break;\n            default:\n                break;\n        }\n    }\n\n    const progressRegex = /^(?:100|[1-9]?\\d(?:\\.\\d+)?)\\s*%$/;\n    if (progressRegex.test(value)) {\n        value = parseFloat(value);\n    }\n\n    if (!isEmpty(value)) {\n        let progressValue = Number(value);\n        if (!Number.isNaN(progressValue)) {\n            progressValue = Math.round(progressValue);\n            if (progressValue >= 0 && progressValue <= 100) {\n                return progressValue;\n            }\n        }\n    }\n\n    return null;\n}\n"]}
|
@@ -1,58 +0,0 @@
|
|
1
|
-
import { helpers } from 'ngx-tethys/util';
|
2
|
-
import { AITableFieldType, AITableFilterOperation, RateFieldBase, isEmpty } from '@ai-table/utils';
|
3
|
-
import { compareNumber, isMeetFilter } from '../operate';
|
4
|
-
import { isNumber } from 'lodash';
|
5
|
-
export class RateField extends RateFieldBase {
|
6
|
-
isMeetFilter(condition, cellValue) {
|
7
|
-
switch (condition.operation) {
|
8
|
-
case AITableFilterOperation.empty:
|
9
|
-
return isEmpty(cellValue);
|
10
|
-
case AITableFilterOperation.exists:
|
11
|
-
return !isEmpty(cellValue);
|
12
|
-
case AITableFilterOperation.in:
|
13
|
-
const isContain = condition.value.some((item) => String(item) === String(cellValue));
|
14
|
-
return !isEmpty(cellValue) && isContain;
|
15
|
-
case AITableFilterOperation.nin:
|
16
|
-
const noContain = condition.value.every((item) => String(item) !== String(cellValue));
|
17
|
-
return isEmpty(cellValue) || noContain;
|
18
|
-
default:
|
19
|
-
return isMeetFilter(condition, cellValue);
|
20
|
-
}
|
21
|
-
}
|
22
|
-
compare(cellValue1, cellValue2) {
|
23
|
-
return compareNumber(cellValue1, cellValue2);
|
24
|
-
}
|
25
|
-
toFieldValue(plainText, targetField, originData) {
|
26
|
-
return toRateFieldValue(plainText, targetField, originData);
|
27
|
-
}
|
28
|
-
}
|
29
|
-
export function toRateFieldValue(plainText, targetField, originData) {
|
30
|
-
let value = plainText.trim();
|
31
|
-
if (originData) {
|
32
|
-
const { field, cellValue } = originData;
|
33
|
-
switch (field.type) {
|
34
|
-
case AITableFieldType.rate:
|
35
|
-
case AITableFieldType.number:
|
36
|
-
case AITableFieldType.progress:
|
37
|
-
value = cellValue;
|
38
|
-
break;
|
39
|
-
case AITableFieldType.select:
|
40
|
-
if (cellValue && Array.isArray(cellValue) && cellValue.length) {
|
41
|
-
const optionsMap = helpers.keyBy(field.settings.options || [], '_id');
|
42
|
-
value = optionsMap[cellValue[0]]?.text;
|
43
|
-
}
|
44
|
-
break;
|
45
|
-
default:
|
46
|
-
break;
|
47
|
-
}
|
48
|
-
}
|
49
|
-
if (!isEmpty(value) || isNumber(value)) {
|
50
|
-
const rateValue = Number(value);
|
51
|
-
if (!Number.isNaN(rateValue) && rateValue > 0 && rateValue < 5) {
|
52
|
-
return Math.round(rateValue);
|
53
|
-
}
|
54
|
-
return 5;
|
55
|
-
}
|
56
|
-
return null;
|
57
|
-
}
|
58
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3V0aWxzL2ZpZWxkL21vZGVsL3JhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzFDLE9BQU8sRUFFSCxnQkFBZ0IsRUFFaEIsc0JBQXNCLEVBSXRCLGFBQWEsRUFDYixPQUFPLEVBQ1YsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxNQUFNLFlBQVksQ0FBQztBQUV6RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBRWxDLE1BQU0sT0FBTyxTQUFVLFNBQVEsYUFBYTtJQUN4QyxZQUFZLENBQUMsU0FBMkMsRUFBRSxTQUF5QjtRQUMvRSxRQUFRLFNBQVMsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMxQixLQUFLLHNCQUFzQixDQUFDLEtBQUs7Z0JBQzdCLE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQzlCLEtBQUssc0JBQXNCLENBQUMsTUFBTTtnQkFDOUIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUMvQixLQUFLLHNCQUFzQixDQUFDLEVBQUU7Z0JBQzFCLE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JGLE9BQU8sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksU0FBUyxDQUFDO1lBQzVDLEtBQUssc0JBQXNCLENBQUMsR0FBRztnQkFDM0IsTUFBTSxTQUFTLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztnQkFDdEYsT0FBTyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksU0FBUyxDQUFDO1lBQzNDO2dCQUNJLE9BQU8sWUFBWSxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNsRCxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sQ0FBQyxVQUEwQixFQUFFLFVBQTBCO1FBQzFELE9BQU8sYUFBYSxDQUFDLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQsWUFBWSxDQUNSLFNBQWlCLEVBQ2pCLFdBQXlCLEVBQ3pCLFVBQTJEO1FBRTNELE9BQU8sZ0JBQWdCLENBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUNoRSxDQUFDO0NBQ0o7QUFFRCxNQUFNLFVBQVUsZ0JBQWdCLENBQzVCLFNBQWlCLEVBQ2pCLFdBQXlCLEVBQ3pCLFVBQTJEO0lBRTNELElBQUksS0FBSyxHQUFRLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNsQyxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2IsTUFBTSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsR0FBRyxVQUFVLENBQUM7UUFDeEMsUUFBUSxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDakIsS0FBSyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUM7WUFDM0IsS0FBSyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUM7WUFDN0IsS0FBSyxnQkFBZ0IsQ0FBQyxRQUFRO2dCQUMxQixLQUFLLEdBQUcsU0FBUyxDQUFDO2dCQUNsQixNQUFNO1lBQ1YsS0FBSyxnQkFBZ0IsQ0FBQyxNQUFNO2dCQUN4QixJQUFJLFNBQVMsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLFNBQVMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztvQkFDNUQsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBRSxLQUFLLENBQUMsUUFBMkIsQ0FBQyxPQUFPLElBQUksRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO29CQUMxRixLQUFLLEdBQUcsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQztnQkFDM0MsQ0FBQztnQkFDRCxNQUFNO1lBQ1Y7Z0JBQ0ksTUFBTTtRQUNkLENBQUM7SUFDTCxDQUFDO0lBRUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUNyQyxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksU0FBUyxHQUFHLENBQUMsSUFBSSxTQUFTLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDN0QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ2pDLENBQUM7UUFDRCxPQUFPLENBQUMsQ0FBQztJQUNiLENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaGVscGVycyB9IGZyb20gJ25neC10ZXRoeXMvdXRpbCc7XG5pbXBvcnQge1xuICAgIEFJVGFibGVGaWVsZCxcbiAgICBBSVRhYmxlRmllbGRUeXBlLFxuICAgIEFJVGFibGVGaWx0ZXJDb25kaXRpb24sXG4gICAgQUlUYWJsZUZpbHRlck9wZXJhdGlvbixcbiAgICBGaWVsZFZhbHVlLFxuICAgIFJhdGVGaWVsZFZhbHVlLFxuICAgIFNlbGVjdFNldHRpbmdzLFxuICAgIFJhdGVGaWVsZEJhc2UsXG4gICAgaXNFbXB0eVxufSBmcm9tICdAYWktdGFibGUvdXRpbHMnO1xuaW1wb3J0IHsgY29tcGFyZU51bWJlciwgaXNNZWV0RmlsdGVyIH0gZnJvbSAnLi4vb3BlcmF0ZSc7XG5pbXBvcnQgeyBGaWVsZE9wZXJhYmxlIH0gZnJvbSAnLi4vZmllbGQtb3BlcmFibGUnO1xuaW1wb3J0IHsgaXNOdW1iZXIgfSBmcm9tICdsb2Rhc2gnO1xuXG5leHBvcnQgY2xhc3MgUmF0ZUZpZWxkIGV4dGVuZHMgUmF0ZUZpZWxkQmFzZSBpbXBsZW1lbnRzIEZpZWxkT3BlcmFibGU8c3RyaW5nW10sIFJhdGVGaWVsZFZhbHVlPiB7XG4gICAgaXNNZWV0RmlsdGVyKGNvbmRpdGlvbjogQUlUYWJsZUZpbHRlckNvbmRpdGlvbjxzdHJpbmdbXT4sIGNlbGxWYWx1ZTogUmF0ZUZpZWxkVmFsdWUpIHtcbiAgICAgICAgc3dpdGNoIChjb25kaXRpb24ub3BlcmF0aW9uKSB7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uZW1wdHk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzRW1wdHkoY2VsbFZhbHVlKTtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5leGlzdHM6XG4gICAgICAgICAgICAgICAgcmV0dXJuICFpc0VtcHR5KGNlbGxWYWx1ZSk7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uaW46XG4gICAgICAgICAgICAgICAgY29uc3QgaXNDb250YWluID0gY29uZGl0aW9uLnZhbHVlLnNvbWUoKGl0ZW0pID0+IFN0cmluZyhpdGVtKSA9PT0gU3RyaW5nKGNlbGxWYWx1ZSkpO1xuICAgICAgICAgICAgICAgIHJldHVybiAhaXNFbXB0eShjZWxsVmFsdWUpICYmIGlzQ29udGFpbjtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5uaW46XG4gICAgICAgICAgICAgICAgY29uc3Qgbm9Db250YWluID0gY29uZGl0aW9uLnZhbHVlLmV2ZXJ5KChpdGVtKSA9PiBTdHJpbmcoaXRlbSkgIT09IFN0cmluZyhjZWxsVmFsdWUpKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gaXNFbXB0eShjZWxsVmFsdWUpIHx8IG5vQ29udGFpbjtcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzTWVldEZpbHRlcihjb25kaXRpb24sIGNlbGxWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBjb21wYXJlKGNlbGxWYWx1ZTE6IFJhdGVGaWVsZFZhbHVlLCBjZWxsVmFsdWUyOiBSYXRlRmllbGRWYWx1ZSk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiBjb21wYXJlTnVtYmVyKGNlbGxWYWx1ZTEsIGNlbGxWYWx1ZTIpO1xuICAgIH1cblxuICAgIHRvRmllbGRWYWx1ZShcbiAgICAgICAgcGxhaW5UZXh0OiBzdHJpbmcsXG4gICAgICAgIHRhcmdldEZpZWxkOiBBSVRhYmxlRmllbGQsXG4gICAgICAgIG9yaWdpbkRhdGE/OiB7IGZpZWxkOiBBSVRhYmxlRmllbGQ7IGNlbGxWYWx1ZTogRmllbGRWYWx1ZSB9XG4gICAgKTogRmllbGRWYWx1ZSB8IG51bGwge1xuICAgICAgICByZXR1cm4gdG9SYXRlRmllbGRWYWx1ZShwbGFpblRleHQsIHRhcmdldEZpZWxkLCBvcmlnaW5EYXRhKTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b1JhdGVGaWVsZFZhbHVlKFxuICAgIHBsYWluVGV4dDogc3RyaW5nLFxuICAgIHRhcmdldEZpZWxkOiBBSVRhYmxlRmllbGQsXG4gICAgb3JpZ2luRGF0YT86IHsgZmllbGQ6IEFJVGFibGVGaWVsZDsgY2VsbFZhbHVlOiBGaWVsZFZhbHVlIH1cbik6IEZpZWxkVmFsdWUgfCBudWxsIHtcbiAgICBsZXQgdmFsdWU6IGFueSA9IHBsYWluVGV4dC50cmltKCk7XG4gICAgaWYgKG9yaWdpbkRhdGEpIHtcbiAgICAgICAgY29uc3QgeyBmaWVsZCwgY2VsbFZhbHVlIH0gPSBvcmlnaW5EYXRhO1xuICAgICAgICBzd2l0Y2ggKGZpZWxkLnR5cGUpIHtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpZWxkVHlwZS5yYXRlOlxuICAgICAgICAgICAgY2FzZSBBSVRhYmxlRmllbGRUeXBlLm51bWJlcjpcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpZWxkVHlwZS5wcm9ncmVzczpcbiAgICAgICAgICAgICAgICB2YWx1ZSA9IGNlbGxWYWx1ZTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpZWxkVHlwZS5zZWxlY3Q6XG4gICAgICAgICAgICAgICAgaWYgKGNlbGxWYWx1ZSAmJiBBcnJheS5pc0FycmF5KGNlbGxWYWx1ZSkgJiYgY2VsbFZhbHVlLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBvcHRpb25zTWFwID0gaGVscGVycy5rZXlCeSgoZmllbGQuc2V0dGluZ3MgYXMgU2VsZWN0U2V0dGluZ3MpLm9wdGlvbnMgfHwgW10sICdfaWQnKTtcbiAgICAgICAgICAgICAgICAgICAgdmFsdWUgPSBvcHRpb25zTWFwW2NlbGxWYWx1ZVswXV0/LnRleHQ7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGlmICghaXNFbXB0eSh2YWx1ZSkgfHwgaXNOdW1iZXIodmFsdWUpKSB7XG4gICAgICAgIGNvbnN0IHJhdGVWYWx1ZSA9IE51bWJlcih2YWx1ZSk7XG4gICAgICAgIGlmICghTnVtYmVyLmlzTmFOKHJhdGVWYWx1ZSkgJiYgcmF0ZVZhbHVlID4gMCAmJiByYXRlVmFsdWUgPCA1KSB7XG4gICAgICAgICAgICByZXR1cm4gTWF0aC5yb3VuZChyYXRlVmFsdWUpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiA1O1xuICAgIH1cblxuICAgIHJldHVybiBudWxsO1xufVxuIl19
|
@@ -1,39 +0,0 @@
|
|
1
|
-
import { AITableFieldType, AITableFilterOperation, RichTextFieldBase, isEmpty } from '@ai-table/utils';
|
2
|
-
import { transformCellValue } from '../../cell';
|
3
|
-
import { compareString, isMeetFilter, stringInclude } from '../operate';
|
4
|
-
export class RichTextField extends RichTextFieldBase {
|
5
|
-
transformCellValue(cellValue, options) {
|
6
|
-
return transformCellValue(options.aiTable, options.field, cellValue);
|
7
|
-
}
|
8
|
-
isMeetFilter(condition, cellValue, options) {
|
9
|
-
const textValue = transformCellValue(options.aiTable, options.field, cellValue || []);
|
10
|
-
switch (condition.operation) {
|
11
|
-
case AITableFilterOperation.empty:
|
12
|
-
return isEmpty(textValue);
|
13
|
-
case AITableFilterOperation.exists:
|
14
|
-
return !isEmpty(textValue);
|
15
|
-
case AITableFilterOperation.contain:
|
16
|
-
return !isEmpty(textValue) && stringInclude(textValue, condition.value);
|
17
|
-
default:
|
18
|
-
return isMeetFilter(condition, textValue);
|
19
|
-
}
|
20
|
-
}
|
21
|
-
compare(cellValue1, cellValue2, references, sortKey, options) {
|
22
|
-
const value1 = this.transformCellValue(cellValue1 || [], options);
|
23
|
-
const value2 = this.transformCellValue(cellValue2 || [], options);
|
24
|
-
return compareString(value1, value2);
|
25
|
-
}
|
26
|
-
toFieldValue(plainText, targetField, originData) {
|
27
|
-
return toRichTextFieldValue(plainText, targetField, originData);
|
28
|
-
}
|
29
|
-
}
|
30
|
-
export function toRichTextFieldValue(plainText, targetField, originData) {
|
31
|
-
if (originData) {
|
32
|
-
const { field, cellValue } = originData;
|
33
|
-
if (field.type === AITableFieldType.richText) {
|
34
|
-
return cellValue;
|
35
|
-
}
|
36
|
-
}
|
37
|
-
return null;
|
38
|
-
}
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmljaC10ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvdXRpbHMvZmllbGQvbW9kZWwvcmljaC10ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFSCxnQkFBZ0IsRUFFaEIsc0JBQXNCLEVBS3RCLGlCQUFpQixFQUNqQixPQUFPLEVBQ1YsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBSXhFLE1BQU0sT0FBTyxhQUFjLFNBQVEsaUJBQWlCO0lBQ3ZDLGtCQUFrQixDQUFDLFNBQXFCLEVBQUUsT0FBcUI7UUFDcEUsT0FBTyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFNLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDMUUsQ0FBQztJQUVELFlBQVksQ0FDUixTQUF5QyxFQUN6QyxTQUE2QixFQUM3QixPQUdDO1FBRUQsTUFBTSxTQUFTLEdBQUcsa0JBQWtCLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsS0FBSyxFQUFFLFNBQVMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUN0RixRQUFRLFNBQVMsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMxQixLQUFLLHNCQUFzQixDQUFDLEtBQUs7Z0JBQzdCLE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQzlCLEtBQUssc0JBQXNCLENBQUMsTUFBTTtnQkFDOUIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUMvQixLQUFLLHNCQUFzQixDQUFDLE9BQU87Z0JBQy9CLE9BQU8sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksYUFBYSxDQUFDLFNBQVMsRUFBRSxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDNUU7Z0JBQ0ksT0FBTyxZQUFZLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ2xELENBQUM7SUFDTCxDQUFDO0lBRUQsT0FBTyxDQUNILFVBQThCLEVBQzlCLFVBQThCLEVBQzlCLFVBQTZCLEVBQzdCLE9BQWUsRUFDZixPQUdDO1FBRUQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsSUFBSSxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDbEUsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsSUFBSSxFQUFFLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDbEUsT0FBTyxhQUFhLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxZQUFZLENBQ1IsU0FBaUIsRUFDakIsV0FBeUIsRUFDekIsVUFBMkQ7UUFFM0QsT0FBTyxvQkFBb0IsQ0FBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQ3BFLENBQUM7Q0FDSjtBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FDaEMsU0FBaUIsRUFDakIsV0FBeUIsRUFDekIsVUFBMkQ7SUFFM0QsSUFBSSxVQUFVLEVBQUUsQ0FBQztRQUNiLE1BQU0sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLEdBQUcsVUFBVSxDQUFDO1FBQ3hDLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUMzQyxPQUFPLFNBQVMsQ0FBQztRQUNyQixDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sSUFBSSxDQUFDO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIEFJVGFibGVGaWVsZCxcbiAgICBBSVRhYmxlRmllbGRUeXBlLFxuICAgIEFJVGFibGVGaWx0ZXJDb25kaXRpb24sXG4gICAgQUlUYWJsZUZpbHRlck9wZXJhdGlvbixcbiAgICBBSVRhYmxlUmVmZXJlbmNlcyxcbiAgICBGaWVsZE9wdGlvbnMsXG4gICAgRmllbGRWYWx1ZSxcbiAgICBSaWNoVGV4dEZpZWxkVmFsdWUsXG4gICAgUmljaFRleHRGaWVsZEJhc2UsXG4gICAgaXNFbXB0eVxufSBmcm9tICdAYWktdGFibGUvdXRpbHMnO1xuaW1wb3J0IHsgdHJhbnNmb3JtQ2VsbFZhbHVlIH0gZnJvbSAnLi4vLi4vY2VsbCc7XG5pbXBvcnQgeyBjb21wYXJlU3RyaW5nLCBpc01lZXRGaWx0ZXIsIHN0cmluZ0luY2x1ZGUgfSBmcm9tICcuLi9vcGVyYXRlJztcbmltcG9ydCB7IEZpZWxkT3BlcmFibGUgfSBmcm9tICcuLi9maWVsZC1vcGVyYWJsZSc7XG5pbXBvcnQgeyBBSVRhYmxlIH0gZnJvbSAnLi4vLi4vLi4vY29yZSc7XG5cbmV4cG9ydCBjbGFzcyBSaWNoVGV4dEZpZWxkIGV4dGVuZHMgUmljaFRleHRGaWVsZEJhc2UgaW1wbGVtZW50cyBGaWVsZE9wZXJhYmxlPHN0cmluZywgUmljaFRleHRGaWVsZFZhbHVlPiB7XG4gICAgb3ZlcnJpZGUgdHJhbnNmb3JtQ2VsbFZhbHVlKGNlbGxWYWx1ZTogRmllbGRWYWx1ZSwgb3B0aW9uczogRmllbGRPcHRpb25zKSB7XG4gICAgICAgIHJldHVybiB0cmFuc2Zvcm1DZWxsVmFsdWUob3B0aW9ucy5haVRhYmxlLCBvcHRpb25zLmZpZWxkISwgY2VsbFZhbHVlKTtcbiAgICB9XG5cbiAgICBpc01lZXRGaWx0ZXIoXG4gICAgICAgIGNvbmRpdGlvbjogQUlUYWJsZUZpbHRlckNvbmRpdGlvbjxzdHJpbmc+LFxuICAgICAgICBjZWxsVmFsdWU6IFJpY2hUZXh0RmllbGRWYWx1ZSxcbiAgICAgICAgb3B0aW9uczoge1xuICAgICAgICAgICAgYWlUYWJsZTogQUlUYWJsZTtcbiAgICAgICAgICAgIGZpZWxkOiBBSVRhYmxlRmllbGQ7XG4gICAgICAgIH1cbiAgICApIHtcbiAgICAgICAgY29uc3QgdGV4dFZhbHVlID0gdHJhbnNmb3JtQ2VsbFZhbHVlKG9wdGlvbnMuYWlUYWJsZSwgb3B0aW9ucy5maWVsZCwgY2VsbFZhbHVlIHx8IFtdKTtcbiAgICAgICAgc3dpdGNoIChjb25kaXRpb24ub3BlcmF0aW9uKSB7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uZW1wdHk6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzRW1wdHkodGV4dFZhbHVlKTtcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUZpbHRlck9wZXJhdGlvbi5leGlzdHM6XG4gICAgICAgICAgICAgICAgcmV0dXJuICFpc0VtcHR5KHRleHRWYWx1ZSk7XG4gICAgICAgICAgICBjYXNlIEFJVGFibGVGaWx0ZXJPcGVyYXRpb24uY29udGFpbjpcbiAgICAgICAgICAgICAgICByZXR1cm4gIWlzRW1wdHkodGV4dFZhbHVlKSAmJiBzdHJpbmdJbmNsdWRlKHRleHRWYWx1ZSwgY29uZGl0aW9uLnZhbHVlKTtcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzTWVldEZpbHRlcihjb25kaXRpb24sIHRleHRWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBjb21wYXJlKFxuICAgICAgICBjZWxsVmFsdWUxOiBSaWNoVGV4dEZpZWxkVmFsdWUsXG4gICAgICAgIGNlbGxWYWx1ZTI6IFJpY2hUZXh0RmllbGRWYWx1ZSxcbiAgICAgICAgcmVmZXJlbmNlczogQUlUYWJsZVJlZmVyZW5jZXMsXG4gICAgICAgIHNvcnRLZXk6IHN0cmluZyxcbiAgICAgICAgb3B0aW9uczoge1xuICAgICAgICAgICAgYWlUYWJsZTogQUlUYWJsZTtcbiAgICAgICAgICAgIGZpZWxkOiBBSVRhYmxlRmllbGQ7XG4gICAgICAgIH1cbiAgICApOiBudW1iZXIge1xuICAgICAgICBjb25zdCB2YWx1ZTEgPSB0aGlzLnRyYW5zZm9ybUNlbGxWYWx1ZShjZWxsVmFsdWUxIHx8IFtdLCBvcHRpb25zKTtcbiAgICAgICAgY29uc3QgdmFsdWUyID0gdGhpcy50cmFuc2Zvcm1DZWxsVmFsdWUoY2VsbFZhbHVlMiB8fCBbXSwgb3B0aW9ucyk7XG4gICAgICAgIHJldHVybiBjb21wYXJlU3RyaW5nKHZhbHVlMSwgdmFsdWUyKTtcbiAgICB9XG5cbiAgICB0b0ZpZWxkVmFsdWUoXG4gICAgICAgIHBsYWluVGV4dDogc3RyaW5nLFxuICAgICAgICB0YXJnZXRGaWVsZDogQUlUYWJsZUZpZWxkLFxuICAgICAgICBvcmlnaW5EYXRhPzogeyBmaWVsZDogQUlUYWJsZUZpZWxkOyBjZWxsVmFsdWU6IEZpZWxkVmFsdWUgfVxuICAgICk6IEZpZWxkVmFsdWUgfCBudWxsIHtcbiAgICAgICAgcmV0dXJuIHRvUmljaFRleHRGaWVsZFZhbHVlKHBsYWluVGV4dCwgdGFyZ2V0RmllbGQsIG9yaWdpbkRhdGEpO1xuICAgIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvUmljaFRleHRGaWVsZFZhbHVlKFxuICAgIHBsYWluVGV4dDogc3RyaW5nLFxuICAgIHRhcmdldEZpZWxkOiBBSVRhYmxlRmllbGQsXG4gICAgb3JpZ2luRGF0YT86IHsgZmllbGQ6IEFJVGFibGVGaWVsZDsgY2VsbFZhbHVlOiBGaWVsZFZhbHVlIH1cbik6IEZpZWxkVmFsdWUgfCBudWxsIHtcbiAgICBpZiAob3JpZ2luRGF0YSkge1xuICAgICAgICBjb25zdCB7IGZpZWxkLCBjZWxsVmFsdWUgfSA9IG9yaWdpbkRhdGE7XG4gICAgICAgIGlmIChmaWVsZC50eXBlID09PSBBSVRhYmxlRmllbGRUeXBlLnJpY2hUZXh0KSB7XG4gICAgICAgICAgICByZXR1cm4gY2VsbFZhbHVlO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIG51bGw7XG59XG4iXX0=
|
@@ -1,131 +0,0 @@
|
|
1
|
-
import { helpers } from 'ngx-tethys/util';
|
2
|
-
import { compareString, hasIntersect, isMeetFilter } from '../operate';
|
3
|
-
import { DEFAULT_COLORS } from 'ngx-tethys/color-picker';
|
4
|
-
import { idCreator } from '../../../core';
|
5
|
-
import { AITableFilterOperation, SelectFieldBase, AITableFieldType, AITableSelectOptionStyle, isEmpty } from '@ai-table/utils';
|
6
|
-
export class SelectField extends SelectFieldBase {
|
7
|
-
isValid(cellValue) {
|
8
|
-
return Array.isArray(cellValue) || cellValue === null;
|
9
|
-
}
|
10
|
-
isMeetFilter(condition, cellValue) {
|
11
|
-
switch (condition.operation) {
|
12
|
-
case AITableFilterOperation.empty:
|
13
|
-
return isEmpty(cellValue);
|
14
|
-
case AITableFilterOperation.exists:
|
15
|
-
return !isEmpty(cellValue);
|
16
|
-
case AITableFilterOperation.in:
|
17
|
-
return Array.isArray(condition.value) && hasIntersect(cellValue, condition.value);
|
18
|
-
case AITableFilterOperation.nin:
|
19
|
-
return Array.isArray(condition.value) && !hasIntersect(cellValue, condition.value);
|
20
|
-
default:
|
21
|
-
return isMeetFilter(condition, cellValue);
|
22
|
-
}
|
23
|
-
}
|
24
|
-
compare(cellValue1, cellValue2, references, sortKey, options) {
|
25
|
-
const value1 = cellValueToSortValue(cellValue1, options.field);
|
26
|
-
const value2 = cellValueToSortValue(cellValue2, options.field);
|
27
|
-
return compareString(value1, value2);
|
28
|
-
}
|
29
|
-
toFieldValue(plainText, targetField, originData) {
|
30
|
-
return toSelectFieldValue(plainText, targetField, originData);
|
31
|
-
}
|
32
|
-
}
|
33
|
-
export function toSelectFieldValue(plainText, targetField, originData) {
|
34
|
-
return null;
|
35
|
-
}
|
36
|
-
export function processPastedValueForSelect(plainText, targetField, originData) {
|
37
|
-
const targetFieldOptions = targetField.settings?.options || [];
|
38
|
-
const targetOptionStyle = targetField.settings?.option_style || AITableSelectOptionStyle.text;
|
39
|
-
let existOptionIds = [];
|
40
|
-
let newOptions = [];
|
41
|
-
let cellFullTexts = plainText
|
42
|
-
.split(',')
|
43
|
-
.map((text) => text.trim())
|
44
|
-
.filter((text) => !!text);
|
45
|
-
const { field, cellValue } = originData || {};
|
46
|
-
if (field && field.type === AITableFieldType.select) {
|
47
|
-
if (cellValue && Array.isArray(cellValue) && cellValue.length) {
|
48
|
-
const targetOptionIds = targetFieldOptions.map((option) => option._id);
|
49
|
-
const originOptionsMap = helpers.keyBy(field.settings?.options || [], '_id');
|
50
|
-
cellValue.forEach((id) => {
|
51
|
-
if (targetOptionIds.includes(id)) {
|
52
|
-
existOptionIds.push(id);
|
53
|
-
}
|
54
|
-
else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]?.text)) {
|
55
|
-
const option = targetFieldOptions.find((option) => option.text === originOptionsMap[id].text);
|
56
|
-
existOptionIds.push(option._id);
|
57
|
-
}
|
58
|
-
else {
|
59
|
-
const originOption = originOptionsMap[id];
|
60
|
-
if (originOption) {
|
61
|
-
const newOption = copyOption(originOption, targetFieldOptions, targetOptionStyle);
|
62
|
-
newOptions.push(newOption);
|
63
|
-
}
|
64
|
-
}
|
65
|
-
});
|
66
|
-
}
|
67
|
-
}
|
68
|
-
else {
|
69
|
-
cellFullTexts.forEach((text) => {
|
70
|
-
const option = targetFieldOptions.find((option) => option.text === text);
|
71
|
-
if (option) {
|
72
|
-
existOptionIds.push(option._id);
|
73
|
-
}
|
74
|
-
else {
|
75
|
-
const originOption = { text };
|
76
|
-
const newOption = copyOption(originOption, targetFieldOptions, targetOptionStyle);
|
77
|
-
newOptions.push(newOption);
|
78
|
-
}
|
79
|
-
});
|
80
|
-
}
|
81
|
-
const isMultiple = targetField.settings?.is_multiple;
|
82
|
-
if (isMultiple) {
|
83
|
-
return { existOptionIds, newOptions };
|
84
|
-
}
|
85
|
-
else {
|
86
|
-
if (existOptionIds.length) {
|
87
|
-
return { existOptionIds: [existOptionIds[0]], newOptions: [] };
|
88
|
-
}
|
89
|
-
else {
|
90
|
-
if (newOptions.length) {
|
91
|
-
return { existOptionIds: [], newOptions: [newOptions[0]] };
|
92
|
-
}
|
93
|
-
else {
|
94
|
-
return { existOptionIds: [], newOptions: [] };
|
95
|
-
}
|
96
|
-
}
|
97
|
-
}
|
98
|
-
}
|
99
|
-
function copyOption(originOption, targetFieldOptions, targetOptionStyle) {
|
100
|
-
let newOption = {
|
101
|
-
_id: idCreator(),
|
102
|
-
text: originOption.text
|
103
|
-
};
|
104
|
-
if (targetOptionStyle !== AITableSelectOptionStyle.text) {
|
105
|
-
const originBgColor = originOption.bg_color;
|
106
|
-
const existBgColors = targetFieldOptions.map((option) => option.bg_color);
|
107
|
-
const defaultBgColor = DEFAULT_COLORS[10 + (targetFieldOptions?.length || 0)];
|
108
|
-
newOption = {
|
109
|
-
...newOption,
|
110
|
-
bg_color: originBgColor && !existBgColors.includes(originBgColor) ? originBgColor : defaultBgColor
|
111
|
-
};
|
112
|
-
}
|
113
|
-
return newOption;
|
114
|
-
}
|
115
|
-
function cellValueToSortValue(cellValue, field) {
|
116
|
-
if (!cellValue) {
|
117
|
-
return null;
|
118
|
-
}
|
119
|
-
const texts = [];
|
120
|
-
const optionsMap = helpers.keyBy(field.settings.options || [], '_id');
|
121
|
-
if (cellValue && Array.isArray(cellValue) && cellValue.length) {
|
122
|
-
cellValue.forEach((optionId) => {
|
123
|
-
const option = optionsMap[optionId];
|
124
|
-
if (option && option.text) {
|
125
|
-
texts.push(option.text);
|
126
|
-
}
|
127
|
-
});
|
128
|
-
}
|
129
|
-
return texts && texts.length ? texts.join(',') : null;
|
130
|
-
}
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/select.ts"],"names":[],"mappings":"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","sourcesContent":["import { helpers } from 'ngx-tethys/util';\nimport { compareString, hasIntersect, isMeetFilter } from '../operate';\nimport { DEFAULT_COLORS } from 'ngx-tethys/color-picker';\nimport { AITable, idCreator } from '../../../core';\nimport {\n    AITableFilterCondition,\n    AITableFilterOperation,\n    AITableReferences,\n    SelectFieldBase,\n    AITableField,\n    AITableFieldType,\n    AITableSelectOption,\n    AITableSelectOptionStyle,\n    FieldValue,\n    SelectFieldValue,\n    SelectSettings,\n    isEmpty\n} from '@ai-table/utils';\nimport { FieldOperable } from '../field-operable';\n\nexport class SelectField extends SelectFieldBase implements FieldOperable<string, SelectFieldValue> {\n    override isValid(cellValue: FieldValue): boolean {\n        return Array.isArray(cellValue) || cellValue === null;\n    }\n\n    isMeetFilter(condition: AITableFilterCondition<string>, cellValue: SelectFieldValue) {\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue);\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue);\n            case AITableFilterOperation.in:\n                return Array.isArray(condition.value) && hasIntersect(cellValue, condition.value);\n            case AITableFilterOperation.nin:\n                return Array.isArray(condition.value) && !hasIntersect(cellValue, condition.value);\n            default:\n                return isMeetFilter(condition, cellValue);\n        }\n    }\n\n    compare(\n        cellValue1: SelectFieldValue,\n        cellValue2: SelectFieldValue,\n        references: AITableReferences,\n        sortKey: string,\n        options: {\n            aiTable: AITable;\n            field: AITableField;\n        }\n    ): number {\n        const value1 = cellValueToSortValue(cellValue1, options.field);\n        const value2 = cellValueToSortValue(cellValue2, options.field);\n        return compareString(value1, value2);\n    }\n\n    toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue } | null\n    ): FieldValue | null {\n        return toSelectFieldValue(plainText, targetField, originData);\n    }\n}\n\nexport function toSelectFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue } | null\n): FieldValue | null {\n    return null;\n}\n\nexport function processPastedValueForSelect(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue } | null\n): { existOptionIds: string[]; newOptions: AITableSelectOption[] } {\n    const targetFieldOptions = (targetField.settings as SelectSettings)?.options || [];\n    const targetOptionStyle = (targetField.settings as SelectSettings)?.option_style || AITableSelectOptionStyle.text;\n\n    let existOptionIds: string[] = [];\n    let newOptions: AITableSelectOption[] = [];\n\n    let cellFullTexts: string[] = plainText\n        .split(',')\n        .map((text) => text.trim())\n        .filter((text) => !!text);\n\n    const { field, cellValue } = originData || {};\n    if (field && field.type === AITableFieldType.select) {\n        if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n            const targetOptionIds = targetFieldOptions.map((option) => option._id);\n            const originOptionsMap = helpers.keyBy((field.settings as SelectSettings)?.options || [], '_id');\n            cellValue.forEach((id) => {\n                if (targetOptionIds.includes(id)) {\n                    existOptionIds.push(id);\n                } else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]?.text)) {\n                    const option = targetFieldOptions.find((option: AITableSelectOption) => option.text === originOptionsMap[id].text);\n                    existOptionIds.push(option!._id);\n                } else {\n                    const originOption = originOptionsMap[id];\n                    if (originOption) {\n                        const newOption = copyOption(originOption, targetFieldOptions, targetOptionStyle);\n                        newOptions.push(newOption);\n                    }\n                }\n            });\n        }\n    } else {\n        cellFullTexts.forEach((text) => {\n            const option = targetFieldOptions.find((option) => option.text === text);\n            if (option) {\n                existOptionIds.push(option._id);\n            } else {\n                const originOption = { text };\n                const newOption = copyOption(originOption, targetFieldOptions, targetOptionStyle);\n                newOptions.push(newOption);\n            }\n        });\n    }\n\n    const isMultiple = (targetField.settings as SelectSettings)?.is_multiple;\n    if (isMultiple) {\n        return { existOptionIds, newOptions };\n    } else {\n        if (existOptionIds.length) {\n            return { existOptionIds: [existOptionIds[0]], newOptions: [] };\n        } else {\n            if (newOptions.length) {\n                return { existOptionIds: [], newOptions: [newOptions[0]] };\n            } else {\n                return { existOptionIds: [], newOptions: [] };\n            }\n        }\n    }\n}\n\nfunction copyOption(\n    originOption: Partial<AITableSelectOption>,\n    targetFieldOptions: AITableSelectOption[],\n    targetOptionStyle: AITableSelectOptionStyle\n): AITableSelectOption {\n    let newOption: AITableSelectOption = {\n        _id: idCreator(),\n        text: originOption.text!\n    };\n\n    if (targetOptionStyle !== AITableSelectOptionStyle.text) {\n        const originBgColor = originOption.bg_color;\n        const existBgColors = targetFieldOptions.map((option) => option.bg_color);\n        const defaultBgColor = DEFAULT_COLORS[10 + (targetFieldOptions?.length || 0)];\n\n        newOption = {\n            ...newOption,\n            bg_color: originBgColor && !existBgColors.includes(originBgColor) ? originBgColor : defaultBgColor\n        };\n    }\n\n    return newOption;\n}\n\nfunction cellValueToSortValue(cellValue: SelectFieldValue, field: AITableField): string | null {\n    if (!cellValue) {\n        return null;\n    }\n    const texts: string[] = [];\n    const optionsMap = helpers.keyBy((field.settings as SelectSettings).options || [], '_id');\n    if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n        cellValue.forEach((optionId) => {\n            const option = optionsMap[optionId];\n            if (option && option.text) {\n                texts.push(option.text);\n            }\n        });\n    }\n    return texts && texts.length ? texts.join(',') : null;\n}\n"]}
|