@ydesign/react-editor 0.0.2

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 (150) hide show
  1. package/CHANGELOG.md +106 -0
  2. package/LICENSE +21 -0
  3. package/README.md +129 -0
  4. package/dist/app.css +2 -0
  5. package/dist/app.d.ts +13 -0
  6. package/dist/app.js +17 -0
  7. package/dist/canvas/context-menu/context-menu.d.ts +2 -0
  8. package/dist/canvas/context-menu/context-menu.js +0 -0
  9. package/dist/canvas/hotkeys.d.ts +3 -0
  10. package/dist/canvas/hotkeys.js +1 -0
  11. package/dist/canvas/workspace-canvas.d.ts +15 -0
  12. package/dist/canvas/workspace-canvas.js +1 -0
  13. package/dist/canvas/workspace.d.ts +9 -0
  14. package/dist/canvas/workspace.js +1 -0
  15. package/dist/chunk-2AWYWIIK.js +1 -0
  16. package/dist/chunk-3HQUN5MA.js +14 -0
  17. package/dist/chunk-55FJG4FK.js +1 -0
  18. package/dist/chunk-5MWZMSER.js +1 -0
  19. package/dist/chunk-6LFGFFHI.js +1 -0
  20. package/dist/chunk-75WC3GVB.js +1 -0
  21. package/dist/chunk-7LU5UGIG.js +16 -0
  22. package/dist/chunk-B35ZYWID.js +1 -0
  23. package/dist/chunk-DBQHEZPG.js +1 -0
  24. package/dist/chunk-DJBTBRPS.js +1 -0
  25. package/dist/chunk-E7ZSWHPU.js +1 -0
  26. package/dist/chunk-EMAFC3HG.js +1 -0
  27. package/dist/chunk-FIAIYSJ7.js +1 -0
  28. package/dist/chunk-GMISU6MD.js +1 -0
  29. package/dist/chunk-GYDTKPW5.js +1 -0
  30. package/dist/chunk-H67HTXU4.js +1 -0
  31. package/dist/chunk-IUFYYEGO.js +1 -0
  32. package/dist/chunk-JMIN2XMC.js +1 -0
  33. package/dist/chunk-JW76IC3E.js +1 -0
  34. package/dist/chunk-JWQ2DUXA.js +8 -0
  35. package/dist/chunk-LW2W4B2N.js +22 -0
  36. package/dist/chunk-M33EDDXB.js +1 -0
  37. package/dist/chunk-MNACXCF5.js +1 -0
  38. package/dist/chunk-O2XFH626.js +1 -0
  39. package/dist/chunk-OQ6HU62L.js +1 -0
  40. package/dist/chunk-P5I43V7X.js +1 -0
  41. package/dist/chunk-PBQY5UTI.js +1 -0
  42. package/dist/chunk-QJBRJELT.js +1 -0
  43. package/dist/chunk-R6Z6F447.js +1 -0
  44. package/dist/chunk-TE6HYOIP.js +7 -0
  45. package/dist/chunk-TX4BNXQC.js +1 -0
  46. package/dist/chunk-U7HIFGXC.js +1 -0
  47. package/dist/chunk-V5RJX32O.js +1 -0
  48. package/dist/chunk-V6ZZKUTN.js +1 -0
  49. package/dist/chunk-WIM26GEM.js +1 -0
  50. package/dist/chunk-WJT6VPDR.js +9 -0
  51. package/dist/chunk-XDLFQXMN.js +54 -0
  52. package/dist/chunk-XRRO2RT7.js +1 -0
  53. package/dist/chunk-XZAP76LL.js +1 -0
  54. package/dist/config.d.ts +2 -0
  55. package/dist/config.js +0 -0
  56. package/dist/hooks/use-duplicate-element.d.ts +12 -0
  57. package/dist/hooks/use-duplicate-element.js +1 -0
  58. package/dist/hooks/use-lock.d.ts +14 -0
  59. package/dist/hooks/use-lock.js +1 -0
  60. package/dist/hooks/use-remove-element.d.ts +12 -0
  61. package/dist/hooks/use-remove-element.js +1 -0
  62. package/dist/lib/utils.d.ts +5 -0
  63. package/dist/lib/utils.js +1 -0
  64. package/dist/model/store.d.ts +307 -0
  65. package/dist/model/store.js +1 -0
  66. package/dist/project.d.ts +21 -0
  67. package/dist/project.js +1 -0
  68. package/dist/side-panel/background-panel.d.ts +10 -0
  69. package/dist/side-panel/background-panel.js +1 -0
  70. package/dist/side-panel/index.d.ts +6 -0
  71. package/dist/side-panel/index.js +1 -0
  72. package/dist/side-panel/layers-panel.d.ts +10 -0
  73. package/dist/side-panel/layers-panel.js +1 -0
  74. package/dist/side-panel/photos-panel.d.ts +10 -0
  75. package/dist/side-panel/photos-panel.js +1 -0
  76. package/dist/side-panel/shapes-panel.d.ts +10 -0
  77. package/dist/side-panel/shapes-panel.js +1 -0
  78. package/dist/side-panel/side-panel.d.ts +35 -0
  79. package/dist/side-panel/side-panel.js +1 -0
  80. package/dist/side-panel/size-panel.d.ts +10 -0
  81. package/dist/side-panel/size-panel.js +1 -0
  82. package/dist/side-panel/tab-button.d.ts +12 -0
  83. package/dist/side-panel/tab-button.js +1 -0
  84. package/dist/side-panel/templates-panel.d.ts +10 -0
  85. package/dist/side-panel/templates-panel.js +1 -0
  86. package/dist/side-panel/text-panel.d.ts +10 -0
  87. package/dist/side-panel/text-panel.js +1 -0
  88. package/dist/side-panel/upload-panel.d.ts +10 -0
  89. package/dist/side-panel/upload-panel.js +1 -0
  90. package/dist/toolbar/default-toolbar.d.ts +12 -0
  91. package/dist/toolbar/default-toolbar.js +1 -0
  92. package/dist/toolbar/download-button.d.ts +10 -0
  93. package/dist/toolbar/download-button.js +1 -0
  94. package/dist/toolbar/duplicate-button.d.ts +12 -0
  95. package/dist/toolbar/duplicate-button.js +1 -0
  96. package/dist/toolbar/element-container.d.ts +13 -0
  97. package/dist/toolbar/element-container.js +1 -0
  98. package/dist/toolbar/filters-picker.d.ts +14 -0
  99. package/dist/toolbar/filters-picker.js +1 -0
  100. package/dist/toolbar/flip-button.d.ts +12 -0
  101. package/dist/toolbar/flip-button.js +1 -0
  102. package/dist/toolbar/group-button.d.ts +12 -0
  103. package/dist/toolbar/group-button.js +1 -0
  104. package/dist/toolbar/history-buttons.d.ts +12 -0
  105. package/dist/toolbar/history-buttons.js +1 -0
  106. package/dist/toolbar/image-eraser-pen.d.ts +5 -0
  107. package/dist/toolbar/image-eraser-pen.js +1 -0
  108. package/dist/toolbar/image-remove-background.d.ts +5 -0
  109. package/dist/toolbar/image-remove-background.js +1 -0
  110. package/dist/toolbar/image-toolbar.d.ts +24 -0
  111. package/dist/toolbar/image-toolbar.js +1 -0
  112. package/dist/toolbar/lock-button.d.ts +12 -0
  113. package/dist/toolbar/lock-button.js +1 -0
  114. package/dist/toolbar/many-toolbar.d.ts +5 -0
  115. package/dist/toolbar/many-toolbar.js +1 -0
  116. package/dist/toolbar/opacity-picker.d.ts +12 -0
  117. package/dist/toolbar/opacity-picker.js +1 -0
  118. package/dist/toolbar/position-picker.d.ts +12 -0
  119. package/dist/toolbar/position-picker.js +1 -0
  120. package/dist/toolbar/remove-button.d.ts +12 -0
  121. package/dist/toolbar/remove-button.js +1 -0
  122. package/dist/toolbar/text-ai-write.d.ts +7 -0
  123. package/dist/toolbar/text-ai-write.js +1 -0
  124. package/dist/toolbar/text-toolbar.d.ts +15 -0
  125. package/dist/toolbar/text-toolbar.js +1 -0
  126. package/dist/toolbar/toolbar.d.ts +20 -0
  127. package/dist/toolbar/toolbar.js +1 -0
  128. package/dist/toolbar/zoom-buttons.d.ts +15 -0
  129. package/dist/toolbar/zoom-buttons.js +12 -0
  130. package/dist/utils/blob.d.ts +5 -0
  131. package/dist/utils/blob.js +1 -0
  132. package/dist/utils/download.d.ts +3 -0
  133. package/dist/utils/download.js +1 -0
  134. package/dist/utils/file.d.ts +3 -0
  135. package/dist/utils/file.js +1 -0
  136. package/dist/utils/filters.d.ts +2 -0
  137. package/dist/utils/filters.js +0 -0
  138. package/dist/utils/fonts.d.ts +68 -0
  139. package/dist/utils/fonts.js +1 -0
  140. package/dist/utils/image.d.ts +13 -0
  141. package/dist/utils/image.js +1 -0
  142. package/dist/utils/index.d.ts +21 -0
  143. package/dist/utils/index.js +1 -0
  144. package/dist/utils/l10n.d.ts +21 -0
  145. package/dist/utils/l10n.js +1 -0
  146. package/dist/utils/loader.d.ts +6 -0
  147. package/dist/utils/loader.js +1 -0
  148. package/dist/utils/screen.d.ts +6 -0
  149. package/dist/utils/screen.js +1 -0
  150. package/package.json +128 -0
@@ -0,0 +1,10 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const TemplatesPanel: ({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element;
9
+
10
+ export { TemplatesPanel };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-QJBRJELT.js";import"../chunk-O2XFH626.js";export{a as TemplatesPanel};
@@ -0,0 +1,10 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const TextPanel: ({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element;
9
+
10
+ export { TextPanel };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-6LFGFFHI.js";import"../chunk-O2XFH626.js";export{a as TextPanel};
@@ -0,0 +1,10 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const UploadPanel: ({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element;
9
+
10
+ export { UploadPanel, UploadPanel as default };
@@ -0,0 +1 @@
1
+ import{a,b}from"../chunk-DBQHEZPG.js";import"../chunk-O2XFH626.js";export{a as UploadPanel,b as default};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ type PageProps = {
7
+ store: StoreType;
8
+ components?: any;
9
+ };
10
+ declare const DefaultToolbar: ({ store, components }: PageProps) => react_jsx_runtime.JSX.Element;
11
+
12
+ export { DefaultToolbar, DefaultToolbar as default };
@@ -0,0 +1 @@
1
+ import{a,b}from"../chunk-XZAP76LL.js";import"../chunk-3HQUN5MA.js";import"../chunk-OQ6HU62L.js";import"../chunk-E7ZSWHPU.js";import"../chunk-JWQ2DUXA.js";import"../chunk-O2XFH626.js";export{a as DefaultToolbar,b as default};
@@ -0,0 +1,10 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const DownloadButton: ({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element;
9
+
10
+ export { DownloadButton, DownloadButton as default };
@@ -0,0 +1 @@
1
+ import{a,b}from"../chunk-B35ZYWID.js";import"../chunk-O2XFH626.js";export{a as DownloadButton,b as default};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const DuplicateButton: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { DuplicateButton };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-H67HTXU4.js";import"../chunk-JMIN2XMC.js";import"../chunk-O2XFH626.js";export{a as DuplicateButton};
@@ -0,0 +1,13 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+
3
+ declare const extendToolbar: ({ type, usedItems, components }: {
4
+ type: string;
5
+ usedItems: Array<string | undefined>;
6
+ components: any;
7
+ }) => (string | undefined)[];
8
+ declare const ElementContainer: ({ items, itemRender }: {
9
+ items: any;
10
+ itemRender: any;
11
+ }) => react_jsx_runtime.JSX.Element;
12
+
13
+ export { ElementContainer, extendToolbar };
@@ -0,0 +1 @@
1
+ import{a,b}from"../chunk-3HQUN5MA.js";import"../chunk-JWQ2DUXA.js";import"../chunk-O2XFH626.js";export{b as ElementContainer,a as extendToolbar};
@@ -0,0 +1,14 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import { FabricObject } from '@ydesign/core';
4
+ import 'mobx-state-tree';
5
+
6
+ declare const FiltersPicker: (({ element, store, elements }: {
7
+ elements?: Array<FabricObject>;
8
+ element?: FabricObject;
9
+ store: StoreType;
10
+ }) => react_jsx_runtime.JSX.Element) & {
11
+ displayName: string;
12
+ };
13
+
14
+ export { FiltersPicker };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-V5RJX32O.js";import"../chunk-E7ZSWHPU.js";import"../chunk-O2XFH626.js";export{a as FiltersPicker};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { FabricObject } from '@ydesign/core';
3
+ import { StoreType } from '../model/store.js';
4
+ import 'mobx-state-tree';
5
+
6
+ declare const FlipButton: ({ element, store }: {
7
+ elements?: Array<FabricObject>;
8
+ element?: FabricObject;
9
+ store: StoreType;
10
+ }) => react_jsx_runtime.JSX.Element;
11
+
12
+ export { FlipButton };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-GMISU6MD.js";import"../chunk-O2XFH626.js";export{a as FlipButton};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const GroupButton: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { GroupButton };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-V6ZZKUTN.js";import"../chunk-O2XFH626.js";export{a as GroupButton};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const HistoryButtons: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { HistoryButtons };
@@ -0,0 +1 @@
1
+ import{e as a}from"../chunk-7LU5UGIG.js";import"../chunk-R6Z6F447.js";import"../chunk-TE6HYOIP.js";import"../chunk-FIAIYSJ7.js";import"../chunk-5MWZMSER.js";import"../chunk-2AWYWIIK.js";import"../chunk-U7HIFGXC.js";import"../chunk-GYDTKPW5.js";import"../chunk-XRRO2RT7.js";import"../chunk-JW76IC3E.js";import"../chunk-MNACXCF5.js";import"../chunk-XZAP76LL.js";import"../chunk-B35ZYWID.js";import"../chunk-H67HTXU4.js";import"../chunk-3HQUN5MA.js";import"../chunk-V5RJX32O.js";import"../chunk-GMISU6MD.js";import"../chunk-V6ZZKUTN.js";import"../chunk-OQ6HU62L.js";import"../chunk-EMAFC3HG.js";import"../chunk-E7ZSWHPU.js";import"../chunk-IUFYYEGO.js";import"../chunk-JWQ2DUXA.js";import"../chunk-WJT6VPDR.js";import"../chunk-JMIN2XMC.js";import"../chunk-75WC3GVB.js";import"../chunk-O2XFH626.js";export{a as HistoryButtons};
@@ -0,0 +1,5 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+
3
+ declare const ImageEraserPen: () => react_jsx_runtime.JSX.Element;
4
+
5
+ export { ImageEraserPen };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-2AWYWIIK.js";import"../chunk-O2XFH626.js";export{a as ImageEraserPen};
@@ -0,0 +1,5 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+
3
+ declare const ImageRemoveBackground: () => react_jsx_runtime.JSX.Element;
4
+
5
+ export { ImageRemoveBackground };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-U7HIFGXC.js";import"../chunk-O2XFH626.js";export{a as ImageRemoveBackground};
@@ -0,0 +1,24 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { FabricImage } from '@ydesign/core';
3
+ import { StoreType } from '../model/store.js';
4
+ import 'mobx-state-tree';
5
+
6
+ type Props = {
7
+ store: StoreType;
8
+ components?: any;
9
+ };
10
+ declare const ImageFitToBackground: ({ element, store }: {
11
+ element: FabricImage;
12
+ store: StoreType;
13
+ }) => react_jsx_runtime.JSX.Element;
14
+ declare const ImageCrop: (() => react_jsx_runtime.JSX.Element) & {
15
+ displayName: string;
16
+ };
17
+ declare const ImageClip: (() => react_jsx_runtime.JSX.Element) & {
18
+ displayName: string;
19
+ };
20
+ declare const ImageToolbar: (({ store, components }: Props) => react_jsx_runtime.JSX.Element) & {
21
+ displayName: string;
22
+ };
23
+
24
+ export { ImageClip, ImageCrop, ImageFitToBackground, ImageToolbar, ImageToolbar as default };
@@ -0,0 +1 @@
1
+ import{a,b,c,d,e}from"../chunk-5MWZMSER.js";import"../chunk-2AWYWIIK.js";import"../chunk-U7HIFGXC.js";import"../chunk-3HQUN5MA.js";import"../chunk-V5RJX32O.js";import"../chunk-GMISU6MD.js";import"../chunk-EMAFC3HG.js";import"../chunk-E7ZSWHPU.js";import"../chunk-JWQ2DUXA.js";import"../chunk-O2XFH626.js";export{c as ImageClip,b as ImageCrop,a as ImageFitToBackground,d as ImageToolbar,e as default};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const LockButton: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { LockButton };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-GYDTKPW5.js";import"../chunk-75WC3GVB.js";import"../chunk-O2XFH626.js";export{a as LockButton};
@@ -0,0 +1,5 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+
3
+ declare const ManyToolbar: () => react_jsx_runtime.JSX.Element;
4
+
5
+ export { ManyToolbar, ManyToolbar as default };
@@ -0,0 +1 @@
1
+ import{a,b}from"../chunk-XRRO2RT7.js";import"../chunk-O2XFH626.js";export{a as ManyToolbar,b as default};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const OpacityPicker: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { OpacityPicker };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-JW76IC3E.js";import"../chunk-O2XFH626.js";export{a as OpacityPicker};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const PositionPicker: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { PositionPicker };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-MNACXCF5.js";import"../chunk-O2XFH626.js";export{a as PositionPicker};
@@ -0,0 +1,12 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const RemoveButton: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+
12
+ export { RemoveButton };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-R6Z6F447.js";import"../chunk-IUFYYEGO.js";import"../chunk-O2XFH626.js";export{a as RemoveButton};
@@ -0,0 +1,7 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+
3
+ declare const TextAiWrite: (() => react_jsx_runtime.JSX.Element) & {
4
+ displayName: string;
5
+ };
6
+
7
+ export { TextAiWrite };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-FIAIYSJ7.js";import"../chunk-O2XFH626.js";export{a as TextAiWrite};
@@ -0,0 +1,15 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ type PageProps = {
7
+ store: StoreType;
8
+ components?: any;
9
+ };
10
+ declare const ALIGN_OPTIONS: string[];
11
+ declare const TextToolbar: (({ store, components }: PageProps) => react_jsx_runtime.JSX.Element) & {
12
+ displayName: string;
13
+ };
14
+
15
+ export { ALIGN_OPTIONS, TextToolbar, TextToolbar as default };
@@ -0,0 +1 @@
1
+ import{a,b,c}from"../chunk-TE6HYOIP.js";import"../chunk-FIAIYSJ7.js";import"../chunk-3HQUN5MA.js";import"../chunk-V5RJX32O.js";import"../chunk-E7ZSWHPU.js";import"../chunk-JWQ2DUXA.js";import"../chunk-WJT6VPDR.js";import"../chunk-O2XFH626.js";export{a as ALIGN_OPTIONS,b as TextToolbar,c as default};
@@ -0,0 +1,20 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import * as node_modules_styled_components_dist_types from 'node_modules/styled-components/dist/types';
3
+ import * as styled_components from 'styled-components';
4
+ import * as react from 'react';
5
+ import { StoreType } from '../model/store.js';
6
+ import 'mobx-state-tree';
7
+ import '@ydesign/core';
8
+
9
+ declare const NavBarGroup: node_modules_styled_components_dist_types.IStyledComponentBase<"web", styled_components.FastOmit<react.DetailedHTMLProps<react.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
10
+ declare function registerToolbarComponent(type: string, reactComponent: any): void;
11
+ type ToolbarProps = {
12
+ store: StoreType;
13
+ downloadButtonEnabled?: boolean;
14
+ components?: any;
15
+ };
16
+ declare const Toolbar: (({ store, downloadButtonEnabled, components }: ToolbarProps) => react_jsx_runtime.JSX.Element) & {
17
+ displayName: string;
18
+ };
19
+
20
+ export { NavBarGroup, Toolbar, Toolbar as default, registerToolbarComponent };
@@ -0,0 +1 @@
1
+ import{a,b,c,d}from"../chunk-7LU5UGIG.js";import"../chunk-R6Z6F447.js";import"../chunk-TE6HYOIP.js";import"../chunk-FIAIYSJ7.js";import"../chunk-5MWZMSER.js";import"../chunk-2AWYWIIK.js";import"../chunk-U7HIFGXC.js";import"../chunk-GYDTKPW5.js";import"../chunk-XRRO2RT7.js";import"../chunk-JW76IC3E.js";import"../chunk-MNACXCF5.js";import"../chunk-XZAP76LL.js";import"../chunk-B35ZYWID.js";import"../chunk-H67HTXU4.js";import"../chunk-3HQUN5MA.js";import"../chunk-V5RJX32O.js";import"../chunk-GMISU6MD.js";import"../chunk-V6ZZKUTN.js";import"../chunk-OQ6HU62L.js";import"../chunk-EMAFC3HG.js";import"../chunk-E7ZSWHPU.js";import"../chunk-IUFYYEGO.js";import"../chunk-JWQ2DUXA.js";import"../chunk-WJT6VPDR.js";import"../chunk-JMIN2XMC.js";import"../chunk-75WC3GVB.js";import"../chunk-O2XFH626.js";export{a as NavBarGroup,c as Toolbar,d as default,b as registerToolbarComponent};
@@ -0,0 +1,15 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { StoreType } from '../model/store.js';
3
+ import 'mobx-state-tree';
4
+ import '@ydesign/core';
5
+
6
+ declare const ZoomGroup: (({ store }: {
7
+ store: StoreType;
8
+ }) => react_jsx_runtime.JSX.Element) & {
9
+ displayName: string;
10
+ };
11
+ declare const ZoomButtons: ({ store }: {
12
+ store: StoreType;
13
+ }) => react_jsx_runtime.JSX.Element;
14
+
15
+ export { ZoomButtons, ZoomGroup, ZoomButtons as default };
@@ -0,0 +1,12 @@
1
+ import"../chunk-O2XFH626.js";import{observer as S}from"mobx-react-lite";import m from"styled-components";import{ZoomOut as f,ZoomIn as h,Shrink as x,Expand as z}from"lucide-react";import{Button as e,Space as a,Tooltip as l,Dropdown as M}from"antd";import{Fragment as B,jsx as o,jsxs as n}from"react/jsx-runtime";var T=m.div`
2
+ position: relative;
3
+ height: 0px;
4
+ `,k=m.div`
5
+ position: absolute;
6
+ bottom: 10px;
7
+ width: auto;
8
+ left: 50%;
9
+ transform: translateX(-50%);
10
+ border-radius: 5px;
11
+ overflow: hidden;
12
+ `,i=[.1,.25,.5,.75,1,1.5,2,3],y=i[i.length-1],b=i[0],v=S(({store:t})=>{let p=Math.max(y,t.scaleToFit),s=Math.min(b,t.scaleToFit),d=t.scale<p,c=t.scale>s,u=i.map((r,C)=>({key:C,label:o("div",{style:{minWidth:80,textAlign:"center"},onClick:()=>{t.editor?.zoomHandler.zoomToRatio(r)},children:`${Math.round(100*r)}%`})}));return n(B,{children:[n(a.Compact,{children:[o(e,{disabled:!c,onClick:()=>t.editor?.zoomHandler.zoomOut(),children:o(f,{size:16})}),o(M,{menu:{items:u},placement:"top",children:n(e,{children:[Math.round(100*t.scale),"%"]})}),o(e,{disabled:!d,onClick:()=>t.editor?.zoomHandler.zoomIn(),children:o(h,{size:16})})]}),n(a.Compact,{style:{marginLeft:10},children:[o(l,{title:"\u9002\u5408\u5C4F\u5E55",children:o(e,{onClick:()=>t.editor?.workareaHandler.auto(),children:o(x,{size:16})})}),o(l,{title:"\u586B\u6EE1\u5C4F\u5E55",children:o(e,{onClick:()=>t.editor?.workareaHandler.one(),children:o(z,{size:16})})})]})]})}),A=({store:t})=>o(T,{children:o(k,{children:o(v,{store:t})})}),E=A;export{A as ZoomButtons,v as ZoomGroup,E as default};
@@ -0,0 +1,5 @@
1
+ declare function dataURLtoBlob(dataurl: string): Blob;
2
+ declare function blobToDataURL(blob: Blob, callback: (dataUrl: string) => void): void;
3
+ declare function blobToDataURLAsync(blob: Blob): Promise<string>;
4
+
5
+ export { blobToDataURL, blobToDataURLAsync, dataURLtoBlob };
@@ -0,0 +1 @@
1
+ import"../chunk-O2XFH626.js";function l(n){let e=n.split(","),r=e[0].match(/:(.*?);/)?.[1]||"application/octet-stream",o=atob(e[1]),t=o.length,a=new Uint8Array(t);for(;t--;)a[t]=o.charCodeAt(t);return new Blob([a],{type:r})}function s(n,e){let r=new FileReader;r.onload=o=>{let t=o.target?.result;typeof t=="string"&&e(t)},r.readAsDataURL(n)}function i(n){return new Promise((e,r)=>{let o=new FileReader;o.onload=t=>{let a=t.target?.result;typeof a=="string"?e(a):r(new Error("Failed to convert blob to data URL"))},o.onerror=()=>r(new Error("Failed to read blob")),o.readAsDataURL(n)})}export{s as blobToDataURL,i as blobToDataURLAsync,l as dataURLtoBlob};
@@ -0,0 +1,3 @@
1
+ declare function downloadFile(file: Blob, fileName: string): Promise<void>;
2
+
3
+ export { downloadFile };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-P5I43V7X.js";import"../chunk-O2XFH626.js";export{a as downloadFile};
@@ -0,0 +1,3 @@
1
+ declare function localFileToURL(e: File): Promise<unknown>;
2
+
3
+ export { localFileToURL };
@@ -0,0 +1 @@
1
+ import{a}from"../chunk-OQ6HU62L.js";import"../chunk-O2XFH626.js";export{a as localFileToURL};
@@ -0,0 +1,2 @@
1
+
2
+ export { }
File without changes
@@ -0,0 +1,68 @@
1
+ import * as mobx from 'mobx';
2
+
3
+ type FONT = {
4
+ fontFamily: string;
5
+ url?: string;
6
+ img?: string;
7
+ name?: string;
8
+ styles?: Array<{
9
+ src: string;
10
+ fontStyle?: string;
11
+ fontWeight?: string;
12
+ }>;
13
+ };
14
+ declare const globalFonts: mobx.IObservableArray<FONT>;
15
+ declare function addGlobalFont(font: FONT): void;
16
+ declare function removeGlobalFont(fontFamily: string): void;
17
+ declare function replaceGlobalFonts(fonts: Array<FONT>): void;
18
+ /**
19
+ * 检查字体是否已加载
20
+ */
21
+ declare const isFontLoaded: (fontFamily: string) => boolean;
22
+ /**
23
+ * 设置字体加载超时回调
24
+ */
25
+ declare const setFontLoadTimeoutCallback: (callback: (message: string) => void) => void;
26
+ declare const setTimeoutGetter: (getter: () => number) => void;
27
+ /**
28
+ * 加载字体并等待其可用
29
+ *
30
+ * 策略:
31
+ * 1. 优先使用 document.fonts.load() API(现代浏览器)
32
+ * 2. 降级方案:轮询检测字体宽度变化
33
+ *
34
+ * @param fontFamily - 字体名称
35
+ * @param fontStyle - 字体样式 (normal/italic)
36
+ * @param fontWeight - 字体粗细 (normal/bold/100-900)
37
+ */
38
+ declare function loadFont(fontFamily: string, fontStyle?: string, fontWeight?: string): Promise<void>;
39
+ /**
40
+ * 注入自定义字体到页面
41
+ * 通过动态创建 @font-face 规则实现
42
+ *
43
+ * @param font - 字体配置对象
44
+ */
45
+ declare function injectCustomFont(font: FONT): void;
46
+ /**
47
+ * 设置 Google Fonts 字体变体
48
+ * @param variants - 变体字符串,如 '400,700,900'
49
+ */
50
+ declare function setGoogleFontsVariants(variants: string): void;
51
+ /**
52
+ * 获取当前 Google Fonts 字体变体配置
53
+ */
54
+ declare function getGoogleFontsVariants(): string;
55
+ /**
56
+ * 生成 Google Fonts CSS URL
57
+ * @param fontFamily - 字体名称
58
+ */
59
+ declare function getGoogleFontsUrl(fontFamily: string): string;
60
+ /**
61
+ * 注入 Google 字体到页面
62
+ * 通过动态创建 <link> 标签加载 Google Fonts CSS
63
+ *
64
+ * @param fontFamily - 字体名称
65
+ */
66
+ declare function injectGoogleFont(fontFamily: string): void;
67
+
68
+ export { type FONT, addGlobalFont, getGoogleFontsUrl, getGoogleFontsVariants, globalFonts, injectCustomFont, injectGoogleFont, isFontLoaded, loadFont, removeGlobalFont, replaceGlobalFonts, setFontLoadTimeoutCallback, setGoogleFontsVariants, setTimeoutGetter };
@@ -0,0 +1 @@
1
+ import{a,b,c,d,e,f,g,h,i,j,k,l,m}from"../chunk-WJT6VPDR.js";import"../chunk-O2XFH626.js";export{b as addGlobalFont,l as getGoogleFontsUrl,k as getGoogleFontsVariants,a as globalFonts,i as injectCustomFont,m as injectGoogleFont,e as isFontLoaded,h as loadFont,c as removeGlobalFont,d as replaceGlobalFonts,f as setFontLoadTimeoutCallback,j as setGoogleFontsVariants,g as setTimeoutGetter};
@@ -0,0 +1,13 @@
1
+ declare function getImageSize(url: string): Promise<any>;
2
+ type Size = {
3
+ width: number;
4
+ height: number;
5
+ };
6
+ declare function getCrop(elementSize: Size, originalImageSize: Size): {
7
+ cropX: number;
8
+ cropY: number;
9
+ cropWidth: number;
10
+ cropHeight: number;
11
+ };
12
+
13
+ export { getCrop, getImageSize };
@@ -0,0 +1 @@
1
+ import{a,b}from"../chunk-EMAFC3HG.js";import"../chunk-O2XFH626.js";export{b as getCrop,a as getImageSize};
@@ -0,0 +1,21 @@
1
+ import { FabricObject } from '@ydesign/core';
2
+
3
+ /**
4
+ * 将 fill 值转换为 ColorPicker 可识别的格式
5
+ */
6
+ declare const convertFillToPickerValue: (fill: any) => any;
7
+ /**
8
+ * TODO:临时方法添加元素
9
+ * 生成随机颜色
10
+ * @returns 十六进制颜色值,如 '#FF5733'
11
+ */
12
+ declare const getRandomColor: () => string;
13
+ /**
14
+ * 抽取出当前使用的字体
15
+ * @param objects - fabric 对象数组
16
+ * @returns 字体列表
17
+ */
18
+ declare const getJSONFontFamily: (objects: any[]) => string[];
19
+ declare function isVectorShape(obj?: FabricObject): boolean;
20
+
21
+ export { convertFillToPickerValue, getJSONFontFamily, getRandomColor, isVectorShape };
@@ -0,0 +1 @@
1
+ import{a,b,c,d}from"../chunk-E7ZSWHPU.js";import"../chunk-O2XFH626.js";export{a as convertFillToPickerValue,c as getJSONFontFamily,b as getRandomColor,d as isVectorShape};
@@ -0,0 +1,21 @@
1
+ /**
2
+ * @file 国际化处理
3
+ */
4
+ declare const getTranslations: () => {
5
+ toolbar: {
6
+ opacity: string;
7
+ effects: string;
8
+ position: string;
9
+ ungroupElements: string;
10
+ groupElements: string;
11
+ };
12
+ workspace: {};
13
+ scale: {
14
+ reset: string;
15
+ };
16
+ sidePanel: {
17
+ templates: string;
18
+ };
19
+ };
20
+
21
+ export { getTranslations };
@@ -0,0 +1 @@
1
+ import"../chunk-O2XFH626.js";import{observable as e,toJS as t}from"mobx";var o=e({toolbar:{opacity:"Opacity",effects:"Effects",position:"Position",ungroupElements:"Ungroup",groupElements:"Group"},workspace:{},scale:{reset:"Reset"},sidePanel:{templates:"Templates"}}),n=()=>t(o);export{n as getTranslations};
@@ -0,0 +1,6 @@
1
+ declare const setAssetLoadTimeout: (e: number) => void;
2
+ declare const getAssetLoadTimeout: () => number;
3
+ declare const setFontLoadTimeout: (e: number) => void;
4
+ declare const getFontLoadTimeout: () => number;
5
+
6
+ export { getAssetLoadTimeout, getFontLoadTimeout, setAssetLoadTimeout, setFontLoadTimeout };
@@ -0,0 +1 @@
1
+ import"../chunk-O2XFH626.js";var e=3e4,s=t=>{e=t},n=()=>e,o=6e3,r=t=>{o=t},m=()=>o;export{n as getAssetLoadTimeout,m as getFontLoadTimeout,s as setAssetLoadTimeout,r as setFontLoadTimeout};
@@ -0,0 +1,6 @@
1
+ declare const MOBILE_BREAKPOINT = 768;
2
+ declare const isMobile: () => boolean;
3
+ declare const mobileStyle: (e: string) => string;
4
+ declare const useMobile: () => boolean;
5
+
6
+ export { MOBILE_BREAKPOINT, isMobile, mobileStyle, useMobile };
@@ -0,0 +1 @@
1
+ import{a,b,c,d}from"../chunk-JWQ2DUXA.js";import"../chunk-O2XFH626.js";export{a as MOBILE_BREAKPOINT,b as isMobile,c as mobileStyle,d as useMobile};