@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.
- package/lib/cjs/index.js +2 -2
- package/lib/es/index.js +6040 -5849
- package/lib/types/basics/i-document-skeleton-cached.d.ts +8 -1
- package/lib/types/basics/interfaces.d.ts +3 -3
- package/lib/types/basics/tools.d.ts +2 -0
- package/lib/types/components/docs/layout/doc-skeleton.d.ts +7 -1
- package/lib/types/components/docs/layout/line-breaker/line-breaker.d.ts +1 -0
- package/lib/types/components/docs/layout/line-breaker/rule.d.ts +4 -17
- package/lib/types/components/docs/layout/model/line.d.ts +4 -3
- package/lib/types/components/docs/layout/tools.d.ts +4 -5
- package/lib/types/components/docs/text-selection/convert-cursor.d.ts +1 -0
- package/lib/types/components/docs/text-selection/text-selection-render-manager.d.ts +1 -0
- package/lib/types/components/sheets/sheet-skeleton.d.ts +8 -13
- package/lib/types/render-manager/render-manager.service.d.ts +8 -0
- package/lib/types/render-manager/render-unit.d.ts +1 -1
- package/lib/types/scene.d.ts +1 -1
- package/lib/umd/index.js +2 -2
- package/package.json +8 -8
|
@@ -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
|
-
|
|
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
|
-
|
|
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;
|
|
@@ -1,23 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
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 {
|
|
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
|
|
15
|
-
export declare function calculateLineTopByDrawings(lineHeight
|
|
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:
|
|
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
|
-
|
|
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(
|
|
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
|
-
|
|
95
|
+
getsStyles(): Styles;
|
|
104
96
|
/**
|
|
105
|
-
*
|
|
97
|
+
* Get which Workbook and Worksheet this skeleton is attached to.
|
|
98
|
+
* @returns [unitId, sheetId]
|
|
106
99
|
*/
|
|
107
|
-
|
|
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(
|
|
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.
|
package/lib/types/scene.d.ts
CHANGED
|
@@ -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[];
|