@ai-table/state 0.0.69 → 0.0.71

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.
Files changed (40) hide show
  1. package/action/field.d.ts +1 -1
  2. package/action/field.d.ts.map +1 -1
  3. package/action/general.d.ts.map +1 -1
  4. package/action/record.d.ts.map +1 -1
  5. package/action/view.d.ts.map +1 -1
  6. package/constants/context-menu-item.d.ts.map +1 -1
  7. package/esm2022/action/field.mjs +3 -3
  8. package/esm2022/action/general.mjs +3 -3
  9. package/esm2022/action/record.mjs +1 -1
  10. package/esm2022/action/view.mjs +1 -1
  11. package/esm2022/constants/context-menu-item.mjs +1 -1
  12. package/esm2022/shared/to-table/index.mjs +1 -1
  13. package/esm2022/shared/to-yjs/add-node.mjs +2 -3
  14. package/esm2022/shared/to-yjs/remove-node.mjs +2 -3
  15. package/esm2022/shared/to-yjs/set-node.mjs +2 -3
  16. package/esm2022/shared/to-yjs/update-field-value.mjs +1 -1
  17. package/esm2022/shared/utils/initialize.mjs +2 -3
  18. package/esm2022/utils/field/add-fields.mjs +4 -6
  19. package/esm2022/utils/field/remove-field.mjs +1 -3
  20. package/esm2022/utils/record/add-records.mjs +3 -12
  21. package/esm2022/utils/record/filter.mjs +2 -3
  22. package/esm2022/utils/record/sort.mjs +1 -2
  23. package/fesm2022/ai-table-state.mjs +18 -28
  24. package/fesm2022/ai-table-state.mjs.map +1 -1
  25. package/package.json +1 -1
  26. package/shared/to-table/index.d.ts.map +1 -1
  27. package/shared/to-yjs/add-node.d.ts +1 -2
  28. package/shared/to-yjs/add-node.d.ts.map +1 -1
  29. package/shared/to-yjs/remove-node.d.ts +1 -2
  30. package/shared/to-yjs/remove-node.d.ts.map +1 -1
  31. package/shared/to-yjs/set-node.d.ts +1 -2
  32. package/shared/to-yjs/set-node.d.ts.map +1 -1
  33. package/shared/to-yjs/update-field-value.d.ts +1 -2
  34. package/shared/to-yjs/update-field-value.d.ts.map +1 -1
  35. package/shared/utils/initialize.d.ts.map +1 -1
  36. package/utils/field/remove-field.d.ts.map +1 -1
  37. package/utils/record/add-records.d.ts +1 -1
  38. package/utils/record/add-records.d.ts.map +1 -1
  39. package/utils/record/filter.d.ts.map +1 -1
  40. package/utils/record/sort.d.ts.map +1 -1
@@ -1,22 +1,13 @@
1
1
  import { getDefaultFieldValue, idsCreator, shortIdsCreator } from '@ai-table/grid';
2
- import { getSortRecords } from './sort';
3
2
  import { getSortFields } from '../field/sort-fields';
4
3
  import { Actions } from '../../action';
5
4
  import { getDefaultRecordDataByFilter } from './filter';
6
- import { Direction } from '@ai-table/utils';
7
- export function addRecords(aiTable, options, trackableEntity) {
8
- const { originId, direction = Direction.after, isDuplicate, count = 1 } = options;
5
+ export function addRecords(aiTable, trackableEntity, options) {
6
+ const { originId, isDuplicate, count = 1 } = options || {};
9
7
  const activeView = aiTable.viewsMap()[aiTable.activeViewId()];
10
- const records = getSortRecords(aiTable, aiTable.gridData().records, activeView);
11
- let addIndex = records.findIndex((item) => item._id === originId);
12
- if (direction === Direction.after) {
13
- addIndex++;
14
- }
15
8
  const newRecordIds = idsCreator(count);
16
9
  const newRecordShortIds = shortIdsCreator(count);
17
10
  const newRecordValues = getDefaultRecordValues(aiTable, isDuplicate, originId);
18
- // TODO: 判断如果存在筛选条件,且 newRecordValues 中没有一项满足筛选条件
19
- // 把 id 添加到 RECORDS_WILL_HIDDEN 中
20
11
  if (activeView.settings?.conditions?.length) {
21
12
  aiTable.recordsWillHidden?.update((value) => {
22
13
  value.push(...newRecordIds);
@@ -46,4 +37,4 @@ export function getDefaultRecordValues(aiTable, isDuplicate = false, recordId) {
46
37
  }
47
38
  return newRecordValues;
48
39
  }
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLXJlY29yZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdGF0ZS9zcmMvdXRpbHMvcmVjb3JkL2FkZC1yZWNvcmRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbkYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN4QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN2QyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDeEQsT0FBTyxFQUtILFNBQVMsRUFHWixNQUFNLGlCQUFpQixDQUFDO0FBRXpCLE1BQU0sVUFBVSxVQUFVLENBQUMsT0FBb0IsRUFBRSxPQUF5QixFQUFFLGVBQWdDO0lBQ3hHLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLEtBQUssR0FBRyxDQUFDLEVBQUUsR0FBRyxPQUFPLENBQUM7SUFDbEYsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDO0lBQzlELE1BQU0sT0FBTyxHQUFHLGNBQWMsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQTZCLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDdEcsSUFBSSxRQUFRLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxRQUFRLENBQUMsQ0FBQztJQUNsRSxJQUFJLFNBQVMsS0FBSyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDaEMsUUFBUSxFQUFFLENBQUM7SUFDZixDQUFDO0lBQ0QsTUFBTSxZQUFZLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZDLE1BQU0saUJBQWlCLEdBQUcsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pELE1BQU0sZUFBZSxHQUFHLHNCQUFzQixDQUFDLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDL0UsaURBQWlEO0lBQ2pELGlDQUFpQztJQUNqQyxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQzFDLE9BQU8sQ0FBQyxpQkFBaUIsRUFBRSxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUN4QyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsWUFBWSxDQUFDLENBQUM7WUFDNUIsT0FBTyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBQ0QsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRTtRQUMvQixNQUFNLFNBQVMsR0FBa0IsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLFFBQVEsRUFBRSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsZUFBZSxFQUFFLEdBQUcsZUFBZSxFQUFFLENBQUM7UUFDOUgsT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDMUMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLE9BQW9CLEVBQUUsV0FBVyxHQUFHLEtBQUssRUFBRSxRQUFpQjtJQUMvRixJQUFJLGVBQWUsR0FBK0IsRUFBRSxDQUFDO0lBQ3JELElBQUksV0FBVyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQzFCLGVBQWUsR0FBRyxPQUFPLENBQUMsVUFBVSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQzVELENBQUM7U0FBTSxDQUFDO1FBQ0osTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzlELE1BQU0sTUFBTSxHQUFHLGFBQWEsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLE1BQU0sRUFBdUIsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUN6RixNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDaEIsZUFBZSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzRCxDQUFDLENBQUMsQ0FBQztRQUNILE1BQU0sRUFBRSxVQUFVLEVBQUUsaUJBQWlCLEVBQUUsR0FBRyxVQUFVLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQztRQUNwRSxJQUFJLFVBQVUsSUFBSSxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbEMsZUFBZSxHQUFHLDRCQUE0QixDQUFDLGVBQWUsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixDQUFDLENBQUM7UUFDM0csQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLGVBQWUsQ0FBQztBQUMzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0RGVmYXVsdEZpZWxkVmFsdWUsIGlkc0NyZWF0b3IsIHNob3J0SWRzQ3JlYXRvciB9IGZyb20gJ0BhaS10YWJsZS9ncmlkJztcbmltcG9ydCB7IEFJVmlld1RhYmxlIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHsgZ2V0U29ydFJlY29yZHMgfSBmcm9tICcuL3NvcnQnO1xuaW1wb3J0IHsgZ2V0U29ydEZpZWxkcyB9IGZyb20gJy4uL2ZpZWxkL3NvcnQtZmllbGRzJztcbmltcG9ydCB7IEFjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb24nO1xuaW1wb3J0IHsgZ2V0RGVmYXVsdFJlY29yZERhdGFCeUZpbHRlciB9IGZyb20gJy4vZmlsdGVyJztcbmltcG9ydCB7XG4gICAgQWRkUmVjb3JkT3B0aW9ucyxcbiAgICBBSVRhYmxlUmVjb3JkLFxuICAgIEFJVGFibGVWaWV3RmllbGRzLFxuICAgIEFJVGFibGVWaWV3UmVjb3JkcyxcbiAgICBEaXJlY3Rpb24sXG4gICAgRmllbGRWYWx1ZSxcbiAgICBUcmFja2FibGVFbnRpdHlcbn0gZnJvbSAnQGFpLXRhYmxlL3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZFJlY29yZHMoYWlUYWJsZTogQUlWaWV3VGFibGUsIG9wdGlvbnM6IEFkZFJlY29yZE9wdGlvbnMsIHRyYWNrYWJsZUVudGl0eTogVHJhY2thYmxlRW50aXR5KSB7XG4gICAgY29uc3QgeyBvcmlnaW5JZCwgZGlyZWN0aW9uID0gRGlyZWN0aW9uLmFmdGVyLCBpc0R1cGxpY2F0ZSwgY291bnQgPSAxIH0gPSBvcHRpb25zO1xuICAgIGNvbnN0IGFjdGl2ZVZpZXcgPSBhaVRhYmxlLnZpZXdzTWFwKClbYWlUYWJsZS5hY3RpdmVWaWV3SWQoKV07XG4gICAgY29uc3QgcmVjb3JkcyA9IGdldFNvcnRSZWNvcmRzKGFpVGFibGUsIGFpVGFibGUuZ3JpZERhdGEoKS5yZWNvcmRzIGFzIEFJVGFibGVWaWV3UmVjb3JkcywgYWN0aXZlVmlldyk7XG4gICAgbGV0IGFkZEluZGV4ID0gcmVjb3Jkcy5maW5kSW5kZXgoKGl0ZW0pID0+IGl0ZW0uX2lkID09PSBvcmlnaW5JZCk7XG4gICAgaWYgKGRpcmVjdGlvbiA9PT0gRGlyZWN0aW9uLmFmdGVyKSB7XG4gICAgICAgIGFkZEluZGV4Kys7XG4gICAgfVxuICAgIGNvbnN0IG5ld1JlY29yZElkcyA9IGlkc0NyZWF0b3IoY291bnQpO1xuICAgIGNvbnN0IG5ld1JlY29yZFNob3J0SWRzID0gc2hvcnRJZHNDcmVhdG9yKGNvdW50KTtcbiAgICBjb25zdCBuZXdSZWNvcmRWYWx1ZXMgPSBnZXREZWZhdWx0UmVjb3JkVmFsdWVzKGFpVGFibGUsIGlzRHVwbGljYXRlLCBvcmlnaW5JZCk7XG4gICAgLy8gVE9ETzog5Yik5pat5aaC5p6c5a2Y5Zyo562b6YCJ5p2h5Lu277yM5LiUIG5ld1JlY29yZFZhbHVlcyDkuK3msqHmnInkuIDpobnmu6HotrPnrZvpgInmnaHku7ZcbiAgICAvLyDmioogaWQg5re75Yqg5YiwIFJFQ09SRFNfV0lMTF9ISURERU4g5LitXG4gICAgaWYgKGFjdGl2ZVZpZXcuc2V0dGluZ3M/LmNvbmRpdGlvbnM/Lmxlbmd0aCkge1xuICAgICAgICBhaVRhYmxlLnJlY29yZHNXaWxsSGlkZGVuPy51cGRhdGUoKHZhbHVlKSA9PiB7XG4gICAgICAgICAgICB2YWx1ZS5wdXNoKC4uLm5ld1JlY29yZElkcyk7XG4gICAgICAgICAgICByZXR1cm4gWy4uLnZhbHVlXTtcbiAgICAgICAgfSk7XG4gICAgfVxuICAgIG5ld1JlY29yZElkcy5mb3JFYWNoKChpZCwgaW5kZXgpID0+IHtcbiAgICAgICAgY29uc3QgbmV3UmVjb3JkOiBBSVRhYmxlUmVjb3JkID0geyBfaWQ6IGlkLCBzaG9ydF9pZDogbmV3UmVjb3JkU2hvcnRJZHNbaW5kZXhdLCB2YWx1ZXM6IG5ld1JlY29yZFZhbHVlcywgLi4udHJhY2thYmxlRW50aXR5IH07XG4gICAgICAgIEFjdGlvbnMuYWRkUmVjb3JkKGFpVGFibGUsIG5ld1JlY29yZCk7XG4gICAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXREZWZhdWx0UmVjb3JkVmFsdWVzKGFpVGFibGU6IEFJVmlld1RhYmxlLCBpc0R1cGxpY2F0ZSA9IGZhbHNlLCByZWNvcmRJZD86IHN0cmluZykge1xuICAgIGxldCBuZXdSZWNvcmRWYWx1ZXM6IFJlY29yZDxzdHJpbmcsIEZpZWxkVmFsdWU+ID0ge307XG4gICAgaWYgKGlzRHVwbGljYXRlICYmIHJlY29yZElkKSB7XG4gICAgICAgIG5ld1JlY29yZFZhbHVlcyA9IGFpVGFibGUucmVjb3Jkc01hcCgpW3JlY29yZElkXS52YWx1ZXM7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgYWN0aXZlVmlldyA9IGFpVGFibGUudmlld3NNYXAoKVthaVRhYmxlLmFjdGl2ZVZpZXdJZCgpXTtcbiAgICAgICAgY29uc3QgZmllbGRzID0gZ2V0U29ydEZpZWxkcyhhaVRhYmxlLCBhaVRhYmxlLmZpZWxkcygpIGFzIEFJVGFibGVWaWV3RmllbGRzLCBhY3RpdmVWaWV3KTtcbiAgICAgICAgZmllbGRzLm1hcCgoaXRlbSkgPT4ge1xuICAgICAgICAgICAgbmV3UmVjb3JkVmFsdWVzW2l0ZW0uX2lkXSA9IGdldERlZmF1bHRGaWVsZFZhbHVlKGl0ZW0pO1xuICAgICAgICB9KTtcbiAgICAgICAgY29uc3QgeyBjb25kaXRpb25zLCBjb25kaXRpb25fbG9naWNhbCB9ID0gYWN0aXZlVmlldy5zZXR0aW5ncyB8fCB7fTtcbiAgICAgICAgaWYgKGNvbmRpdGlvbnMgJiYgY29uZGl0aW9ucy5sZW5ndGgpIHtcbiAgICAgICAgICAgIG5ld1JlY29yZFZhbHVlcyA9IGdldERlZmF1bHRSZWNvcmREYXRhQnlGaWx0ZXIobmV3UmVjb3JkVmFsdWVzLCBjb25kaXRpb25zLCBmaWVsZHMsIGNvbmRpdGlvbl9sb2dpY2FsKTtcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gbmV3UmVjb3JkVmFsdWVzO1xufVxuIl19
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLXJlY29yZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zdGF0ZS9zcmMvdXRpbHMvcmVjb3JkL2FkZC1yZWNvcmRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbkYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDdkMsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBR3hELE1BQU0sVUFBVSxVQUFVLENBQUMsT0FBb0IsRUFBRSxlQUFnQyxFQUFFLE9BQTBCO0lBQ3pHLE1BQU0sRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLEtBQUssR0FBRyxDQUFDLEVBQUUsR0FBRyxPQUFPLElBQUksRUFBRSxDQUFDO0lBQzNELE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQztJQUU5RCxNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDdkMsTUFBTSxpQkFBaUIsR0FBRyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakQsTUFBTSxlQUFlLEdBQUcsc0JBQXNCLENBQUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUUvRSxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQzFDLE9BQU8sQ0FBQyxpQkFBaUIsRUFBRSxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUN4QyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsWUFBWSxDQUFDLENBQUM7WUFDNUIsT0FBTyxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBQ0QsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRTtRQUMvQixNQUFNLFNBQVMsR0FBa0IsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLFFBQVEsRUFBRSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsZUFBZSxFQUFFLEdBQUcsZUFBZSxFQUFFLENBQUM7UUFDOUgsT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDMUMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUFDLE9BQW9CLEVBQUUsV0FBVyxHQUFHLEtBQUssRUFBRSxRQUFpQjtJQUMvRixJQUFJLGVBQWUsR0FBK0IsRUFBRSxDQUFDO0lBQ3JELElBQUksV0FBVyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQzFCLGVBQWUsR0FBRyxPQUFPLENBQUMsVUFBVSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQzVELENBQUM7U0FBTSxDQUFDO1FBQ0osTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzlELE1BQU0sTUFBTSxHQUFHLGFBQWEsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLE1BQU0sRUFBdUIsRUFBRSxVQUFVLENBQUMsQ0FBQztRQUN6RixNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDaEIsZUFBZSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzRCxDQUFDLENBQUMsQ0FBQztRQUNILE1BQU0sRUFBRSxVQUFVLEVBQUUsaUJBQWlCLEVBQUUsR0FBRyxVQUFVLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQztRQUNwRSxJQUFJLFVBQVUsSUFBSSxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbEMsZUFBZSxHQUFHLDRCQUE0QixDQUFDLGVBQWUsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixDQUFDLENBQUM7UUFDM0csQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLGVBQWUsQ0FBQztBQUMzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0RGVmYXVsdEZpZWxkVmFsdWUsIGlkc0NyZWF0b3IsIHNob3J0SWRzQ3JlYXRvciB9IGZyb20gJ0BhaS10YWJsZS9ncmlkJztcbmltcG9ydCB7IEFJVmlld1RhYmxlIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHsgZ2V0U29ydEZpZWxkcyB9IGZyb20gJy4uL2ZpZWxkL3NvcnQtZmllbGRzJztcbmltcG9ydCB7IEFjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb24nO1xuaW1wb3J0IHsgZ2V0RGVmYXVsdFJlY29yZERhdGFCeUZpbHRlciB9IGZyb20gJy4vZmlsdGVyJztcbmltcG9ydCB7IEFkZFJlY29yZE9wdGlvbnMsIEFJVGFibGVSZWNvcmQsIEFJVGFibGVWaWV3RmllbGRzLCBGaWVsZFZhbHVlLCBUcmFja2FibGVFbnRpdHkgfSBmcm9tICdAYWktdGFibGUvdXRpbHMnO1xuXG5leHBvcnQgZnVuY3Rpb24gYWRkUmVjb3JkcyhhaVRhYmxlOiBBSVZpZXdUYWJsZSwgdHJhY2thYmxlRW50aXR5OiBUcmFja2FibGVFbnRpdHksIG9wdGlvbnM/OiBBZGRSZWNvcmRPcHRpb25zKSB7XG4gICAgY29uc3QgeyBvcmlnaW5JZCwgaXNEdXBsaWNhdGUsIGNvdW50ID0gMSB9ID0gb3B0aW9ucyB8fCB7fTtcbiAgICBjb25zdCBhY3RpdmVWaWV3ID0gYWlUYWJsZS52aWV3c01hcCgpW2FpVGFibGUuYWN0aXZlVmlld0lkKCldO1xuXG4gICAgY29uc3QgbmV3UmVjb3JkSWRzID0gaWRzQ3JlYXRvcihjb3VudCk7XG4gICAgY29uc3QgbmV3UmVjb3JkU2hvcnRJZHMgPSBzaG9ydElkc0NyZWF0b3IoY291bnQpO1xuICAgIGNvbnN0IG5ld1JlY29yZFZhbHVlcyA9IGdldERlZmF1bHRSZWNvcmRWYWx1ZXMoYWlUYWJsZSwgaXNEdXBsaWNhdGUsIG9yaWdpbklkKTtcblxuICAgIGlmIChhY3RpdmVWaWV3LnNldHRpbmdzPy5jb25kaXRpb25zPy5sZW5ndGgpIHtcbiAgICAgICAgYWlUYWJsZS5yZWNvcmRzV2lsbEhpZGRlbj8udXBkYXRlKCh2YWx1ZSkgPT4ge1xuICAgICAgICAgICAgdmFsdWUucHVzaCguLi5uZXdSZWNvcmRJZHMpO1xuICAgICAgICAgICAgcmV0dXJuIFsuLi52YWx1ZV07XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBuZXdSZWNvcmRJZHMuZm9yRWFjaCgoaWQsIGluZGV4KSA9PiB7XG4gICAgICAgIGNvbnN0IG5ld1JlY29yZDogQUlUYWJsZVJlY29yZCA9IHsgX2lkOiBpZCwgc2hvcnRfaWQ6IG5ld1JlY29yZFNob3J0SWRzW2luZGV4XSwgdmFsdWVzOiBuZXdSZWNvcmRWYWx1ZXMsIC4uLnRyYWNrYWJsZUVudGl0eSB9O1xuICAgICAgICBBY3Rpb25zLmFkZFJlY29yZChhaVRhYmxlLCBuZXdSZWNvcmQpO1xuICAgIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RGVmYXVsdFJlY29yZFZhbHVlcyhhaVRhYmxlOiBBSVZpZXdUYWJsZSwgaXNEdXBsaWNhdGUgPSBmYWxzZSwgcmVjb3JkSWQ/OiBzdHJpbmcpIHtcbiAgICBsZXQgbmV3UmVjb3JkVmFsdWVzOiBSZWNvcmQ8c3RyaW5nLCBGaWVsZFZhbHVlPiA9IHt9O1xuICAgIGlmIChpc0R1cGxpY2F0ZSAmJiByZWNvcmRJZCkge1xuICAgICAgICBuZXdSZWNvcmRWYWx1ZXMgPSBhaVRhYmxlLnJlY29yZHNNYXAoKVtyZWNvcmRJZF0udmFsdWVzO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGFjdGl2ZVZpZXcgPSBhaVRhYmxlLnZpZXdzTWFwKClbYWlUYWJsZS5hY3RpdmVWaWV3SWQoKV07XG4gICAgICAgIGNvbnN0IGZpZWxkcyA9IGdldFNvcnRGaWVsZHMoYWlUYWJsZSwgYWlUYWJsZS5maWVsZHMoKSBhcyBBSVRhYmxlVmlld0ZpZWxkcywgYWN0aXZlVmlldyk7XG4gICAgICAgIGZpZWxkcy5tYXAoKGl0ZW0pID0+IHtcbiAgICAgICAgICAgIG5ld1JlY29yZFZhbHVlc1tpdGVtLl9pZF0gPSBnZXREZWZhdWx0RmllbGRWYWx1ZShpdGVtKTtcbiAgICAgICAgfSk7XG4gICAgICAgIGNvbnN0IHsgY29uZGl0aW9ucywgY29uZGl0aW9uX2xvZ2ljYWwgfSA9IGFjdGl2ZVZpZXcuc2V0dGluZ3MgfHwge307XG4gICAgICAgIGlmIChjb25kaXRpb25zICYmIGNvbmRpdGlvbnMubGVuZ3RoKSB7XG4gICAgICAgICAgICBuZXdSZWNvcmRWYWx1ZXMgPSBnZXREZWZhdWx0UmVjb3JkRGF0YUJ5RmlsdGVyKG5ld1JlY29yZFZhbHVlcywgY29uZGl0aW9ucywgZmllbGRzLCBjb25kaXRpb25fbG9naWNhbCk7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIG5ld1JlY29yZFZhbHVlcztcbn1cbiJdfQ==
@@ -1,6 +1,5 @@
1
1
  import { isSystemField, FieldModelMap } from '@ai-table/grid';
2
- import { AITableFieldType, AITableFilterLogical, AITableFilterOperation } from '@ai-table/utils';
3
- import { isEmpty } from 'lodash';
2
+ import { AITableFieldType, AITableFilterLogical, AITableFilterOperation, isEmpty } from '@ai-table/utils';
4
3
  export function getFilteredRecords(aiTable, records, fields, activeView) {
5
4
  const { conditions, condition_logical } = activeView.settings || {};
6
5
  if (!conditions) {
@@ -119,4 +118,4 @@ function getFilterValue(fields, record, condition) {
119
118
  cellValue
120
119
  };
121
120
  }
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../../../packages/state/src/utils/record/filter.ts"],"names":[],"mappings":"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","sourcesContent":["import { isSystemField, FieldModelMap, AITable } from '@ai-table/grid';\nimport { AIViewTable } from '../../types';\nimport {\n    AITableRecord,\n    AITableField,\n    AITableFieldType,\n    FieldValue,\n    SelectSettings,\n    SystemFieldTypes,\n    AITableViewRecords,\n    AITableViewFields,\n    AITableView,\n    AITableFilterConditions,\n    AITableFilterLogical,\n    AITableViewField,\n    AITableFilterCondition,\n    AITableFilterOperation\n} from '@ai-table/utils';\nimport { isEmpty } from 'lodash';\n\nexport function getFilteredRecords(aiTable: AIViewTable, records: AITableViewRecords, fields: AITableViewFields, activeView: AITableView) {\n    const { conditions, condition_logical } = activeView.settings || {};\n    if (!conditions) {\n        return records;\n    }\n    const illegalConditions = conditions.filter((item) => item.operation) || [];\n    if (!illegalConditions.length) {\n        return records;\n    }\n    const recordsWillHidden = aiTable.recordsWillHidden();\n    return records.filter((record) => {\n        if (recordsWillHidden && recordsWillHidden.length && recordsWillHidden.includes(record._id)) {\n            return true;\n        }\n        return checkConditions(aiTable, fields, record, { conditions: illegalConditions, condition_logical });\n    });\n}\n\nfunction checkConditions(\n    aiTable: AIViewTable,\n    fields: AITableViewFields,\n    record: AITableRecord,\n    filterConditions: AITableFilterConditions\n) {\n    if (!record) {\n        return false;\n    }\n    if (!filterConditions?.conditions) {\n        return true;\n    }\n    const { condition_logical, conditions } = filterConditions;\n    if (condition_logical === AITableFilterLogical.and) {\n        return conditions.every((condition) => doFilterOperations(aiTable, fields, record, condition));\n    }\n    if (!condition_logical || condition_logical === AITableFilterLogical.or) {\n        return conditions.some((condition) => doFilterOperations(aiTable, fields, record, condition));\n    }\n    return false;\n}\n\nfunction doFilterOperations(aiTable: AIViewTable, fields: AITableViewFields, record: AITableRecord, condition: AITableFilterCondition) {\n    const { field, cellValue } = getFilterValue(fields, record, condition);\n\n    try {\n        return (\n            field &&\n            doFilter(condition, cellValue, {\n                aiTable,\n                field\n            })\n        );\n    } catch (error) {\n        return false;\n    }\n}\n\nexport function doFilter(\n    condition: AITableFilterCondition,\n    cellValue: FieldValue,\n    options: {\n        aiTable: AITable;\n        field: AITableField;\n    }\n) {\n    const fieldModel = FieldModelMap[options.field.type];\n    if (fieldModel && fieldModel.isValid(cellValue)) {\n        return fieldModel.isMeetFilter(condition, cellValue, options);\n    } else {\n        if (condition.operation === AITableFilterOperation.empty) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n}\n\nexport function getDefaultRecordDataByFilter(\n    recordValues: Record<string, FieldValue>,\n    conditions: AITableFilterCondition[],\n    fields: AITableViewFields,\n    conditionLogical?: AITableFilterLogical\n) {\n    const fieldMap = new Map<string, AITableViewField>(fields.map((field) => [field._id, field]));\n    const conditionFieldCountMap = new Map<string, number>();\n    conditions.forEach((condition) => {\n        const fieldId = condition.field_id.toString();\n        const tmpFieldCount = conditionFieldCountMap.get(fieldId) || 0;\n        conditionFieldCountMap.set(fieldId, tmpFieldCount + 1);\n    });\n    if (conditionLogical === AITableFilterLogical.and) {\n        conditions.forEach((condition) => {\n            if (conditionFieldCountMap.get(condition.field_id.toString()) === 1) {\n                const field = fieldMap.get(condition.field_id.toString())!;\n                const canMultipleOperationCondition =\n                    (!(field.settings as SelectSettings)?.is_multiple && condition.operation === AITableFilterOperation.eq) ||\n                    (field?.settings as SelectSettings)?.is_multiple;\n                if (\n                    [AITableFilterOperation.eq, AITableFilterOperation.in].includes(condition.operation) &&\n                    [AITableFieldType.select, AITableFieldType.member].includes(field?.type) &&\n                    canMultipleOperationCondition\n                ) {\n                    recordValues[condition.field_id] = condition.value;\n                }\n\n                if (field?.type === AITableFieldType.date && condition.operation === AITableFilterOperation.eq) {\n                    recordValues[condition.field_id] = {\n                        timestamp: condition.value\n                    };\n                }\n\n                if (condition.operation === AITableFilterOperation.contain && AITableFieldType.text === field?.type) {\n                    recordValues[condition.field_id] = condition.value;\n                }\n\n                if (\n                    condition.operation === AITableFilterOperation.eq &&\n                    [AITableFieldType.rate, AITableFieldType.number, AITableFieldType.progress].includes(field?.type)\n                ) {\n                    recordValues[condition.field_id] = condition.value;\n                }\n            }\n        });\n    }\n    return recordValues;\n}\n\nfunction getFilterValue(fields: AITableViewFields, record: AITableRecord, condition: AITableFilterCondition) {\n    const field = fields.find((item) => item._id === condition.field_id);\n    let cellValue = null;\n    if (field && isSystemField(field)) {\n        if ([AITableFieldType.createdAt, AITableFieldType.updatedAt].includes(field.type)) {\n            cellValue = { timestamp: record[field.type as SystemFieldTypes] };\n        } else {\n            cellValue = record[field.type as SystemFieldTypes];\n        }\n    } else {\n        cellValue = record.values[condition.field_id];\n    }\n\n    if (field && [AITableFieldType.createdBy, AITableFieldType.updatedBy, AITableFieldType.member].includes(field.type)) {\n        cellValue = Array.isArray(cellValue) ? cellValue : isEmpty(cellValue) ? [] : [cellValue];\n    }\n\n    return {\n        field,\n        cellValue\n    };\n}\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../../../packages/state/src/utils/record/filter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAW,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAGH,gBAAgB,EAQhB,oBAAoB,EAGpB,sBAAsB,EACtB,OAAO,EACV,MAAM,iBAAiB,CAAC;AAEzB,MAAM,UAAU,kBAAkB,CAAC,OAAoB,EAAE,OAA2B,EAAE,MAAyB,EAAE,UAAuB;IACpI,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,GAAG,UAAU,CAAC,QAAQ,IAAI,EAAE,CAAC;IACpE,IAAI,CAAC,UAAU,EAAE,CAAC;QACd,OAAO,OAAO,CAAC;IACnB,CAAC;IACD,MAAM,iBAAiB,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IAC5E,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC;QAC5B,OAAO,OAAO,CAAC;IACnB,CAAC;IACD,MAAM,iBAAiB,GAAG,OAAO,CAAC,iBAAiB,EAAE,CAAC;IACtD,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE;QAC7B,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,MAAM,IAAI,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1F,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,UAAU,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,CAAC,CAAC;IAC1G,CAAC,CAAC,CAAC;AACP,CAAC;AAED,SAAS,eAAe,CACpB,OAAoB,EACpB,MAAyB,EACzB,MAAqB,EACrB,gBAAyC;IAEzC,IAAI,CAAC,MAAM,EAAE,CAAC;QACV,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,CAAC,gBAAgB,EAAE,UAAU,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC;IAChB,CAAC;IACD,MAAM,EAAE,iBAAiB,EAAE,UAAU,EAAE,GAAG,gBAAgB,CAAC;IAC3D,IAAI,iBAAiB,KAAK,oBAAoB,CAAC,GAAG,EAAE,CAAC;QACjD,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IACnG,CAAC;IACD,IAAI,CAAC,iBAAiB,IAAI,iBAAiB,KAAK,oBAAoB,CAAC,EAAE,EAAE,CAAC;QACtE,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAClG,CAAC;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AAED,SAAS,kBAAkB,CAAC,OAAoB,EAAE,MAAyB,EAAE,MAAqB,EAAE,SAAiC;IACjI,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IAEvE,IAAI,CAAC;QACD,OAAO,CACH,KAAK;YACL,QAAQ,CAAC,SAAS,EAAE,SAAS,EAAE;gBAC3B,OAAO;gBACP,KAAK;aACR,CAAC,CACL,CAAC;IACN,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACb,OAAO,KAAK,CAAC;IACjB,CAAC;AACL,CAAC;AAED,MAAM,UAAU,QAAQ,CACpB,SAAiC,EACjC,SAAqB,EACrB,OAGC;IAED,MAAM,UAAU,GAAG,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACrD,IAAI,UAAU,IAAI,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QAC9C,OAAO,UAAU,CAAC,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAClE,CAAC;SAAM,CAAC;QACJ,IAAI,SAAS,CAAC,SAAS,KAAK,sBAAsB,CAAC,KAAK,EAAE,CAAC;YACvD,OAAO,IAAI,CAAC;QAChB,CAAC;aAAM,CAAC;YACJ,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC;AACL,CAAC;AAED,MAAM,UAAU,4BAA4B,CACxC,YAAwC,EACxC,UAAoC,EACpC,MAAyB,EACzB,gBAAuC;IAEvC,MAAM,QAAQ,GAAG,IAAI,GAAG,CAA2B,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;IAC9F,MAAM,sBAAsB,GAAG,IAAI,GAAG,EAAkB,CAAC;IACzD,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;QAC7B,MAAM,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAC9C,MAAM,aAAa,GAAG,sBAAsB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/D,sBAAsB,CAAC,GAAG,CAAC,OAAO,EAAE,aAAa,GAAG,CAAC,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;IACH,IAAI,gBAAgB,KAAK,oBAAoB,CAAC,GAAG,EAAE,CAAC;QAChD,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC7B,IAAI,sBAAsB,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;gBAClE,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAE,CAAC;gBAC3D,MAAM,6BAA6B,GAC/B,CAAC,CAAE,KAAK,CAAC,QAA2B,EAAE,WAAW,IAAI,SAAS,CAAC,SAAS,KAAK,sBAAsB,CAAC,EAAE,CAAC;oBACtG,KAAK,EAAE,QAA2B,EAAE,WAAW,CAAC;gBACrD,IACI,CAAC,sBAAsB,CAAC,EAAE,EAAE,sBAAsB,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,CAAC;oBACpF,CAAC,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC;oBACxE,6BAA6B,EAC/B,CAAC;oBACC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC;gBACvD,CAAC;gBAED,IAAI,KAAK,EAAE,IAAI,KAAK,gBAAgB,CAAC,IAAI,IAAI,SAAS,CAAC,SAAS,KAAK,sBAAsB,CAAC,EAAE,EAAE,CAAC;oBAC7F,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG;wBAC/B,SAAS,EAAE,SAAS,CAAC,KAAK;qBAC7B,CAAC;gBACN,CAAC;gBAED,IAAI,SAAS,CAAC,SAAS,KAAK,sBAAsB,CAAC,OAAO,IAAI,gBAAgB,CAAC,IAAI,KAAK,KAAK,EAAE,IAAI,EAAE,CAAC;oBAClG,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC;gBACvD,CAAC;gBAED,IACI,SAAS,CAAC,SAAS,KAAK,sBAAsB,CAAC,EAAE;oBACjD,CAAC,gBAAgB,CAAC,IAAI,EAAE,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,EACnG,CAAC;oBACC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC;gBACvD,CAAC;YACL,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,OAAO,YAAY,CAAC;AACxB,CAAC;AAED,SAAS,cAAc,CAAC,MAAyB,EAAE,MAAqB,EAAE,SAAiC;IACvG,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,KAAK,SAAS,CAAC,QAAQ,CAAC,CAAC;IACrE,IAAI,SAAS,GAAG,IAAI,CAAC;IACrB,IAAI,KAAK,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,gBAAgB,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YAChF,SAAS,GAAG,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,IAAwB,CAAC,EAAE,CAAC;QACtE,CAAC;aAAM,CAAC;YACJ,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,IAAwB,CAAC,CAAC;QACvD,CAAC;IACL,CAAC;SAAM,CAAC;QACJ,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IAClD,CAAC;IAED,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,gBAAgB,CAAC,SAAS,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;QAClH,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAC7F,CAAC;IAED,OAAO;QACH,KAAK;QACL,SAAS;KACZ,CAAC;AACN,CAAC","sourcesContent":["import { isSystemField, FieldModelMap, AITable } from '@ai-table/grid';\nimport { AIViewTable } from '../../types';\nimport {\n    AITableRecord,\n    AITableField,\n    AITableFieldType,\n    FieldValue,\n    SelectSettings,\n    SystemFieldTypes,\n    AITableViewRecords,\n    AITableViewFields,\n    AITableView,\n    AITableFilterConditions,\n    AITableFilterLogical,\n    AITableViewField,\n    AITableFilterCondition,\n    AITableFilterOperation,\n    isEmpty\n} from '@ai-table/utils';\n\nexport function getFilteredRecords(aiTable: AIViewTable, records: AITableViewRecords, fields: AITableViewFields, activeView: AITableView) {\n    const { conditions, condition_logical } = activeView.settings || {};\n    if (!conditions) {\n        return records;\n    }\n    const illegalConditions = conditions.filter((item) => item.operation) || [];\n    if (!illegalConditions.length) {\n        return records;\n    }\n    const recordsWillHidden = aiTable.recordsWillHidden();\n    return records.filter((record) => {\n        if (recordsWillHidden && recordsWillHidden.length && recordsWillHidden.includes(record._id)) {\n            return true;\n        }\n        return checkConditions(aiTable, fields, record, { conditions: illegalConditions, condition_logical });\n    });\n}\n\nfunction checkConditions(\n    aiTable: AIViewTable,\n    fields: AITableViewFields,\n    record: AITableRecord,\n    filterConditions: AITableFilterConditions\n) {\n    if (!record) {\n        return false;\n    }\n    if (!filterConditions?.conditions) {\n        return true;\n    }\n    const { condition_logical, conditions } = filterConditions;\n    if (condition_logical === AITableFilterLogical.and) {\n        return conditions.every((condition) => doFilterOperations(aiTable, fields, record, condition));\n    }\n    if (!condition_logical || condition_logical === AITableFilterLogical.or) {\n        return conditions.some((condition) => doFilterOperations(aiTable, fields, record, condition));\n    }\n    return false;\n}\n\nfunction doFilterOperations(aiTable: AIViewTable, fields: AITableViewFields, record: AITableRecord, condition: AITableFilterCondition) {\n    const { field, cellValue } = getFilterValue(fields, record, condition);\n\n    try {\n        return (\n            field &&\n            doFilter(condition, cellValue, {\n                aiTable,\n                field\n            })\n        );\n    } catch (error) {\n        return false;\n    }\n}\n\nexport function doFilter(\n    condition: AITableFilterCondition,\n    cellValue: FieldValue,\n    options: {\n        aiTable: AITable;\n        field: AITableField;\n    }\n) {\n    const fieldModel = FieldModelMap[options.field.type];\n    if (fieldModel && fieldModel.isValid(cellValue)) {\n        return fieldModel.isMeetFilter(condition, cellValue, options);\n    } else {\n        if (condition.operation === AITableFilterOperation.empty) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n}\n\nexport function getDefaultRecordDataByFilter(\n    recordValues: Record<string, FieldValue>,\n    conditions: AITableFilterCondition[],\n    fields: AITableViewFields,\n    conditionLogical?: AITableFilterLogical\n) {\n    const fieldMap = new Map<string, AITableViewField>(fields.map((field) => [field._id, field]));\n    const conditionFieldCountMap = new Map<string, number>();\n    conditions.forEach((condition) => {\n        const fieldId = condition.field_id.toString();\n        const tmpFieldCount = conditionFieldCountMap.get(fieldId) || 0;\n        conditionFieldCountMap.set(fieldId, tmpFieldCount + 1);\n    });\n    if (conditionLogical === AITableFilterLogical.and) {\n        conditions.forEach((condition) => {\n            if (conditionFieldCountMap.get(condition.field_id.toString()) === 1) {\n                const field = fieldMap.get(condition.field_id.toString())!;\n                const canMultipleOperationCondition =\n                    (!(field.settings as SelectSettings)?.is_multiple && condition.operation === AITableFilterOperation.eq) ||\n                    (field?.settings as SelectSettings)?.is_multiple;\n                if (\n                    [AITableFilterOperation.eq, AITableFilterOperation.in].includes(condition.operation) &&\n                    [AITableFieldType.select, AITableFieldType.member].includes(field?.type) &&\n                    canMultipleOperationCondition\n                ) {\n                    recordValues[condition.field_id] = condition.value;\n                }\n\n                if (field?.type === AITableFieldType.date && condition.operation === AITableFilterOperation.eq) {\n                    recordValues[condition.field_id] = {\n                        timestamp: condition.value\n                    };\n                }\n\n                if (condition.operation === AITableFilterOperation.contain && AITableFieldType.text === field?.type) {\n                    recordValues[condition.field_id] = condition.value;\n                }\n\n                if (\n                    condition.operation === AITableFilterOperation.eq &&\n                    [AITableFieldType.rate, AITableFieldType.number, AITableFieldType.progress].includes(field?.type)\n                ) {\n                    recordValues[condition.field_id] = condition.value;\n                }\n            }\n        });\n    }\n    return recordValues;\n}\n\nfunction getFilterValue(fields: AITableViewFields, record: AITableRecord, condition: AITableFilterCondition) {\n    const field = fields.find((item) => item._id === condition.field_id);\n    let cellValue = null;\n    if (field && isSystemField(field)) {\n        if ([AITableFieldType.createdAt, AITableFieldType.updatedAt].includes(field.type)) {\n            cellValue = { timestamp: record[field.type as SystemFieldTypes] };\n        } else {\n            cellValue = record[field.type as SystemFieldTypes];\n        }\n    } else {\n        cellValue = record.values[condition.field_id];\n    }\n\n    if (field && [AITableFieldType.createdBy, AITableFieldType.updatedBy, AITableFieldType.member].includes(field.type)) {\n        cellValue = Array.isArray(cellValue) ? cellValue : isEmpty(cellValue) ? [] : [cellValue];\n    }\n\n    return {\n        field,\n        cellValue\n    };\n}\n"]}
@@ -1,6 +1,5 @@
1
1
  import { AITableQueries, FieldModelMap } from '@ai-table/grid';
2
2
  import { sortByViewPosition } from '../common';
3
- // import { FieldModelMap } from '../../../../grid/src/utils/field/field';
4
3
  export function getSortRecords(aiTable, records, activeView, sortKeysMap) {
5
4
  if (!activeView?.settings || !activeView.settings.sorts?.length) {
6
5
  return sortByViewPosition(records, activeView);
@@ -36,4 +35,4 @@ export function sortRecordsBySortInfo(aiTable, records, activeView, sortKeysMap)
36
35
  }
37
36
  return shallowRows;
38
37
  }
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0YXRlL3NyYy91dGlscy9yZWNvcmQvc29ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQVcsY0FBYyxFQUFFLGFBQWEsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUMvQywwRUFBMEU7QUFFMUUsTUFBTSxVQUFVLGNBQWMsQ0FDMUIsT0FBZ0IsRUFDaEIsT0FBMkIsRUFDM0IsVUFBdUIsRUFDdkIsV0FBdUQ7SUFFdkQsSUFBSSxDQUFDLFVBQVUsRUFBRSxRQUFRLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUM5RCxPQUFPLGtCQUFrQixDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBQ0QsTUFBTSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDO0lBQ3BELElBQUksWUFBWSxJQUFJLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUNoQyxPQUFPLHFCQUFxQixDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQzVFLENBQUM7SUFDRCxPQUFPLGtCQUFrQixDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQztBQUNuRCxDQUFDO0FBRUQsTUFBTSxVQUFVLHFCQUFxQixDQUNqQyxPQUFnQixFQUNoQixPQUEyQixFQUMzQixVQUF1QixFQUN2QixXQUF1RDtJQUV2RCxNQUFNLFdBQVcsR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUM7SUFDakMsSUFBSSxVQUFVLENBQUMsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUNyQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQy9CLE9BQU8sVUFBVSxDQUFDLFFBQVMsQ0FBQyxLQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxFQUFFO2dCQUNwRCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsU0FBUyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUNoRCxJQUFJLENBQUMsS0FBSyxJQUFJLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQztvQkFDdEIsT0FBTyxHQUFHLENBQUM7Z0JBQ2YsQ0FBQztnQkFDRCxNQUFNLFdBQVcsR0FBRyxhQUFhLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUM5QyxNQUFNLE9BQU8sR0FBRyxXQUFXLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBRTFDLE1BQU0sVUFBVSxHQUFHLGNBQWMsQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztnQkFDaEYsTUFBTSxVQUFVLEdBQUcsY0FBYyxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2dCQUNuRixNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsT0FBUSxDQUFDLFVBQVUsRUFBRSxDQUFDO2dCQUNqRCxNQUFNLEdBQUcsR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRTtvQkFDekUsT0FBTztvQkFDUCxLQUFLO2lCQUNSLENBQUMsQ0FBQztnQkFDSCxPQUFPLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ2hDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNWLENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxXQUFXLENBQUM7SUFDdkIsQ0FBQztJQUNELE9BQU8sV0FBVyxDQUFDO0FBQ3ZCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBSVRhYmxlRmllbGRUeXBlLCBBSVRhYmxlVmlldywgQUlUYWJsZVZpZXdSZWNvcmRzIH0gZnJvbSAnQGFpLXRhYmxlL3V0aWxzJztcbmltcG9ydCB7IEFJVGFibGUsIEFJVGFibGVRdWVyaWVzLCBGaWVsZE1vZGVsTWFwIH0gZnJvbSAnQGFpLXRhYmxlL2dyaWQnO1xuaW1wb3J0IHsgc29ydEJ5Vmlld1Bvc2l0aW9uIH0gZnJvbSAnLi4vY29tbW9uJztcbi8vIGltcG9ydCB7IEZpZWxkTW9kZWxNYXAgfSBmcm9tICcuLi8uLi8uLi8uLi9ncmlkL3NyYy91dGlscy9maWVsZC9maWVsZCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRTb3J0UmVjb3JkcyhcbiAgICBhaVRhYmxlOiBBSVRhYmxlLFxuICAgIHJlY29yZHM6IEFJVGFibGVWaWV3UmVjb3JkcyxcbiAgICBhY3RpdmVWaWV3OiBBSVRhYmxlVmlldyxcbiAgICBzb3J0S2V5c01hcD86IFBhcnRpYWw8UmVjb3JkPEFJVGFibGVGaWVsZFR5cGUsIHN0cmluZz4+XG4pIHtcbiAgICBpZiAoIWFjdGl2ZVZpZXc/LnNldHRpbmdzIHx8ICFhY3RpdmVWaWV3LnNldHRpbmdzLnNvcnRzPy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIHNvcnRCeVZpZXdQb3NpdGlvbihyZWNvcmRzLCBhY3RpdmVWaWV3KTtcbiAgICB9XG4gICAgY29uc3QgeyBpc19rZWVwX3NvcnQsIHNvcnRzIH0gPSBhY3RpdmVWaWV3LnNldHRpbmdzO1xuICAgIGlmIChpc19rZWVwX3NvcnQgJiYgc29ydHM/Lmxlbmd0aCkge1xuICAgICAgICByZXR1cm4gc29ydFJlY29yZHNCeVNvcnRJbmZvKGFpVGFibGUsIHJlY29yZHMsIGFjdGl2ZVZpZXcsIHNvcnRLZXlzTWFwKTtcbiAgICB9XG4gICAgcmV0dXJuIHNvcnRCeVZpZXdQb3NpdGlvbihyZWNvcmRzLCBhY3RpdmVWaWV3KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNvcnRSZWNvcmRzQnlTb3J0SW5mbyhcbiAgICBhaVRhYmxlOiBBSVRhYmxlLFxuICAgIHJlY29yZHM6IEFJVGFibGVWaWV3UmVjb3JkcyxcbiAgICBhY3RpdmVWaWV3OiBBSVRhYmxlVmlldyxcbiAgICBzb3J0S2V5c01hcD86IFBhcnRpYWw8UmVjb3JkPEFJVGFibGVGaWVsZFR5cGUsIHN0cmluZz4+XG4pIHtcbiAgICBjb25zdCBzaGFsbG93Um93cyA9IFsuLi5yZWNvcmRzXTtcbiAgICBpZiAoYWN0aXZlVmlldy5zZXR0aW5ncz8uc29ydHM/Lmxlbmd0aCkge1xuICAgICAgICBzaGFsbG93Um93cy5zb3J0KChwcmV2LCBjdXJyZW50KSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gYWN0aXZlVmlldy5zZXR0aW5ncyEuc29ydHMhLnJlZHVjZSgoYWNjLCBydWxlKSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgZmllbGQgPSBhaVRhYmxlLmZpZWxkc01hcCgpW3J1bGUuc29ydF9ieV07XG4gICAgICAgICAgICAgICAgaWYgKCFmaWVsZCB8fCBhY2MgIT09IDApIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgY29uc3QgZmllbGRNZXRob2QgPSBGaWVsZE1vZGVsTWFwW2ZpZWxkLnR5cGVdO1xuICAgICAgICAgICAgICAgIGNvbnN0IHNvcnRLZXkgPSBzb3J0S2V5c01hcD8uW2ZpZWxkLnR5cGVdO1xuXG4gICAgICAgICAgICAgICAgY29uc3QgY2VsbFZhbHVlMSA9IEFJVGFibGVRdWVyaWVzLmdldEZpZWxkVmFsdWUoYWlUYWJsZSwgW3ByZXYuX2lkLCBmaWVsZC5faWRdKTtcbiAgICAgICAgICAgICAgICBjb25zdCBjZWxsVmFsdWUyID0gQUlUYWJsZVF1ZXJpZXMuZ2V0RmllbGRWYWx1ZShhaVRhYmxlLCBbY3VycmVudC5faWQsIGZpZWxkLl9pZF0pO1xuICAgICAgICAgICAgICAgIGNvbnN0IHJlZmVyZW5jZXMgPSBhaVRhYmxlLmNvbnRleHQhLnJlZmVyZW5jZXMoKTtcbiAgICAgICAgICAgICAgICBjb25zdCByZXMgPSBmaWVsZE1ldGhvZC5jb21wYXJlKGNlbGxWYWx1ZTEsIGNlbGxWYWx1ZTIsIHJlZmVyZW5jZXMsIHNvcnRLZXksIHtcbiAgICAgICAgICAgICAgICAgICAgYWlUYWJsZSxcbiAgICAgICAgICAgICAgICAgICAgZmllbGRcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICByZXR1cm4gcmVzICogcnVsZS5kaXJlY3Rpb247XG4gICAgICAgICAgICB9LCAwKTtcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiBzaGFsbG93Um93cztcbiAgICB9XG4gICAgcmV0dXJuIHNoYWxsb3dSb3dzO1xufVxuIl19
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3N0YXRlL3NyYy91dGlscy9yZWNvcmQvc29ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQVcsY0FBYyxFQUFFLGFBQWEsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUUvQyxNQUFNLFVBQVUsY0FBYyxDQUMxQixPQUFnQixFQUNoQixPQUEyQixFQUMzQixVQUF1QixFQUN2QixXQUF1RDtJQUV2RCxJQUFJLENBQUMsVUFBVSxFQUFFLFFBQVEsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQzlELE9BQU8sa0JBQWtCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFDRCxNQUFNLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUM7SUFDcEQsSUFBSSxZQUFZLElBQUksS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ2hDLE9BQU8scUJBQXFCLENBQUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDNUUsQ0FBQztJQUNELE9BQU8sa0JBQWtCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBQ25ELENBQUM7QUFFRCxNQUFNLFVBQVUscUJBQXFCLENBQ2pDLE9BQWdCLEVBQ2hCLE9BQTJCLEVBQzNCLFVBQXVCLEVBQ3ZCLFdBQXVEO0lBRXZELE1BQU0sV0FBVyxHQUFHLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQztJQUNqQyxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ3JDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUU7WUFDL0IsT0FBTyxVQUFVLENBQUMsUUFBUyxDQUFDLEtBQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEVBQUU7Z0JBQ3BELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQ2hELElBQUksQ0FBQyxLQUFLLElBQUksR0FBRyxLQUFLLENBQUMsRUFBRSxDQUFDO29CQUN0QixPQUFPLEdBQUcsQ0FBQztnQkFDZixDQUFDO2dCQUNELE1BQU0sV0FBVyxHQUFHLGFBQWEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQzlDLE1BQU0sT0FBTyxHQUFHLFdBQVcsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFFMUMsTUFBTSxVQUFVLEdBQUcsY0FBYyxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2dCQUNoRixNQUFNLFVBQVUsR0FBRyxjQUFjLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7Z0JBQ25GLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFRLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQ2pELE1BQU0sR0FBRyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFO29CQUN6RSxPQUFPO29CQUNQLEtBQUs7aUJBQ1IsQ0FBQyxDQUFDO2dCQUNILE9BQU8sR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDaEMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ1YsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLFdBQVcsQ0FBQztJQUN2QixDQUFDO0lBQ0QsT0FBTyxXQUFXLENBQUM7QUFDdkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFJVGFibGVGaWVsZFR5cGUsIEFJVGFibGVWaWV3LCBBSVRhYmxlVmlld1JlY29yZHMgfSBmcm9tICdAYWktdGFibGUvdXRpbHMnO1xuaW1wb3J0IHsgQUlUYWJsZSwgQUlUYWJsZVF1ZXJpZXMsIEZpZWxkTW9kZWxNYXAgfSBmcm9tICdAYWktdGFibGUvZ3JpZCc7XG5pbXBvcnQgeyBzb3J0QnlWaWV3UG9zaXRpb24gfSBmcm9tICcuLi9jb21tb24nO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U29ydFJlY29yZHMoXG4gICAgYWlUYWJsZTogQUlUYWJsZSxcbiAgICByZWNvcmRzOiBBSVRhYmxlVmlld1JlY29yZHMsXG4gICAgYWN0aXZlVmlldzogQUlUYWJsZVZpZXcsXG4gICAgc29ydEtleXNNYXA/OiBQYXJ0aWFsPFJlY29yZDxBSVRhYmxlRmllbGRUeXBlLCBzdHJpbmc+PlxuKSB7XG4gICAgaWYgKCFhY3RpdmVWaWV3Py5zZXR0aW5ncyB8fCAhYWN0aXZlVmlldy5zZXR0aW5ncy5zb3J0cz8ubGVuZ3RoKSB7XG4gICAgICAgIHJldHVybiBzb3J0QnlWaWV3UG9zaXRpb24ocmVjb3JkcywgYWN0aXZlVmlldyk7XG4gICAgfVxuICAgIGNvbnN0IHsgaXNfa2VlcF9zb3J0LCBzb3J0cyB9ID0gYWN0aXZlVmlldy5zZXR0aW5ncztcbiAgICBpZiAoaXNfa2VlcF9zb3J0ICYmIHNvcnRzPy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIHNvcnRSZWNvcmRzQnlTb3J0SW5mbyhhaVRhYmxlLCByZWNvcmRzLCBhY3RpdmVWaWV3LCBzb3J0S2V5c01hcCk7XG4gICAgfVxuICAgIHJldHVybiBzb3J0QnlWaWV3UG9zaXRpb24ocmVjb3JkcywgYWN0aXZlVmlldyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzb3J0UmVjb3Jkc0J5U29ydEluZm8oXG4gICAgYWlUYWJsZTogQUlUYWJsZSxcbiAgICByZWNvcmRzOiBBSVRhYmxlVmlld1JlY29yZHMsXG4gICAgYWN0aXZlVmlldzogQUlUYWJsZVZpZXcsXG4gICAgc29ydEtleXNNYXA/OiBQYXJ0aWFsPFJlY29yZDxBSVRhYmxlRmllbGRUeXBlLCBzdHJpbmc+PlxuKSB7XG4gICAgY29uc3Qgc2hhbGxvd1Jvd3MgPSBbLi4ucmVjb3Jkc107XG4gICAgaWYgKGFjdGl2ZVZpZXcuc2V0dGluZ3M/LnNvcnRzPy5sZW5ndGgpIHtcbiAgICAgICAgc2hhbGxvd1Jvd3Muc29ydCgocHJldiwgY3VycmVudCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIGFjdGl2ZVZpZXcuc2V0dGluZ3MhLnNvcnRzIS5yZWR1Y2UoKGFjYywgcnVsZSkgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnN0IGZpZWxkID0gYWlUYWJsZS5maWVsZHNNYXAoKVtydWxlLnNvcnRfYnldO1xuICAgICAgICAgICAgICAgIGlmICghZmllbGQgfHwgYWNjICE9PSAwKSB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBhY2M7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGNvbnN0IGZpZWxkTWV0aG9kID0gRmllbGRNb2RlbE1hcFtmaWVsZC50eXBlXTtcbiAgICAgICAgICAgICAgICBjb25zdCBzb3J0S2V5ID0gc29ydEtleXNNYXA/LltmaWVsZC50eXBlXTtcblxuICAgICAgICAgICAgICAgIGNvbnN0IGNlbGxWYWx1ZTEgPSBBSVRhYmxlUXVlcmllcy5nZXRGaWVsZFZhbHVlKGFpVGFibGUsIFtwcmV2Ll9pZCwgZmllbGQuX2lkXSk7XG4gICAgICAgICAgICAgICAgY29uc3QgY2VsbFZhbHVlMiA9IEFJVGFibGVRdWVyaWVzLmdldEZpZWxkVmFsdWUoYWlUYWJsZSwgW2N1cnJlbnQuX2lkLCBmaWVsZC5faWRdKTtcbiAgICAgICAgICAgICAgICBjb25zdCByZWZlcmVuY2VzID0gYWlUYWJsZS5jb250ZXh0IS5yZWZlcmVuY2VzKCk7XG4gICAgICAgICAgICAgICAgY29uc3QgcmVzID0gZmllbGRNZXRob2QuY29tcGFyZShjZWxsVmFsdWUxLCBjZWxsVmFsdWUyLCByZWZlcmVuY2VzLCBzb3J0S2V5LCB7XG4gICAgICAgICAgICAgICAgICAgIGFpVGFibGUsXG4gICAgICAgICAgICAgICAgICAgIGZpZWxkXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHJlcyAqIHJ1bGUuZGlyZWN0aW9uO1xuICAgICAgICAgICAgfSwgMCk7XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gc2hhbGxvd1Jvd3M7XG4gICAgfVxuICAgIHJldHVybiBzaGFsbG93Um93cztcbn1cbiJdfQ==
@@ -1,12 +1,12 @@
1
1
  import * as Y from 'yjs';
2
2
  import { UndoManager } from 'yjs';
3
- import { getShareTypeNumberPath, ActionName, translateArrayEvent, getSharedRecordIndex, getSharedMapValueIndex, toMapSyncElement, getIdBySystemFieldValuesType, setRecordUpdatedInfo, getPositionsByRecordSyncElement, setRecordPositions as setRecordPositions$1, toRecordSyncElement, AI_TABLE_CONTENT_FIELD_NAME, getIdBySystemFieldValues, getShortIdBySystemFieldValues, getTrackableEntityBySystemFieldValues, getPositionsBySystemFieldValues, getValuesByCustomFieldValues, AITableFilterLogical, AITableFilterOperation, AITableFieldType, Direction } from '@ai-table/utils';
3
+ import { getShareTypeNumberPath, ActionName, translateArrayEvent, getSharedRecordIndex, getSharedMapValueIndex, toMapSyncElement, getIdBySystemFieldValuesType, setRecordUpdatedInfo, getPositionsByRecordSyncElement, setRecordPositions as setRecordPositions$1, toRecordSyncElement, AI_TABLE_CONTENT_FIELD_NAME, getIdBySystemFieldValues, getShortIdBySystemFieldValues, getTrackableEntityBySystemFieldValues, getPositionsBySystemFieldValues, getValuesByCustomFieldValues, AITableFilterLogical, AITableFilterOperation, AITableFieldType, isEmpty } from '@ai-table/utils';
4
4
  import * as i0 from '@angular/core';
5
5
  import { signal, Injectable } from '@angular/core';
6
6
  import { FieldModelMap, AITableQueries, isSystemField, getDefaultFieldValue, idCreator, shortIdCreator, generateNewName, idsCreator, shortIdsCreator, AI_TABLE_GRID_FIELD_SERVICE_MAP, AITable, isMac, buildClipboardData, writeToClipboard, getI18nTextByKey, AITableGridI18nKey, writeToAITable } from '@ai-table/grid';
7
- import * as _ from 'lodash';
8
- import ___default, { isEmpty } from 'lodash';
9
7
  import { createDraft, finishDraft } from 'immer';
8
+ import * as _ from 'lodash';
9
+ import ___default from 'lodash';
10
10
 
11
11
  const IS_LOCAL = new WeakSet();
12
12
  const IS_REMOTE = new WeakSet();
@@ -459,7 +459,6 @@ function generateCopyName(aiTable, existNames, name) {
459
459
  return newName;
460
460
  }
461
461
 
462
- // import { FieldModelMap } from '../../../../grid/src/utils/field/field';
463
462
  function getSortRecords(aiTable, records, activeView, sortKeysMap) {
464
463
  if (!activeView?.settings || !activeView.settings.sorts?.length) {
465
464
  return sortByViewPosition(records, activeView);
@@ -665,12 +664,12 @@ function getFieldsSizeMap(fields, activeView) {
665
664
  return fieldsSizeMap;
666
665
  }
667
666
 
668
- function addField(aiTable, field, originId, isCopy) {
667
+ function addField(aiTable, field, originId, isDuplicate) {
669
668
  const operation = {
670
669
  type: ActionName.AddField,
671
670
  field,
672
671
  originId,
673
- isCopy
672
+ isDuplicate
674
673
  };
675
674
  const existField = aiTable.fields().some((item) => {
676
675
  return item._id === field._id;
@@ -771,7 +770,7 @@ const apply = (aiTable, records, fields, views, action) => {
771
770
  fields.push(newField);
772
771
  records.forEach((item) => {
773
772
  item.values[newField._id] =
774
- action.isCopy && action.originId ? item.values[action.originId] : getDefaultFieldValue(action.field);
773
+ action.isDuplicate && action.originId ? item.values[action.originId] : getDefaultFieldValue(action.field);
775
774
  });
776
775
  break;
777
776
  }
@@ -1029,13 +1028,6 @@ const Actions = {
1029
1028
  ...PositionsActions
1030
1029
  };
1031
1030
 
1032
- function updateRecordsUpdatedInfo(aiTable, updatedInfo) {
1033
- const records = aiTable.records();
1034
- records.forEach((item) => {
1035
- Actions.updateSystemFieldValue(aiTable, [item._id], updatedInfo);
1036
- });
1037
- }
1038
-
1039
1031
  function createDefaultPositions(views, activeId, data, index) {
1040
1032
  const positions = {};
1041
1033
  const position = getPosition(data, activeId, index);
@@ -1126,7 +1118,7 @@ function sortViews(data) {
1126
1118
  }
1127
1119
 
1128
1120
  function addFields(aiTable, options, updatedInfo) {
1129
- const { defaultValue, isDuplicate, isCopy } = options;
1121
+ const { defaultValue, isDuplicate, originId } = options;
1130
1122
  const fields = aiTable.gridData().fields;
1131
1123
  const fieldsMap = aiTable.fieldsMap();
1132
1124
  const activeViewId = aiTable.activeViewId();
@@ -1135,7 +1127,7 @@ function addFields(aiTable, options, updatedInfo) {
1135
1127
  newField._id = idCreator();
1136
1128
  }
1137
1129
  if (isDuplicate) {
1138
- const currentFieldIndex = fields.findIndex((item) => item._id === options.originId);
1130
+ const currentFieldIndex = fields.findIndex((item) => item._id === originId);
1139
1131
  newField.positions = {
1140
1132
  ...newField.positions,
1141
1133
  [activeViewId]: getPosition(fields, activeViewId, currentFieldIndex + 1)
@@ -1144,8 +1136,7 @@ function addFields(aiTable, options, updatedInfo) {
1144
1136
  else {
1145
1137
  newField.positions = createDefaultPositions(aiTable.views(), aiTable.activeViewId(), aiTable.gridData().fields, fields.length);
1146
1138
  }
1147
- Actions.addField(aiTable, newField, options.originId, isCopy || isDuplicate);
1148
- updateRecordsUpdatedInfo(aiTable, updatedInfo);
1139
+ Actions.addField(aiTable, newField, originId, isDuplicate);
1149
1140
  }
1150
1141
 
1151
1142
  const buildRemoveFieldItem = (aiTable, getUpdatedInfo) => {
@@ -1155,24 +1146,16 @@ const buildRemoveFieldItem = (aiTable, getUpdatedInfo) => {
1155
1146
  icon: 'trash',
1156
1147
  exec: (aiTable, field) => {
1157
1148
  Actions.removeField(aiTable, [field()._id]);
1158
- updateRecordsUpdatedInfo(aiTable, getUpdatedInfo());
1159
1149
  }
1160
1150
  };
1161
1151
  };
1162
1152
 
1163
- function addRecords(aiTable, options, trackableEntity) {
1164
- const { originId, direction = Direction.after, isDuplicate, count = 1 } = options;
1153
+ function addRecords(aiTable, trackableEntity, options) {
1154
+ const { originId, isDuplicate, count = 1 } = options || {};
1165
1155
  const activeView = aiTable.viewsMap()[aiTable.activeViewId()];
1166
- const records = getSortRecords(aiTable, aiTable.gridData().records, activeView);
1167
- let addIndex = records.findIndex((item) => item._id === originId);
1168
- if (direction === Direction.after) {
1169
- addIndex++;
1170
- }
1171
1156
  const newRecordIds = idsCreator(count);
1172
1157
  const newRecordShortIds = shortIdsCreator(count);
1173
1158
  const newRecordValues = getDefaultRecordValues(aiTable, isDuplicate, originId);
1174
- // TODO: 判断如果存在筛选条件,且 newRecordValues 中没有一项满足筛选条件
1175
- // 把 id 添加到 RECORDS_WILL_HIDDEN 中
1176
1159
  if (activeView.settings?.conditions?.length) {
1177
1160
  aiTable.recordsWillHidden?.update((value) => {
1178
1161
  value.push(...newRecordIds);
@@ -1211,6 +1194,13 @@ function updateFieldValue(aiTable, options, updatedInfo) {
1211
1194
  }
1212
1195
  }
1213
1196
 
1197
+ function updateRecordsUpdatedInfo(aiTable, updatedInfo) {
1198
+ const records = aiTable.records();
1199
+ records.forEach((item) => {
1200
+ Actions.updateSystemFieldValue(aiTable, [item._id], updatedInfo);
1201
+ });
1202
+ }
1203
+
1214
1204
  const FLUSHING = new WeakMap();
1215
1205
 
1216
1206
  function moveFields(aiTable, options, updatedInfo) {