@univerjs/engine-render 0.2.3 → 0.2.4

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.
@@ -12,13 +12,18 @@ export interface ISkeletonResourceReference {
12
12
  skeHeaders: Map<string, Map<number, IDocumentSkeletonHeaderFooter>>;
13
13
  skeFooters: Map<string, Map<number, IDocumentSkeletonHeaderFooter>>;
14
14
  skeListLevel?: Map<string, IDocumentSkeletonBullet[]>;
15
- drawingAnchor?: Map<number, IDocumentSkeletonDrawingAnchor>;
15
+ drawingAnchor?: Map<string, Map<number, IDocumentSkeletonDrawingAnchor>>;
16
16
  }
17
17
  export interface IDocumentSkeletonDrawingAnchor {
18
18
  elements: IDocumentSkeletonLine[];
19
19
  paragraphIndex: number;
20
20
  top: number;
21
21
  }
22
+ export declare enum DocumentSkeletonPageType {
23
+ BODY = 0,
24
+ HEADER = 1,
25
+ FOOTER = 2
26
+ }
22
27
  export interface IDocumentSkeletonPage {
23
28
  sections: IDocumentSkeletonSection[];
24
29
  headerId: string;
@@ -42,6 +47,8 @@ export interface IDocumentSkeletonPage {
42
47
  st: number;
43
48
  ed: number;
44
49
  skeDrawings: Map<string, IDocumentSkeletonDrawing>;
50
+ segmentId: string;
51
+ type: DocumentSkeletonPageType;
45
52
  renderConfig?: IDocumentRenderConfig;
46
53
  parent?: IDocumentSkeletonCached;
47
54
  }
@@ -1,6 +1,6 @@
1
1
  import { BooleanNumber, GridType, IDocStyleBase, IDocumentLayout, IOffset, IParagraphStyle, IReferenceSource, IScale, ISectionBreakBase, ISize, ITextStyle, ITransformState, LocaleService } from '@univerjs/core';
2
2
  import { DocumentViewModel } from '../components/docs/view-model/document-view-model';
3
- import { IDocumentSkeletonBullet, IDocumentSkeletonDrawing, IDocumentSkeletonDrawingAnchor, IDocumentSkeletonFontStyle, IDocumentSkeletonGlyph, IDocumentSkeletonHeaderFooter } from './i-document-skeleton-cached';
3
+ import { DocumentSkeletonPageType, IDocumentSkeletonBullet, IDocumentSkeletonDrawing, IDocumentSkeletonDrawingAnchor, IDocumentSkeletonFontStyle, IDocumentSkeletonGlyph, IDocumentSkeletonHeaderFooter } from './i-document-skeleton-cached';
4
4
  import { Vector2 } from './vector2';
5
5
  import { ITransformerConfig } from './transformer-config';
6
6
 
@@ -64,7 +64,7 @@ export interface IParagraphConfig {
64
64
  paragraphStyle?: IParagraphStyle;
65
65
  skeHeaders: Map<string, Map<number, IDocumentSkeletonHeaderFooter>>;
66
66
  skeFooters: Map<string, Map<number, IDocumentSkeletonHeaderFooter>>;
67
- drawingAnchor?: Map<number, IDocumentSkeletonDrawingAnchor>;
67
+ pDrawingAnchor?: Map<number, IDocumentSkeletonDrawingAnchor>;
68
68
  }
69
69
  export interface IFontCreateConfig {
70
70
  fontStyle: IDocumentSkeletonFontStyle;
@@ -89,7 +89,7 @@ export interface INodeSearch {
89
89
  section: number;
90
90
  page: number;
91
91
  segmentPage: number;
92
- isInBody: boolean;
92
+ pageType: DocumentSkeletonPageType;
93
93
  }
94
94
  export interface INodePosition extends INodeSearch {
95
95
  isBack: boolean;
@@ -87,6 +87,8 @@ export declare function mergeInfoOffset(mergeInfo: IRangeWithCoord, offsetX: num
87
87
  endAbsoluteRefType?: import('@univerjs/core').AbsoluteRefType;
88
88
  startRow: number;
89
89
  endRow: number;
90
+ unitId?: string;
91
+ sheetId?: string;
90
92
  startColumn: number;
91
93
  endColumn: number;
92
94
  };
@@ -11,6 +11,11 @@ export declare enum DocumentSkeletonState {
11
11
  READY = "ready",
12
12
  INVALID = "invalid"
13
13
  }
14
+ export interface IFindNodeRestrictions {
15
+ strict: boolean;
16
+ segmentId: string;
17
+ segmentPage: number;
18
+ }
14
19
  export declare class DocumentSkeleton extends Skeleton {
15
20
  private _docViewModel;
16
21
  private _skeletonData;
@@ -39,7 +44,8 @@ export declare class DocumentSkeleton extends Skeleton {
39
44
  pageNumber: number;
40
45
  page: Nullable<IDocumentSkeletonPage>;
41
46
  };
42
- findNodeByCoord(coord: Vector2, pageLayoutType: PageLayoutType, pageMarginLeft: number, pageMarginTop: number): Nullable<INodeInfo>;
47
+ findNodeByCoord(coord: Vector2, pageLayoutType: PageLayoutType, pageMarginLeft: number, pageMarginTop: number, restrictions?: IFindNodeRestrictions): Nullable<INodeInfo>;
48
+ private _collectNearestNode;
43
49
  private _getNearestNode;
44
50
  private _getPageBoundingBox;
45
51
  private _translatePage;
@@ -14,6 +14,7 @@ export declare class LineBreaker implements IBreakPoints {
14
14
  private _lastPos;
15
15
  private _curClass;
16
16
  private _codePoint;
17
+ private _lastCodePoint;
17
18
  private _nextClass;
18
19
  private _LB8a;
19
20
  private _LB21a;
@@ -1,23 +1,10 @@
1
- /**
2
- * Copyright 2023-present DreamNum Inc.
3
- *
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * http://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
1
+ import { Nullable } from '@univerjs/core';
2
+
16
3
  export interface ILineBreakRule {
17
- (codePoint: number, className: number): boolean;
4
+ (codePoint: number, lastCodePoint: Nullable<number>, className: number): boolean;
18
5
  }
19
6
  export declare class Rule {
20
7
  private _rules;
21
8
  add(key: string, rule: ILineBreakRule): void;
22
- shouldBreak(codePoint: number, className: number): boolean;
9
+ shouldBreak(codePoint: number, lastCodePoint: Nullable<number>, className: number): boolean;
23
10
  }
@@ -1,4 +1,5 @@
1
- import { IDocumentSkeletonDivide, IDocumentSkeletonDrawing, IDocumentSkeletonDrawingAnchor, IDocumentSkeletonLine, LineType } from '../../../../basics/i-document-skeleton-cached';
1
+ import { Nullable } from '@univerjs/core';
2
+ import { IDocumentSkeletonDivide, IDocumentSkeletonDrawing, IDocumentSkeletonDrawingAnchor, IDocumentSkeletonLine, IDocumentSkeletonPage, LineType } from '../../../../basics/i-document-skeleton-cached';
2
3
 
3
4
  interface ILineBoundingBox {
4
5
  lineHeight: number;
@@ -11,8 +12,8 @@ interface ILineBoundingBox {
11
12
  marginTop?: number;
12
13
  spaceBelowApply?: number;
13
14
  }
14
- export declare function createSkeletonLine(paragraphIndex: number, lineType: LineType, lineBoundingBox: ILineBoundingBox, columnWidth: number, lineIndex?: number, isParagraphStart?: boolean, pageSkeDrawings?: Map<string, IDocumentSkeletonDrawing>, headersDrawings?: Map<string, IDocumentSkeletonDrawing>, footersDrawings?: Map<string, IDocumentSkeletonDrawing>): IDocumentSkeletonLine;
15
- export declare function calculateLineTopByDrawings(lineHeight?: number, lineTop?: number, pageSkeDrawings?: Map<string, IDocumentSkeletonDrawing>, headersDrawings?: Map<string, IDocumentSkeletonDrawing>, footersDrawings?: Map<string, IDocumentSkeletonDrawing>): number;
15
+ export declare function createSkeletonLine(paragraphIndex: number, lineType: LineType, lineBoundingBox: ILineBoundingBox, columnWidth: number, lineIndex: number | undefined, isParagraphStart: boolean | undefined, page: IDocumentSkeletonPage, headerPage: Nullable<IDocumentSkeletonPage>, footerPage: Nullable<IDocumentSkeletonPage>): IDocumentSkeletonLine;
16
+ export declare function calculateLineTopByDrawings(lineHeight: number | undefined, lineTop: number | undefined, page: IDocumentSkeletonPage, headerPage: Nullable<IDocumentSkeletonPage>, footerPage: Nullable<IDocumentSkeletonPage>): number;
16
17
  export declare function updateDivideInfo(divide: IDocumentSkeletonDivide, states: Partial<IDocumentSkeletonDivide>): void;
17
18
  export declare function setLineMarginBottom(line: IDocumentSkeletonLine, marginBottom: number): void;
18
19
  export declare function collisionDetection(drawing: IDocumentSkeletonDrawing, lineHeight: number, lineTop: number, columnLeft: number, columnWidth: number): boolean;
@@ -30,7 +30,7 @@ export declare function getLastSpan(page: IDocumentSkeletonPage): IDocumentSkele
30
30
  export declare function isColumnFull(page: IDocumentSkeletonPage): boolean;
31
31
  export declare function isBlankPage(page: IDocumentSkeletonPage): boolean;
32
32
  export declare function isBlankColumn(column: IDocumentSkeletonColumn): boolean;
33
- export declare function getNumberUnitValue(unitValue: number | INumberUnit, benchMark: number): number;
33
+ export declare function getNumberUnitValue(unitValue: Nullable<INumberUnit>, benchMark: number): number;
34
34
  export declare function getCharSpaceApply(charSpace: number | undefined, defaultTabStop: number, gridType?: GridType, snapToGrid?: BooleanNumber): number;
35
35
  export declare function validationGrid(gridType?: GridType, snapToGrid?: BooleanNumber): boolean;
36
36
  export declare function getLineHeightConfig(sectionBreakConfig: ISectionBreakConfig, paragraphConfig: IParagraphConfig): {
@@ -81,9 +81,7 @@ export interface ILayoutContext {
81
81
  dataModel: DocumentDataModel;
82
82
  docsConfig: IDocsConfig;
83
83
  skeleton: IDocumentSkeletonCached;
84
- layoutStartPointer: {
85
- paragraphIndex: Nullable<number>;
86
- };
84
+ layoutStartPointer: Record<string, Nullable<number>>;
87
85
  isDirty: boolean;
88
86
  skeletonResourceReference: ISkeletonResourceReference;
89
87
  drawingsCache: Map<string, {
@@ -91,7 +89,7 @@ export interface ILayoutContext {
91
89
  page: IDocumentSkeletonPage;
92
90
  drawing: IDocumentSkeletonDrawing;
93
91
  }>;
94
- paragraphConfigCache: Map<number, IParagraphConfig>;
92
+ paragraphConfigCache: Map<string, Map<number, IParagraphConfig>>;
95
93
  sectionBreakConfigCache: Map<number, ISectionBreakConfig>;
96
94
  paragraphsOpenNewPage: Set<number>;
97
95
  hyphen: Hyphen;
@@ -102,4 +100,5 @@ export declare const DEFAULT_PAGE_SIZE: {
102
100
  height: number;
103
101
  };
104
102
  export declare function prepareSectionBreakConfig(ctx: ILayoutContext, nodeIndex: number): ISectionBreakConfig;
103
+ export declare function resetContext(ctx: ILayoutContext): void;
105
104
  export {};
@@ -51,6 +51,7 @@ export declare class NodePositionConvertToCursor {
51
51
  contentBoxPointGroup: IPoint[][];
52
52
  cursorList: ITextRange[];
53
53
  };
54
+ private _isValidPosition;
54
55
  private _resetCurrentNodePositionState;
55
56
  private _setNodePositionState;
56
57
  private _checkPreviousNodePositionState;
@@ -53,6 +53,7 @@ export interface ITextSelectionRenderManager {
53
53
  enableSelection(): void;
54
54
  disableSelection(): void;
55
55
  setSegment(id: string): void;
56
+ getSegment(): string;
56
57
  setSegmentPage(pageIndex: number): void;
57
58
  getSegmentPage(): number;
58
59
  setStyle(style: ITextSelectionStyle): void;
@@ -37,7 +37,7 @@ export declare const DEFAULT_PADDING_DATA: {
37
37
  };
38
38
  export declare const RENDER_RAW_FORMULA_KEY = "RENDER_RAW_FORMULA";
39
39
  export declare class SpreadsheetSkeleton extends Skeleton {
40
- private _worksheet;
40
+ readonly worksheet: Worksheet;
41
41
  /**
42
42
  * @deprecated avoid use `IWorksheetData` directly, use API provided by `Worksheet`, otherwise
43
43
  * `ViewModel` will be not working.
@@ -65,7 +65,7 @@ export declare class SpreadsheetSkeleton extends Skeleton {
65
65
  private _marginTop;
66
66
  private _marginLeft;
67
67
  private _renderRawFormula;
68
- constructor(_worksheet: Worksheet | undefined,
68
+ constructor(worksheet: Worksheet,
69
69
  /**
70
70
  * @deprecated avoid use `IWorksheetData` directly, use API provided by `Worksheet`, otherwise
71
71
  * `ViewModel` will be not working.
@@ -88,23 +88,16 @@ export declare class SpreadsheetSkeleton extends Skeleton {
88
88
  get mergeData(): IRange[];
89
89
  get rowHeaderWidthAndMarginLeft(): number;
90
90
  get columnHeaderHeightAndMarginTop(): number;
91
- get worksheet(): Worksheet | undefined;
92
- /**
93
- * @deprecated
94
- */
95
- static create(worksheet: Worksheet | undefined, config: IWorksheetData, cellData: ObjectMatrix<Nullable<ICellData>>, styles: Styles, localeService: LocaleService, contextService: IContextService): SpreadsheetSkeleton;
96
- /**
97
- * TODO: DR-Univer, fix as unknown as
98
- */
99
91
  dispose(): void;
100
92
  /**
101
93
  * @deprecated should never expose a property that is provided by another module!
102
94
  */
103
- getCellData(): ObjectMatrix<Nullable<ICellData>>;
95
+ getsStyles(): Styles;
104
96
  /**
105
- * @deprecated should never expose a property that is provided by another module!
97
+ * Get which Workbook and Worksheet this skeleton is attached to.
98
+ * @returns [unitId, sheetId]
106
99
  */
107
- getsStyles(): Styles;
100
+ getLocation(): [string, string];
108
101
  private _initContextListener;
109
102
  setOverflowCache(value: ObjectMatrix<IRange>): void;
110
103
  setMarginLeft(left: number): void;
@@ -237,6 +230,8 @@ export declare class SpreadsheetSkeleton extends Skeleton {
237
230
  endAbsoluteRefType?: import('@univerjs/core').AbsoluteRefType;
238
231
  startRow: number;
239
232
  endRow: number;
233
+ unitId?: string;
234
+ sheetId?: string;
240
235
  startColumn: number;
241
236
  endColumn: number;
242
237
  };
@@ -17,6 +17,7 @@ export interface IRenderManagerService extends IDisposable {
17
17
  removeRender(unitId: string): void;
18
18
  setCurrent(unitId: string): void;
19
19
  getRenderById(unitId: string): Nullable<IRender>;
20
+ getAllRenderersOfType(type: UniverInstanceType): RenderUnit[];
20
21
  getCurrentTypeOfRenderer(type: UniverInstanceType): Nullable<RenderUnit>;
21
22
  getRenderAll(): Map<string, IRender>;
22
23
  defaultEngine: Engine;
@@ -24,6 +25,8 @@ export interface IRenderManagerService extends IDisposable {
24
25
  createRender$: Observable<string>;
25
26
  /** @deprecated this design is very very weird! Remove it. */
26
27
  create(unitId: string): void;
28
+ created$: Observable<IRender>;
29
+ disposed$: Observable<string>;
27
30
  /** @deprecated There will be multi units to render at the same time, so there is no *current*. */
28
31
  getCurrent(): Nullable<IRender>;
29
32
  /** @deprecated There will be multi units to render at the same time, so there is no *first*. */
@@ -43,6 +46,10 @@ export declare class RenderManagerService extends Disposable implements IRenderM
43
46
  private readonly _createRender$;
44
47
  /** @deprecated */
45
48
  readonly createRender$: Observable<string>;
49
+ private readonly _renderCreated$;
50
+ readonly created$: Observable<IRender>;
51
+ private readonly _renderDisposed$;
52
+ readonly disposed$: Observable<string>;
46
53
  get defaultEngine(): Engine;
47
54
  private readonly _renderDependencies;
48
55
  constructor(_injector: Injector, _univerInstanceService: IUniverInstanceService);
@@ -52,6 +59,7 @@ export declare class RenderManagerService extends Disposable implements IRenderM
52
59
  private _getRenderControllersForType;
53
60
  create(unitId: string): void;
54
61
  createRender(unitId: string): IRender;
62
+ getAllRenderersOfType(type: UniverInstanceType): RenderUnit[];
55
63
  getCurrentTypeOfRenderer(type: UniverInstanceType): Nullable<RenderUnit>;
56
64
  withCurrentTypeOfUnit<T>(type: UniverInstanceType, id: DependencyIdentifier<T>): Nullable<T>;
57
65
  private _createRender;
@@ -40,7 +40,7 @@ export declare class RenderUnit extends Disposable implements IRender {
40
40
  set scene(scene: Scene);
41
41
  get scene(): Scene;
42
42
  get components(): Map<string, RenderComponentType>;
43
- constructor(parentInjector: Injector, init: Pick<IRenderContext, 'engine' | 'scene' | 'isMainScene' | 'unit'>);
43
+ constructor(init: Pick<IRenderContext, 'engine' | 'scene' | 'isMainScene' | 'unit'>, parentInjector: Injector);
44
44
  dispose(): void;
45
45
  /**
46
46
  * Get render controller hold by this render unit.
@@ -85,7 +85,7 @@ export declare class Scene extends ThinScene {
85
85
  getAllObjectsByOrderForPick(isDesc?: boolean): BaseObject[];
86
86
  getObject(oKey: string): BaseObject | undefined;
87
87
  getObjectIncludeInGroup(oKey: string): BaseObject | undefined;
88
- fuzzyMathObjects(oKey: string): BaseObject[];
88
+ fuzzyMathObjects(oKey: string, matchStart?: boolean): BaseObject[];
89
89
  addViewport(...viewport: Viewport[]): this;
90
90
  removeViewport(key: string): Viewport | undefined;
91
91
  getViewports(): Viewport[];