mce 0.1.4 → 0.2.1

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/README.md CHANGED
@@ -18,7 +18,7 @@
18
18
  </a>
19
19
  </p>
20
20
 
21
- <p align="center">Modern canvas editor, based modern-canvas and Vue.js. only the ESM.</p>
21
+ <p align="center">The headless canvas editor framework. only the ESM.</p>
22
22
 
23
23
  ## 📦 Install
24
24
 
@@ -30,7 +30,7 @@ npm i mce
30
30
 
31
31
  ```vue
32
32
  <script setup lang="ts">
33
- import { Drawboard, Editor } from 'mce'
33
+ import { Editor, EditorLayout, EditorLayoutItem } from 'mce'
34
34
  import 'mce/styles'
35
35
 
36
36
  const editor = new Editor({
@@ -42,7 +42,6 @@ npm i mce
42
42
  camera: true,
43
43
  ruler: true,
44
44
  scrollbar: true,
45
- bottombar: true,
46
45
  statusbar: true,
47
46
  wheelZoom: false,
48
47
  frameGap: 48,
@@ -85,23 +84,15 @@ npm i mce
85
84
 
86
85
  <template>
87
86
  <div style="width: 100vw; height: 100vh">
88
- <Drawboard :editor="editor">
89
- <template #selector="{ box }">
90
- Selector
91
- </template>
92
-
93
- <template #transformer="{ box }">
94
- <text>Transformer(in SVG)</text>
95
- </template>
96
-
97
- <template #floatbar>
98
- Floatbar
99
- </template>
100
-
101
- <template #bottombar>
102
- Bottombar
103
- </template>
104
- </Drawboard>
87
+ <EditorLayout :editor="editor">
88
+ <template #selector="{ box }" />
89
+ <template #transformer="{ box }" />
90
+ <template #floatbar />
91
+ <template #drawboard />
92
+ <EditorLayoutItem model-value position="top" :size="56" />
93
+ <EditorLayoutItem model-value position="left" :size="380" />
94
+ <EditorLayoutItem model-value position="right" :size="260" />
95
+ </EditorLayout>
105
96
  </div>
106
97
  </template>
107
98
  ```
@@ -111,12 +102,12 @@ slot sub component
111
102
  ```vue
112
103
  <script setup lang="ts">
113
104
  import { useEditor } from 'mce'
114
- const { activeElement } = useEditor()
105
+ const { selection } = useEditor()
115
106
  </script>
116
107
 
117
108
  <template>
118
109
  <div>
119
- {{ activeElement }}
110
+ {{ selection }}
120
111
  </div>
121
112
  </template>
122
113
  ```
@@ -8,7 +8,7 @@ type __VLS_Slots = {
8
8
  box: Partial<OrientedBoundingBox>;
9
9
  }) => void;
10
10
  floatbar?: () => void;
11
- bottombar?: () => void;
11
+ drawboard?: () => void;
12
12
  default?: () => void;
13
13
  };
14
14
  declare const __VLS_base: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
@@ -1,18 +1,18 @@
1
1
  declare const __VLS_export: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
2
2
  icon: {
3
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
3
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
4
4
  };
5
5
  tag: {
6
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
6
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
7
7
  default: string;
8
8
  };
9
9
  disabled: BooleanConstructor;
10
10
  }>, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
11
11
  icon: {
12
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
12
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
13
13
  };
14
14
  tag: {
15
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
15
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
16
16
  default: string;
17
17
  };
18
18
  disabled: BooleanConstructor;
@@ -0,0 +1,40 @@
1
+ declare var __VLS_1: {};
2
+ type __VLS_Slots = {} & {
3
+ default?: (props: typeof __VLS_1) => any;
4
+ };
5
+ declare const __VLS_base: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
6
+ overlaps: import("vue").Prop<string[]>;
7
+ fullHeight: BooleanConstructor;
8
+ }>, {
9
+ items: import("vue").ComputedRef<{
10
+ size: number;
11
+ position: import("../..").Position;
12
+ top: number;
13
+ bottom: number;
14
+ left: number;
15
+ right: number;
16
+ id: string;
17
+ }[]>;
18
+ getLayoutItem: (id: string) => {
19
+ size: number;
20
+ position: import("../..").Position;
21
+ top: number;
22
+ bottom: number;
23
+ left: number;
24
+ right: number;
25
+ id: string;
26
+ } | undefined;
27
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
28
+ overlaps: import("vue").Prop<string[]>;
29
+ fullHeight: BooleanConstructor;
30
+ }>> & Readonly<{}>, {
31
+ fullHeight: boolean;
32
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
33
+ declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
34
+ declare const _default: typeof __VLS_export;
35
+ export default _default;
36
+ type __VLS_WithSlots<T, S> = T & {
37
+ new (): {
38
+ $slots: S;
39
+ };
40
+ };
@@ -0,0 +1,55 @@
1
+ import type { PropType } from 'vue';
2
+ declare var __VLS_1: {};
3
+ type __VLS_Slots = {} & {
4
+ default?: (props: typeof __VLS_1) => any;
5
+ };
6
+ declare const __VLS_base: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
7
+ name: {
8
+ type: StringConstructor;
9
+ };
10
+ order: {
11
+ type: (NumberConstructor | StringConstructor)[];
12
+ default: number;
13
+ };
14
+ absolute: BooleanConstructor;
15
+ position: {
16
+ type: PropType<"top" | "right" | "bottom" | "left">;
17
+ required: true;
18
+ };
19
+ size: {
20
+ type: (NumberConstructor | StringConstructor)[];
21
+ default: number;
22
+ };
23
+ modelValue: BooleanConstructor;
24
+ }>, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
25
+ name: {
26
+ type: StringConstructor;
27
+ };
28
+ order: {
29
+ type: (NumberConstructor | StringConstructor)[];
30
+ default: number;
31
+ };
32
+ absolute: BooleanConstructor;
33
+ position: {
34
+ type: PropType<"top" | "right" | "bottom" | "left">;
35
+ required: true;
36
+ };
37
+ size: {
38
+ type: (NumberConstructor | StringConstructor)[];
39
+ default: number;
40
+ };
41
+ modelValue: BooleanConstructor;
42
+ }>> & Readonly<{}>, {
43
+ size: string | number;
44
+ absolute: boolean;
45
+ order: string | number;
46
+ modelValue: boolean;
47
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
48
+ declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
49
+ declare const _default: typeof __VLS_export;
50
+ export default _default;
51
+ type __VLS_WithSlots<T, S> = T & {
52
+ new (): {
53
+ $slots: S;
54
+ };
55
+ };
@@ -0,0 +1,21 @@
1
+ declare var __VLS_1: {}, __VLS_3: {};
2
+ type __VLS_Slots = {} & {
3
+ default?: (props: typeof __VLS_1) => any;
4
+ } & {
5
+ default?: (props: typeof __VLS_3) => any;
6
+ };
7
+ declare const __VLS_base: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
8
+ scrollable: BooleanConstructor;
9
+ }>, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
10
+ scrollable: BooleanConstructor;
11
+ }>> & Readonly<{}>, {
12
+ scrollable: boolean;
13
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
14
+ declare const __VLS_export: __VLS_WithSlots<typeof __VLS_base, __VLS_Slots>;
15
+ declare const _default: typeof __VLS_export;
16
+ export default _default;
17
+ type __VLS_WithSlots<T, S> = T & {
18
+ new (): {
19
+ $slots: S;
20
+ };
21
+ };
@@ -1,3 +1,3 @@
1
1
  import { Editor } from '../editor';
2
2
  export declare function useEditor(): Editor;
3
- export declare function provideEditor(): Editor;
3
+ export declare function provideEditor(editor?: Editor): Editor;
@@ -2,29 +2,29 @@ import type { Component, MaybeRefOrGetter } from 'vue';
2
2
  export type IconValue = string | (string | [path: string, opacity: number])[] | Component;
3
3
  export declare function makeIconProps(): {
4
4
  icon: {
5
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
5
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
6
6
  };
7
7
  tag: {
8
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
8
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
9
9
  default: string;
10
10
  };
11
11
  };
12
12
  export declare const MceSvgIcon: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
13
13
  icon: {
14
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
14
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
15
15
  };
16
16
  tag: {
17
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
17
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
18
18
  default: string;
19
19
  };
20
20
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
21
21
  [key: string]: any;
22
22
  }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
23
23
  icon: {
24
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
24
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
25
25
  };
26
26
  tag: {
27
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
27
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
28
28
  default: string;
29
29
  };
30
30
  }>> & Readonly<{}>, {
@@ -32,20 +32,20 @@ export declare const MceSvgIcon: import("vue").DefineComponent<import("vue").Ext
32
32
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
33
33
  export declare const MceComponentIcon: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
34
34
  icon: {
35
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
35
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
36
36
  };
37
37
  tag: {
38
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
38
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
39
39
  default: string;
40
40
  };
41
41
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
42
42
  [key: string]: any;
43
43
  }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
44
44
  icon: {
45
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
45
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
46
46
  };
47
47
  tag: {
48
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
48
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
49
49
  default: string;
50
50
  };
51
51
  }>> & Readonly<{}>, {
@@ -55,20 +55,20 @@ export declare function useIcon(props: MaybeRefOrGetter<IconValue | undefined>):
55
55
  iconData: import("vue").ComputedRef<{
56
56
  component: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
57
57
  icon: {
58
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
58
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
59
59
  };
60
60
  tag: {
61
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
61
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
62
62
  default: string;
63
63
  };
64
64
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
65
65
  [key: string]: any;
66
66
  }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
67
67
  icon: {
68
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
68
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
69
69
  };
70
70
  tag: {
71
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
71
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
72
72
  default: string;
73
73
  };
74
74
  }>> & Readonly<{}>, {
@@ -78,20 +78,20 @@ export declare function useIcon(props: MaybeRefOrGetter<IconValue | undefined>):
78
78
  } | {
79
79
  component: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
80
80
  icon: {
81
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
81
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
82
82
  };
83
83
  tag: {
84
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
84
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
85
85
  default: string;
86
86
  };
87
87
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
88
88
  [key: string]: any;
89
89
  }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
90
90
  icon: {
91
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
91
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
92
92
  };
93
93
  tag: {
94
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
94
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
95
95
  default: string;
96
96
  };
97
97
  }>> & Readonly<{}>, {
@@ -1,6 +1,8 @@
1
1
  export * from './editor';
2
2
  export * from './icon';
3
3
  export * from './icons';
4
+ export * from './layout';
4
5
  export * from './menu';
5
6
  export * from './overlay';
7
+ export * from './resizeObserver';
6
8
  export * from './strategy';
@@ -0,0 +1,133 @@
1
+ import type { ComponentInternalInstance, CSSProperties, InjectionKey, Prop, Ref } from 'vue';
2
+ export type Position = 'top' | 'left' | 'right' | 'bottom';
3
+ interface Layer {
4
+ top: number;
5
+ bottom: number;
6
+ left: number;
7
+ right: number;
8
+ }
9
+ interface LayoutItem extends Layer {
10
+ id: string;
11
+ size: number;
12
+ position: Position;
13
+ }
14
+ interface LayoutProvide {
15
+ register: (vm: ComponentInternalInstance, options: {
16
+ id: string;
17
+ order: Ref<number>;
18
+ position: Ref<Position>;
19
+ layoutSize: Ref<number | string>;
20
+ elementSize: Ref<number | string | undefined>;
21
+ active: Ref<boolean>;
22
+ disableTransitions?: Ref<boolean>;
23
+ absolute: Ref<boolean | undefined>;
24
+ }) => {
25
+ layoutItemStyles: Ref<CSSProperties>;
26
+ layoutItemScrimStyles: Ref<CSSProperties>;
27
+ zIndex: Ref<number>;
28
+ };
29
+ unregister: (id: string) => void;
30
+ mainRect: Ref<Layer>;
31
+ mainStyles: Ref<CSSProperties>;
32
+ getLayoutItem: (id: string) => LayoutItem | undefined;
33
+ items: Ref<LayoutItem[]>;
34
+ layoutRect: Ref<DOMRectReadOnly | undefined>;
35
+ rootZIndex: Ref<number>;
36
+ }
37
+ export declare const MceLayoutKey: InjectionKey<LayoutProvide>;
38
+ export declare const MceLayoutItemKey: InjectionKey<{
39
+ id: string;
40
+ }>;
41
+ export declare function makeLayoutProps(): {
42
+ overlaps: Prop<string[]>;
43
+ fullHeight: BooleanConstructor;
44
+ };
45
+ export declare function makeLayoutItemProps(): {
46
+ name: {
47
+ type: StringConstructor;
48
+ };
49
+ order: {
50
+ type: (NumberConstructor | StringConstructor)[];
51
+ default: number;
52
+ };
53
+ absolute: BooleanConstructor;
54
+ };
55
+ export declare function useLayout(): {
56
+ getLayoutItem: (id: string) => LayoutItem | undefined;
57
+ mainRect: Ref<Layer, Layer>;
58
+ mainStyles: Ref<CSSProperties, CSSProperties>;
59
+ };
60
+ export declare function useLayoutItem(options: {
61
+ id: string | undefined;
62
+ order: Ref<number>;
63
+ position: Ref<Position>;
64
+ layoutSize: Ref<number | string>;
65
+ elementSize: Ref<number | string | undefined>;
66
+ active: Ref<boolean>;
67
+ disableTransitions?: Ref<boolean>;
68
+ absolute: Ref<boolean | undefined>;
69
+ }): {
70
+ layoutItemStyles: Ref<CSSProperties, CSSProperties>;
71
+ layoutRect: Ref<DOMRectReadOnly | undefined, DOMRectReadOnly | undefined>;
72
+ layoutItemScrimStyles: Ref<CSSProperties, CSSProperties>;
73
+ };
74
+ export declare function createLayout(props: {
75
+ overlaps?: string[];
76
+ fullHeight?: boolean;
77
+ }): {
78
+ layoutClasses: Readonly<Ref<(string | {
79
+ 'mce-layout--full-height': boolean | undefined;
80
+ })[], (string | {
81
+ 'mce-layout--full-height': boolean | undefined;
82
+ })[]>>;
83
+ layoutStyles: Readonly<Ref<{
84
+ zIndex: number | undefined;
85
+ position: "relative" | undefined;
86
+ overflow: string | undefined;
87
+ }, {
88
+ zIndex: number | undefined;
89
+ position: "relative" | undefined;
90
+ overflow: string | undefined;
91
+ }>>;
92
+ getLayoutItem: (id: string) => {
93
+ size: number;
94
+ position: Position;
95
+ top: number;
96
+ bottom: number;
97
+ left: number;
98
+ right: number;
99
+ id: string;
100
+ } | undefined;
101
+ items: import("vue").ComputedRef<{
102
+ size: number;
103
+ position: Position;
104
+ top: number;
105
+ bottom: number;
106
+ left: number;
107
+ right: number;
108
+ id: string;
109
+ }[]>;
110
+ layoutRect: Readonly<Ref<{
111
+ readonly bottom: number;
112
+ readonly height: number;
113
+ readonly left: number;
114
+ readonly right: number;
115
+ readonly top: number;
116
+ readonly width: number;
117
+ readonly x: number;
118
+ readonly y: number;
119
+ readonly toJSON: () => any;
120
+ } | undefined, {
121
+ readonly bottom: number;
122
+ readonly height: number;
123
+ readonly left: number;
124
+ readonly right: number;
125
+ readonly top: number;
126
+ readonly width: number;
127
+ readonly x: number;
128
+ readonly y: number;
129
+ readonly toJSON: () => any;
130
+ } | undefined>>;
131
+ layoutRef: import("..").TemplateRef;
132
+ };
133
+ export {};
@@ -0,0 +1,8 @@
1
+ import type { DeepReadonly, Ref } from 'vue';
2
+ import type { TemplateRef } from '../utils';
3
+ interface ResizeState {
4
+ resizeRef: TemplateRef;
5
+ contentRect: DeepReadonly<Ref<DOMRectReadOnly | undefined>>;
6
+ }
7
+ export declare function useResizeObserver(callback?: ResizeObserverCallback, box?: 'content' | 'border'): ResizeState;
8
+ export {};
package/dist/editor.d.ts CHANGED
@@ -29,7 +29,6 @@ export declare class Editor extends Observable<Events> {
29
29
  setup: () => Promise<void>;
30
30
  install: (app: App) => void;
31
31
  }
32
- export declare function createEditor(options?: Options): Editor;
33
32
  export interface PluginObject {
34
33
  name: string;
35
34
  ignore?: boolean | (() => boolean);
@@ -3,20 +3,20 @@ export declare const aliases: IconAliases;
3
3
  export declare const svg: {
4
4
  component: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
5
5
  icon: {
6
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
6
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
7
7
  };
8
8
  tag: {
9
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
9
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
10
10
  default: string;
11
11
  };
12
12
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
13
13
  [key: string]: any;
14
14
  }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
15
15
  icon: {
16
- type: (ObjectConstructor | ArrayConstructor | FunctionConstructor | StringConstructor)[];
16
+ type: (ObjectConstructor | ArrayConstructor | StringConstructor | FunctionConstructor)[];
17
17
  };
18
18
  tag: {
19
- type: (ObjectConstructor | FunctionConstructor | StringConstructor)[];
19
+ type: (ObjectConstructor | StringConstructor | FunctionConstructor)[];
20
20
  default: string;
21
21
  };
22
22
  }>> & Readonly<{}>, {
package/dist/index.css CHANGED
@@ -1 +1 @@
1
- .mce-auxiliary{position:absolute;overflow:hidden;inset:0}.mce-auxiliary__alignment{position:absolute;background-color:#ff4aff;height:1px;width:1px}.mce-auxiliary__area{position:absolute;display:flex;align-items:center;justify-content:center;background-color:#f424fd33}.mce-auxiliary__area:before{content:"";background:#1690ff;height:1px;width:100%}.mce-auxiliary__area:after{position:absolute;content:"";height:5px;width:100%;border-left:1px solid #1690ff;border-right:1px solid #1690ff}.mce-auxiliary__area--vertical:before{height:100%;width:1px}.mce-auxiliary__area--vertical:after{height:100%;width:5px;border-left:none;border-right:none;border-top:1px solid #1690ff;border-bottom:1px solid #1690ff}.mce-bottombar{position:absolute}.mce-icon{align-items:center;display:inline-flex;font-feature-settings:"liga";height:1em;justify-content:center;letter-spacing:normal;line-height:1;position:relative;opacity:var(--mce-icon-opacity, 1);text-indent:0;text-align:center;-webkit-user-select:none;user-select:none;vertical-align:middle;width:1em;min-width:1em}.mce-icon__svg{fill:currentColor;width:100%;height:100%}.mce-overlay>*{pointer-events:auto}.mce-menu{-webkit-user-select:none;user-select:none}.mce-list{display:flex;flex-direction:column;background-color:rgb(var(--mce-theme-on-surface));color:rgb(var(--mce-theme-surface));box-shadow:var(--mce-shadow);padding:8px;border-radius:8px;gap:2px;max-height:inherit;overflow-y:auto}.mce-list__divider{border-bottom:1px solid rgba(var(--mce-theme-surface),.12)}.mce-list-item{display:flex;width:100%;padding:4px 8px;border-radius:4px;cursor:pointer;align-items:center;gap:12px}.mce-list-item--opened,.mce-list-item:hover{background-color:rgba(var(--mce-theme-primary),1);color:rgba(var(--mce-theme-on-primary),1)}.mce-list-item--disabled{pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.4}.mce-list-item__prepend{width:12px;height:12px;display:flex;align-items:center;justify-content:center}.mce-list-item__title{flex:1;display:flex;align-items:center;font-size:12px;white-space:nowrap}.mce-list-item__append{width:12px;height:12px;display:flex;align-items:center;justify-content:center;font-size:22px}.mce-context-menu__title{flex:1}.mce-context-menu__kbd{letter-spacing:.08em;margin-left:24px;opacity:.3}.mce-drawing{pointer-events:auto!important;position:fixed}.mce-drawing__content{margin:4px;border:1px solid rgba(0,0,0,.168627451);border-radius:4px;width:fit-content;height:22px;padding:0 4px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background-color:rgba(var(--mce-theme-surface),1)}.mce-frame{position:absolute}.mce-frame--outline{outline:1px solid rgba(0,0,0,.168627451)}.mce-frame__name{position:absolute;top:0;left:0;transform:translateY(-100%) translateY(-4px);transform-origin:left bottom;font-size:12px;line-height:1.5;white-space:nowrap;pointer-events:auto;-webkit-user-select:none;user-select:none}.mce-frame__name>div{position:relative;min-width:28px;box-sizing:content-box;color:rgba(var(--mce-theme-on-surface),.8)}.mce-frame__name>input{position:absolute;left:0;top:0;outline:none;width:100%;height:100%;border:1px solid rgba(0,0,0,.168627451);border-radius:4px;cursor:default}.mce-back-selected-aera{pointer-events:auto!important;position:absolute;left:50%;bottom:24px;padding:4px 8px;display:flex;align-items:center;gap:4px;color:rgba(var(--mce-theme-surface),1);background-color:rgba(var(--mce-theme-on-background),var(--mce-medium-emphasis-opacity));transform:translate(-50%);-webkit-backdrop-filter:blur(var(--mce-blur));backdrop-filter:blur(var(--mce-blur));border-radius:8px;font-size:14px;cursor:pointer}.mce-hover{position:absolute;border-style:solid;border-width:2px;color:rgba(var(--mce-theme-primary),1)}.mce-tooltip{background:rgb(var(--mce-theme-surface-variant));color:rgb(var(--mce-theme-on-surface-variant));border-radius:4px;font-size:.875rem;line-height:1.6;display:inline-block;padding:5px 16px;text-transform:initial;width:auto;opacity:1;transition-property:opacity,transform;overflow-wrap:break-word}.mce-ruler{position:absolute;left:0;top:0;width:100%;height:100%;--text-color: rgba(var(--mce-theme-on-background), var(--mce-low-emphasis-opacity));--border-color: rgba(var(--mce-border-color), var(--mce-border-opacity))}.mce-ruler--vertical{width:var(--size)}.mce-ruler--horizontal{height:var(--size)}.mce-ruler__canvas{display:block;pointer-events:auto;cursor:pointer;background-color:rgb(var(--mce-theme-surface));-webkit-backdrop-filter:blur(var(--mce-blur));backdrop-filter:blur(var(--mce-blur))}.mce-ruler-refline{position:absolute;border-style:dashed;border-width:0;border-color:rgb(var(--mce-theme-primary));pointer-events:auto!important}.mce-ruler-refline--vertical{border-top-width:1px;cursor:ns-resize}.mce-ruler-refline--horizontal{border-left-width:1px;cursor:ew-resize}.mce-ruler-refline--temp{border-color:rgba(var(--mce-theme-primary),var(--mce-low-emphasis-opacity));pointer-events:none!important}.mce-rulers{position:absolute;inset:0;pointer-events:none}.mce-rulers__left-top{position:absolute;left:0;top:0;width:16px;height:16px;border:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity));border-top-width:0;border-left-width:0;background-color:rgb(var(--mce-theme-surface))}.mce-scrollbar{position:absolute;display:flex;pointer-events:auto!important}.mce-scrollbar--vertical{right:0;flex-direction:column}.mce-scrollbar--horizontal{bottom:0}.mce-scrollbar__track{flex:1}.mce-scrollbar__thumb{position:absolute;border-radius:calc(infinity * 1px);background-color:rgba(var(--mce-theme-on-background),var(--mce-low-emphasis-opacity));-webkit-backdrop-filter:blur(var(--mce-blur));backdrop-filter:blur(var(--mce-blur))}.mce-scrollbar__thumb--active,.mce-scrollbar__thumb:hover{background-color:rgba(var(--mce-theme-on-background),var(--mce-medium-emphasis-opacity))}.mce-transformable{left:0;top:0;color:rgb(var(--mce-theme-primary))}.mce-transformable__svg{position:absolute;left:0;top:0;width:100%;height:100%;overflow:visible;pointer-events:none}.mce-transformable__box{stroke:currentColor;stroke-width:1px}.mce-transformable__handle{stroke:currentColor;stroke-width:1px;pointer-events:none}.mce-transformable__handle-box{stroke-width:1px;fill:transparent;stroke:transparent}.mce-transformable__tip{position:absolute;bottom:0;left:50%;transform:translate(-50%,calc(100% + 8px));background-color:rgb(var(--mce-theme-primary));color:rgb(var(--mce-theme-on-primary));font-size:12px;padding:2px 4px;border-radius:3px;text-wrap:nowrap}.mce-parent-element-obb{position:absolute;pointer-events:none;border-width:1px;border-style:dashed;color:rgba(var(--mce-theme-primary),1);opacity:.5}.mce-selected-area{position:absolute;border-width:1px;border-style:solid;color:rgba(var(--mce-theme-primary),1);background-color:rgba(var(--mce-theme-primary),.1)}.mce-selection-obb{position:absolute;color:rgba(var(--mce-theme-primary),1)}.mce-element-obb{position:absolute;border-width:1px;border-style:solid;color:rgba(var(--mce-theme-primary),1)}.progress-indicator[data-v-49cebb96]{display:flex;align-items:center;gap:12px}.progress-indicator__status[data-v-49cebb96]{font-size:12px;color:rgb(var(--mce-theme-on-surface))}.progress-indicator__bar[data-v-49cebb96]{position:relative;width:100px;height:6px;background-color:rgb(var(--mce-theme-background));border-radius:4px;overflow:hidden}.progress-indicator__bar-fill[data-v-49cebb96]{position:absolute;top:0;left:0;height:100%;background-color:rgb(var(--mce-theme-primary));transition:width .3s ease}.progress-indicator__bar-indeterminate[data-v-49cebb96]{position:absolute;top:0;left:-30%;width:30%;height:100%;background-color:#3b82f6;animation:indeterminate-slide-49cebb96 1.5s linear infinite}@keyframes indeterminate-slide-49cebb96{0%{left:-30%}to{left:100%}}.mce-statusbar[data-v-b59bbabb]{-webkit-user-select:none;user-select:none;position:relative;display:flex;align-items:center;gap:4px;font-size:12px;line-height:1;width:100%;height:24px;padding:0 8px;background-color:rgba(var(--mce-theme-surface),1);color:rgba(var(--mce-theme-on-surface),1);font-weight:700}.mce-statusbar__main[data-v-b59bbabb]{flex:1;display:flex;align-items:center}.mce-statusbar__item[data-v-b59bbabb]{display:flex;align-items:center;gap:4px}.mce-statusbar__item>svg[data-v-b59bbabb]{width:1em;height:1em}.mce-statusbar__divider[data-v-b59bbabb]{width:0;height:60%;border-right:1px solid rgba(var(--mce-theme-on-surface),.2);margin:0 8px}.mce-statusbar__kbd[data-v-b59bbabb]{outline:1px solid rgba(var(--mce-theme-on-surface),.4);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;padding:0 2px;font-family:system-ui,-apple-system,sans-serif}.mce-text-editor{position:absolute;width:0;height:0;left:0;top:0;overflow:visible}.mce-text-editor__wrapper{position:absolute}.mce-text-editor__editor{pointer-events:auto!important;cursor:move}.mce-payhead{bottom:0;left:-5px;position:absolute;top:0;width:10px;color:rgb(var(--mce-theme-on-surface));cursor:col-resize}.mce-payhead__header{position:relative;background-color:transparent;border:2px solid currentColor;border-bottom:none;height:12px;left:0;position:-webkit-sticky;position:sticky;right:0;top:0;width:10px}.mce-payhead__header:after{box-sizing:content-box;content:"";background-color:transparent;border-bottom:2px solid currentColor;border-right:2px solid currentColor;bottom:0;display:block;height:5px;position:absolute;right:0;transform:rotate(45deg) translate(2.8px,2px);width:5px}.mce-payhead__main{background-color:currentColor;bottom:0;left:4px;position:absolute;top:16px;transform:translate(.5px);width:1px}.mce-segment{display:flex;font-size:12px;align-items:center;position:absolute;top:2px;height:calc(100% - 4px);-webkit-user-select:none;user-select:none;flex-wrap:nowrap;color:#fff;border-radius:2px;background-color:#cc9641}.mce-segment--active{outline:1px solid rgb(var(--mce-theme-on-surface))}.mce-segment__animation{position:absolute;bottom:2px}.mce-segment__animation--in{width:0;left:4px;background-color:#fff;height:2px}.mce-segment__animation--in:after{border-color:transparent transparent transparent white;border-style:solid;border-width:5px 0 0 6px;bottom:0;content:"";display:block;height:0;left:100%;position:absolute;width:0}.mce-segment__animation--out{width:0;right:4px;background-color:#fff;height:2px}.mce-segment__animation--out:before{border-color:transparent white transparent transparent;border-style:solid;border-width:5px 6px 0 0;bottom:0;content:"";display:block;height:0;position:absolute;right:100%;width:0}.mce-segment__animation--stay{left:0;background-color:#fff;height:2px}.mce-segment__animation--stay:before{border-color:transparent white transparent transparent;border-style:solid;border-width:5px 6px 0 0;bottom:0;content:"";display:block;height:0;position:absolute;right:100%;width:0}.mce-segment__animation--stay:after{border-color:transparent transparent transparent white;border-style:solid;border-width:5px 0 0 6px;bottom:0;content:"";display:block;height:0;left:100%;position:absolute;width:0}.mce-segment__edge{align-items:center;background-color:rgb(var(--mce-theme-on-surface));bottom:0;content:"";display:flex;justify-content:center;pointer-events:auto;position:absolute;top:0;width:4px;cursor:col-resize}.mce-segment__edge:before{background-color:rgb(var(--mce-theme-surface));content:"";display:block;height:10px;width:2px}.mce-segment__edge--front{border-bottom-left-radius:2px;border-top-left-radius:2px;left:0}.mce-segment__edge--end{border-bottom-right-radius:2px;border-top-right-radius:2px;right:0}.mce-segment__node{border-radius:2px;padding:2px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mce-track{position:relative;display:flex;height:22px;background-color:rgb(var(--mce-theme-background))}.mce-trackhead{display:flex;height:22px;min-height:22px;align-items:center;color:rgba(var(--mce-theme-on-surface),.6);font-size:12px;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mce-timeline{position:relative;height:160px;color:rgb(var(--mce-theme-on-surface));background-color:rgb(var(--mce-theme-surface));display:flex;flex-direction:column;width:100%;border-top:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity));border-bottom:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-timeline__toolbar{display:flex;align-items:center;height:24px;border-bottom:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-timeline__play{position:absolute;left:50%;transform:translate(-50%);cursor:pointer}.mce-timeline__main{position:relative;display:flex;min-height:0;flex:1}.mce-timeline__left{display:flex;flex-direction:column-reverse;align-items:center;width:120px;height:max-content;min-height:100%;padding-top:24px;overflow:hidden}.mce-timeline__left-wrapper{position:relative;height:100%;width:100%;padding:0 0 0 4px}.mce-timeline__right{position:relative;display:flex;min-width:0;flex:1;overflow:hidden;flex-direction:column;border-left:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity));padding-left:48px}.mce-timeline__right-wrapper{position:relative;height:100%;width:100%}.mce-timeline__ruler{position:relative;width:100%;height:24px;min-height:24px}.mce-timeline__track{position:relative;display:flex;flex-direction:column-reverse;justify-content:start;gap:8px;flex:1;height:max-content;min-height:100%;overflow:hidden}.mce-drawboard{--mce-theme-primary: 97, 101, 253;--mce-theme-on-primary: 247, 247, 248;--mce-theme-surface: 255, 255, 255;--mce-theme-on-surface: 56, 56, 56;--mce-theme-surface-variant: 35, 37, 41;--mce-theme-on-surface-variant: 255, 255, 255;--mce-theme-background: 240, 242, 245;--mce-theme-on-background: 56, 56, 56;--mce-border-color: 0, 0, 0;--mce-border-opacity: .08;--mce-high-emphasis-opacity: 1;--mce-medium-emphasis-opacity: .5;--mce-low-emphasis-opacity: .3;--mce-shadow: 0 8px 32px 2px rgba(0, 0, 0, .08), 0 0 1px rgba(0, 0, 0, .2);--mce-blur: 8px}.mce-drawboard{position:relative;width:100%;height:100%;display:flex;flex-direction:column;background-color:rgb(var(--mce-theme-surface));color:rgb(var(--mce-theme-on-surface));overflow:hidden;-webkit-user-select:none;user-select:none;cursor:url() 4 4,auto}.mce-drawboard *{box-sizing:border-box}.mce-drawboard__overlay-container{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none}.mce-drawboard__main{position:relative;width:100%;flex:1;overflow:hidden}.mce-drawboard__main>*{pointer-events:none}.mce-drawboard__canvas{position:absolute;left:0;top:0;width:100%;height:100%;display:block}
1
+ .mce-auxiliary{position:absolute;overflow:hidden;inset:0}.mce-auxiliary__alignment{position:absolute;background-color:#ff4aff;height:1px;width:1px}.mce-auxiliary__area{position:absolute;display:flex;align-items:center;justify-content:center;background-color:#f424fd33}.mce-auxiliary__area:before{content:"";background:#1690ff;height:1px;width:100%}.mce-auxiliary__area:after{position:absolute;content:"";height:5px;width:100%;border-left:1px solid #1690ff;border-right:1px solid #1690ff}.mce-auxiliary__area--vertical:before{height:100%;width:1px}.mce-auxiliary__area--vertical:after{height:100%;width:5px;border-left:none;border-right:none;border-top:1px solid #1690ff;border-bottom:1px solid #1690ff}.mce-icon{align-items:center;display:inline-flex;font-feature-settings:"liga";height:1em;justify-content:center;letter-spacing:normal;line-height:1;position:relative;opacity:var(--mce-icon-opacity, 1);text-indent:0;text-align:center;-webkit-user-select:none;user-select:none;vertical-align:middle;width:1em;min-width:1em}.mce-icon__svg{fill:currentColor;width:100%;height:100%}.mce-overlay>*{pointer-events:auto}.mce-menu{-webkit-user-select:none;user-select:none}.mce-list{display:flex;flex-direction:column;background-color:rgb(var(--mce-theme-on-surface));color:rgb(var(--mce-theme-surface));box-shadow:var(--mce-shadow);padding:8px;border-radius:8px;gap:2px;max-height:inherit;overflow-y:auto}.mce-list__divider{border-bottom:1px solid rgba(var(--mce-theme-surface),.12)}.mce-list-item{display:flex;width:100%;padding:4px 8px;border-radius:4px;cursor:pointer;align-items:center;gap:12px}.mce-list-item--opened,.mce-list-item:hover{background-color:rgba(var(--mce-theme-primary),1);color:rgba(var(--mce-theme-on-primary),1)}.mce-list-item--disabled{pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.4}.mce-list-item__prepend{width:12px;height:12px;display:flex;align-items:center;justify-content:center}.mce-list-item__title{flex:1;display:flex;align-items:center;font-size:12px;white-space:nowrap}.mce-list-item__append{width:12px;height:12px;display:flex;align-items:center;justify-content:center;font-size:22px}.mce-context-menu__title{flex:1}.mce-context-menu__kbd{letter-spacing:.08em;margin-left:24px;opacity:.3}.mce-drawing{pointer-events:auto!important;position:fixed}.mce-drawing__content{margin:4px;border:1px solid rgba(0,0,0,.168627451);border-radius:4px;width:fit-content;height:22px;padding:0 4px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background-color:rgba(var(--mce-theme-surface),1)}.mce-frame{position:absolute}.mce-frame--outline{outline:1px solid rgba(0,0,0,.168627451)}.mce-frame__name{position:absolute;top:0;left:0;transform:translateY(-100%) translateY(-4px);transform-origin:left bottom;font-size:12px;line-height:1.5;white-space:nowrap;pointer-events:auto;-webkit-user-select:none;user-select:none}.mce-frame__name>div{position:relative;min-width:28px;box-sizing:content-box;color:rgba(var(--mce-theme-on-surface),.8)}.mce-frame__name>input{position:absolute;left:0;top:0;outline:none;width:100%;height:100%;border:1px solid rgba(0,0,0,.168627451);border-radius:4px;cursor:default}.mce-back-selected-aera{pointer-events:auto!important;position:absolute;left:50%;bottom:24px;padding:4px 8px;display:flex;align-items:center;gap:4px;color:rgba(var(--mce-theme-surface),1);background-color:rgba(var(--mce-theme-on-background),var(--mce-medium-emphasis-opacity));transform:translate(-50%);-webkit-backdrop-filter:blur(var(--mce-blur));backdrop-filter:blur(var(--mce-blur));border-radius:8px;font-size:14px;cursor:pointer}.mce-hover{position:absolute;border-style:solid;border-width:2px;color:rgba(var(--mce-theme-primary),1)}.mce-tooltip{background:rgb(var(--mce-theme-surface-variant));color:rgb(var(--mce-theme-on-surface-variant));border-radius:4px;font-size:.875rem;line-height:1.6;display:inline-block;padding:5px 16px;text-transform:initial;width:auto;opacity:1;transition-property:opacity,transform;overflow-wrap:break-word}.mce-ruler{position:absolute;left:0;top:0;width:100%;height:100%;--text-color: rgba(var(--mce-theme-on-background), var(--mce-low-emphasis-opacity));--border-color: rgba(var(--mce-border-color), var(--mce-border-opacity))}.mce-ruler--vertical{width:var(--size)}.mce-ruler--horizontal{height:var(--size)}.mce-ruler__canvas{display:block;pointer-events:auto;cursor:pointer;background-color:rgb(var(--mce-theme-surface));-webkit-backdrop-filter:blur(var(--mce-blur));backdrop-filter:blur(var(--mce-blur))}.mce-ruler-refline{position:absolute;border-style:dashed;border-width:0;border-color:rgb(var(--mce-theme-primary));pointer-events:auto!important}.mce-ruler-refline--vertical{border-top-width:1px;cursor:ns-resize}.mce-ruler-refline--horizontal{border-left-width:1px;cursor:ew-resize}.mce-ruler-refline--temp{border-color:rgba(var(--mce-theme-primary),var(--mce-low-emphasis-opacity));pointer-events:none!important}.mce-rulers{position:absolute;inset:0;pointer-events:none}.mce-rulers__left-top{position:absolute;left:0;top:0;width:16px;height:16px;border:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity));border-top-width:0;border-left-width:0;background-color:rgb(var(--mce-theme-surface))}.mce-scrollbar{position:absolute;display:flex;pointer-events:auto!important}.mce-scrollbar--vertical{right:0;flex-direction:column}.mce-scrollbar--horizontal{bottom:0}.mce-scrollbar__track{flex:1}.mce-scrollbar__thumb{position:absolute;border-radius:calc(infinity * 1px);background-color:rgba(var(--mce-theme-on-background),var(--mce-low-emphasis-opacity));-webkit-backdrop-filter:blur(var(--mce-blur));backdrop-filter:blur(var(--mce-blur))}.mce-scrollbar__thumb--active,.mce-scrollbar__thumb:hover{background-color:rgba(var(--mce-theme-on-background),var(--mce-medium-emphasis-opacity))}.mce-transformable{left:0;top:0;color:rgb(var(--mce-theme-primary))}.mce-transformable__svg{position:absolute;left:0;top:0;width:100%;height:100%;overflow:visible;pointer-events:none}.mce-transformable__box{stroke:currentColor;stroke-width:1px}.mce-transformable__handle{stroke:currentColor;stroke-width:1px;pointer-events:none}.mce-transformable__handle-box{stroke-width:1px;fill:transparent;stroke:transparent}.mce-transformable__tip{position:absolute;bottom:0;left:50%;transform:translate(-50%,calc(100% + 8px));background-color:rgb(var(--mce-theme-primary));color:rgb(var(--mce-theme-on-primary));font-size:12px;padding:2px 4px;border-radius:3px;text-wrap:nowrap}.mce-parent-element-obb{position:absolute;pointer-events:none;border-width:1px;border-style:dashed;color:rgba(var(--mce-theme-primary),1);opacity:.5}.mce-selected-area{position:absolute;border-width:1px;border-style:solid;color:rgba(var(--mce-theme-primary),1);background-color:rgba(var(--mce-theme-primary),.1)}.mce-selection-obb{position:absolute;color:rgba(var(--mce-theme-primary),1)}.mce-element-obb{position:absolute;border-width:1px;border-style:solid;color:rgba(var(--mce-theme-primary),1)}.mce-layout{--mce-scrollbar-offset: 0px;display:flex;flex:1 1 auto}.mce-layout--full-height{--mce-scrollbar-offset: inherit;height:100%}.mce-layout-item,.mce-layout-item--absolute{position:absolute}.mce-layout-item--left{border-right:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-layout-item--top{border-bottom:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-layout-item--right{border-left:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-layout-item--bottom{border-top:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-main{flex:1 0 auto;max-width:100%;padding-left:var(--mce-layout-left);padding-right:var(--mce-layout-right);padding-top:var(--mce-layout-top);padding-bottom:var(--mce-layout-bottom)}.mce-main__scroller{max-width:100%;position:relative}.mce-main--scrollable{display:flex;position:absolute;top:0;left:0;width:100%;height:100%}.mce-main--scrollable>.v-main__scroller{flex:1 1 auto;overflow-y:auto;--v-layout-left: 0px;--v-layout-right: 0px;--v-layout-top: 0px;--v-layout-bottom: 0px}.progress-indicator[data-v-c4234331]{display:flex;align-items:center;gap:12px}.progress-indicator__status[data-v-c4234331]{font-size:12px;color:rgb(var(--mce-theme-on-surface))}.progress-indicator__bar[data-v-c4234331]{position:relative;width:100px;height:6px;background-color:rgb(var(--mce-theme-background));border-radius:4px;overflow:hidden}.progress-indicator__bar-fill[data-v-c4234331]{position:absolute;top:0;left:0;height:100%;background-color:rgb(var(--mce-theme-primary));transition:width .3s ease}.progress-indicator__bar-indeterminate[data-v-c4234331]{position:absolute;top:0;left:-30%;width:30%;height:100%;background-color:#3b82f6;animation:indeterminate-slide-c4234331 1.5s linear infinite}@keyframes indeterminate-slide-c4234331{0%{left:-30%}to{left:100%}}.mce-statusbar[data-v-36c89bd7]{-webkit-user-select:none;user-select:none;position:relative;display:flex;align-items:center;gap:4px;font-size:12px;line-height:1;width:100%;height:100%;padding:0 8px;background-color:rgba(var(--mce-theme-surface),1);color:rgba(var(--mce-theme-on-surface),1);font-weight:700}.mce-statusbar__main[data-v-36c89bd7]{flex:1;display:flex;align-items:center}.mce-statusbar__item[data-v-36c89bd7]{display:flex;align-items:center;gap:4px}.mce-statusbar__item>svg[data-v-36c89bd7]{width:1em;height:1em}.mce-statusbar__divider[data-v-36c89bd7]{width:0;height:60%;border-right:1px solid rgba(var(--mce-theme-on-surface),.2);margin:0 8px}.mce-statusbar__kbd[data-v-36c89bd7]{outline:1px solid rgba(var(--mce-theme-on-surface),.4);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;padding:0 2px;font-family:system-ui,-apple-system,sans-serif}.mce-text-editor{position:absolute;width:0;height:0;left:0;top:0;overflow:visible}.mce-text-editor__wrapper{position:absolute}.mce-text-editor__editor{pointer-events:auto!important;cursor:move}.mce-payhead{bottom:0;left:-5px;position:absolute;top:0;width:10px;color:rgb(var(--mce-theme-on-surface));cursor:col-resize}.mce-payhead__header{position:relative;background-color:transparent;border:2px solid currentColor;border-bottom:none;height:12px;left:0;position:-webkit-sticky;position:sticky;right:0;top:0;width:10px}.mce-payhead__header:after{box-sizing:content-box;content:"";background-color:transparent;border-bottom:2px solid currentColor;border-right:2px solid currentColor;bottom:0;display:block;height:5px;position:absolute;right:0;transform:rotate(45deg) translate(2.8px,2px);width:5px}.mce-payhead__main{background-color:currentColor;bottom:0;left:4px;position:absolute;top:16px;transform:translate(.5px);width:1px}.mce-segment{display:flex;font-size:12px;align-items:center;position:absolute;top:2px;height:calc(100% - 4px);-webkit-user-select:none;user-select:none;flex-wrap:nowrap;color:#fff;border-radius:2px;background-color:#cc9641}.mce-segment--active{outline:1px solid rgb(var(--mce-theme-on-surface))}.mce-segment__animation{position:absolute;bottom:2px}.mce-segment__animation--in{width:0;left:4px;background-color:#fff;height:2px}.mce-segment__animation--in:after{border-color:transparent transparent transparent white;border-style:solid;border-width:5px 0 0 6px;bottom:0;content:"";display:block;height:0;left:100%;position:absolute;width:0}.mce-segment__animation--out{width:0;right:4px;background-color:#fff;height:2px}.mce-segment__animation--out:before{border-color:transparent white transparent transparent;border-style:solid;border-width:5px 6px 0 0;bottom:0;content:"";display:block;height:0;position:absolute;right:100%;width:0}.mce-segment__animation--stay{left:0;background-color:#fff;height:2px}.mce-segment__animation--stay:before{border-color:transparent white transparent transparent;border-style:solid;border-width:5px 6px 0 0;bottom:0;content:"";display:block;height:0;position:absolute;right:100%;width:0}.mce-segment__animation--stay:after{border-color:transparent transparent transparent white;border-style:solid;border-width:5px 0 0 6px;bottom:0;content:"";display:block;height:0;left:100%;position:absolute;width:0}.mce-segment__edge{align-items:center;background-color:rgb(var(--mce-theme-on-surface));bottom:0;content:"";display:flex;justify-content:center;pointer-events:auto;position:absolute;top:0;width:4px;cursor:col-resize}.mce-segment__edge:before{background-color:rgb(var(--mce-theme-surface));content:"";display:block;height:10px;width:2px}.mce-segment__edge--front{border-bottom-left-radius:2px;border-top-left-radius:2px;left:0}.mce-segment__edge--end{border-bottom-right-radius:2px;border-top-right-radius:2px;right:0}.mce-segment__node{border-radius:2px;padding:2px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mce-track{position:relative;display:flex;height:22px;background-color:rgb(var(--mce-theme-background))}.mce-trackhead{display:flex;height:22px;min-height:22px;align-items:center;color:rgba(var(--mce-theme-on-surface),.6);font-size:12px;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mce-timeline{position:relative;color:rgb(var(--mce-theme-on-surface));background-color:rgb(var(--mce-theme-surface));display:flex;flex-direction:column;width:100%;height:100%}.mce-timeline__toolbar{display:flex;align-items:center;height:24px;border-bottom:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity))}.mce-timeline__play{position:absolute;left:50%;transform:translate(-50%);cursor:pointer}.mce-timeline__main{position:relative;display:flex;min-height:0;flex:1}.mce-timeline__left{display:flex;flex-direction:column-reverse;align-items:center;width:120px;height:max-content;min-height:100%;padding-top:24px;overflow:hidden}.mce-timeline__left-wrapper{position:relative;height:100%;width:100%;padding:0 0 0 4px}.mce-timeline__right{position:relative;display:flex;min-width:0;flex:1;overflow:hidden;flex-direction:column;border-left:1px solid rgba(var(--mce-border-color),var(--mce-border-opacity));padding-left:48px}.mce-timeline__right-wrapper{position:relative;height:100%;width:100%}.mce-timeline__ruler{position:relative;width:100%;height:24px;min-height:24px}.mce-timeline__track{position:relative;display:flex;flex-direction:column-reverse;justify-content:start;gap:8px;flex:1;height:max-content;min-height:100%;overflow:hidden}.mce-editor{--mce-theme-primary: 97, 101, 253;--mce-theme-on-primary: 247, 247, 248;--mce-theme-surface: 255, 255, 255;--mce-theme-on-surface: 56, 56, 56;--mce-theme-surface-variant: 35, 37, 41;--mce-theme-on-surface-variant: 255, 255, 255;--mce-theme-background: 240, 242, 245;--mce-theme-on-background: 56, 56, 56;--mce-border-color: 0, 0, 0;--mce-border-opacity: .08;--mce-high-emphasis-opacity: 1;--mce-medium-emphasis-opacity: .5;--mce-low-emphasis-opacity: .3;--mce-shadow: 0 8px 32px 2px rgba(0, 0, 0, .08), 0 0 1px rgba(0, 0, 0, .2);--mce-blur: 8px}.mce-editor{position:relative;width:100%;height:100%;display:flex;flex-direction:column;background-color:rgb(var(--mce-theme-surface));color:rgb(var(--mce-theme-on-surface));overflow:hidden;-webkit-user-select:none;user-select:none;cursor:url() 4 4,auto}.mce-editor *{box-sizing:border-box}.mce-editor__overlay-container{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none}.mce-editor__drawboard{position:relative;width:100%;height:100%;overflow:hidden}.mce-editor__drawboard>*{pointer-events:none}.mce-editor__canvas{position:absolute;left:0;top:0;width:100%;height:100%;display:block}
package/dist/index.d.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  import './typed-global.d.ts';
2
2
  import './typed-plugins.d.ts';
3
- export { default as Drawboard } from './components/Drawboard.vue';
3
+ export { default as EditorLayout } from './components/EditorLayout.vue';
4
+ export { default as EditorLayoutItem } from './components/shared/LayoutItem.vue';
4
5
  export { default as Transformable } from './components/shared/Transformable.vue';
5
6
  export * from './composables';
6
7
  export * from './editor';