@nocobase/client-v2 2.1.0-alpha.26 → 2.1.0-alpha.27

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 (45) hide show
  1. package/es/BaseApplication.d.ts +1 -0
  2. package/es/flow/actions/dataScopeFilter.d.ts +9 -0
  3. package/es/flow/components/Grid/index.d.ts +5 -3
  4. package/es/flow/components/code-editor/types.d.ts +1 -0
  5. package/es/flow/internal/utils/rebuildFieldSubModel.d.ts +2 -1
  6. package/es/flow/models/base/GridModel.d.ts +19 -2
  7. package/es/flow/models/blocks/filter-form/FilterFormGridModel.d.ts +1 -0
  8. package/es/flow/models/fields/JSFieldModel.d.ts +5 -0
  9. package/es/index.mjs +83 -83
  10. package/lib/index.js +83 -83
  11. package/package.json +5 -5
  12. package/src/BaseApplication.tsx +4 -0
  13. package/src/flow/actions/__tests__/dataScopeFilter.test.ts +158 -0
  14. package/src/flow/actions/dataScope.tsx +6 -4
  15. package/src/flow/actions/dataScopeFilter.ts +70 -0
  16. package/src/flow/actions/setTargetDataScope.tsx +6 -5
  17. package/src/flow/components/Grid/index.tsx +66 -20
  18. package/src/flow/components/code-editor/__tests__/linter.test.ts +18 -0
  19. package/src/flow/components/code-editor/__tests__/runjsDiagnostics.test.ts +23 -0
  20. package/src/flow/components/code-editor/index.tsx +18 -17
  21. package/src/flow/components/code-editor/linter.ts +222 -158
  22. package/src/flow/components/code-editor/runjsDiagnostics.ts +161 -97
  23. package/src/flow/components/code-editor/types.ts +1 -0
  24. package/src/flow/internal/utils/__tests__/rebuildFieldSubModel.test.ts +77 -2
  25. package/src/flow/internal/utils/rebuildFieldSubModel.ts +21 -5
  26. package/src/flow/models/base/BlockGridModel.tsx +2 -2
  27. package/src/flow/models/base/GridModel.tsx +428 -195
  28. package/src/flow/models/base/__tests__/BlockGridModel.dragOverlayConfig.test.ts +44 -0
  29. package/src/flow/models/base/__tests__/GridModel.computeOverlayRect.test.ts +29 -0
  30. package/src/flow/models/base/__tests__/GridModel.dragSnapshotContainer.test.ts +181 -2
  31. package/src/flow/models/base/__tests__/GridModel.resizeLayout.test.ts +124 -0
  32. package/src/flow/models/base/__tests__/GridModel.visibleLayout.test.ts +55 -15
  33. package/src/flow/models/blocks/details/DetailsGridModel.tsx +6 -6
  34. package/src/flow/models/blocks/filter-form/FilterFormBlockModel.tsx +9 -5
  35. package/src/flow/models/blocks/filter-form/FilterFormGridModel.tsx +54 -14
  36. package/src/flow/models/blocks/filter-form/__tests__/FilterFormBlockModel.cleanup.test.ts +138 -0
  37. package/src/flow/models/blocks/filter-form/__tests__/FilterFormGridModel.toggleFormFieldsCollapse.test.ts +45 -0
  38. package/src/flow/models/blocks/form/FormGridModel.tsx +6 -6
  39. package/src/flow/models/blocks/form/__tests__/FormBlockModel.test.tsx +22 -0
  40. package/src/flow/models/blocks/table/JSColumnModel.tsx +30 -2
  41. package/src/flow/models/blocks/table/TableBlockModel.tsx +8 -1
  42. package/src/flow/models/blocks/table/TableColumnModel.tsx +1 -0
  43. package/src/flow/models/blocks/table/__tests__/JSColumnModel.test.tsx +51 -0
  44. package/src/flow/models/blocks/table/__tests__/TableBlockModel.quickEditRefresh.test.ts +49 -0
  45. package/src/flow/models/fields/JSFieldModel.tsx +54 -14
@@ -121,6 +121,7 @@ export declare abstract class BaseApplication<TOptions extends BaseApplicationOp
121
121
  * 注册两边共享的默认 providers。
122
122
  */
123
123
  protected addBaseProviders(): void;
124
+ protected addFinalProviders(): void;
124
125
  addReactRouterComponents(): void;
125
126
  addRoutes(): void;
126
127
  updateFavicon(favicon?: string): void;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * This file is part of the NocoBase (R) project.
3
+ * Copyright (c) 2020-2024 NocoBase Co., Ltd.
4
+ * Authors: NocoBase Team.
5
+ *
6
+ * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
+ * For more information, please refer to: https://www.nocobase.com/agreement.
8
+ */
9
+ export declare function normalizeDataScopeFilter(rawFilter: any, resolvedFilter: any): any;
@@ -6,21 +6,23 @@
6
6
  * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
7
  * For more information, please refer to: https://www.nocobase.com/agreement.
8
8
  */
9
+ import { GridLayoutV2 } from '@nocobase/flow-engine';
9
10
  import React from 'react';
10
11
  interface DragOverlayRect {
11
12
  readonly top: number;
12
13
  readonly left: number;
13
14
  readonly width: number;
14
15
  readonly height: number;
15
- readonly type: 'column' | 'column-edge' | 'row-gap' | 'empty-row' | 'empty-column';
16
+ readonly type: 'column' | 'column-edge' | 'row-gap' | 'empty-row' | 'empty-column' | 'item-edge';
16
17
  }
17
18
  interface GridProps {
18
- readonly rows: Record<string, string[][]>;
19
+ readonly rows?: Record<string, string[][]>;
19
20
  readonly sizes?: Record<string, number[]>;
21
+ readonly layout?: GridLayoutV2;
20
22
  readonly renderItem: (uid: string) => React.ReactNode;
21
23
  readonly rowGap?: number;
22
24
  readonly colGap?: number;
23
25
  readonly dragOverlayRect?: DragOverlayRect | null;
24
26
  }
25
- export declare function Grid({ rows, sizes, renderItem, rowGap, colGap, dragOverlayRect }: GridProps): React.JSX.Element;
27
+ export declare function Grid({ rows, sizes, layout, renderItem, rowGap, colGap, dragOverlayRect, }: GridProps): React.JSX.Element;
26
28
  export {};
@@ -15,6 +15,7 @@ import { RunLog } from './hooks/useCodeRunner';
15
15
  export interface EditorRef {
16
16
  write(document: string): void;
17
17
  read(): string;
18
+ run?(): Promise<unknown>;
18
19
  buttonGroupHeight?: number;
19
20
  snippetEntries: SnippetEntry[];
20
21
  logs: RunLog[];
@@ -9,8 +9,9 @@
9
9
  /**
10
10
  * 通用的字段子模型重建工具:
11
11
  * - 保留原有 uid
12
- * - 通过 FieldModel 入口 + fieldBinding.use 动态选择目标字段类
12
+ * - 直接重建为目标字段类,保持与 defineChildren 初始创建逻辑一致
13
13
  * - 支持同步父项模式(pattern)
14
+ * - 同一字段模型类型下保留已有字段设置;切换到其他字段模型类型时丢弃不兼容设置
14
15
  * - 重建后触发 beforeRender(useCache: false)
15
16
  */
16
17
  import { FieldModel } from '../../models/base/FieldModel';
@@ -7,8 +7,8 @@
7
7
  * For more information, please refer to: https://www.nocobase.com/agreement.
8
8
  */
9
9
  import { DragCancelEvent, DragEndEvent, DragMoveEvent, DragStartEvent } from '@dnd-kit/core';
10
- import { DragOverlayConfig, FlowModel, GridLayoutData } from '@nocobase/flow-engine';
11
10
  import type { FlowModelRendererProps } from '@nocobase/flow-engine';
11
+ import { DragOverlayConfig, FlowModel, GridLayoutData, GridLayoutV2 } from '@nocobase/flow-engine';
12
12
  import React from 'react';
13
13
  export declare const GRID_FLOW_KEY = "gridSettings";
14
14
  export declare const GRID_STEP = "grid";
@@ -33,6 +33,9 @@ export declare class GridModel<T extends {
33
33
  private readonly itemExtraToolbarItems;
34
34
  private dragState?;
35
35
  private _memoItemFlowSettings?;
36
+ private updateDragPointerPosition;
37
+ private handleDragScroll;
38
+ private bindDragDocumentListeners;
36
39
  protected deriveRowOrder(rows: Record<string, string[][]>, provided?: string[]): string[];
37
40
  normalizeRowsWithOrder(rows: Record<string, string[][]>, provided?: string[]): {
38
41
  rows: Record<string, string[][]>;
@@ -40,18 +43,32 @@ export declare class GridModel<T extends {
40
43
  };
41
44
  orderSizesByRowOrder(sizes: Record<string, number[]>, rowOrder: string[]): Record<string, number[]>;
42
45
  private getItemFlowSettings;
46
+ getItemUids(): string[];
47
+ protected normalizeLayoutFromSource(source?: Partial<GridLayoutData>): GridLayoutV2;
48
+ getGridLayout(): GridLayoutV2;
49
+ syncLayoutProps(layout: GridLayoutV2): void;
50
+ setGridStepLayout(layout: GridLayoutV2): void;
51
+ private findLayoutRowByPath;
52
+ private collectCellItemsForResize;
53
+ private buildResizedCells;
54
+ private getResizeRowPath;
55
+ private getResizeContainerWidth;
56
+ private resizeGridLayout;
43
57
  onMount(): void;
44
- saveGridLayout(layout?: GridLayoutData): void;
58
+ saveGridLayout(layout?: GridLayoutData | GridLayoutV2): void;
45
59
  mergeRowsWithItems(rows: Record<string, string[][]>): Record<string, string[][]>;
46
60
  resetRows(syncProps?: boolean): void;
47
61
  private computePointerPosition;
48
62
  private getDragContainer;
49
63
  private updateLayoutSnapshot;
50
64
  private scheduleSnapshotRefresh;
65
+ private refreshPreviewFromPointer;
51
66
  /**
52
67
  * 根据 slot 类型、位置和配置计算最终的 overlay 尺寸和位置
53
68
  */
54
69
  private computeOverlayRect;
70
+ private getHitTestSlot;
71
+ private resolveDragSlot;
55
72
  private applyPreview;
56
73
  handleDragStart(event: DragStartEvent): void;
57
74
  handleDragMove(event: DragMoveEvent): void;
@@ -11,6 +11,7 @@ import React from 'react';
11
11
  import { GridModel } from '../../base';
12
12
  import { FilterFormItemModel } from './FilterFormItemModel';
13
13
  export declare class FilterFormGridModel extends GridModel {
14
+ private fullLayoutBeforeCollapse?;
14
15
  itemSettingsMenuLevel: number;
15
16
  itemFlowSettings: {
16
17
  showBackground: boolean;
@@ -17,6 +17,9 @@ import { FieldModel } from '../base/FieldModel';
17
17
  */
18
18
  export declare class JSFieldModel extends FieldModel {
19
19
  private _mountedOnce;
20
+ private _lastRenderedElement?;
21
+ private _pendingRenderedElement?;
22
+ private _lastRunJs?;
20
23
  getInputArgs(): {
21
24
  collectionName: any;
22
25
  associationName: string;
@@ -36,6 +39,8 @@ export declare class JSFieldModel extends FieldModel {
36
39
  /**
37
40
  * 渲染一个占位容器,供 JS 脚本写入内容
38
41
  */
42
+ private getRunJsCode;
43
+ private refreshRenderedElement;
39
44
  render(): React.JSX.Element;
40
45
  /**
41
46
  * 组件挂载后,如果容器引用已就绪,强制重跑一次 beforeRender flows 以把 HTML 写入当前 DOM。