@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.
Files changed (141) hide show
  1. package/dist/commands/index.d.ts +3 -0
  2. package/dist/commands/index.d.ts.map +1 -0
  3. package/dist/commands/index.js +34 -0
  4. package/dist/commands/index.js.map +1 -0
  5. package/dist/index.d.ts +3 -0
  6. package/dist/index.d.ts.map +1 -0
  7. package/dist/index.js +2 -0
  8. package/dist/index.js.map +1 -0
  9. package/dist/options.d.ts +12 -0
  10. package/dist/options.d.ts.map +1 -0
  11. package/dist/options.js +14 -0
  12. package/dist/options.js.map +1 -0
  13. package/dist/ui/editor.d.ts +76 -0
  14. package/dist/ui/editor.d.ts.map +1 -0
  15. package/dist/ui/editor.js +338 -0
  16. package/dist/ui/editor.js.map +1 -0
  17. package/dist/ui/editor.style.d.ts +2 -0
  18. package/dist/ui/editor.style.d.ts.map +1 -0
  19. package/dist/ui/editor.style.js +38 -0
  20. package/dist/ui/editor.style.js.map +1 -0
  21. package/dist/ui/editorZoom.d.ts +16 -0
  22. package/dist/ui/editorZoom.d.ts.map +1 -0
  23. package/dist/ui/editorZoom.js +82 -0
  24. package/dist/ui/editorZoom.js.map +1 -0
  25. package/dist/ui/editors/hyperlinkEditor.d.ts +10 -0
  26. package/dist/ui/editors/hyperlinkEditor.d.ts.map +1 -0
  27. package/dist/ui/editors/hyperlinkEditor.js +70 -0
  28. package/dist/ui/editors/hyperlinkEditor.js.map +1 -0
  29. package/dist/ui/editors/index.d.ts +6 -0
  30. package/dist/ui/editors/index.d.ts.map +1 -0
  31. package/dist/ui/editors/index.js +6 -0
  32. package/dist/ui/editors/index.js.map +1 -0
  33. package/dist/ui/editors/ruleEditor.d.ts +27 -0
  34. package/dist/ui/editors/ruleEditor.d.ts.map +1 -0
  35. package/dist/ui/editors/ruleEditor.js +251 -0
  36. package/dist/ui/editors/ruleEditor.js.map +1 -0
  37. package/dist/ui/editors/styleEditor.d.ts +14 -0
  38. package/dist/ui/editors/styleEditor.d.ts.map +1 -0
  39. package/dist/ui/editors/styleEditor.js +160 -0
  40. package/dist/ui/editors/styleEditor.js.map +1 -0
  41. package/dist/ui/editors/themeEditor.d.ts +24 -0
  42. package/dist/ui/editors/themeEditor.d.ts.map +1 -0
  43. package/dist/ui/editors/themeEditor.js +138 -0
  44. package/dist/ui/editors/themeEditor.js.map +1 -0
  45. package/dist/ui/editors/themeItemEditor.d.ts +22 -0
  46. package/dist/ui/editors/themeItemEditor.d.ts.map +1 -0
  47. package/dist/ui/editors/themeItemEditor.js +181 -0
  48. package/dist/ui/editors/themeItemEditor.js.map +1 -0
  49. package/dist/ui/forms/configForm.d.ts +12 -0
  50. package/dist/ui/forms/configForm.d.ts.map +1 -0
  51. package/dist/ui/forms/configForm.js +101 -0
  52. package/dist/ui/forms/configForm.js.map +1 -0
  53. package/dist/ui/forms/headerForm.d.ts +18 -0
  54. package/dist/ui/forms/headerForm.d.ts.map +1 -0
  55. package/dist/ui/forms/headerForm.js +144 -0
  56. package/dist/ui/forms/headerForm.js.map +1 -0
  57. package/dist/ui/forms/index.d.ts +9 -0
  58. package/dist/ui/forms/index.d.ts.map +1 -0
  59. package/dist/ui/forms/index.js +9 -0
  60. package/dist/ui/forms/index.js.map +1 -0
  61. package/dist/ui/forms/namesForm.d.ts +21 -0
  62. package/dist/ui/forms/namesForm.d.ts.map +1 -0
  63. package/dist/ui/forms/namesForm.js +124 -0
  64. package/dist/ui/forms/namesForm.js.map +1 -0
  65. package/dist/ui/forms/ruleForm.d.ts +13 -0
  66. package/dist/ui/forms/ruleForm.d.ts.map +1 -0
  67. package/dist/ui/forms/ruleForm.js +56 -0
  68. package/dist/ui/forms/ruleForm.js.map +1 -0
  69. package/dist/ui/forms/ruleForm.style.d.ts +2 -0
  70. package/dist/ui/forms/ruleForm.style.d.ts.map +1 -0
  71. package/dist/ui/forms/ruleForm.style.js +50 -0
  72. package/dist/ui/forms/ruleForm.style.js.map +1 -0
  73. package/dist/ui/forms/ruleFormThreshold.d.ts +19 -0
  74. package/dist/ui/forms/ruleFormThreshold.d.ts.map +1 -0
  75. package/dist/ui/forms/ruleFormThreshold.js +97 -0
  76. package/dist/ui/forms/ruleFormThreshold.js.map +1 -0
  77. package/dist/ui/forms/ruleList.d.ts +25 -0
  78. package/dist/ui/forms/ruleList.d.ts.map +1 -0
  79. package/dist/ui/forms/ruleList.js +169 -0
  80. package/dist/ui/forms/ruleList.js.map +1 -0
  81. package/dist/ui/forms/ruleList.style.d.ts +3 -0
  82. package/dist/ui/forms/ruleList.style.d.ts.map +1 -0
  83. package/dist/ui/forms/ruleList.style.js +69 -0
  84. package/dist/ui/forms/ruleList.style.js.map +1 -0
  85. package/dist/ui/forms/sparklineForm.d.ts +22 -0
  86. package/dist/ui/forms/sparklineForm.d.ts.map +1 -0
  87. package/dist/ui/forms/sparklineForm.js +199 -0
  88. package/dist/ui/forms/sparklineForm.js.map +1 -0
  89. package/dist/ui/forms/sparklineForm.style.d.ts +3 -0
  90. package/dist/ui/forms/sparklineForm.style.d.ts.map +1 -0
  91. package/dist/ui/forms/sparklineForm.style.js +94 -0
  92. package/dist/ui/forms/sparklineForm.style.js.map +1 -0
  93. package/dist/ui/forms/styleForm.d.ts +14 -0
  94. package/dist/ui/forms/styleForm.d.ts.map +1 -0
  95. package/dist/ui/forms/styleForm.js +151 -0
  96. package/dist/ui/forms/styleForm.js.map +1 -0
  97. package/dist/ui/formulabar.d.ts +23 -0
  98. package/dist/ui/formulabar.d.ts.map +1 -0
  99. package/dist/ui/formulabar.js +155 -0
  100. package/dist/ui/formulabar.js.map +1 -0
  101. package/dist/ui/formulabar.style.d.ts +2 -0
  102. package/dist/ui/formulabar.style.d.ts.map +1 -0
  103. package/dist/ui/formulabar.style.js +48 -0
  104. package/dist/ui/formulabar.style.js.map +1 -0
  105. package/dist/ui/gridStats.d.ts +11 -0
  106. package/dist/ui/gridStats.d.ts.map +1 -0
  107. package/dist/ui/gridStats.js +71 -0
  108. package/dist/ui/gridStats.js.map +1 -0
  109. package/dist/ui/index.d.ts +11 -0
  110. package/dist/ui/index.d.ts.map +1 -0
  111. package/dist/ui/index.js +11 -0
  112. package/dist/ui/index.js.map +1 -0
  113. package/dist/ui/sidebars/baseSidebar.d.ts +10 -0
  114. package/dist/ui/sidebars/baseSidebar.d.ts.map +1 -0
  115. package/dist/ui/sidebars/baseSidebar.js +24 -0
  116. package/dist/ui/sidebars/baseSidebar.js.map +1 -0
  117. package/dist/ui/sidebars/index.d.ts +2 -0
  118. package/dist/ui/sidebars/index.d.ts.map +1 -0
  119. package/dist/ui/sidebars/index.js +2 -0
  120. package/dist/ui/sidebars/index.js.map +1 -0
  121. package/dist/ui/sidebars/themeEditorSidebar.d.ts +14 -0
  122. package/dist/ui/sidebars/themeEditorSidebar.d.ts.map +1 -0
  123. package/dist/ui/sidebars/themeEditorSidebar.js +110 -0
  124. package/dist/ui/sidebars/themeEditorSidebar.js.map +1 -0
  125. package/dist/ui/statusbar.d.ts +19 -0
  126. package/dist/ui/statusbar.d.ts.map +1 -0
  127. package/dist/ui/statusbar.js +69 -0
  128. package/dist/ui/statusbar.js.map +1 -0
  129. package/dist/ui/toolbar.config.d.ts +7 -0
  130. package/dist/ui/toolbar.config.d.ts.map +1 -0
  131. package/dist/ui/toolbar.config.js +166 -0
  132. package/dist/ui/toolbar.config.js.map +1 -0
  133. package/dist/ui/toolbar.d.ts +42 -0
  134. package/dist/ui/toolbar.d.ts.map +1 -0
  135. package/dist/ui/toolbar.js +356 -0
  136. package/dist/ui/toolbar.js.map +1 -0
  137. package/dist/ui/toolbar.style.d.ts +2 -0
  138. package/dist/ui/toolbar.style.d.ts.map +1 -0
  139. package/dist/ui/toolbar.style.js +22 -0
  140. package/dist/ui/toolbar.style.js.map +1 -0
  141. package/package.json +10 -10
@@ -0,0 +1,3 @@
1
+ import { Editor } from "../ui";
2
+ export declare function initEditorCommands(editor: Editor): void;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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}"]}
@@ -0,0 +1,3 @@
1
+ export * from './ui';
2
+ export { Options as EditorOptions } from './options';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export * from './ui';
2
+ //# sourceMappingURL=index.js.map
@@ -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"}
@@ -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,2 @@
1
+ export declare const style: import("lit").CSSResult;
2
+ //# sourceMappingURL=editor.style.d.ts.map
@@ -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"}