@omegagrid/editor 0.10.2 → 0.10.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/dist/commands/index.d.ts +3 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +34 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/options.d.ts +12 -0
- package/dist/options.d.ts.map +1 -0
- package/dist/options.js +14 -0
- package/dist/options.js.map +1 -0
- package/dist/ui/editor.d.ts +76 -0
- package/dist/ui/editor.d.ts.map +1 -0
- package/dist/ui/editor.js +338 -0
- package/dist/ui/editor.js.map +1 -0
- package/dist/ui/editor.style.d.ts +2 -0
- package/dist/ui/editor.style.d.ts.map +1 -0
- package/dist/ui/editor.style.js +38 -0
- package/dist/ui/editor.style.js.map +1 -0
- package/dist/ui/editorZoom.d.ts +16 -0
- package/dist/ui/editorZoom.d.ts.map +1 -0
- package/dist/ui/editorZoom.js +82 -0
- package/dist/ui/editorZoom.js.map +1 -0
- package/dist/ui/editors/hyperlinkEditor.d.ts +10 -0
- package/dist/ui/editors/hyperlinkEditor.d.ts.map +1 -0
- package/dist/ui/editors/hyperlinkEditor.js +70 -0
- package/dist/ui/editors/hyperlinkEditor.js.map +1 -0
- package/dist/ui/editors/index.d.ts +6 -0
- package/dist/ui/editors/index.d.ts.map +1 -0
- package/dist/ui/editors/index.js +6 -0
- package/dist/ui/editors/index.js.map +1 -0
- package/dist/ui/editors/ruleEditor.d.ts +27 -0
- package/dist/ui/editors/ruleEditor.d.ts.map +1 -0
- package/dist/ui/editors/ruleEditor.js +251 -0
- package/dist/ui/editors/ruleEditor.js.map +1 -0
- package/dist/ui/editors/styleEditor.d.ts +14 -0
- package/dist/ui/editors/styleEditor.d.ts.map +1 -0
- package/dist/ui/editors/styleEditor.js +160 -0
- package/dist/ui/editors/styleEditor.js.map +1 -0
- package/dist/ui/editors/themeEditor.d.ts +24 -0
- package/dist/ui/editors/themeEditor.d.ts.map +1 -0
- package/dist/ui/editors/themeEditor.js +138 -0
- package/dist/ui/editors/themeEditor.js.map +1 -0
- package/dist/ui/editors/themeItemEditor.d.ts +22 -0
- package/dist/ui/editors/themeItemEditor.d.ts.map +1 -0
- package/dist/ui/editors/themeItemEditor.js +181 -0
- package/dist/ui/editors/themeItemEditor.js.map +1 -0
- package/dist/ui/forms/configForm.d.ts +12 -0
- package/dist/ui/forms/configForm.d.ts.map +1 -0
- package/dist/ui/forms/configForm.js +101 -0
- package/dist/ui/forms/configForm.js.map +1 -0
- package/dist/ui/forms/headerForm.d.ts +18 -0
- package/dist/ui/forms/headerForm.d.ts.map +1 -0
- package/dist/ui/forms/headerForm.js +144 -0
- package/dist/ui/forms/headerForm.js.map +1 -0
- package/dist/ui/forms/index.d.ts +9 -0
- package/dist/ui/forms/index.d.ts.map +1 -0
- package/dist/ui/forms/index.js +9 -0
- package/dist/ui/forms/index.js.map +1 -0
- package/dist/ui/forms/namesForm.d.ts +21 -0
- package/dist/ui/forms/namesForm.d.ts.map +1 -0
- package/dist/ui/forms/namesForm.js +124 -0
- package/dist/ui/forms/namesForm.js.map +1 -0
- package/dist/ui/forms/ruleForm.d.ts +13 -0
- package/dist/ui/forms/ruleForm.d.ts.map +1 -0
- package/dist/ui/forms/ruleForm.js +56 -0
- package/dist/ui/forms/ruleForm.js.map +1 -0
- package/dist/ui/forms/ruleForm.style.d.ts +2 -0
- package/dist/ui/forms/ruleForm.style.d.ts.map +1 -0
- package/dist/ui/forms/ruleForm.style.js +50 -0
- package/dist/ui/forms/ruleForm.style.js.map +1 -0
- package/dist/ui/forms/ruleFormThreshold.d.ts +19 -0
- package/dist/ui/forms/ruleFormThreshold.d.ts.map +1 -0
- package/dist/ui/forms/ruleFormThreshold.js +97 -0
- package/dist/ui/forms/ruleFormThreshold.js.map +1 -0
- package/dist/ui/forms/ruleList.d.ts +25 -0
- package/dist/ui/forms/ruleList.d.ts.map +1 -0
- package/dist/ui/forms/ruleList.js +169 -0
- package/dist/ui/forms/ruleList.js.map +1 -0
- package/dist/ui/forms/ruleList.style.d.ts +3 -0
- package/dist/ui/forms/ruleList.style.d.ts.map +1 -0
- package/dist/ui/forms/ruleList.style.js +69 -0
- package/dist/ui/forms/ruleList.style.js.map +1 -0
- package/dist/ui/forms/sparklineForm.d.ts +22 -0
- package/dist/ui/forms/sparklineForm.d.ts.map +1 -0
- package/dist/ui/forms/sparklineForm.js +199 -0
- package/dist/ui/forms/sparklineForm.js.map +1 -0
- package/dist/ui/forms/sparklineForm.style.d.ts +3 -0
- package/dist/ui/forms/sparklineForm.style.d.ts.map +1 -0
- package/dist/ui/forms/sparklineForm.style.js +94 -0
- package/dist/ui/forms/sparklineForm.style.js.map +1 -0
- package/dist/ui/forms/styleForm.d.ts +14 -0
- package/dist/ui/forms/styleForm.d.ts.map +1 -0
- package/dist/ui/forms/styleForm.js +151 -0
- package/dist/ui/forms/styleForm.js.map +1 -0
- package/dist/ui/formulabar.d.ts +23 -0
- package/dist/ui/formulabar.d.ts.map +1 -0
- package/dist/ui/formulabar.js +155 -0
- package/dist/ui/formulabar.js.map +1 -0
- package/dist/ui/formulabar.style.d.ts +2 -0
- package/dist/ui/formulabar.style.d.ts.map +1 -0
- package/dist/ui/formulabar.style.js +48 -0
- package/dist/ui/formulabar.style.js.map +1 -0
- package/dist/ui/gridStats.d.ts +11 -0
- package/dist/ui/gridStats.d.ts.map +1 -0
- package/dist/ui/gridStats.js +71 -0
- package/dist/ui/gridStats.js.map +1 -0
- package/dist/ui/index.d.ts +11 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +11 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/sidebars/baseSidebar.d.ts +10 -0
- package/dist/ui/sidebars/baseSidebar.d.ts.map +1 -0
- package/dist/ui/sidebars/baseSidebar.js +24 -0
- package/dist/ui/sidebars/baseSidebar.js.map +1 -0
- package/dist/ui/sidebars/index.d.ts +2 -0
- package/dist/ui/sidebars/index.d.ts.map +1 -0
- package/dist/ui/sidebars/index.js +2 -0
- package/dist/ui/sidebars/index.js.map +1 -0
- package/dist/ui/sidebars/themeEditorSidebar.d.ts +14 -0
- package/dist/ui/sidebars/themeEditorSidebar.d.ts.map +1 -0
- package/dist/ui/sidebars/themeEditorSidebar.js +110 -0
- package/dist/ui/sidebars/themeEditorSidebar.js.map +1 -0
- package/dist/ui/statusbar.d.ts +19 -0
- package/dist/ui/statusbar.d.ts.map +1 -0
- package/dist/ui/statusbar.js +69 -0
- package/dist/ui/statusbar.js.map +1 -0
- package/dist/ui/toolbar.config.d.ts +7 -0
- package/dist/ui/toolbar.config.d.ts.map +1 -0
- package/dist/ui/toolbar.config.js +166 -0
- package/dist/ui/toolbar.config.js.map +1 -0
- package/dist/ui/toolbar.d.ts +42 -0
- package/dist/ui/toolbar.d.ts.map +1 -0
- package/dist/ui/toolbar.js +356 -0
- package/dist/ui/toolbar.js.map +1 -0
- package/dist/ui/toolbar.style.d.ts +2 -0
- package/dist/ui/toolbar.style.d.ts.map +1 -0
- package/dist/ui/toolbar.style.js +22 -0
- package/dist/ui/toolbar.style.js.map +1 -0
- package/package.json +10 -10
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAgC/B,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,QAGhD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
function createEditorCommands(editor) {
|
|
2
|
+
return [{
|
|
3
|
+
group: 'editor',
|
|
4
|
+
name: 'show controls',
|
|
5
|
+
exec: () => {
|
|
6
|
+
editor.toolbarDisabled = false;
|
|
7
|
+
editor.formulabarDisabled = false;
|
|
8
|
+
}
|
|
9
|
+
}, {
|
|
10
|
+
group: 'editor',
|
|
11
|
+
name: 'hide controls',
|
|
12
|
+
exec: () => {
|
|
13
|
+
editor.toolbarDisabled = true;
|
|
14
|
+
editor.formulabarDisabled = true;
|
|
15
|
+
}
|
|
16
|
+
}, {
|
|
17
|
+
group: 'editor',
|
|
18
|
+
name: 'show statusbar',
|
|
19
|
+
exec: () => {
|
|
20
|
+
editor.statusbarDisabled = false;
|
|
21
|
+
}
|
|
22
|
+
}, {
|
|
23
|
+
group: 'editor',
|
|
24
|
+
name: 'hide statusbar',
|
|
25
|
+
exec: () => {
|
|
26
|
+
editor.statusbarDisabled = true;
|
|
27
|
+
}
|
|
28
|
+
}];
|
|
29
|
+
}
|
|
30
|
+
export function initEditorCommands(editor) {
|
|
31
|
+
editor.commands.clear();
|
|
32
|
+
createEditorCommands(editor).forEach(c => editor.commands.add(c));
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/commands/index.ts"],"names":[],"mappings":"AAGA,SAAS,oBAAoB,CAAC,MAAc;IAC3C,OAAO,CAAC;YACP,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE,GAAG,EAAE;gBACV,MAAM,CAAC,eAAe,GAAG,KAAK,CAAC;gBAC/B,MAAM,CAAC,kBAAkB,GAAG,KAAK,CAAC;YACnC,CAAC;SACD,EAAE;YACF,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE,GAAG,EAAE;gBACV,MAAM,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC9B,MAAM,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAClC,CAAC;SACD,EAAE;YACF,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE,GAAG,EAAE;gBACV,MAAM,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAClC,CAAC;SACD,EAAE;YACF,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE,GAAG,EAAE;gBACV,MAAM,CAAC,iBAAiB,GAAG,IAAI,CAAC;YACjC,CAAC;SACD,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,MAAc;IAChD,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,oBAAoB,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AACnE,CAAC","sourcesContent":["import { FlowCommandSource } from \"@omegagrid/commands\";\nimport { Editor } from \"../ui\";\n\nfunction createEditorCommands(editor: Editor): FlowCommandSource[] {\n\treturn [{\n\t\tgroup: 'editor', \n\t\tname: 'show controls', \n\t\texec: () => {\n\t\t\teditor.toolbarDisabled = false;\n\t\t\teditor.formulabarDisabled = false;\n\t\t}\n\t}, {\n\t\tgroup: 'editor',\n\t\tname: 'hide controls', \n\t\texec: () => {\n\t\t\teditor.toolbarDisabled = true;\n\t\t\teditor.formulabarDisabled = true;\n\t\t}\n\t}, {\n\t\tgroup: 'editor',\n\t\tname: 'show statusbar',\n\t\texec: () => {\n\t\t\teditor.statusbarDisabled = false;\n\t\t}\n\t}, {\n\t\tgroup: 'editor',\n\t\tname: 'hide statusbar',\n\t\texec: () => {\n\t\t\teditor.statusbarDisabled = true;\n\t\t}\n\t}];\n}\n\nexport function initEditorCommands(editor: Editor) {\n\teditor.commands.clear();\n\tcreateEditorCommands(editor).forEach(c => editor.commands.add(c));\n}"]}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,MAAM,CAAC;AACrB,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,WAAW,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,MAAM,CAAC","sourcesContent":["export * from './ui';\nexport { Options as EditorOptions } from './options';"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { CommonOptions } from "@omegagrid/core";
|
|
2
|
+
export type Options = CommonOptions & {
|
|
3
|
+
commandWindow?: boolean;
|
|
4
|
+
editing?: {
|
|
5
|
+
headers?: boolean;
|
|
6
|
+
conditionalStyles?: boolean;
|
|
7
|
+
names?: boolean;
|
|
8
|
+
sparklines?: boolean;
|
|
9
|
+
};
|
|
10
|
+
};
|
|
11
|
+
export declare function initOptions(options?: Partial<Options>, origOptions?: Options): Options;
|
|
12
|
+
//# sourceMappingURL=options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../src/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,aAAa,EAAS,MAAM,iBAAiB,CAAC;AAE1E,MAAM,MAAM,OAAO,GAAG,aAAa,GAAG;IACrC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,OAAO,CAAC,EAAE;QACT,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,iBAAiB,CAAC,EAAE,OAAO,CAAC;QAC5B,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,UAAU,CAAC,EAAE,OAAO,CAAA;KACpB,CAAA;CACD,CAAC;AAYF,wBAAgB,WAAW,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,WAAW,GAAE,OAAc,GAAG,OAAO,CAE5F"}
|
package/dist/options.js
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { initCommonOptions, utils } from "@omegagrid/core";
|
|
2
|
+
const DEFAULT_OPTIONS = {
|
|
3
|
+
commandWindow: true,
|
|
4
|
+
editing: {
|
|
5
|
+
headers: true,
|
|
6
|
+
conditionalStyles: true,
|
|
7
|
+
names: true,
|
|
8
|
+
sparklines: true
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
export function initOptions(options, origOptions = null) {
|
|
12
|
+
return utils.mergeDeep({}, DEFAULT_OPTIONS, initCommonOptions(options, origOptions));
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.js","sourceRoot":"","sources":["../src/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAiB,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAY1E,MAAM,eAAe,GAAqB;IACzC,aAAa,EAAE,IAAI;IACnB,OAAO,EAAE;QACR,OAAO,EAAE,IAAI;QACb,iBAAiB,EAAE,IAAI;QACvB,KAAK,EAAE,IAAI;QACX,UAAU,EAAE,IAAI;KAChB;CACD,CAAC;AAEF,MAAM,UAAU,WAAW,CAAC,OAA0B,EAAE,cAAuB,IAAI;IAClF,OAAO,KAAK,CAAC,SAAS,CAAC,EAAE,EAAE,eAAe,EAAE,iBAAiB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC;AACtF,CAAC","sourcesContent":["import { initCommonOptions, CommonOptions, utils } from \"@omegagrid/core\";\n\nexport type Options = CommonOptions & {\n\tcommandWindow?: boolean,\n\tediting?: {\n\t\theaders?: boolean,\n\t\tconditionalStyles?: boolean,\n\t\tnames?: boolean,\n\t\tsparklines?: boolean\n\t}\n};\n\nconst DEFAULT_OPTIONS: Partial<Options> = {\n\tcommandWindow: true,\n\tediting: {\n\t\theaders: true,\n\t\tconditionalStyles: true,\n\t\tnames: true,\n\t\tsparklines: true\n\t}\n};\n\nexport function initOptions(options?: Partial<Options>, origOptions: Options = null): Options {\n\treturn utils.mergeDeep({}, DEFAULT_OPTIONS, initCommonOptions(options, origOptions));\n}"]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { actions, ComponentContainer, ComponentFactory, ComponentId, ComponentStore, Layout, ListSelectEvent, Menu, Overlay, Plugin, Plugins, ShortcutManager, SplitContainer } from '@omegagrid/core';
|
|
2
|
+
import { CommandManager } from '@omegagrid/commands';
|
|
3
|
+
import { ElementModel, Grid, GridEvent, GridGroup, GridModel, GroupModel, GroupModelSource, GridEditEvent, CellRange } from '@omegagrid/grid';
|
|
4
|
+
import { CommandWindow } from '@omegagrid/commands';
|
|
5
|
+
import { LitElement } from 'lit';
|
|
6
|
+
import { EditorFormula } from './formulabar';
|
|
7
|
+
import { EditorToolbar } from './toolbar';
|
|
8
|
+
import { TabEvent } from '@omegagrid/tabs';
|
|
9
|
+
import { EditorStatusbar } from './statusbar';
|
|
10
|
+
import { Options } from '../options';
|
|
11
|
+
export type SidebarComponent = LitElement & {
|
|
12
|
+
grid: Grid;
|
|
13
|
+
group: GridGroup;
|
|
14
|
+
model: GridModel;
|
|
15
|
+
range: CellRange;
|
|
16
|
+
};
|
|
17
|
+
export type SidebarComponentType = 'config' | 'headers' | 'rules' | 'sparklines' | 'names' | ComponentId;
|
|
18
|
+
export declare class EditorEvent extends Event {
|
|
19
|
+
readonly editor: Editor;
|
|
20
|
+
constructor(type: string, args?: Partial<EditorEvent>);
|
|
21
|
+
}
|
|
22
|
+
export declare class Editor extends LitElement implements Layout, ComponentContainer {
|
|
23
|
+
static styles: import("lit").CSSResult[];
|
|
24
|
+
formulaBar: EditorFormula;
|
|
25
|
+
container: SplitContainer;
|
|
26
|
+
toolbar: EditorToolbar;
|
|
27
|
+
statusbar: EditorStatusbar;
|
|
28
|
+
overlay: Overlay;
|
|
29
|
+
enableDrag: boolean;
|
|
30
|
+
model: GroupModel;
|
|
31
|
+
createComponent: ComponentFactory<LitElement>;
|
|
32
|
+
toolbarDisabled: boolean;
|
|
33
|
+
statusbarDisabled: boolean;
|
|
34
|
+
formulabarDisabled: boolean;
|
|
35
|
+
options: Options;
|
|
36
|
+
rightSidebarComponent: SidebarComponentType;
|
|
37
|
+
gridElements: ElementModel[];
|
|
38
|
+
activeRange: CellRange;
|
|
39
|
+
activeGrid: Grid;
|
|
40
|
+
activeModel: GridModel;
|
|
41
|
+
gridContainer: GridGroup;
|
|
42
|
+
get group(): GridGroup;
|
|
43
|
+
private commandWindowRef;
|
|
44
|
+
get commandWindow(): CommandWindow;
|
|
45
|
+
private tabMenuRef;
|
|
46
|
+
get tabMenu(): Menu;
|
|
47
|
+
private activeMenuSheet;
|
|
48
|
+
readonly plugins: Plugins<Editor>;
|
|
49
|
+
readonly commands: CommandManager;
|
|
50
|
+
readonly shortcuts: ShortcutManager;
|
|
51
|
+
readonly sidebarComponents: ComponentStore<SidebarComponent>;
|
|
52
|
+
constructor();
|
|
53
|
+
updateOptions(options: Partial<Options>): void;
|
|
54
|
+
_onDragover: (e: DragEvent) => void;
|
|
55
|
+
connectedCallback(): void;
|
|
56
|
+
willUpdate(props: Map<PropertyKey, unknown>): void;
|
|
57
|
+
updated(props: Map<PropertyKey, unknown>): void;
|
|
58
|
+
updateComponents(): void;
|
|
59
|
+
setSourceData(sourceData: GroupModelSource): void;
|
|
60
|
+
updateCommands(): void;
|
|
61
|
+
layout(): void;
|
|
62
|
+
updateSelectedRange(range: CellRange): void;
|
|
63
|
+
activateGrid(grid: Grid): void;
|
|
64
|
+
_onGridSelect: (e: GridEvent) => Promise<void>;
|
|
65
|
+
_onGridEdit: (e: GridEditEvent) => void;
|
|
66
|
+
registerPlugin(plugin: Plugin<Editor>): void;
|
|
67
|
+
_onTabContextMenu: (e: TabEvent) => void;
|
|
68
|
+
createGridContainer: () => GridGroup;
|
|
69
|
+
getGridContainer(): GridGroup;
|
|
70
|
+
createDefaultComponent: ComponentFactory;
|
|
71
|
+
_onToolbarAction: (_e: actions.ActionEvent) => void;
|
|
72
|
+
_onCommandsOpen: () => void;
|
|
73
|
+
_onTabMenuItemSelect: (e: ListSelectEvent) => void;
|
|
74
|
+
render: () => import("lit-html").TemplateResult<1>;
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=editor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../src/ui/editor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,338 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { ComponentStore, dom, Plugins, ShortcutManager } from '@omegagrid/core';
|
|
8
|
+
import { CommandManager } from '@omegagrid/commands';
|
|
9
|
+
import { Grid } from '@omegagrid/grid';
|
|
10
|
+
import { LitElement, html } from 'lit';
|
|
11
|
+
import { customElement, property, query, state } from 'lit/decorators.js';
|
|
12
|
+
import { guard } from 'lit/directives/guard.js';
|
|
13
|
+
import { style } from './editor.style';
|
|
14
|
+
import { createRef, ref } from 'lit-html/directives/ref.js';
|
|
15
|
+
import { initEditorCommands } from '../commands';
|
|
16
|
+
import { initOptions } from '../options';
|
|
17
|
+
export class EditorEvent extends Event {
|
|
18
|
+
constructor(type, args) {
|
|
19
|
+
super(`editor.${type}`, { bubbles: true, composed: true });
|
|
20
|
+
Object.assign(this, args);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
let Editor = class Editor extends LitElement {
|
|
24
|
+
get group() { return this.gridContainer; }
|
|
25
|
+
get commandWindow() { return this.commandWindowRef.value; }
|
|
26
|
+
get tabMenu() { return this.tabMenuRef.value; }
|
|
27
|
+
constructor() {
|
|
28
|
+
super();
|
|
29
|
+
this.enableDrag = true;
|
|
30
|
+
this.toolbarDisabled = false;
|
|
31
|
+
this.statusbarDisabled = false;
|
|
32
|
+
this.formulabarDisabled = false;
|
|
33
|
+
this.options = initOptions();
|
|
34
|
+
this.commandWindowRef = createRef();
|
|
35
|
+
this.tabMenuRef = createRef();
|
|
36
|
+
this.plugins = new Plugins(this);
|
|
37
|
+
this.commands = new CommandManager(this);
|
|
38
|
+
this.shortcuts = new ShortcutManager(this);
|
|
39
|
+
this.sidebarComponents = new ComponentStore(async (id) => {
|
|
40
|
+
let component;
|
|
41
|
+
switch (id) {
|
|
42
|
+
case 'config':
|
|
43
|
+
component = dom.createElement('og-editor-form-config');
|
|
44
|
+
break;
|
|
45
|
+
case 'headers':
|
|
46
|
+
component = dom.createElement('og-editor-form-headers');
|
|
47
|
+
break;
|
|
48
|
+
case 'rules':
|
|
49
|
+
component = dom.createElement('og-editor-rules');
|
|
50
|
+
break;
|
|
51
|
+
case 'sparklines':
|
|
52
|
+
component = dom.createElement('og-editor-form-sparklines');
|
|
53
|
+
break;
|
|
54
|
+
case 'names':
|
|
55
|
+
component = dom.createElement('og-editor-form-names');
|
|
56
|
+
break;
|
|
57
|
+
case 'themes':
|
|
58
|
+
component = dom.createElement('og-editor-themesidebar');
|
|
59
|
+
break;
|
|
60
|
+
default: component = this.createComponent ? await this.createComponent(id) : null;
|
|
61
|
+
}
|
|
62
|
+
if (!component)
|
|
63
|
+
return null;
|
|
64
|
+
if (this.activeGrid) {
|
|
65
|
+
component.grid = this.activeGrid;
|
|
66
|
+
component.range = this.activeGrid.selection.range;
|
|
67
|
+
}
|
|
68
|
+
if (this.activeModel)
|
|
69
|
+
component.model = this.activeModel;
|
|
70
|
+
if (this.gridContainer)
|
|
71
|
+
component.group = this.gridContainer;
|
|
72
|
+
return component;
|
|
73
|
+
});
|
|
74
|
+
this._onDragover = (e) => {
|
|
75
|
+
if (!this.enableDrag)
|
|
76
|
+
return;
|
|
77
|
+
e.preventDefault();
|
|
78
|
+
e.stopPropagation();
|
|
79
|
+
if (e.dataTransfer.types[0] == 'Files') {
|
|
80
|
+
e.dataTransfer.dropEffect = 'move';
|
|
81
|
+
this.overlay.text = 'drop file';
|
|
82
|
+
this.overlay.show(this);
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
this._onGridSelect = async (e) => {
|
|
86
|
+
if (this.gridContainer.isFormulaMode)
|
|
87
|
+
return;
|
|
88
|
+
this.activateGrid(e.composedPath().find(elm => elm instanceof Grid));
|
|
89
|
+
if (this.rightSidebarComponent == 'headers') {
|
|
90
|
+
const headerForm = await this.sidebarComponents.get('headers');
|
|
91
|
+
headerForm.grid = this.activeGrid;
|
|
92
|
+
headerForm.range = this.activeGrid.selection.range.clone();
|
|
93
|
+
}
|
|
94
|
+
this.updateSelectedRange(e.selection.range);
|
|
95
|
+
};
|
|
96
|
+
this._onGridEdit = (e) => {
|
|
97
|
+
switch (e.editType) {
|
|
98
|
+
case 'delete_column':
|
|
99
|
+
case 'delete_row':
|
|
100
|
+
case 'insert_column':
|
|
101
|
+
case 'insert_row':
|
|
102
|
+
this.updateSelectedRange(e.selection.range);
|
|
103
|
+
break;
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
this._onTabContextMenu = (e) => {
|
|
107
|
+
const uiEvent = e.uiEvent;
|
|
108
|
+
this.activeMenuSheet = e.tab.id;
|
|
109
|
+
this.tabMenu.openAt(uiEvent.pageX, uiEvent.pageY + 1);
|
|
110
|
+
};
|
|
111
|
+
this.createGridContainer = () => {
|
|
112
|
+
const container = dom.createElement('og-gridgroup');
|
|
113
|
+
container.tabPosition = 'bottom';
|
|
114
|
+
container.designMode = true;
|
|
115
|
+
container.model = this.model;
|
|
116
|
+
container.options.commandWindow = false;
|
|
117
|
+
container.addEventListener('gridgroup.activate', () => {
|
|
118
|
+
if (this.gridContainer.isFormulaMode)
|
|
119
|
+
return;
|
|
120
|
+
this.activateGrid(this.gridContainer.activeGrid);
|
|
121
|
+
this.updateCommands();
|
|
122
|
+
this.updateComponents();
|
|
123
|
+
});
|
|
124
|
+
container.addEventListener('tab.contextmenu', this._onTabContextMenu);
|
|
125
|
+
container.addEventListener('grid.select', this._onGridSelect);
|
|
126
|
+
container.addEventListener('grid.edit', this._onGridEdit);
|
|
127
|
+
return container;
|
|
128
|
+
};
|
|
129
|
+
this.createDefaultComponent = (index) => {
|
|
130
|
+
if (index == 0) {
|
|
131
|
+
return this.getGridContainer();
|
|
132
|
+
}
|
|
133
|
+
else if (index == 1) {
|
|
134
|
+
return this.sidebarComponents.get(this.rightSidebarComponent);
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
this._onToolbarAction = (_e) => {
|
|
138
|
+
// if (e.action.key == 'config') {
|
|
139
|
+
// this.rightSidebarComponent = e.action.value ? e.action.key : null;
|
|
140
|
+
// }
|
|
141
|
+
};
|
|
142
|
+
this._onCommandsOpen = () => {
|
|
143
|
+
// this.commandWindow.requestUpdate();
|
|
144
|
+
};
|
|
145
|
+
this._onTabMenuItemSelect = (e) => {
|
|
146
|
+
switch (this.tabMenu.items[e.index].key) {
|
|
147
|
+
case 'properties':
|
|
148
|
+
this.activateGrid(this.gridContainer.grids.get(this.activeMenuSheet));
|
|
149
|
+
this.rightSidebarComponent = 'config';
|
|
150
|
+
break;
|
|
151
|
+
case 'delete':
|
|
152
|
+
this.gridContainer.deleteModel(this.activeMenuSheet);
|
|
153
|
+
break;
|
|
154
|
+
case 'duplicate':
|
|
155
|
+
this.gridContainer.duplicateModel(this.activeMenuSheet);
|
|
156
|
+
break;
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
this.render = () => html `
|
|
160
|
+
${this.toolbarDisabled ? '' : html `
|
|
161
|
+
<og-editor-toolbar
|
|
162
|
+
.grid="${this.activeGrid}"
|
|
163
|
+
.gridElements=${this.gridElements}
|
|
164
|
+
.editor="${this}"
|
|
165
|
+
@toolbar.action="${this._onToolbarAction}">
|
|
166
|
+
</og-editor-toolbar>
|
|
167
|
+
`}
|
|
168
|
+
|
|
169
|
+
${this.toolbarDisabled ? '' : html `
|
|
170
|
+
<og-editor-formula .grid="${this.activeGrid}"></og-editor-formula>
|
|
171
|
+
`}
|
|
172
|
+
|
|
173
|
+
${guard([this.rightSidebarComponent], () => html `
|
|
174
|
+
<og-splitcontainer
|
|
175
|
+
.items="${[{}, { size: 300, collapsed: !this.rightSidebarComponent }]}"
|
|
176
|
+
.createComponent="${this.createDefaultComponent}">
|
|
177
|
+
</og-splitcontainer>
|
|
178
|
+
`)}
|
|
179
|
+
|
|
180
|
+
${this.statusbarDisabled ? '' : html `
|
|
181
|
+
<og-editor-statusbar
|
|
182
|
+
.group="${this.getGridContainer()}"
|
|
183
|
+
.grid="${this.activeGrid}"
|
|
184
|
+
.range="${this.activeRange}">
|
|
185
|
+
</og-editor-statusbar>
|
|
186
|
+
`}
|
|
187
|
+
|
|
188
|
+
<og-menu ${ref(this.tabMenuRef)}
|
|
189
|
+
style="display: none; z-index: 20000"
|
|
190
|
+
@select=${this._onTabMenuItemSelect}
|
|
191
|
+
.items=${[
|
|
192
|
+
{ key: 'properties', value: 'Properties', icon: 'pen' },
|
|
193
|
+
{ key: 'duplicate', value: 'Duplicate', icon: 'copy' },
|
|
194
|
+
{ key: 'delete', value: 'Delete', icon: 'trash' },
|
|
195
|
+
]}>
|
|
196
|
+
</og-menu>
|
|
197
|
+
|
|
198
|
+
<og-overlay striped></og-overlay>
|
|
199
|
+
`;
|
|
200
|
+
this.addEventListener('dragover', this._onDragover);
|
|
201
|
+
this.addEventListener('dragleave', () => this.overlay.hide());
|
|
202
|
+
this.addEventListener('drop', () => this.overlay.hide());
|
|
203
|
+
initEditorCommands(this);
|
|
204
|
+
this.shortcuts.register('F1', 'open_commands');
|
|
205
|
+
this.shortcuts.addEventListener('shortcut', (e) => {
|
|
206
|
+
if (e.action == 'open_commands') {
|
|
207
|
+
this.commands.open();
|
|
208
|
+
}
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
updateOptions(options) {
|
|
212
|
+
this.options = initOptions(options, this.options);
|
|
213
|
+
this.requestUpdate();
|
|
214
|
+
}
|
|
215
|
+
connectedCallback() {
|
|
216
|
+
super.connectedCallback();
|
|
217
|
+
this.tabIndex = 0;
|
|
218
|
+
}
|
|
219
|
+
willUpdate(props) {
|
|
220
|
+
if (!this.hasUpdated) {
|
|
221
|
+
this.dispatchEvent(new EditorEvent('init', { editor: this }));
|
|
222
|
+
}
|
|
223
|
+
if (props.has('model'))
|
|
224
|
+
this.gridContainer = null;
|
|
225
|
+
}
|
|
226
|
+
updated(props) {
|
|
227
|
+
this.updateComponents();
|
|
228
|
+
if (props.has('toolbarDisabled') || props.has('formulabarDisabled'))
|
|
229
|
+
this.layout();
|
|
230
|
+
}
|
|
231
|
+
updateComponents() {
|
|
232
|
+
this.sidebarComponents.items.forEach(c => {
|
|
233
|
+
c.grid = this.activeGrid;
|
|
234
|
+
c.model = this.activeModel;
|
|
235
|
+
c.group = this.gridContainer;
|
|
236
|
+
c.range = this.activeGrid?.selection?.range.clone();
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
setSourceData(sourceData) {
|
|
240
|
+
const container = this.getGridContainer();
|
|
241
|
+
sourceData.models?.forEach(m => {
|
|
242
|
+
m.options ?? (m.options = {});
|
|
243
|
+
m.options.commandWindow = false;
|
|
244
|
+
});
|
|
245
|
+
container.setSourceData(sourceData);
|
|
246
|
+
this.activeGrid = this.gridContainer?.grids?.entries().next().value;
|
|
247
|
+
this.activeModel = this.activeGrid?.model;
|
|
248
|
+
}
|
|
249
|
+
updateCommands() {
|
|
250
|
+
this.activeGrid.commands.commands.forEach(c => this.commands.add(c));
|
|
251
|
+
}
|
|
252
|
+
layout() {
|
|
253
|
+
this.container?.layout();
|
|
254
|
+
}
|
|
255
|
+
updateSelectedRange(range) {
|
|
256
|
+
const m = this.activeGrid.model;
|
|
257
|
+
if (range.isColumn) {
|
|
258
|
+
this.gridElements = [...Array(range.size.columns).keys()].map(c => m.columns[c + range.c1]);
|
|
259
|
+
}
|
|
260
|
+
else if (range.isRow) {
|
|
261
|
+
this.gridElements = [...Array(range.size.rows).keys()].map(r => m.rows[r + range.r1]);
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
this.gridElements = m.getCellArray(this.activeGrid.selection.range);
|
|
265
|
+
}
|
|
266
|
+
this.statusbar.grid = this.activeGrid;
|
|
267
|
+
this.statusbar.range = range.clone();
|
|
268
|
+
}
|
|
269
|
+
activateGrid(grid) {
|
|
270
|
+
if (!grid)
|
|
271
|
+
return;
|
|
272
|
+
this.activeGrid = grid;
|
|
273
|
+
this.activeModel = grid.model;
|
|
274
|
+
}
|
|
275
|
+
registerPlugin(plugin) {
|
|
276
|
+
this.plugins.register(plugin);
|
|
277
|
+
}
|
|
278
|
+
getGridContainer() {
|
|
279
|
+
return this.gridContainer ?? (this.gridContainer = this.createGridContainer());
|
|
280
|
+
}
|
|
281
|
+
};
|
|
282
|
+
Editor.styles = [style];
|
|
283
|
+
__decorate([
|
|
284
|
+
query('og-editor-formula')
|
|
285
|
+
], Editor.prototype, "formulaBar", void 0);
|
|
286
|
+
__decorate([
|
|
287
|
+
query('og-splitcontainer')
|
|
288
|
+
], Editor.prototype, "container", void 0);
|
|
289
|
+
__decorate([
|
|
290
|
+
query('og-editor-toolbar')
|
|
291
|
+
], Editor.prototype, "toolbar", void 0);
|
|
292
|
+
__decorate([
|
|
293
|
+
query('og-editor-statusbar')
|
|
294
|
+
], Editor.prototype, "statusbar", void 0);
|
|
295
|
+
__decorate([
|
|
296
|
+
query('og-overlay')
|
|
297
|
+
], Editor.prototype, "overlay", void 0);
|
|
298
|
+
__decorate([
|
|
299
|
+
property({ type: Boolean })
|
|
300
|
+
], Editor.prototype, "enableDrag", void 0);
|
|
301
|
+
__decorate([
|
|
302
|
+
property({ type: Object })
|
|
303
|
+
], Editor.prototype, "model", void 0);
|
|
304
|
+
__decorate([
|
|
305
|
+
property({ attribute: false })
|
|
306
|
+
], Editor.prototype, "createComponent", void 0);
|
|
307
|
+
__decorate([
|
|
308
|
+
property({ type: Boolean })
|
|
309
|
+
], Editor.prototype, "toolbarDisabled", void 0);
|
|
310
|
+
__decorate([
|
|
311
|
+
property({ type: Boolean })
|
|
312
|
+
], Editor.prototype, "statusbarDisabled", void 0);
|
|
313
|
+
__decorate([
|
|
314
|
+
property({ type: Boolean })
|
|
315
|
+
], Editor.prototype, "formulabarDisabled", void 0);
|
|
316
|
+
__decorate([
|
|
317
|
+
property({ type: Object })
|
|
318
|
+
], Editor.prototype, "options", void 0);
|
|
319
|
+
__decorate([
|
|
320
|
+
property({ type: String })
|
|
321
|
+
], Editor.prototype, "rightSidebarComponent", void 0);
|
|
322
|
+
__decorate([
|
|
323
|
+
state()
|
|
324
|
+
], Editor.prototype, "gridElements", void 0);
|
|
325
|
+
__decorate([
|
|
326
|
+
state()
|
|
327
|
+
], Editor.prototype, "activeRange", void 0);
|
|
328
|
+
__decorate([
|
|
329
|
+
state()
|
|
330
|
+
], Editor.prototype, "activeGrid", void 0);
|
|
331
|
+
__decorate([
|
|
332
|
+
state()
|
|
333
|
+
], Editor.prototype, "activeModel", void 0);
|
|
334
|
+
Editor = __decorate([
|
|
335
|
+
customElement('og-editor')
|
|
336
|
+
], Editor);
|
|
337
|
+
export { Editor };
|
|
338
|
+
//# sourceMappingURL=editor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"editor.js","sourceRoot":"","sources":["../../src/ui/editor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tactions, ComponentContainer, ComponentFactory, ComponentId, ComponentStore, dom, Layout, ListSelectEvent,\n\tMenu, Overlay, Plugin, Plugins, ShortcutEvent, ShortcutManager, SplitContainer\n} from '@omegagrid/core';\nimport { CommandManager } from '@omegagrid/commands';\nimport { ElementModel, Grid, GridEvent, GridGroup, GridModel, GroupModel, GroupModelSource, GridEditEvent, CellRange } from '@omegagrid/grid';\nimport { CommandWindow } from '@omegagrid/commands';\nimport { LitElement, html } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { EditorFormula } from './formulabar';\nimport { EditorToolbar } from './toolbar';\nimport { guard } from 'lit/directives/guard.js';\nimport { style } from './editor.style';\nimport { createRef, ref } from 'lit-html/directives/ref.js';\nimport { TabEvent } from '@omegagrid/tabs';\nimport { initEditorCommands } from '../commands';\nimport { EditorStatusbar } from './statusbar';\nimport { initOptions, Options } from '../options';\nimport { ThemeEditorSidebar } from './sidebars';\n\nexport type SidebarComponent = LitElement & {grid: Grid, group: GridGroup, model: GridModel, range: CellRange};\nexport type SidebarComponentType = 'config'|'headers'|'rules'|'sparklines'|'names'|ComponentId;\n\nexport class EditorEvent extends Event {\n\n\treadonly editor: Editor;\n\n\tconstructor(type: string, args?: Partial<EditorEvent>) {\n\t\tsuper(`editor.${type}`, {bubbles: true, composed: true});\n\t\tObject.assign(this, args);\n\t}\n\n}\n\n@customElement('og-editor')\nexport class Editor extends LitElement implements Layout, ComponentContainer {\n\n\tstatic styles = [style];\n\n\t@query('og-editor-formula')\n\tformulaBar: EditorFormula;\n\n\t@query('og-splitcontainer')\n\tcontainer: SplitContainer;\n\n\t@query('og-editor-toolbar')\n\ttoolbar: EditorToolbar;\n\n\t@query('og-editor-statusbar')\n\tstatusbar: EditorStatusbar;\n\n\t@query('og-overlay')\n\toverlay: Overlay;\n\n\t@property({type: Boolean})\n\tenableDrag = true;\n\n\t@property({type: Object})\n\tmodel: GroupModel;\n\n\t@property({attribute: false})\n\tcreateComponent: ComponentFactory<LitElement>;\n\n\t@property({type: Boolean})\n\ttoolbarDisabled = false;\n\n\t@property({type: Boolean})\n\tstatusbarDisabled = false;\n\n\t@property({type: Boolean})\n\tformulabarDisabled = false;\n\n\t@property({type: Object})\n\toptions = initOptions();\n\n\t@property({type: String})\n\trightSidebarComponent: SidebarComponentType; // = 'names';\n\t\n\t@state()\n\tgridElements: ElementModel[];\n\n\t@state()\n\tactiveRange: CellRange;\n\t\n\t@state()\n\tactiveGrid: Grid;\n\n\t@state()\n\tactiveModel: GridModel;\n\n\tgridContainer: GridGroup;\n\tget group() { return this.gridContainer }\n\t\n\tprivate commandWindowRef = createRef<CommandWindow>();\n\tget commandWindow() { return this.commandWindowRef.value }\n\n\tprivate tabMenuRef = createRef<Menu>();\n\tget tabMenu() { return this.tabMenuRef.value }\n\t\n\tprivate activeMenuSheet: string;\n\n\treadonly plugins = new Plugins<Editor>(this);\n\treadonly commands = new CommandManager(this);\n\treadonly shortcuts = new ShortcutManager(this);\n\t\n\treadonly sidebarComponents = new ComponentStore<SidebarComponent>(async (id: ComponentId) => {\n\t\tlet component: SidebarComponent;\n\t\tswitch (id) {\n\t\t\tcase 'config': component = dom.createElement<SidebarComponent>('og-editor-form-config'); break;\n\t\t\tcase 'headers': component = dom.createElement<SidebarComponent>('og-editor-form-headers'); break;\n\t\t\tcase 'rules': component = dom.createElement<SidebarComponent>('og-editor-rules'); break;\n\t\t\tcase 'sparklines': component = dom.createElement<SidebarComponent>('og-editor-form-sparklines'); break;\n\t\t\tcase 'names': component = dom.createElement<SidebarComponent>('og-editor-form-names'); break;\n\t\t\tcase 'themes': component = dom.createElement<ThemeEditorSidebar>('og-editor-themesidebar'); break;\n\t\t\tdefault : component = this.createComponent ? await this.createComponent(id) as SidebarComponent : null;\n\t\t}\n\n\t\tif (!component) return null;\n\n\t\tif (this.activeGrid) {\n\t\t\tcomponent.grid = this.activeGrid;\n\t\t\tcomponent.range = this.activeGrid.selection.range;\n\t\t}\n\t\tif (this.activeModel) component.model = this.activeModel;\n\t\tif (this.gridContainer) component.group = this.gridContainer;\n\t\treturn component;\n\t});\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis.addEventListener('dragover', this._onDragover);\n\t\tthis.addEventListener('dragleave', () => this.overlay.hide());\n\t\tthis.addEventListener('drop', () => this.overlay.hide());\n\t\tinitEditorCommands(this);\n\t\tthis.shortcuts.register('F1', 'open_commands');\n\t\tthis.shortcuts.addEventListener('shortcut', (e: ShortcutEvent) => {\n\t\t\tif (e.action == 'open_commands') {\n\t\t\t\tthis.commands.open();\n\t\t\t}\n\t\t});\n\t}\n\n\tupdateOptions(options: Partial<Options>) {\n\t\tthis.options = initOptions(options, this.options);\n\t\tthis.requestUpdate();\n\t}\n\n\t_onDragover = (e: DragEvent) => {\n\t\tif (!this.enableDrag) return;\n\t\te.preventDefault();\n\t\te.stopPropagation();\n\t\tif (e.dataTransfer.types[0] == 'Files') {\n\t\t\te.dataTransfer.dropEffect = 'move';\n\t\t\tthis.overlay.text = 'drop file';\n\t\t\tthis.overlay.show(this);\n\t\t}\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback();\n\t\tthis.tabIndex = 0;\n\t}\n\n\twillUpdate(props: Map<PropertyKey, unknown>) {\n\t\tif (!this.hasUpdated) {\n\t\t\tthis.dispatchEvent(new EditorEvent('init', {editor: this}));\n\t\t}\n\t\tif (props.has('model')) this.gridContainer = null;\n\t}\n\n\tupdated(props: Map<PropertyKey, unknown>) {\n\t\tthis.updateComponents();\n\t\tif (props.has('toolbarDisabled') || props.has('formulabarDisabled')) this.layout();\n\t}\n\n\tupdateComponents() {\n\t\tthis.sidebarComponents.items.forEach(c => {\n\t\t\tc.grid = this.activeGrid;\n\t\t\tc.model = this.activeModel;\n\t\t\tc.group = this.gridContainer;\n\t\t\tc.range = this.activeGrid?.selection?.range.clone()\n\t\t});\n\t}\n\n\tsetSourceData(sourceData: GroupModelSource) {\n\t\tconst container = this.getGridContainer();\n\t\tsourceData.models?.forEach(m => {\n\t\t\tm.options ??= {};\n\t\t\tm.options.commandWindow = false;\n\t\t});\n\t\tcontainer.setSourceData(sourceData);\n\t\tthis.activeGrid = this.gridContainer?.grids?.entries().next().value;\n\t\tthis.activeModel = this.activeGrid?.model;\n\t}\n\n\tupdateCommands() {\n\t\tthis.activeGrid.commands.commands.forEach(c => this.commands.add(c));\n\t}\n\t\n\tlayout() {\n\t\tthis.container?.layout();\n\t}\n\n\tupdateSelectedRange(range: CellRange) {\n\t\tconst m = this.activeGrid.model;\n\t\tif (range.isColumn) {\n\t\t\tthis.gridElements = [...Array(range.size.columns).keys()].map(c => m.columns[c + range.c1]);\n\t\t} else if (range.isRow) {\n\t\t\tthis.gridElements = [...Array(range.size.rows).keys()].map(r => m.rows[r + range.r1]);\n\t\t} else {\n\t\t\tthis.gridElements = m.getCellArray( this.activeGrid.selection.range);\n\t\t}\n\t\tthis.statusbar.grid = this.activeGrid;\n\t\tthis.statusbar.range = range.clone();\n\t}\n\n\tactivateGrid(grid: Grid) {\n\t\tif (!grid) return;\n\t\tthis.activeGrid = grid;\n\t\tthis.activeModel = grid.model;\n\t}\n\n\t_onGridSelect = async (e: GridEvent) => {\n\t\tif (this.gridContainer.isFormulaMode) return;\n\n\t\tthis.activateGrid(e.composedPath().find(elm => elm instanceof Grid) as Grid);\n\t\t\n\t\tif (this.rightSidebarComponent == 'headers') {\n\t\t\tconst headerForm = await this.sidebarComponents.get('headers');\n\t\t\theaderForm.grid = this.activeGrid;\n\t\t\theaderForm.range = this.activeGrid.selection.range.clone();\n\t\t}\n\n\t\tthis.updateSelectedRange(e.selection.range);\n\t}\n\n\t_onGridEdit = (e: GridEditEvent) => {\n\t\tswitch (e.editType) {\n\t\t\tcase 'delete_column':\n\t\t\tcase 'delete_row':\n\t\t\tcase 'insert_column':\n\t\t\tcase 'insert_row':\n\t\t\t\tthis.updateSelectedRange(e.selection.range);\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\tregisterPlugin(plugin: Plugin<Editor>) {\n\t\tthis.plugins.register(plugin);\n\t}\n\n\t_onTabContextMenu = (e: TabEvent) => {\n\t\tconst uiEvent = e.uiEvent as MouseEvent;\n\t\tthis.activeMenuSheet = e.tab.id as string\n\t\tthis.tabMenu.openAt(uiEvent.pageX, uiEvent.pageY + 1);\n\t}\n\n\tcreateGridContainer = () => {\n\t\tconst container = dom.createElement<GridGroup>('og-gridgroup');\n\t\tcontainer.tabPosition = 'bottom';\n\t\tcontainer.designMode = true;\n\t\tcontainer.model = this.model;\n\t\tcontainer.options.commandWindow = false;\n\t\tcontainer.addEventListener('gridgroup.activate', () => {\n\t\t\tif (this.gridContainer.isFormulaMode) return;\n\t\t\tthis.activateGrid(this.gridContainer.activeGrid);\n\t\t\tthis.updateCommands();\n\t\t\tthis.updateComponents();\n\t\t});\n\t\tcontainer.addEventListener('tab.contextmenu', this._onTabContextMenu);\n\t\tcontainer.addEventListener('grid.select', this._onGridSelect);\n\t\tcontainer.addEventListener('grid.edit', this._onGridEdit);\n\t\treturn container;\n\t}\n\n\tgetGridContainer() {\n\t\treturn this.gridContainer ?? (this.gridContainer = this.createGridContainer());\n\t}\n\n\tcreateDefaultComponent: ComponentFactory = (index: ComponentId) => {\n\t\tif (index == 0) {\n\t\t\treturn this.getGridContainer();\n\t\t} else if (index == 1) {\n\t\t\treturn this.sidebarComponents.get(this.rightSidebarComponent);\n\t\t}\n\t}\n\n\t_onToolbarAction = (_e: actions.ActionEvent) => {\n\t\t// if (e.action.key == 'config') {\n\t\t// \tthis.rightSidebarComponent = e.action.value ? e.action.key : null;\n\t\t// }\n\t}\n\n\t_onCommandsOpen = () => {\n\t\t// this.commandWindow.requestUpdate();\n\t}\n\n\t_onTabMenuItemSelect = (e: ListSelectEvent) => {\n\t\tswitch (this.tabMenu.items[e.index].key) {\n\t\t\tcase 'properties':\n\t\t\t\tthis.activateGrid(this.gridContainer.grids.get(this.activeMenuSheet));\n\t\t\t\tthis.rightSidebarComponent = 'config';\n\t\t\t\tbreak;\n\t\t\tcase 'delete':\n\t\t\t\tthis.gridContainer.deleteModel(this.activeMenuSheet);\n\t\t\t\tbreak;\n\t\t\tcase 'duplicate':\n\t\t\t\tthis.gridContainer.duplicateModel(this.activeMenuSheet);\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\trender = () => html`\n\t\t${this.toolbarDisabled ? '' : html`\n\t\t\t<og-editor-toolbar\n\t\t\t\t.grid=\"${this.activeGrid}\"\n\t\t\t\t.gridElements=${this.gridElements}\n\t\t\t\t.editor=\"${this}\"\n\t\t\t\t@toolbar.action=\"${this._onToolbarAction}\">\n\t\t\t</og-editor-toolbar>\n\t\t`}\n\t\t\n\t\t${this.toolbarDisabled ? '' : html`\n\t\t\t<og-editor-formula .grid=\"${this.activeGrid}\"></og-editor-formula>\n\t\t`}\n\n\t\t${guard([this.rightSidebarComponent], () => html`\n\t\t\t<og-splitcontainer \n\t\t\t\t.items=\"${[{}, {size: 300, collapsed: !this.rightSidebarComponent}]}\"\n\t\t\t\t.createComponent=\"${this.createDefaultComponent}\">\n\t\t\t</og-splitcontainer>\n\t\t`)}\n\n\t\t${this.statusbarDisabled ? '' : html`\n\t\t\t<og-editor-statusbar\n\t\t\t\t.group=\"${this.getGridContainer()}\"\n\t\t\t\t.grid=\"${this.activeGrid}\"\n\t\t\t\t.range=\"${this.activeRange}\">\n\t\t\t</og-editor-statusbar>\n\t\t`}\n\n\t\t<og-menu ${ref(this.tabMenuRef)}\n\t\t\tstyle=\"display: none; z-index: 20000\"\n\t\t\t@select=${this._onTabMenuItemSelect}\n\t\t\t.items=${[\n\t\t\t\t{key: 'properties', value: 'Properties', icon: 'pen'},\n\t\t\t\t{key: 'duplicate', value: 'Duplicate', icon: 'copy'},\n\t\t\t\t{key: 'delete', value: 'Delete', icon: 'trash'},\n\t\t\t]}>\n\t\t</og-menu>\n\n\t\t<og-overlay striped></og-overlay>\n\t`;\n\n}"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"editor.style.d.ts","sourceRoot":"","sources":["../../src/ui/editor.style.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,KAAK,yBAmCjB,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { css } from 'lit';
|
|
2
|
+
export const style = css `
|
|
3
|
+
:host {
|
|
4
|
+
box-sizing: border-box;
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-direction: column;
|
|
7
|
+
position: relative;
|
|
8
|
+
-webkit-user-select: none;
|
|
9
|
+
user-select: none;
|
|
10
|
+
height: 100%;
|
|
11
|
+
color: var(--og-text-color);
|
|
12
|
+
background-color: var(--og-background-color);
|
|
13
|
+
font-family: var(--og-font-family);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.toolbar {
|
|
17
|
+
display: flex;
|
|
18
|
+
flex-direction: row;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
og-splitcontainer {
|
|
22
|
+
flex: 1;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
og-editor-toolbar, og-editor-formula {
|
|
26
|
+
flex: 0;
|
|
27
|
+
//min-height: 30px;
|
|
28
|
+
height: 30px;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
og-overlay {
|
|
32
|
+
position: absolute;
|
|
33
|
+
top: 0;
|
|
34
|
+
left: 0;
|
|
35
|
+
//pointer-events: none;
|
|
36
|
+
}
|
|
37
|
+
`;
|
|
38
|
+
//# sourceMappingURL=editor.style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"editor.style.js","sourceRoot":"","sources":["../../src/ui/editor.style.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,KAAK,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmCvB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const style = css`\n\t:host {\n\t\tbox-sizing: border-box;\n\t\tdisplay: flex;\n\t\tflex-direction: column;\n\t\tposition: relative;\n\t\t-webkit-user-select: none;\n\t\tuser-select: none;\n\t\theight: 100%;\n\t\tcolor: var(--og-text-color);\n\t\tbackground-color: var(--og-background-color);\n\t\tfont-family: var(--og-font-family);\n\t}\n\n\t.toolbar {\n\t\tdisplay: flex;\n\t\tflex-direction: row;\n\t}\n\n\tog-splitcontainer {\n\t\tflex: 1;\n\t}\n\n\tog-editor-toolbar, og-editor-formula {\n\t\tflex: 0;\n\t\t//min-height: 30px;\n\t\theight: 30px;\n\t}\n\n\tog-overlay {\n\t\tposition: absolute;\n\t\ttop: 0;\n\t\tleft: 0;\n\t\t//pointer-events: none;\n\t}\n`;"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { GridGroup } from '@omegagrid/grid';
|
|
2
|
+
import { LitElement } from 'lit';
|
|
3
|
+
import { SlideEvent, Slider } from '@omegagrid/core';
|
|
4
|
+
export declare class EditorZoom extends LitElement {
|
|
5
|
+
static styles: import("lit").CSSResult[];
|
|
6
|
+
group: GridGroup;
|
|
7
|
+
slider: Slider;
|
|
8
|
+
translateValue(value: number): number;
|
|
9
|
+
updateText(value: number): void;
|
|
10
|
+
_onSlideStart: (_e: SlideEvent) => void;
|
|
11
|
+
_onSlide: (e: SlideEvent) => void;
|
|
12
|
+
_onSlideEnd: (e: SlideEvent) => void;
|
|
13
|
+
updated(): Promise<void>;
|
|
14
|
+
render: () => import("lit-html").TemplateResult<1>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=editorZoom.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"editorZoom.d.ts","sourceRoot":"","sources":["../../src/ui/editorZoom.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAa,MAAM,KAAK,CAAC;AAE5C,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAErD,qBACa,UAAW,SAAQ,UAAU;IAEzC,MAAM,CAAC,MAAM,4BAeV;IAGH,KAAK,EAAE,SAAS,CAAC;IAGjB,MAAM,EAAE,MAAM,CAAC;IAEf,cAAc,CAAC,KAAK,EAAE,MAAM;IAI5B,UAAU,CAAC,KAAK,EAAE,MAAM;IAIxB,aAAa,GAAI,IAAI,UAAU,UAE9B;IAED,QAAQ,GAAI,GAAG,UAAU,UAGxB;IAED,WAAW,GAAI,GAAG,UAAU,UAK3B;IAEK,OAAO;IAYb,MAAM,6CAYJ;CAEF"}
|