@ai-table/grid 0.0.3 → 0.0.4
Sign up to get free protection for your applications and to get access to all the features.
- package/components/cell-editors/select/select-editor.component.d.ts +15 -0
- package/components/cell-editors/select/select-editor.component.d.ts.map +1 -0
- package/components/field-menu/field-menu.component.d.ts +6 -6
- package/components/field-menu/field-menu.component.d.ts.map +1 -1
- package/components/field-property-editor/field-property-editor.component.d.ts +2 -1
- package/components/field-property-editor/field-property-editor.component.d.ts.map +1 -1
- package/constants/editor.d.ts +1 -1
- package/constants/editor.d.ts.map +1 -1
- package/constants/field.d.ts +10 -4
- package/constants/field.d.ts.map +1 -1
- package/core/action/field.d.ts +6 -0
- package/core/action/field.d.ts.map +1 -1
- package/core/action/general.d.ts.map +1 -1
- package/core/action/index.d.ts +5 -0
- package/core/action/index.d.ts.map +1 -1
- package/core/action/record.d.ts +4 -0
- package/core/action/record.d.ts.map +1 -1
- package/core/constants/field.d.ts +2 -0
- package/core/constants/field.d.ts.map +1 -1
- package/core/types/action.d.ts +31 -2
- package/core/types/action.d.ts.map +1 -1
- package/core/types/core.d.ts +31 -10
- package/core/types/core.d.ts.map +1 -1
- package/core/utils/common.d.ts +2 -1
- package/core/utils/common.d.ts.map +1 -1
- package/core/utils/queries.d.ts +3 -1
- package/core/utils/queries.d.ts.map +1 -1
- package/esm2022/components/cell-editors/select/select-editor.component.mjs +46 -0
- package/esm2022/components/field-menu/field-menu.component.mjs +6 -5
- package/esm2022/components/field-property-editor/field-property-editor.component.mjs +8 -5
- package/esm2022/constants/editor.mjs +8 -8
- package/esm2022/constants/field.mjs +15 -3
- package/esm2022/constants/grid.mjs +5 -5
- package/esm2022/core/action/field.mjs +43 -2
- package/esm2022/core/action/general.mjs +68 -14
- package/esm2022/core/action/record.mjs +22 -5
- package/esm2022/core/constants/field.mjs +19 -13
- package/esm2022/core/types/action.mjs +6 -1
- package/esm2022/core/types/core.mjs +11 -14
- package/esm2022/core/types/index.mjs +1 -1
- package/esm2022/core/utils/common.mjs +10 -1
- package/esm2022/core/utils/field.mjs +3 -3
- package/esm2022/core/utils/queries.mjs +36 -6
- package/esm2022/core/utils/record.mjs +3 -3
- package/esm2022/grid.component.mjs +40 -11
- package/esm2022/pipes/grid.mjs +1 -2
- package/esm2022/services/event.service.mjs +10 -3
- package/esm2022/services/selection.servive.mjs +64 -0
- package/esm2022/types/field.mjs +1 -1
- package/esm2022/types/grid.mjs +1 -1
- package/esm2022/utils/build.mjs +13 -5
- package/fesm2022/ai-table-grid.mjs +454 -182
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid.component.d.ts +13 -6
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/pipes/grid.d.ts.map +1 -1
- package/services/event.service.d.ts +2 -0
- package/services/event.service.d.ts.map +1 -1
- package/services/selection.servive.d.ts +16 -0
- package/services/selection.servive.d.ts.map +1 -0
- package/styles/styles.scss +70 -3
- package/types/field.d.ts +3 -3
- package/types/field.d.ts.map +1 -1
- package/types/grid.d.ts +7 -2
- package/types/grid.d.ts.map +1 -1
- package/utils/build.d.ts +2 -2
- package/utils/build.d.ts.map +1 -1
- package/components/cell-editors/single-select/single-select-editor.component.d.ts +0 -14
- package/components/cell-editors/single-select/single-select-editor.component.d.ts.map +0 -1
- package/esm2022/components/cell-editors/single-select/single-select-editor.component.mjs +0 -44
@@ -1,18 +1,15 @@
|
|
1
1
|
export var AITableFieldType;
|
2
2
|
(function (AITableFieldType) {
|
3
|
-
|
4
|
-
AITableFieldType[
|
5
|
-
AITableFieldType[
|
6
|
-
AITableFieldType[
|
7
|
-
|
8
|
-
AITableFieldType[
|
9
|
-
//
|
10
|
-
AITableFieldType[
|
11
|
-
|
12
|
-
|
13
|
-
// Checkbox = 11,
|
14
|
-
AITableFieldType[AITableFieldType["Rating"] = 12] = "Rating";
|
15
|
-
// Member = 13
|
3
|
+
AITableFieldType["text"] = "text";
|
4
|
+
AITableFieldType["richText"] = "rich_text";
|
5
|
+
AITableFieldType["select"] = "select";
|
6
|
+
AITableFieldType["number"] = "number";
|
7
|
+
AITableFieldType["date"] = "date";
|
8
|
+
AITableFieldType["member"] = "member";
|
9
|
+
// cascadeSelect = "cascade_select", // 包含单选和多选,参数复杂后续再进行设计
|
10
|
+
AITableFieldType["progress"] = "progress";
|
11
|
+
AITableFieldType["rate"] = "rate";
|
12
|
+
AITableFieldType["link"] = "link";
|
16
13
|
})(AITableFieldType || (AITableFieldType = {}));
|
17
14
|
export var AITableStatType;
|
18
15
|
(function (AITableStatType) {
|
@@ -35,4 +32,4 @@ export var AITableStatType;
|
|
35
32
|
AITableStatType[AITableStatType["PercentChecked"] = 16] = "PercentChecked";
|
36
33
|
AITableStatType[AITableStatType["PercentUnChecked"] = 17] = "PercentUnChecked";
|
37
34
|
})(AITableStatType || (AITableStatType = {}));
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL2NvcmUvdHlwZXMvY29yZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLENBQU4sSUFBWSxnQkFXWDtBQVhELFdBQVksZ0JBQWdCO0lBQ3hCLGlDQUFhLENBQUE7SUFDYiwwQ0FBc0IsQ0FBQTtJQUN0QixxQ0FBaUIsQ0FBQTtJQUNqQixxQ0FBaUIsQ0FBQTtJQUNqQixpQ0FBYSxDQUFBO0lBQ2IscUNBQWlCLENBQUE7SUFDakIsMkRBQTJEO0lBQzNELHlDQUFxQixDQUFBO0lBQ3JCLGlDQUFhLENBQUE7SUFDYixpQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFYVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBVzNCO0FBRUQsTUFBTSxDQUFOLElBQVksZUFtQlg7QUFuQkQsV0FBWSxlQUFlO0lBQ3ZCLHFEQUFRLENBQUE7SUFDUiw2REFBWSxDQUFBO0lBQ1osdURBQVMsQ0FBQTtJQUNULHlEQUFVLENBQUE7SUFDVix5REFBVSxDQUFBO0lBQ1YscUVBQWdCLENBQUE7SUFDaEIsdUVBQWlCLENBQUE7SUFDakIsdUVBQWlCLENBQUE7SUFDakIsbURBQU8sQ0FBQTtJQUNQLDJEQUFXLENBQUE7SUFDWCxvREFBUSxDQUFBO0lBQ1Isb0RBQVEsQ0FBQTtJQUNSLDRFQUFvQixDQUFBO0lBQ3BCLGdGQUFzQixDQUFBO0lBQ3RCLDREQUFZLENBQUE7SUFDWixnRUFBYyxDQUFBO0lBQ2QsMEVBQW1CLENBQUE7SUFDbkIsOEVBQXFCLENBQUE7QUFDekIsQ0FBQyxFQW5CVyxlQUFlLEtBQWYsZUFBZSxRQW1CMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQUlUYWJsZUFjdGlvbiB9IGZyb20gJy4vYWN0aW9uJztcbmltcG9ydCB7IEFJVGFibGVTZWxlY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcyc7XG5pbXBvcnQgeyBJZCB9IGZyb20gJ25neC10ZXRoeXMvdHlwZXMnO1xuXG5leHBvcnQgZW51bSBBSVRhYmxlRmllbGRUeXBlIHtcbiAgICB0ZXh0ID0gJ3RleHQnLCAvLyDljIXlkKvlpJrooYzmlofmnKxcbiAgICByaWNoVGV4dCA9ICdyaWNoX3RleHQnLCAvLyDljIXlkKvlpJrooYzmlofmnKxcbiAgICBzZWxlY3QgPSAnc2VsZWN0JywgLy8g5YyF5ZCr5Y2V6YCJ5ZKM5aSa6YCJXG4gICAgbnVtYmVyID0gJ251bWJlcicsXG4gICAgZGF0ZSA9ICdkYXRlJyxcbiAgICBtZW1iZXIgPSAnbWVtYmVyJywgLy8g5YyF5ZCr5Y2V5Liq5ZKM5aSa5LiqXG4gICAgLy8gY2FzY2FkZVNlbGVjdCA9IFwiY2FzY2FkZV9zZWxlY3RcIiwgLy8g5YyF5ZCr5Y2V6YCJ5ZKM5aSa6YCJ77yM5Y+C5pWw5aSN5p2C5ZCO57ut5YaN6L+b6KGM6K6+6K6hXG4gICAgcHJvZ3Jlc3MgPSAncHJvZ3Jlc3MnLFxuICAgIHJhdGUgPSAncmF0ZScsXG4gICAgbGluayA9ICdsaW5rJ1xufVxuXG5leHBvcnQgZW51bSBBSVRhYmxlU3RhdFR5cGUge1xuICAgIE5vbmUgPSAwLFxuICAgIENvdW50QWxsID0gMSxcbiAgICBFbXB0eSA9IDIsXG4gICAgRmlsbGVkID0gMyxcbiAgICBVbmlxdWUgPSA0LFxuICAgIFBlcmNlbnRFbXB0eSA9IDUsXG4gICAgUGVyY2VudEZpbGxlZCA9IDYsXG4gICAgUGVyY2VudFVuaXF1ZSA9IDcsXG4gICAgU3VtID0gOCxcbiAgICBBdmVyYWdlID0gOSxcbiAgICBNYXggPSAxMCxcbiAgICBNaW4gPSAxMSxcbiAgICBEYXRlUmFuZ2VPZkRheXMgPSAxMixcbiAgICBEYXRlUmFuZ2VPZk1vbnRocyA9IDEzLFxuICAgIENoZWNrZWQgPSAxNCxcbiAgICBVbkNoZWNrZWQgPSAxNSxcbiAgICBQZXJjZW50Q2hlY2tlZCA9IDE2LFxuICAgIFBlcmNlbnRVbkNoZWNrZWQgPSAxN1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVTZWxlY3RPcHRpb24ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGNvbG9yPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVGaWVsZDxUID0gdW5rbm93bj4ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHR5cGU6IEFJVGFibGVGaWVsZFR5cGU7XG4gICAgaWNvbj86IHN0cmluZztcbiAgICB3aWR0aD86IG51bWJlcjtcbiAgICBoaWRkZW4/OiBib29sZWFuO1xuICAgIGZyb3plbj86IGJvb2xlYW47XG4gICAgc3RhdFR5cGU/OiBBSVRhYmxlU3RhdFR5cGU7XG4gICAgaXNNdWx0aXBsZT86IGJvb2xlYW47XG4gICAgW2tleTogc3RyaW5nXTogVCB8IGFueTtcbn1cblxuZXhwb3J0IHR5cGUgVGV4dEZpZWxkVmFsdWUgPSBzdHJpbmc7XG5cbmV4cG9ydCB0eXBlIFNlbGVjdEZpZWxkVmFsdWUgPSBJZFtdOyAvLyDmlbDlrZdcblxuZXhwb3J0IHR5cGUgTnVtYmVyRmllbGRWYWx1ZSA9IG51bWJlcjtcblxuZXhwb3J0IHR5cGUgRGF0ZUZpZWxkVmFsdWUgPSB7IHRpbWVzdGFtcDogbnVtYmVyIH07IC8vIOaXtumXtOaIs1xuXG5leHBvcnQgdHlwZSBNZW1iZXJGaWVsZFZhbHVlID0gSWRbXTtcblxuZXhwb3J0IHR5cGUgUHJvZ3Jlc3NGaWVsZFZhbHVlID0gbnVtYmVyOyAvLyBbMCwxXVxuXG5leHBvcnQgdHlwZSBSYXRlRmllbGRWYWx1ZSA9IDEgfCAyIHwgMyB8IDQgfCA1O1xuXG5leHBvcnQgdHlwZSBGaWVsZFZhbHVlID1cbiAgICB8IFRleHRGaWVsZFZhbHVlXG4gICAgfCBTZWxlY3RGaWVsZFZhbHVlXG4gICAgfCBOdW1iZXJGaWVsZFZhbHVlXG4gICAgfCBEYXRlRmllbGRWYWx1ZVxuICAgIHwgTWVtYmVyRmllbGRWYWx1ZVxuICAgIHwgUHJvZ3Jlc3NGaWVsZFZhbHVlXG4gICAgfCBSYXRlRmllbGRWYWx1ZVxuICAgIHwgYW55O1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVSZWNvcmQge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgY2hlY2tlZD86IGJvb2xlYW47XG4gICAgdmFsdWVzOiBSZWNvcmQ8c3RyaW5nLCBGaWVsZFZhbHVlPjtcbn1cblxuZXhwb3J0IHR5cGUgQUlUYWJsZVJlY29yZHMgPSBBSVRhYmxlUmVjb3JkW107XG5cbmV4cG9ydCB0eXBlIEFJVGFibGVGaWVsZHMgPSBBSVRhYmxlRmllbGRbXTtcblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlVmFsdWUge1xuICAgIHJlY29yZHM6IEFJVGFibGVSZWNvcmRzO1xuICAgIGZpZWxkczogQUlUYWJsZUZpZWxkcztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlIHtcbiAgICByZWNvcmRzOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlUmVjb3Jkcz47XG4gICAgZmllbGRzOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlRmllbGRzPjtcbiAgICBhY3Rpb25zOiBBSVRhYmxlQWN0aW9uW107XG4gICAgc2VsZWN0aW9uOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlU2VsZWN0aW9uPjtcbiAgICBvbkNoYW5nZTogKCkgPT4gdm9pZDtcbiAgICBhcHBseTogKGFjdGlvbjogQUlUYWJsZUFjdGlvbikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlQ2hhbmdlT3B0aW9ucyB7XG4gICAgcmVjb3JkczogQUlUYWJsZVJlY29yZFtdO1xuICAgIGZpZWxkczogQUlUYWJsZUZpZWxkW107XG4gICAgYWN0aW9uczogQUlUYWJsZUFjdGlvbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVGaWVsZEluZm8ge1xuICAgIHR5cGU6IEFJVGFibGVGaWVsZFR5cGU7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGljb246IHN0cmluZztcbiAgICB3aWR0aDogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBBSVBsdWdpbiA9IChhaVRhYmxlOiBBSVRhYmxlKSA9PiBBSVRhYmxlO1xuIl19
|
@@ -1,3 +1,3 @@
|
|
1
1
|
export * from './core';
|
2
2
|
export * from './action';
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9jb3JlL3R5cGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb3JlJztcbmV4cG9ydCAqIGZyb20gJy4vYWN0aW9uJzsiXX0=
|
@@ -1,10 +1,16 @@
|
|
1
1
|
import { Actions } from '../action';
|
2
2
|
import { FLUSHING } from './weak-map';
|
3
|
+
import { signal } from '@angular/core';
|
3
4
|
export function createAITable(records, fields) {
|
4
5
|
const aiTable = {
|
5
6
|
records,
|
6
7
|
fields,
|
7
8
|
actions: [],
|
9
|
+
selection: signal({
|
10
|
+
selectedRecords: new Map(),
|
11
|
+
selectedFields: new Map(),
|
12
|
+
selectedCells: new Map()
|
13
|
+
}),
|
8
14
|
onChange: () => { },
|
9
15
|
apply: (action) => {
|
10
16
|
aiTable.actions.push(action);
|
@@ -21,4 +27,7 @@ export function createAITable(records, fields) {
|
|
21
27
|
};
|
22
28
|
return aiTable;
|
23
29
|
}
|
24
|
-
|
30
|
+
export function isPathEqual(path, another) {
|
31
|
+
return path.length === another.length && path.every((n, i) => n === another[i]);
|
32
|
+
}
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvY29yZS91dGlscy9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUVwQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3RDLE9BQU8sRUFBa0IsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZELE1BQU0sVUFBVSxhQUFhLENBQUMsT0FBdUMsRUFBRSxNQUFxQztJQUN4RyxNQUFNLE9BQU8sR0FBWTtRQUNyQixPQUFPO1FBQ1AsTUFBTTtRQUNOLE9BQU8sRUFBRSxFQUFFO1FBQ1gsU0FBUyxFQUFFLE1BQU0sQ0FBQztZQUNkLGVBQWUsRUFBRSxJQUFJLEdBQUcsRUFBRTtZQUMxQixjQUFjLEVBQUUsSUFBSSxHQUFHLEVBQUU7WUFDekIsYUFBYSxFQUFFLElBQUksR0FBRyxFQUFFO1NBQzNCLENBQUM7UUFDRixRQUFRLEVBQUUsR0FBRyxFQUFFLEdBQUUsQ0FBQztRQUNsQixLQUFLLEVBQUUsQ0FBQyxNQUFxQixFQUFFLEVBQUU7WUFDN0IsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDN0IsT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7WUFFbkMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztnQkFDekIsUUFBUSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7Z0JBQzVCLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFO29CQUN4QixRQUFRLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztvQkFDN0IsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO29CQUNuQixPQUFPLENBQUMsT0FBTyxHQUFHLEVBQUUsQ0FBQztnQkFDekIsQ0FBQyxDQUFDLENBQUM7WUFDUCxDQUFDO1FBQ0wsQ0FBQztLQUNKLENBQUM7SUFDRixPQUFPLE9BQU8sQ0FBQztBQUNuQixDQUFDO0FBRUQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxJQUFVLEVBQUUsT0FBYTtJQUNqRCxPQUFPLElBQUksQ0FBQyxNQUFNLEtBQUssT0FBTyxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3BGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBY3Rpb25zIH0gZnJvbSAnLi4vYWN0aW9uJztcbmltcG9ydCB7IEFJVGFibGUsIEFJVGFibGVBY3Rpb24sIEFJVGFibGVGaWVsZHMsIEFJVGFibGVSZWNvcmRzLCBQYXRoIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgRkxVU0hJTkcgfSBmcm9tICcuL3dlYWstbWFwJztcbmltcG9ydCB7IFdyaXRhYmxlU2lnbmFsLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFJVGFibGUocmVjb3JkczogV3JpdGFibGVTaWduYWw8QUlUYWJsZVJlY29yZHM+LCBmaWVsZHM6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVGaWVsZHM+KTogQUlUYWJsZSB7XG4gICAgY29uc3QgYWlUYWJsZTogQUlUYWJsZSA9IHtcbiAgICAgICAgcmVjb3JkcyxcbiAgICAgICAgZmllbGRzLFxuICAgICAgICBhY3Rpb25zOiBbXSxcbiAgICAgICAgc2VsZWN0aW9uOiBzaWduYWwoe1xuICAgICAgICAgICAgc2VsZWN0ZWRSZWNvcmRzOiBuZXcgTWFwKCksXG4gICAgICAgICAgICBzZWxlY3RlZEZpZWxkczogbmV3IE1hcCgpLFxuICAgICAgICAgICAgc2VsZWN0ZWRDZWxsczogbmV3IE1hcCgpXG4gICAgICAgIH0pLFxuICAgICAgICBvbkNoYW5nZTogKCkgPT4ge30sXG4gICAgICAgIGFwcGx5OiAoYWN0aW9uOiBBSVRhYmxlQWN0aW9uKSA9PiB7XG4gICAgICAgICAgICBhaVRhYmxlLmFjdGlvbnMucHVzaChhY3Rpb24pO1xuICAgICAgICAgICAgQWN0aW9ucy50cmFuc2Zvcm0oYWlUYWJsZSwgYWN0aW9uKTtcblxuICAgICAgICAgICAgaWYgKCFGTFVTSElORy5nZXQoYWlUYWJsZSkpIHtcbiAgICAgICAgICAgICAgICBGTFVTSElORy5zZXQoYWlUYWJsZSwgdHJ1ZSk7XG4gICAgICAgICAgICAgICAgUHJvbWlzZS5yZXNvbHZlKCkudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIEZMVVNISU5HLnNldChhaVRhYmxlLCBmYWxzZSk7XG4gICAgICAgICAgICAgICAgICAgIGFpVGFibGUub25DaGFuZ2UoKTtcbiAgICAgICAgICAgICAgICAgICAgYWlUYWJsZS5hY3Rpb25zID0gW107XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9O1xuICAgIHJldHVybiBhaVRhYmxlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNQYXRoRXF1YWwocGF0aDogUGF0aCwgYW5vdGhlcjogUGF0aCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBwYXRoLmxlbmd0aCA9PT0gYW5vdGhlci5sZW5ndGggJiYgcGF0aC5ldmVyeSgobiwgaSkgPT4gbiA9PT0gYW5vdGhlcltpXSk7XG59XG4iXX0=
|
@@ -4,12 +4,12 @@ import { idCreator } from './id-creator';
|
|
4
4
|
export function getDefaultFieldValue(type) {
|
5
5
|
return '';
|
6
6
|
}
|
7
|
-
export function createDefaultFieldName(aiTable, type = AITableFieldType.
|
7
|
+
export function createDefaultFieldName(aiTable, type = AITableFieldType.text) {
|
8
8
|
const fields = aiTable.fields();
|
9
9
|
const count = fields.filter((item) => item.type === type).length;
|
10
10
|
return count === 0 ? FieldsMap[type].name : FieldsMap[type].name + count;
|
11
11
|
}
|
12
|
-
export function createDefaultField(aiTable, type = AITableFieldType.
|
12
|
+
export function createDefaultField(aiTable, type = AITableFieldType.text) {
|
13
13
|
return { id: idCreator(), type, name: createDefaultFieldName(aiTable, type) };
|
14
14
|
}
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9jb3JlL3V0aWxzL2ZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMvQyxPQUFPLEVBQVcsZ0JBQWdCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDckQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUV6QyxNQUFNLFVBQVUsb0JBQW9CLENBQUMsSUFBc0I7SUFDdkQsT0FBTyxFQUFFLENBQUM7QUFDZCxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLE9BQWdCLEVBQUUsT0FBeUIsZ0JBQWdCLENBQUMsSUFBSTtJQUNuRyxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDaEMsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksS0FBSyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDakUsT0FBTyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQztBQUM3RSxDQUFDO0FBRUQsTUFBTSxVQUFVLGtCQUFrQixDQUFDLE9BQWdCLEVBQUUsT0FBeUIsZ0JBQWdCLENBQUMsSUFBSTtJQUMvRixPQUFPLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsc0JBQXNCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUM7QUFDbEYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpZWxkc01hcCB9IGZyb20gJy4uL2NvbnN0YW50cy9maWVsZCc7XG5pbXBvcnQgeyBBSVRhYmxlLCBBSVRhYmxlRmllbGRUeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgaWRDcmVhdG9yIH0gZnJvbSAnLi9pZC1jcmVhdG9yJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERlZmF1bHRGaWVsZFZhbHVlKHR5cGU6IEFJVGFibGVGaWVsZFR5cGUpIHtcbiAgICByZXR1cm4gJyc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEZWZhdWx0RmllbGROYW1lKGFpVGFibGU6IEFJVGFibGUsIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUgPSBBSVRhYmxlRmllbGRUeXBlLnRleHQpIHtcbiAgICBjb25zdCBmaWVsZHMgPSBhaVRhYmxlLmZpZWxkcygpO1xuICAgIGNvbnN0IGNvdW50ID0gZmllbGRzLmZpbHRlcigoaXRlbSkgPT4gaXRlbS50eXBlID09PSB0eXBlKS5sZW5ndGg7XG4gICAgcmV0dXJuIGNvdW50ID09PSAwID8gRmllbGRzTWFwW3R5cGVdLm5hbWUgOiBGaWVsZHNNYXBbdHlwZV0ubmFtZSArIGNvdW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRGVmYXVsdEZpZWxkKGFpVGFibGU6IEFJVGFibGUsIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUgPSBBSVRhYmxlRmllbGRUeXBlLnRleHQpIHtcbiAgICByZXR1cm4geyBpZDogaWRDcmVhdG9yKCksIHR5cGUsIG5hbWU6IGNyZWF0ZURlZmF1bHRGaWVsZE5hbWUoYWlUYWJsZSwgdHlwZSkgfTtcbn1cbiJdfQ==
|
@@ -12,14 +12,44 @@ export const AITableQueries = {
|
|
12
12
|
if (!isUndefinedOrNull(fieldIndex) && fieldIndex > -1) {
|
13
13
|
return [fieldIndex];
|
14
14
|
}
|
15
|
-
throw new Error(`
|
15
|
+
throw new Error(`can not find the path: ${JSON.stringify({ ...(field || {}), ...(record || {}) })}`);
|
16
16
|
},
|
17
17
|
getFieldValue(aiTable, path) {
|
18
|
-
if (!aiTable
|
19
|
-
throw new Error(`
|
18
|
+
if (!aiTable) {
|
19
|
+
throw new Error(`aiTable does not exist`);
|
20
20
|
}
|
21
|
-
|
22
|
-
|
21
|
+
if (!aiTable.records()) {
|
22
|
+
throw new Error(`aiTable has no records`);
|
23
|
+
}
|
24
|
+
if (!aiTable.fields()) {
|
25
|
+
throw new Error(`aiTable has no fields`);
|
26
|
+
}
|
27
|
+
if (!path) {
|
28
|
+
throw new Error(`path does not exist as path [${path}]`);
|
29
|
+
}
|
30
|
+
const field = aiTable.fields()[path[1]];
|
31
|
+
if (!field) {
|
32
|
+
throw new Error(`can not find field at path [${path}]`);
|
33
|
+
}
|
34
|
+
return aiTable.records()[path[0]].values[field.id];
|
35
|
+
},
|
36
|
+
getField(aiTable, path) {
|
37
|
+
if (!aiTable) {
|
38
|
+
throw new Error(`aiTable does not exist`);
|
39
|
+
}
|
40
|
+
if (!path) {
|
41
|
+
throw new Error(`path does not exist as path [${path}]`);
|
42
|
+
}
|
43
|
+
return aiTable.fields()[path[0]];
|
44
|
+
},
|
45
|
+
getRecord(aiTable, path) {
|
46
|
+
if (!aiTable) {
|
47
|
+
throw new Error(`aiTable does not exist`);
|
48
|
+
}
|
49
|
+
if (!path) {
|
50
|
+
throw new Error(`path does not exist as path [${path}]`);
|
51
|
+
}
|
52
|
+
return aiTable.records()[path[0]];
|
23
53
|
}
|
24
54
|
};
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcmllcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL2NvcmUvdXRpbHMvcXVlcmllcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUdwRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUc7SUFDMUIsUUFBUSxDQUFDLE9BQWdCLEVBQUUsS0FBb0IsRUFBRSxNQUFzQjtRQUNuRSxNQUFNLFdBQVcsR0FBRyxNQUFNLElBQUksT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNoRSxNQUFNLFVBQVUsR0FBRyxLQUFLLElBQUksT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1RCxJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLElBQUksV0FBVyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLElBQUksVUFBVSxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDM0csT0FBTyxDQUFDLFdBQVksRUFBRSxVQUFXLENBQXFCLENBQUM7UUFDM0QsQ0FBQztRQUNELElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxXQUFXLENBQUMsSUFBSSxXQUFXLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUN0RCxPQUFPLENBQUMsV0FBVyxDQUFpQixDQUFDO1FBQ3pDLENBQUM7UUFDRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLElBQUksVUFBVSxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDcEQsT0FBTyxDQUFDLFVBQVUsQ0FBZ0IsQ0FBQztRQUN2QyxDQUFDO1FBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQywwQkFBMEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3pHLENBQUM7SUFDRCxhQUFhLENBQUMsT0FBZ0IsRUFBRSxJQUFzQjtRQUNsRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDWCxNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUNELElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztZQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUNELElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQztZQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDN0MsQ0FBQztRQUNELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNSLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLElBQUksR0FBRyxDQUFDLENBQUM7UUFDN0QsQ0FBQztRQUVELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDVCxNQUFNLElBQUksS0FBSyxDQUFDLCtCQUErQixJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQzVELENBQUM7UUFDRCxPQUFPLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRCxRQUFRLENBQUMsT0FBZ0IsRUFBRSxJQUFpQjtRQUN4QyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDWCxNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUNELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNSLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLElBQUksR0FBRyxDQUFDLENBQUM7UUFDN0QsQ0FBQztRQUNELE9BQU8sT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBZ0IsRUFBRSxJQUFrQjtRQUMxQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDWCxNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUNELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNSLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLElBQUksR0FBRyxDQUFDLENBQUM7UUFDN0QsQ0FBQztRQUNELE9BQU8sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNVbmRlZmluZWRPck51bGwgfSBmcm9tICduZ3gtdGV0aHlzL3V0aWwnO1xuaW1wb3J0IHsgUGF0aCwgQUlUYWJsZSwgQUlUYWJsZUZpZWxkLCBBSVRhYmxlUmVjb3JkLCBBSUZpZWxkVmFsdWVQYXRoLCBBSVJlY29yZFBhdGgsIEFJRmllbGRQYXRoIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgQUlUYWJsZVF1ZXJpZXMgPSB7XG4gICAgZmluZFBhdGgoYWlUYWJsZTogQUlUYWJsZSwgZmllbGQ/OiBBSVRhYmxlRmllbGQsIHJlY29yZD86IEFJVGFibGVSZWNvcmQpOiBQYXRoIHtcbiAgICAgICAgY29uc3QgcmVjb3JkSW5kZXggPSByZWNvcmQgJiYgYWlUYWJsZS5yZWNvcmRzKCkuaW5kZXhPZihyZWNvcmQpO1xuICAgICAgICBjb25zdCBmaWVsZEluZGV4ID0gZmllbGQgJiYgYWlUYWJsZS5maWVsZHMoKS5pbmRleE9mKGZpZWxkKTtcbiAgICAgICAgaWYgKCFpc1VuZGVmaW5lZE9yTnVsbChyZWNvcmRJbmRleCkgJiYgcmVjb3JkSW5kZXggPiAtMSAmJiAhaXNVbmRlZmluZWRPck51bGwoZmllbGRJbmRleCkgJiYgZmllbGRJbmRleCA+IC0xKSB7XG4gICAgICAgICAgICByZXR1cm4gW3JlY29yZEluZGV4ISwgZmllbGRJbmRleCFdIGFzIEFJRmllbGRWYWx1ZVBhdGg7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFpc1VuZGVmaW5lZE9yTnVsbChyZWNvcmRJbmRleCkgJiYgcmVjb3JkSW5kZXggPiAtMSkge1xuICAgICAgICAgICAgcmV0dXJuIFtyZWNvcmRJbmRleF0gYXMgQUlSZWNvcmRQYXRoO1xuICAgICAgICB9XG4gICAgICAgIGlmICghaXNVbmRlZmluZWRPck51bGwoZmllbGRJbmRleCkgJiYgZmllbGRJbmRleCA+IC0xKSB7XG4gICAgICAgICAgICByZXR1cm4gW2ZpZWxkSW5kZXhdIGFzIEFJRmllbGRQYXRoO1xuICAgICAgICB9XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgY2FuIG5vdCBmaW5kIHRoZSBwYXRoOiAke0pTT04uc3RyaW5naWZ5KHsgLi4uKGZpZWxkIHx8IHt9KSwgLi4uKHJlY29yZCB8fCB7fSkgfSl9YCk7XG4gICAgfSxcbiAgICBnZXRGaWVsZFZhbHVlKGFpVGFibGU6IEFJVGFibGUsIHBhdGg6IFtudW1iZXIsIG51bWJlcl0pOiBhbnkge1xuICAgICAgICBpZiAoIWFpVGFibGUpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgYWlUYWJsZSBkb2VzIG5vdCBleGlzdGApO1xuICAgICAgICB9XG4gICAgICAgIGlmICghYWlUYWJsZS5yZWNvcmRzKCkpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgYWlUYWJsZSBoYXMgbm8gcmVjb3Jkc2ApO1xuICAgICAgICB9XG4gICAgICAgIGlmICghYWlUYWJsZS5maWVsZHMoKSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBhaVRhYmxlIGhhcyBubyBmaWVsZHNgKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIXBhdGgpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgcGF0aCBkb2VzIG5vdCBleGlzdCBhcyBwYXRoIFske3BhdGh9XWApO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgZmllbGQgPSBhaVRhYmxlLmZpZWxkcygpW3BhdGhbMV1dO1xuICAgICAgICBpZiAoIWZpZWxkKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYGNhbiBub3QgZmluZCBmaWVsZCBhdCBwYXRoIFske3BhdGh9XWApO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBhaVRhYmxlLnJlY29yZHMoKVtwYXRoWzBdXS52YWx1ZXNbZmllbGQuaWRdO1xuICAgIH0sXG5cbiAgICBnZXRGaWVsZChhaVRhYmxlOiBBSVRhYmxlLCBwYXRoOiBBSUZpZWxkUGF0aCk6IEFJVGFibGVGaWVsZCB7XG4gICAgICAgIGlmICghYWlUYWJsZSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBhaVRhYmxlIGRvZXMgbm90IGV4aXN0YCk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFwYXRoKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHBhdGggZG9lcyBub3QgZXhpc3QgYXMgcGF0aCBbJHtwYXRofV1gKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gYWlUYWJsZS5maWVsZHMoKVtwYXRoWzBdXTtcbiAgICB9LFxuXG4gICAgZ2V0UmVjb3JkKGFpVGFibGU6IEFJVGFibGUsIHBhdGg6IEFJUmVjb3JkUGF0aCk6IEFJVGFibGVSZWNvcmQge1xuICAgICAgICBpZiAoIWFpVGFibGUpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgYWlUYWJsZSBkb2VzIG5vdCBleGlzdGApO1xuICAgICAgICB9XG4gICAgICAgIGlmICghcGF0aCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBwYXRoIGRvZXMgbm90IGV4aXN0IGFzIHBhdGggWyR7cGF0aH1dYCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGFpVGFibGUucmVjb3JkcygpW3BhdGhbMF1dO1xuICAgIH1cbn07XG4iXX0=
|
@@ -3,11 +3,11 @@ import { idCreator } from './id-creator';
|
|
3
3
|
export function getDefaultRecord(fields) {
|
4
4
|
const newRow = {
|
5
5
|
id: idCreator(),
|
6
|
-
|
6
|
+
values: {}
|
7
7
|
};
|
8
8
|
fields.map((item) => {
|
9
|
-
newRow.
|
9
|
+
newRow.values[item.id] = getDefaultFieldValue(item.type);
|
10
10
|
});
|
11
11
|
return newRow;
|
12
12
|
}
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvY29yZS91dGlscy9yZWNvcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFekMsTUFBTSxVQUFVLGdCQUFnQixDQUFDLE1BQXFCO0lBQ2xELE1BQU0sTUFBTSxHQUFrQjtRQUMxQixFQUFFLEVBQUUsU0FBUyxFQUFFO1FBQ2YsTUFBTSxFQUFFLEVBQUU7S0FDYixDQUFDO0lBQ0YsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1FBQ2hCLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxHQUFHLG9CQUFvQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3RCxDQUFDLENBQUMsQ0FBQztJQUNILE9BQU8sTUFBTSxDQUFDO0FBQ2xCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBSVRhYmxlRmllbGRzLCBBSVRhYmxlUmVjb3JkIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgZ2V0RGVmYXVsdEZpZWxkVmFsdWUgfSBmcm9tICcuL2ZpZWxkJztcbmltcG9ydCB7IGlkQ3JlYXRvciB9IGZyb20gJy4vaWQtY3JlYXRvcic7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREZWZhdWx0UmVjb3JkKGZpZWxkczogQUlUYWJsZUZpZWxkcykge1xuICAgIGNvbnN0IG5ld1JvdzogQUlUYWJsZVJlY29yZCA9IHtcbiAgICAgICAgaWQ6IGlkQ3JlYXRvcigpLFxuICAgICAgICB2YWx1ZXM6IHt9XG4gICAgfTtcbiAgICBmaWVsZHMubWFwKChpdGVtKSA9PiB7XG4gICAgICAgIG5ld1Jvdy52YWx1ZXNbaXRlbS5pZF0gPSBnZXREZWZhdWx0RmllbGRWYWx1ZShpdGVtLnR5cGUpO1xuICAgIH0pO1xuICAgIHJldHVybiBuZXdSb3c7XG59XG4iXX0=
|
@@ -14,41 +14,62 @@ import { ThyRate } from 'ngx-tethys/rate';
|
|
14
14
|
import { FormsModule } from '@angular/forms';
|
15
15
|
import { ThyFlexibleText } from 'ngx-tethys/flexible-text';
|
16
16
|
import { ThyTooltipModule, ThyTooltipService } from 'ngx-tethys/tooltip';
|
17
|
+
import { ThyCheckboxModule } from 'ngx-tethys/checkbox';
|
17
18
|
import { ThyStopPropagationDirective } from 'ngx-tethys/shared';
|
18
19
|
import { FieldMenu } from './components/field-menu/field-menu.component';
|
19
20
|
import { ThyAction } from 'ngx-tethys/action';
|
20
21
|
import { ThyDropdownDirective, ThyDropdownMenuComponent } from 'ngx-tethys/dropdown';
|
21
22
|
import { DefaultFieldMenus } from './constants';
|
22
23
|
import { AI_TABLE_GRID_FIELD_SERVICE_MAP, AITableGridFieldService } from './services/field.service';
|
24
|
+
import { AITableGridSelectionService } from './services/selection.servive';
|
23
25
|
import * as i0 from "@angular/core";
|
24
26
|
import * as i1 from "./services/event.service";
|
25
|
-
import * as i2 from "./services/
|
26
|
-
import * as i3 from "
|
27
|
+
import * as i2 from "./services/selection.servive";
|
28
|
+
import * as i3 from "./services/field.service";
|
29
|
+
import * as i4 from "@angular/common";
|
30
|
+
import * as i5 from "@angular/forms";
|
31
|
+
import * as i6 from "ngx-tethys/checkbox";
|
27
32
|
export class AITableGrid {
|
28
|
-
|
33
|
+
get isSelectedAll() {
|
34
|
+
return this.aiTable.selection().selectedRecords.size === this.aiRecords().length;
|
35
|
+
}
|
36
|
+
constructor(elementRef, aiTableGridEventService, aiTableGridSelectionService, aiTableGridFieldService, ngZone) {
|
29
37
|
this.elementRef = elementRef;
|
30
38
|
this.aiTableGridEventService = aiTableGridEventService;
|
39
|
+
this.aiTableGridSelectionService = aiTableGridSelectionService;
|
31
40
|
this.aiTableGridFieldService = aiTableGridFieldService;
|
41
|
+
this.ngZone = ngZone;
|
32
42
|
this.aiRecords = model.required();
|
33
43
|
this.aiFields = model.required();
|
34
44
|
this.aiRowHeight = input();
|
35
45
|
this.aiFieldConfig = input();
|
36
46
|
this.aiReadonly = input();
|
47
|
+
this.aiPlugins = input();
|
37
48
|
this.AITableFieldType = AITableFieldType;
|
38
49
|
this.takeUntilDestroyed = takeUntilDestroyed();
|
39
50
|
this.onChange = output();
|
40
51
|
this.aiTableInitialized = output();
|
41
52
|
this.gridData = computed(() => {
|
42
|
-
return buildGridData(this.aiRecords(), this.aiFields());
|
53
|
+
return buildGridData(this.aiRecords(), this.aiFields(), this.aiTable.selection());
|
43
54
|
});
|
44
55
|
}
|
45
56
|
ngOnInit() {
|
46
57
|
this.initAITable();
|
47
58
|
this.initService();
|
48
59
|
this.buildFieldMenus();
|
60
|
+
this.ngZone.runOutsideAngular(() => {
|
61
|
+
this.aiTableGridEventService.mousedownEvent$.pipe(this.takeUntilDestroyed).subscribe((event) => {
|
62
|
+
if (event?.target) {
|
63
|
+
this.aiTableGridSelectionService.updateSelect(event);
|
64
|
+
}
|
65
|
+
});
|
66
|
+
});
|
49
67
|
}
|
50
68
|
initAITable() {
|
51
69
|
this.aiTable = createAITable(this.aiRecords, this.aiFields);
|
70
|
+
this.aiPlugins()?.forEach((plugin) => {
|
71
|
+
this.aiTable = plugin(this.aiTable);
|
72
|
+
});
|
52
73
|
this.aiTableInitialized.emit(this.aiTable);
|
53
74
|
this.aiTable.onChange = () => {
|
54
75
|
this.onChange.emit({
|
@@ -60,6 +81,7 @@ export class AITableGrid {
|
|
60
81
|
}
|
61
82
|
initService() {
|
62
83
|
this.aiTableGridEventService.initialize(this.aiTable, this.aiFieldConfig()?.fieldPropertyEditor);
|
84
|
+
this.aiTableGridSelectionService.initialize(this.aiTable);
|
63
85
|
this.aiTableGridEventService.registerEvents(this.elementRef.nativeElement);
|
64
86
|
this.aiTableGridFieldService.initAIFieldConfig(this.aiFieldConfig());
|
65
87
|
AI_TABLE_GRID_FIELD_SERVICE_MAP.set(this.aiTable, this.aiTableGridFieldService);
|
@@ -70,12 +92,18 @@ export class AITableGrid {
|
|
70
92
|
addRecord() {
|
71
93
|
Actions.addRecord(this.aiTable, getDefaultRecord(this.aiFields()), [this.aiRecords().length]);
|
72
94
|
}
|
95
|
+
selectRecord(recordId) {
|
96
|
+
this.aiTableGridSelectionService.selectRecord(recordId);
|
97
|
+
}
|
98
|
+
toggleSelectAll(checked) {
|
99
|
+
this.aiTableGridSelectionService.toggleSelectAll(checked);
|
100
|
+
}
|
73
101
|
addField(gridColumnBlank) {
|
74
|
-
const field = signal(createDefaultField(this.aiTable, AITableFieldType.
|
102
|
+
const field = signal(createDefaultField(this.aiTable, AITableFieldType.text));
|
75
103
|
this.aiTableGridFieldService.editFieldProperty(gridColumnBlank, this.aiTable, field, false);
|
76
104
|
}
|
77
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: AITableGrid, deps: [{ token: i0.ElementRef }, { token: i1.AITableGridEventService }, { token: i2.AITableGridFieldService }], target: i0.ɵɵFactoryTarget.Component }); }
|
78
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: AITableGrid, isStandalone: true, selector: "ai-table-grid", inputs: { aiRecords: { classPropertyName: "aiRecords", publicName: "aiRecords", isSignal: true, isRequired: true, transformFunction: null }, aiFields: { classPropertyName: "aiFields", publicName: "aiFields", isSignal: true, isRequired: true, transformFunction: null }, aiRowHeight: { classPropertyName: "aiRowHeight", publicName: "aiRowHeight", isSignal: true, isRequired: false, transformFunction: null }, aiFieldConfig: { classPropertyName: "aiFieldConfig", publicName: "aiFieldConfig", isSignal: true, isRequired: false, transformFunction: null }, aiReadonly: { classPropertyName: "aiReadonly", publicName: "aiReadonly", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { aiRecords: "aiRecordsChange", aiFields: "aiFieldsChange", onChange: "onChange", aiTableInitialized: "aiTableInitialized" }, host: { classAttribute: "ai-table-grid" }, providers: [ThyTooltipService, AITableGridEventService, AITableGridFieldService], ngImport: i0, template: "<div class=\"grid-header d-flex\">\n <div class=\"grid-column-checkbox grid-cell\">\n <
|
105
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: AITableGrid, deps: [{ token: i0.ElementRef }, { token: i1.AITableGridEventService }, { token: i2.AITableGridSelectionService }, { token: i3.AITableGridFieldService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
106
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: AITableGrid, isStandalone: true, selector: "ai-table-grid", inputs: { aiRecords: { classPropertyName: "aiRecords", publicName: "aiRecords", isSignal: true, isRequired: true, transformFunction: null }, aiFields: { classPropertyName: "aiFields", publicName: "aiFields", isSignal: true, isRequired: true, transformFunction: null }, aiRowHeight: { classPropertyName: "aiRowHeight", publicName: "aiRowHeight", isSignal: true, isRequired: false, transformFunction: null }, aiFieldConfig: { classPropertyName: "aiFieldConfig", publicName: "aiFieldConfig", isSignal: true, isRequired: false, transformFunction: null }, aiReadonly: { classPropertyName: "aiReadonly", publicName: "aiReadonly", isSignal: true, isRequired: false, transformFunction: null }, aiPlugins: { classPropertyName: "aiPlugins", publicName: "aiPlugins", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { aiRecords: "aiRecordsChange", aiFields: "aiFieldsChange", onChange: "onChange", aiTableInitialized: "aiTableInitialized" }, host: { classAttribute: "ai-table-grid" }, providers: [ThyTooltipService, AITableGridEventService, AITableGridFieldService, AITableGridSelectionService], ngImport: i0, template: "<div class=\"grid-header d-flex\">\n <div class=\"grid-column-checkbox grid-cell\">\n <label thyCheckbox thyLabelText=\"\" [ngModel]=\"isSelectedAll\" (ngModelChange)=\"toggleSelectAll($event)\"></label>\n </div>\n @for (field of gridData().fields; track field.id) {\n <div\n class=\"grid-cell grid-field\"\n #fieldAction\n [attr.fieldId]=\"field.id\"\n [ngClass]=\"{ highlight: aiTable.selection().selectedFields.has(field.id) }\"\n [ngStyle]=\"{ width: field.width + 'px' }\"\n >\n <span class=\"text-truncate\">\n <thy-icon [thyIconName]=\"field.icon!\" class=\"mr-2 text-muted\"></thy-icon>\n <span>{{ field.name }}</span>\n </span>\n <a\n class=\"grid-field-action\"\n thyAction\n thyActiveClass=\"active\"\n thyIcon=\"more-vertical\"\n [thyDropdown]=\"fieldMenu\"\n href=\"javascript:;\"\n >\n <thy-dropdown-menu #fieldMenu>\n <field-menu [origin]=\"fieldAction\" [fieldId]=\"field.id\" [aiTable]=\"aiTable\" [fieldMenus]=\"fieldMenus\"></field-menu>\n </thy-dropdown-menu>\n </a>\n </div>\n }\n <div class=\"grid-column-blank cursor-pointer\" #gridColumnBlank (click)=\"addField(gridColumnBlank)\">\n <thy-icon thyIconName=\"plus\"></thy-icon>\n </div>\n</div>\n<div class=\"grid-body d-flex\">\n @for (record of gridData().records; track record.id; let index = $index) {\n <div class=\"grid-row d-flex\" [ngClass]=\"{ highlight: aiTable.selection().selectedRecords.has(record.id) }\">\n <div class=\"grid-row-index\">\n <label\n [ngClass]=\"record.checked ? 'checked-box' : 'unchecked-box'\"\n thyCheckbox\n thyLabelText=\"\"\n [ngModel]=\"record.checked\"\n (ngModelChange)=\"selectRecord(record.id)\"\n ></label>\n <span [ngClass]=\"record.checked ? 'grid-row-no-number' : 'grid-row-number'\"> {{ index + 1 }} </span>\n </div>\n @for (field of gridData().fields; track $index) {\n <div\n class=\"grid-cell\"\n [ngClass]=\"{\n highlight: aiTable.selection().selectedCells.has(record.id) || aiTable.selection().selectedFields.has(field.id),\n selected: aiTable.selection().selectedCells.get(record.id)?.hasOwnProperty(field.id)\n }\"\n [attr.type]=\"[field.type]\"\n [attr.fieldId]=\"[field.id]\"\n [attr.recordId]=\"[record.id]\"\n [ngStyle]=\"{ width: field.width + 'px' }\"\n #cell\n >\n @switch (field.type) {\n @case (AITableFieldType.select) {\n @if (!field.isMultiple && record.values[field.id] | selectOption: field['options']; as selectedOption) {\n <thy-tag [thyColor]=\"selectedOption!.color!\">{{ selectedOption.name }}</thy-tag>\n }\n }\n @case (AITableFieldType.date) {\n {{ record.values[field.id] | thyDatePickerFormat }}\n }\n @case (AITableFieldType.rate) {\n <thy-rate [(ngModel)]=\"record.values[field.id]\"></thy-rate>\n }\n @case (AITableFieldType.link) {\n <a\n class=\"d-block\"\n thyStopPropagation\n thyFlexibleText\n [thyTooltipContent]=\"record.values[field.id]?.text\"\n [href]=\"record.values[field.id]?.url\"\n target=\"_blank\"\n >{{ record.values[field.id]?.text }}</a\n >\n }\n @default {\n <span class=\"text-truncate\"> {{ record.values[field.id] }}</span>\n }\n }\n <div class=\"autofill-container\"></div>\n </div>\n }\n <div class=\"grid-column-blank\"></div>\n </div>\n }\n <div class=\"grid-row-insert grid-row cursor-pointer\" (click)=\"addRecord()\">\n <thy-icon thyIconName=\"plus\"></thy-icon>\n </div>\n</div>\n\n<div #activeBorder class=\"active-border\"></div>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: SelectOptionPipe, name: "selectOption" }, { kind: "component", type: ThyTag, selector: "thy-tag,[thyTag]", inputs: ["thyTag", "thyShape", "thyColor", "thyTheme", "thySize", "thyHoverable"] }, { kind: "ngmodule", type: ThyPopoverModule }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyRate, selector: "thy-rate", inputs: ["thyCount", "thyDisabled", "thyAllowHalf", "thyAllowClear", "thyTooltips", "thyIconTemplate"], outputs: ["thyItemHoverChange"] }, { kind: "pipe", type: ThyDatePickerFormatPipe, name: "thyDatePickerFormat" }, { kind: "ngmodule", type: ThyTooltipModule }, { kind: "component", type: ThyFlexibleText, selector: "thy-flexible-text,[thyFlexibleText]", inputs: ["thyTooltipTrigger", "thyContainerClass", "thyTooltipContent", "thyTooltipPlacement", "thyTooltipOffset"], exportAs: ["thyFlexibleText"] }, { kind: "directive", type: ThyStopPropagationDirective, selector: "[thyStopPropagation]", inputs: ["thyStopPropagation"] }, { kind: "component", type: FieldMenu, selector: "field-menu", inputs: ["fieldId", "aiTable", "fieldMenus", "origin"] }, { kind: "component", type: ThyAction, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "directive", type: ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyActiveClass", "thyPopoverOptions", "thyPlacement", "thyMenuInsideClosable", "thyPanelClass"], outputs: ["thyActiveChange"] }, { kind: "component", type: ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth", "thyImmediateRender"] }, { kind: "ngmodule", type: ThyCheckboxModule }, { kind: "component", type: i6.ThyCheckbox, selector: "thy-checkbox,[thy-checkbox],[thyCheckbox]", inputs: ["thyIndeterminate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
79
107
|
}
|
80
108
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: AITableGrid, decorators: [{
|
81
109
|
type: Component,
|
@@ -100,7 +128,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
100
128
|
FieldMenu,
|
101
129
|
ThyAction,
|
102
130
|
ThyDropdownDirective,
|
103
|
-
ThyDropdownMenuComponent
|
104
|
-
|
105
|
-
}]
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"","sources":["../../../packages/grid/src/grid.component.ts","../../../packages/grid/src/grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, ElementRef, input, model, OnInit, output, signal, viewChild } from '@angular/core';\nimport { CommonModule, NgClass, NgComponentOutlet, NgForOf } from '@angular/common';\nimport { SelectOptionPipe } from './pipes/grid';\nimport { ThyTag } from 'ngx-tethys/tag';\nimport { ThyPopoverModule } from 'ngx-tethys/popover';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { buildGridData } from './utils';\nimport { AIFieldConfig, AITableFieldMenu, AITableRowHeight } from './types';\nimport {\n    Actions,\n    createAITable,\n    getDefaultRecord,\n    AITable,\n    AITableChangeOptions,\n    AITableFields,\n    AITableFieldType,\n    AITableRecords,\n    createDefaultField\n} from './core';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { AITableGridEventService } from './services/event.service';\nimport { AITableFieldPropertyEditor } from './components/field-property-editor/field-property-editor.component';\nimport { ThyDatePickerFormatPipe } from 'ngx-tethys/date-picker';\nimport { ThyRate } from 'ngx-tethys/rate';\nimport { FormsModule } from '@angular/forms';\nimport { ThyFlexibleText } from 'ngx-tethys/flexible-text';\nimport { ThyTooltipModule, ThyTooltipService } from 'ngx-tethys/tooltip';\nimport { ThyStopPropagationDirective } from 'ngx-tethys/shared';\nimport { FieldMenu } from './components/field-menu/field-menu.component';\nimport { ThyAction } from 'ngx-tethys/action';\nimport { ThyDropdownDirective, ThyDropdownMenuComponent } from 'ngx-tethys/dropdown';\nimport { DefaultFieldMenus } from './constants';\nimport { AI_TABLE_GRID_FIELD_SERVICE_MAP, AITableGridFieldService } from './services/field.service';\n\n@Component({\n    selector: 'ai-table-grid',\n    templateUrl: './grid.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'ai-table-grid'\n    },\n    imports: [\n        NgForOf,\n        NgClass,\n        NgComponentOutlet,\n        CommonModule,\n        FormsModule,\n        SelectOptionPipe,\n        ThyTag,\n        ThyPopoverModule,\n        ThyIcon,\n        ThyRate,\n        AITableFieldPropertyEditor,\n        ThyDatePickerFormatPipe,\n        ThyTooltipModule,\n        ThyFlexibleText,\n        ThyStopPropagationDirective,\n        FieldMenu,\n        ThyAction,\n        ThyDropdownDirective,\n        ThyDropdownMenuComponent\n    ],\n    providers: [ThyTooltipService, AITableGridEventService, AITableGridFieldService]\n})\nexport class AITableGrid implements OnInit {\n    aiRecords = model.required<AITableRecords>();\n\n    aiFields = model.required<AITableFields>();\n\n    aiRowHeight = input<AITableRowHeight>();\n\n    aiFieldConfig = input<AIFieldConfig>();\n\n    aiReadonly = input<boolean>();\n\n    AITableFieldType = AITableFieldType;\n\n    takeUntilDestroyed = takeUntilDestroyed();\n\n    aiTable!: AITable;\n\n    onChange = output<AITableChangeOptions>();\n\n    aiTableInitialized = output<AITable>();\n\n    fieldMenus!: AITableFieldMenu[];\n\n    gridData = computed(() => {\n        return buildGridData(this.aiRecords(), this.aiFields());\n    });\n\n    constructor(\n        private elementRef: ElementRef,\n        private aiTableGridEventService: AITableGridEventService,\n        private aiTableGridFieldService: AITableGridFieldService\n    ) {}\n\n    ngOnInit(): void {\n        this.initAITable();\n        this.initService();\n        this.buildFieldMenus();\n    }\n\n    initAITable() {\n        this.aiTable = createAITable(this.aiRecords, this.aiFields);\n        this.aiTableInitialized.emit(this.aiTable);\n        this.aiTable.onChange = () => {\n            this.onChange.emit({\n                records: this.aiRecords(),\n                fields: this.aiFields(),\n                actions: this.aiTable.actions\n            });\n        };\n    }\n\n    initService() {\n        this.aiTableGridEventService.initialize(this.aiTable, this.aiFieldConfig()?.fieldPropertyEditor);\n        this.aiTableGridEventService.registerEvents(this.elementRef.nativeElement);\n        this.aiTableGridFieldService.initAIFieldConfig(this.aiFieldConfig());\n        AI_TABLE_GRID_FIELD_SERVICE_MAP.set(this.aiTable, this.aiTableGridFieldService);\n    }\n\n    buildFieldMenus() {\n        this.fieldMenus = this.aiFieldConfig()?.fieldMenus ?? DefaultFieldMenus;\n    }\n\n    addRecord() {\n        Actions.addRecord(this.aiTable, getDefaultRecord(this.aiFields()), [this.aiRecords().length]);\n    }\n\n    addField(gridColumnBlank: HTMLElement) {\n        const field = signal(createDefaultField(this.aiTable, AITableFieldType.Text));\n        this.aiTableGridFieldService.editFieldProperty(gridColumnBlank, this.aiTable, field, false);\n    }\n}\n","<div class=\"grid-header d-flex\">\n    <div class=\"grid-column-checkbox grid-cell\">\n        <input type=\"checkbox\" />\n    </div>\n    @for (field of gridData().fields; track field.id) {\n        <div class=\"grid-cell grid-field\" #fieldAction>\n            {{ field.name }}\n            <a thyAction thyActiveClass=\"active\" thyIcon=\"more-vertical\" [thyDropdown]=\"fieldMenu\" href=\"javascript:;\">\n                <thy-dropdown-menu #fieldMenu>\n                    <field-menu [origin]=\"fieldAction\" [field]=\"field\" [aiTable]=\"aiTable\" [fieldMenus]=\"fieldMenus\"></field-menu>\n                </thy-dropdown-menu>\n            </a>\n        </div>\n    }\n    <div class=\"grid-column-blank cursor-pointer\" #gridColumnBlank (click)=\"addField(gridColumnBlank)\">\n        <thy-icon thyIconName=\"plus\"></thy-icon>\n    </div>\n</div>\n<div class=\"grid-body d-flex\">\n    @for (record of gridData().records; track record.id; let index = $index) {\n        <div class=\"grid-row d-flex\">\n            <div class=\"grid-row-index\">\n                {{ index + 1 }}\n            </div>\n            @for (field of gridData().fields; track $index) {\n                <div class=\"grid-cell\" [attr.type]=\"[field.type]\" [attr.fieldId]=\"[field.id]\" [attr.recordId]=\"[record.id]\" #cell>\n                    @switch (field.type) {\n                        @case (AITableFieldType.SingleSelect) {\n                            @if (record.value[field.id] | selectOption: field['options']; as selectedOption) {\n                                <thy-tag [thyColor]=\"selectedOption!.color!\">{{ selectedOption.name }}</thy-tag>\n                            }\n                        }\n                        @case (AITableFieldType.DateTime) {\n                            {{ record.value[field.id] | thyDatePickerFormat }}\n                        }\n                        @case (AITableFieldType.Rating) {\n                            <thy-rate [(ngModel)]=\"record.value[field.id]\"></thy-rate>\n                        }\n                        @case (AITableFieldType.Link) {\n                            <a\n                                class=\"d-block pl-4 pr-4\"\n                                thyStopPropagation\n                                thyFlexibleText\n                                [thyTooltipContent]=\"record.value[field.id]?.text\"\n                                [href]=\"record.value[field.id]?.url\"\n                                target=\"_blank\"\n                                >{{ record.value[field.id]?.text }}</a\n                            >\n                        }\n                        @default {\n                            {{ record.value[field.id] }}\n                        }\n                    }\n                </div>\n            }\n            <div class=\"grid-column-blank\"></div>\n        </div>\n    }\n    <div class=\"grid-row-insert grid-row cursor-pointer\" (click)=\"addRecord()\">\n        <thy-icon thyIconName=\"plus\"></thy-icon>\n    </div>\n</div>\n\n<div #activeBorder class=\"active-border\"></div>\n"]}
|
131
|
+
ThyDropdownMenuComponent,
|
132
|
+
ThyCheckboxModule
|
133
|
+
], providers: [ThyTooltipService, AITableGridEventService, AITableGridFieldService, AITableGridSelectionService], template: "<div class=\"grid-header d-flex\">\n <div class=\"grid-column-checkbox grid-cell\">\n <label thyCheckbox thyLabelText=\"\" [ngModel]=\"isSelectedAll\" (ngModelChange)=\"toggleSelectAll($event)\"></label>\n </div>\n @for (field of gridData().fields; track field.id) {\n <div\n class=\"grid-cell grid-field\"\n #fieldAction\n [attr.fieldId]=\"field.id\"\n [ngClass]=\"{ highlight: aiTable.selection().selectedFields.has(field.id) }\"\n [ngStyle]=\"{ width: field.width + 'px' }\"\n >\n <span class=\"text-truncate\">\n <thy-icon [thyIconName]=\"field.icon!\" class=\"mr-2 text-muted\"></thy-icon>\n <span>{{ field.name }}</span>\n </span>\n <a\n class=\"grid-field-action\"\n thyAction\n thyActiveClass=\"active\"\n thyIcon=\"more-vertical\"\n [thyDropdown]=\"fieldMenu\"\n href=\"javascript:;\"\n >\n <thy-dropdown-menu #fieldMenu>\n <field-menu [origin]=\"fieldAction\" [fieldId]=\"field.id\" [aiTable]=\"aiTable\" [fieldMenus]=\"fieldMenus\"></field-menu>\n </thy-dropdown-menu>\n </a>\n </div>\n }\n <div class=\"grid-column-blank cursor-pointer\" #gridColumnBlank (click)=\"addField(gridColumnBlank)\">\n <thy-icon thyIconName=\"plus\"></thy-icon>\n </div>\n</div>\n<div class=\"grid-body d-flex\">\n @for (record of gridData().records; track record.id; let index = $index) {\n <div class=\"grid-row d-flex\" [ngClass]=\"{ highlight: aiTable.selection().selectedRecords.has(record.id) }\">\n <div class=\"grid-row-index\">\n <label\n [ngClass]=\"record.checked ? 'checked-box' : 'unchecked-box'\"\n thyCheckbox\n thyLabelText=\"\"\n [ngModel]=\"record.checked\"\n (ngModelChange)=\"selectRecord(record.id)\"\n ></label>\n <span [ngClass]=\"record.checked ? 'grid-row-no-number' : 'grid-row-number'\"> {{ index + 1 }} </span>\n </div>\n @for (field of gridData().fields; track $index) {\n <div\n class=\"grid-cell\"\n [ngClass]=\"{\n highlight: aiTable.selection().selectedCells.has(record.id) || aiTable.selection().selectedFields.has(field.id),\n selected: aiTable.selection().selectedCells.get(record.id)?.hasOwnProperty(field.id)\n }\"\n [attr.type]=\"[field.type]\"\n [attr.fieldId]=\"[field.id]\"\n [attr.recordId]=\"[record.id]\"\n [ngStyle]=\"{ width: field.width + 'px' }\"\n #cell\n >\n @switch (field.type) {\n @case (AITableFieldType.select) {\n @if (!field.isMultiple && record.values[field.id] | selectOption: field['options']; as selectedOption) {\n <thy-tag [thyColor]=\"selectedOption!.color!\">{{ selectedOption.name }}</thy-tag>\n }\n }\n @case (AITableFieldType.date) {\n {{ record.values[field.id] | thyDatePickerFormat }}\n }\n @case (AITableFieldType.rate) {\n <thy-rate [(ngModel)]=\"record.values[field.id]\"></thy-rate>\n }\n @case (AITableFieldType.link) {\n <a\n class=\"d-block\"\n thyStopPropagation\n thyFlexibleText\n [thyTooltipContent]=\"record.values[field.id]?.text\"\n [href]=\"record.values[field.id]?.url\"\n target=\"_blank\"\n >{{ record.values[field.id]?.text }}</a\n >\n }\n @default {\n <span class=\"text-truncate\"> {{ record.values[field.id] }}</span>\n }\n }\n <div class=\"autofill-container\"></div>\n </div>\n }\n <div class=\"grid-column-blank\"></div>\n </div>\n }\n <div class=\"grid-row-insert grid-row cursor-pointer\" (click)=\"addRecord()\">\n <thy-icon thyIconName=\"plus\"></thy-icon>\n </div>\n</div>\n\n<div #activeBorder class=\"active-border\"></div>\n" }]
|
134
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.AITableGridEventService }, { type: i2.AITableGridSelectionService }, { type: i3.AITableGridFieldService }, { type: i0.NgZone }] });
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"","sources":["../../../packages/grid/src/grid.component.ts","../../../packages/grid/src/grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, ElementRef, input, model, NgZone, OnInit, output, signal } from '@angular/core';\nimport { CommonModule, NgClass, NgComponentOutlet, NgForOf } from '@angular/common';\nimport { SelectOptionPipe } from './pipes/grid';\nimport { ThyTag } from 'ngx-tethys/tag';\nimport { ThyPopoverModule } from 'ngx-tethys/popover';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { buildGridData } from './utils';\nimport { AIFieldConfig, AITableFieldMenuItem, AITableRowHeight } from './types';\nimport {\n    Actions,\n    createAITable,\n    getDefaultRecord,\n    AITable,\n    AITableChangeOptions,\n    AITableFields,\n    AITableFieldType,\n    AITableRecords,\n    createDefaultField,\n    AIPlugin\n} from './core';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { AITableGridEventService } from './services/event.service';\nimport { AITableFieldPropertyEditor } from './components/field-property-editor/field-property-editor.component';\nimport { ThyDatePickerFormatPipe } from 'ngx-tethys/date-picker';\nimport { ThyRate } from 'ngx-tethys/rate';\nimport { FormsModule } from '@angular/forms';\nimport { ThyFlexibleText } from 'ngx-tethys/flexible-text';\nimport { ThyTooltipModule, ThyTooltipService } from 'ngx-tethys/tooltip';\nimport { ThyCheckboxModule } from 'ngx-tethys/checkbox';\nimport { ThyStopPropagationDirective } from 'ngx-tethys/shared';\nimport { FieldMenu } from './components/field-menu/field-menu.component';\nimport { ThyAction } from 'ngx-tethys/action';\nimport { ThyDropdownDirective, ThyDropdownMenuComponent } from 'ngx-tethys/dropdown';\nimport { DefaultFieldMenus } from './constants';\nimport { AI_TABLE_GRID_FIELD_SERVICE_MAP, AITableGridFieldService } from './services/field.service';\nimport { AITableGridSelectionService } from './services/selection.servive';\n\n@Component({\n    selector: 'ai-table-grid',\n    templateUrl: './grid.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'ai-table-grid'\n    },\n    imports: [\n        NgForOf,\n        NgClass,\n        NgComponentOutlet,\n        CommonModule,\n        FormsModule,\n        SelectOptionPipe,\n        ThyTag,\n        ThyPopoverModule,\n        ThyIcon,\n        ThyRate,\n        AITableFieldPropertyEditor,\n        ThyDatePickerFormatPipe,\n        ThyTooltipModule,\n        ThyFlexibleText,\n        ThyStopPropagationDirective,\n        FieldMenu,\n        ThyAction,\n        ThyDropdownDirective,\n        ThyDropdownMenuComponent,\n        ThyCheckboxModule\n    ],\n    providers: [ThyTooltipService, AITableGridEventService, AITableGridFieldService, AITableGridSelectionService]\n})\nexport class AITableGrid implements OnInit {\n    aiRecords = model.required<AITableRecords>();\n\n    aiFields = model.required<AITableFields>();\n\n    aiRowHeight = input<AITableRowHeight>();\n\n    aiFieldConfig = input<AIFieldConfig>();\n\n    aiReadonly = input<boolean>();\n\n    aiPlugins = input<AIPlugin[]>();\n\n    AITableFieldType = AITableFieldType;\n\n    takeUntilDestroyed = takeUntilDestroyed();\n\n    aiTable!: AITable;\n\n    get isSelectedAll() {\n        return this.aiTable.selection().selectedRecords.size === this.aiRecords().length;\n    }\n\n    onChange = output<AITableChangeOptions>();\n\n    aiTableInitialized = output<AITable>();\n\n    fieldMenus!: AITableFieldMenuItem[];\n\n    gridData = computed(() => {\n        return buildGridData(this.aiRecords(), this.aiFields(), this.aiTable.selection());\n    });\n\n    constructor(\n        private elementRef: ElementRef,\n        private aiTableGridEventService: AITableGridEventService,\n        public aiTableGridSelectionService: AITableGridSelectionService,\n        private aiTableGridFieldService: AITableGridFieldService,\n        private ngZone: NgZone\n    ) {}\n\n    ngOnInit(): void {\n        this.initAITable();\n        this.initService();\n        this.buildFieldMenus();\n        this.ngZone.runOutsideAngular(() => {\n            this.aiTableGridEventService.mousedownEvent$.pipe(this.takeUntilDestroyed).subscribe((event) => {\n                if ((event as MouseEvent)?.target) {\n                    this.aiTableGridSelectionService.updateSelect(event as MouseEvent);\n                }\n            });\n        });\n    }\n\n    initAITable() {\n        this.aiTable = createAITable(this.aiRecords, this.aiFields);\n        this.aiPlugins()?.forEach((plugin) => {\n            this.aiTable = plugin(this.aiTable);\n        });\n        this.aiTableInitialized.emit(this.aiTable);\n        this.aiTable.onChange = () => {\n            this.onChange.emit({\n                records: this.aiRecords(),\n                fields: this.aiFields(),\n                actions: this.aiTable.actions\n            });\n        };\n    }\n\n    initService() {\n        this.aiTableGridEventService.initialize(this.aiTable, this.aiFieldConfig()?.fieldPropertyEditor);\n        this.aiTableGridSelectionService.initialize(this.aiTable);\n        this.aiTableGridEventService.registerEvents(this.elementRef.nativeElement);\n        this.aiTableGridFieldService.initAIFieldConfig(this.aiFieldConfig());\n        AI_TABLE_GRID_FIELD_SERVICE_MAP.set(this.aiTable, this.aiTableGridFieldService);\n    }\n\n    buildFieldMenus() {\n        this.fieldMenus = this.aiFieldConfig()?.fieldMenus ?? DefaultFieldMenus;\n    }\n\n    addRecord() {\n        Actions.addRecord(this.aiTable, getDefaultRecord(this.aiFields()), [this.aiRecords().length]);\n    }\n\n    selectRecord(recordId: string) {\n        this.aiTableGridSelectionService.selectRecord(recordId);\n    }\n\n    toggleSelectAll(checked: boolean) {\n        this.aiTableGridSelectionService.toggleSelectAll(checked);\n    }\n\n    addField(gridColumnBlank: HTMLElement) {\n        const field = signal(createDefaultField(this.aiTable, AITableFieldType.text));\n        this.aiTableGridFieldService.editFieldProperty(gridColumnBlank, this.aiTable, field, false);\n    }\n}\n","<div class=\"grid-header d-flex\">\n    <div class=\"grid-column-checkbox grid-cell\">\n        <label thyCheckbox thyLabelText=\"\" [ngModel]=\"isSelectedAll\" (ngModelChange)=\"toggleSelectAll($event)\"></label>\n    </div>\n    @for (field of gridData().fields; track field.id) {\n        <div\n            class=\"grid-cell grid-field\"\n            #fieldAction\n            [attr.fieldId]=\"field.id\"\n            [ngClass]=\"{ highlight: aiTable.selection().selectedFields.has(field.id) }\"\n            [ngStyle]=\"{ width: field.width + 'px' }\"\n        >\n            <span class=\"text-truncate\">\n                <thy-icon [thyIconName]=\"field.icon!\" class=\"mr-2 text-muted\"></thy-icon>\n                <span>{{ field.name }}</span>\n            </span>\n            <a\n                class=\"grid-field-action\"\n                thyAction\n                thyActiveClass=\"active\"\n                thyIcon=\"more-vertical\"\n                [thyDropdown]=\"fieldMenu\"\n                href=\"javascript:;\"\n            >\n                <thy-dropdown-menu #fieldMenu>\n                    <field-menu [origin]=\"fieldAction\" [fieldId]=\"field.id\" [aiTable]=\"aiTable\" [fieldMenus]=\"fieldMenus\"></field-menu>\n                </thy-dropdown-menu>\n            </a>\n        </div>\n    }\n    <div class=\"grid-column-blank cursor-pointer\" #gridColumnBlank (click)=\"addField(gridColumnBlank)\">\n        <thy-icon thyIconName=\"plus\"></thy-icon>\n    </div>\n</div>\n<div class=\"grid-body d-flex\">\n    @for (record of gridData().records; track record.id; let index = $index) {\n        <div class=\"grid-row d-flex\" [ngClass]=\"{ highlight: aiTable.selection().selectedRecords.has(record.id) }\">\n            <div class=\"grid-row-index\">\n                <label\n                    [ngClass]=\"record.checked ? 'checked-box' : 'unchecked-box'\"\n                    thyCheckbox\n                    thyLabelText=\"\"\n                    [ngModel]=\"record.checked\"\n                    (ngModelChange)=\"selectRecord(record.id)\"\n                ></label>\n                <span [ngClass]=\"record.checked ? 'grid-row-no-number' : 'grid-row-number'\"> {{ index + 1 }} </span>\n            </div>\n            @for (field of gridData().fields; track $index) {\n                <div\n                    class=\"grid-cell\"\n                    [ngClass]=\"{\n                        highlight: aiTable.selection().selectedCells.has(record.id) || aiTable.selection().selectedFields.has(field.id),\n                        selected: aiTable.selection().selectedCells.get(record.id)?.hasOwnProperty(field.id)\n                    }\"\n                    [attr.type]=\"[field.type]\"\n                    [attr.fieldId]=\"[field.id]\"\n                    [attr.recordId]=\"[record.id]\"\n                    [ngStyle]=\"{ width: field.width + 'px' }\"\n                    #cell\n                >\n                    @switch (field.type) {\n                        @case (AITableFieldType.select) {\n                            @if (!field.isMultiple && record.values[field.id] | selectOption: field['options']; as selectedOption) {\n                                <thy-tag [thyColor]=\"selectedOption!.color!\">{{ selectedOption.name }}</thy-tag>\n                            }\n                        }\n                        @case (AITableFieldType.date) {\n                            {{ record.values[field.id] | thyDatePickerFormat }}\n                        }\n                        @case (AITableFieldType.rate) {\n                            <thy-rate [(ngModel)]=\"record.values[field.id]\"></thy-rate>\n                        }\n                        @case (AITableFieldType.link) {\n                            <a\n                                class=\"d-block\"\n                                thyStopPropagation\n                                thyFlexibleText\n                                [thyTooltipContent]=\"record.values[field.id]?.text\"\n                                [href]=\"record.values[field.id]?.url\"\n                                target=\"_blank\"\n                                >{{ record.values[field.id]?.text }}</a\n                            >\n                        }\n                        @default {\n                            <span class=\"text-truncate\"> {{ record.values[field.id] }}</span>\n                        }\n                    }\n                    <div class=\"autofill-container\"></div>\n                </div>\n            }\n            <div class=\"grid-column-blank\"></div>\n        </div>\n    }\n    <div class=\"grid-row-insert grid-row cursor-pointer\" (click)=\"addRecord()\">\n        <thy-icon thyIconName=\"plus\"></thy-icon>\n    </div>\n</div>\n\n<div #activeBorder class=\"active-border\"></div>\n"]}
|
package/esm2022/pipes/grid.mjs
CHANGED
@@ -1,6 +1,5 @@
|
|
1
1
|
import { Pipe } from '@angular/core';
|
2
2
|
import * as i0 from "@angular/core";
|
3
|
-
;
|
4
3
|
export class SelectOptionPipe {
|
5
4
|
transform(id, options) {
|
6
5
|
return options.find((item) => item.id === id);
|
@@ -15,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
15
14
|
standalone: true
|
16
15
|
}]
|
17
16
|
}] });
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3BpcGVzL2dyaWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBT3BELE1BQU0sT0FBTyxnQkFBZ0I7SUFDekIsU0FBUyxDQUFDLEVBQVUsRUFBRSxPQUE4QjtRQUNoRCxPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs4R0FIUSxnQkFBZ0I7NEdBQWhCLGdCQUFnQjs7MkZBQWhCLGdCQUFnQjtrQkFKNUIsSUFBSTttQkFBQztvQkFDRixJQUFJLEVBQUUsY0FBYztvQkFDcEIsVUFBVSxFQUFFLElBQUk7aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQUlUYWJsZVNlbGVjdE9wdGlvbiB9IGZyb20gJy4uL2NvcmUnO1xuXG5AUGlwZSh7XG4gICAgbmFtZTogJ3NlbGVjdE9wdGlvbicsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBTZWxlY3RPcHRpb25QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgdHJhbnNmb3JtKGlkOiBzdHJpbmcsIG9wdGlvbnM6IEFJVGFibGVTZWxlY3RPcHRpb25bXSkge1xuICAgICAgICByZXR1cm4gb3B0aW9ucy5maW5kKChpdGVtKSA9PiBpdGVtLmlkID09PSBpZCk7XG4gICAgfVxufVxuIl19
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { Injectable } from '@angular/core';
|
2
2
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
3
|
-
import { fromEvent } from 'rxjs';
|
3
|
+
import { fromEvent, Subject } from 'rxjs';
|
4
4
|
import { DBL_CLICK_EDIT_TYPE } from '../constants';
|
5
5
|
import { getRecordOrField } from '../utils';
|
6
6
|
import { GRID_CELL_EDITOR_MAP } from '../constants/editor';
|
@@ -10,6 +10,7 @@ export class AITableGridEventService {
|
|
10
10
|
constructor(thyPopover) {
|
11
11
|
this.thyPopover = thyPopover;
|
12
12
|
this.takeUntilDestroyed = takeUntilDestroyed();
|
13
|
+
this.mousedownEvent$ = new Subject();
|
13
14
|
}
|
14
15
|
initialize(aiTable, aiFieldRenderers) {
|
15
16
|
this.aiTable = aiTable;
|
@@ -21,11 +22,16 @@ export class AITableGridEventService {
|
|
21
22
|
.subscribe((event) => {
|
22
23
|
this.dblClick(event);
|
23
24
|
});
|
25
|
+
fromEvent(element, 'mousedown')
|
26
|
+
.pipe(this.takeUntilDestroyed)
|
27
|
+
.subscribe((event) => {
|
28
|
+
this.mousedownEvent$.next(event);
|
29
|
+
});
|
24
30
|
}
|
25
31
|
dblClick(event) {
|
26
32
|
const cellDom = event.target.closest('.grid-cell');
|
27
33
|
const type = cellDom && cellDom.getAttribute('type');
|
28
|
-
if (type && DBL_CLICK_EDIT_TYPE.includes(
|
34
|
+
if (type && DBL_CLICK_EDIT_TYPE.includes(type)) {
|
29
35
|
this.openEdit(cellDom);
|
30
36
|
}
|
31
37
|
}
|
@@ -54,6 +60,7 @@ export class AITableGridEventService {
|
|
54
60
|
height: height + 2 + 'px',
|
55
61
|
placement: 'top',
|
56
62
|
offset: -(height + 4),
|
63
|
+
minWidth: width,
|
57
64
|
initialState: {
|
58
65
|
field: field,
|
59
66
|
record: record,
|
@@ -72,4 +79,4 @@ export class AITableGridEventService {
|
|
72
79
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: AITableGridEventService, decorators: [{
|
73
80
|
type: Injectable
|
74
81
|
}], ctorParameters: () => [{ type: i1.ThyPopover }] });
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event.service.js","sourceRoot":"","sources":["../../../../packages/grid/src/services/event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Signal } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { fromEvent, Subject } from 'rxjs';\nimport { DBL_CLICK_EDIT_TYPE } from '../constants';\nimport { getRecordOrField } from '../utils';\nimport { AITable, AITableField, AITableFieldType, AITableRecord } from '../core';\nimport { GRID_CELL_EDITOR_MAP } from '../constants/editor';\nimport { ThyPopover } from 'ngx-tethys/popover';\nimport { AITableGridCellRenderSchema } from '../types';\n\n@Injectable()\nexport class AITableGridEventService {\n    aiTable!: AITable;\n\n    aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>;\n\n    takeUntilDestroyed = takeUntilDestroyed();\n\n    mousedownEvent$ = new Subject<MouseEvent>();\n\n    constructor(private thyPopover: ThyPopover) {}\n\n    initialize(aiTable: AITable, aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>) {\n        this.aiTable = aiTable;\n        this.aiFieldRenderers = aiFieldRenderers;\n    }\n\n    registerEvents(element: HTMLElement) {\n        fromEvent<MouseEvent>(element, 'dblclick')\n            .pipe(this.takeUntilDestroyed)\n            .subscribe((event) => {\n                this.dblClick(event as MouseEvent);\n            });\n\n        fromEvent<MouseEvent>(element, 'mousedown')\n            .pipe(this.takeUntilDestroyed)\n            .subscribe((event) => {\n                this.mousedownEvent$.next(event as MouseEvent);\n            });\n    }\n\n    private dblClick(event: MouseEvent) {\n        const cellDom = (event.target as HTMLElement).closest('.grid-cell') as HTMLElement;\n        const type = cellDom && cellDom.getAttribute('type')! as AITableFieldType;\n        if (type && DBL_CLICK_EDIT_TYPE.includes(type)) {\n            this.openEdit(cellDom);\n        }\n    }\n\n    private getEditorComponent(type: AITableFieldType) {\n        if (this.aiFieldRenderers && this.aiFieldRenderers[type]) {\n            return this.aiFieldRenderers[type]!.editor;\n        }\n        return GRID_CELL_EDITOR_MAP[type];\n    }\n\n    private openEdit(cellDom: HTMLElement) {\n        const { x, y, width, height } = cellDom.getBoundingClientRect();\n        const fieldId = cellDom.getAttribute('fieldId')!;\n        const recordId = cellDom.getAttribute('recordId')!;\n        const field = getRecordOrField(this.aiTable.fields, fieldId) as Signal<AITableField>;\n        const record = getRecordOrField(this.aiTable.records, recordId) as Signal<AITableRecord>;\n        const component = this.getEditorComponent(field().type);\n        this.thyPopover.open(component, {\n            origin: cellDom,\n            originPosition: {\n                x: x - 1,\n                y: y + 1,\n                width: width + 2,\n                height: height + 2\n            },\n            width: width + 2 + 'px',\n            height: height + 2 + 'px',\n            placement: 'top',\n            offset: -(height + 4),\n            minWidth: width,\n            initialState: {\n                field: field,\n                record: record,\n                aiTable: this.aiTable\n            },\n            panelClass: 'grid-cell-editor',\n            outsideClosable: false,\n            hasBackdrop: false,\n            manualClosure: true,\n            animationDisabled: true\n        });\n    }\n}\n"]}
|