@cs-open/react-fabric 0.0.3

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 (256) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/components/BackgroundImage/index.cjs +2 -0
  3. package/dist/cjs/components/BackgroundImage/index.cjs.map +1 -0
  4. package/dist/cjs/components/Canvas/index.cjs +2 -0
  5. package/dist/cjs/components/Canvas/index.cjs.map +1 -0
  6. package/dist/cjs/components/Control/index.cjs +2 -0
  7. package/dist/cjs/components/Control/index.cjs.map +1 -0
  8. package/dist/cjs/components/Ellipse/index.cjs +2 -0
  9. package/dist/cjs/components/Ellipse/index.cjs.map +1 -0
  10. package/dist/cjs/components/Group/index.cjs +2 -0
  11. package/dist/cjs/components/Group/index.cjs.map +1 -0
  12. package/dist/cjs/components/Image/index.cjs +2 -0
  13. package/dist/cjs/components/Image/index.cjs.map +1 -0
  14. package/dist/cjs/components/Line/index.cjs +2 -0
  15. package/dist/cjs/components/Line/index.cjs.map +1 -0
  16. package/dist/cjs/components/Loading/index.cjs +2 -0
  17. package/dist/cjs/components/Loading/index.cjs.map +1 -0
  18. package/dist/cjs/components/NodeToolbarPortal/index.cjs +2 -0
  19. package/dist/cjs/components/NodeToolbarPortal/index.cjs.map +1 -0
  20. package/dist/cjs/components/Objects/index.cjs +2 -0
  21. package/dist/cjs/components/Objects/index.cjs.map +1 -0
  22. package/dist/cjs/components/Path/index.cjs +2 -0
  23. package/dist/cjs/components/Path/index.cjs.map +1 -0
  24. package/dist/cjs/components/ReactFabricProvider.cjs +2 -0
  25. package/dist/cjs/components/ReactFabricProvider.cjs.map +1 -0
  26. package/dist/cjs/components/Rect/index.cjs +2 -0
  27. package/dist/cjs/components/Rect/index.cjs.map +1 -0
  28. package/dist/cjs/components/StoreUpdater/index.cjs +2 -0
  29. package/dist/cjs/components/StoreUpdater/index.cjs.map +1 -0
  30. package/dist/cjs/components/Text/index.cjs +2 -0
  31. package/dist/cjs/components/Text/index.cjs.map +1 -0
  32. package/dist/cjs/constants.cjs +2 -0
  33. package/dist/cjs/constants.cjs.map +1 -0
  34. package/dist/cjs/container/ReactFabric/Wrapper.cjs +2 -0
  35. package/dist/cjs/container/ReactFabric/Wrapper.cjs.map +1 -0
  36. package/dist/cjs/container/ReactFabric/index.cjs +2 -0
  37. package/dist/cjs/container/ReactFabric/index.cjs.map +1 -0
  38. package/dist/cjs/contexts/StoreContext.cjs +2 -0
  39. package/dist/cjs/contexts/StoreContext.cjs.map +1 -0
  40. package/dist/cjs/hooks/useCreateObject.cjs +2 -0
  41. package/dist/cjs/hooks/useCreateObject.cjs.map +1 -0
  42. package/dist/cjs/hooks/useDidUpdate.cjs +2 -0
  43. package/dist/cjs/hooks/useDidUpdate.cjs.map +1 -0
  44. package/dist/cjs/hooks/useDraggable.cjs +2 -0
  45. package/dist/cjs/hooks/useDraggable.cjs.map +1 -0
  46. package/dist/cjs/hooks/useReactFabric.cjs +2 -0
  47. package/dist/cjs/hooks/useReactFabric.cjs.map +1 -0
  48. package/dist/cjs/hooks/useResizeHandler.cjs +2 -0
  49. package/dist/cjs/hooks/useResizeHandler.cjs.map +1 -0
  50. package/dist/cjs/hooks/useSplitProps.cjs +2 -0
  51. package/dist/cjs/hooks/useSplitProps.cjs.map +1 -0
  52. package/dist/cjs/hooks/useStore.cjs +2 -0
  53. package/dist/cjs/hooks/useStore.cjs.map +1 -0
  54. package/dist/cjs/hooks/useZoom.cjs +2 -0
  55. package/dist/cjs/hooks/useZoom.cjs.map +1 -0
  56. package/dist/cjs/index.cjs +2 -0
  57. package/dist/cjs/index.cjs.map +1 -0
  58. package/dist/cjs/plugins/FreeRect.cjs +2 -0
  59. package/dist/cjs/plugins/FreeRect.cjs.map +1 -0
  60. package/dist/cjs/plugins/GridLine.cjs +5 -0
  61. package/dist/cjs/plugins/GridLine.cjs.map +1 -0
  62. package/dist/cjs/plugins/Pinch.cjs +2 -0
  63. package/dist/cjs/plugins/Pinch.cjs.map +1 -0
  64. package/dist/cjs/store/index.cjs +2 -0
  65. package/dist/cjs/store/index.cjs.map +1 -0
  66. package/dist/cjs/store/initialState.cjs +2 -0
  67. package/dist/cjs/store/initialState.cjs.map +1 -0
  68. package/dist/cjs/toolbar/Vertical/index.cjs +2 -0
  69. package/dist/cjs/toolbar/Vertical/index.cjs.map +1 -0
  70. package/dist/cjs/types/canvas.cjs +2 -0
  71. package/dist/cjs/types/canvas.cjs.map +1 -0
  72. package/dist/cjs/types/component-props.cjs +2 -0
  73. package/dist/cjs/types/component-props.cjs.map +1 -0
  74. package/dist/cjs/types/general.cjs +2 -0
  75. package/dist/cjs/types/general.cjs.map +1 -0
  76. package/dist/cjs/types/nodes.cjs +2 -0
  77. package/dist/cjs/types/nodes.cjs.map +1 -0
  78. package/dist/cjs/types/object.cjs +2 -0
  79. package/dist/cjs/types/object.cjs.map +1 -0
  80. package/dist/cjs/types/store.cjs +2 -0
  81. package/dist/cjs/types/store.cjs.map +1 -0
  82. package/dist/cjs/types/utils.cjs +2 -0
  83. package/dist/cjs/types/utils.cjs.map +1 -0
  84. package/dist/cjs/utils/constants.cjs +2 -0
  85. package/dist/cjs/utils/constants.cjs.map +1 -0
  86. package/dist/cjs/utils/dom.cjs +2 -0
  87. package/dist/cjs/utils/dom.cjs.map +1 -0
  88. package/dist/cjs/utils/events.cjs +2 -0
  89. package/dist/cjs/utils/events.cjs.map +1 -0
  90. package/dist/cjs/utils/position.cjs +2 -0
  91. package/dist/cjs/utils/position.cjs.map +1 -0
  92. package/dist/cjs/utils/props.cjs +2 -0
  93. package/dist/cjs/utils/props.cjs.map +1 -0
  94. package/dist/esm/components/BackgroundImage/index.mjs +2 -0
  95. package/dist/esm/components/BackgroundImage/index.mjs.map +1 -0
  96. package/dist/esm/components/Canvas/index.mjs +2 -0
  97. package/dist/esm/components/Canvas/index.mjs.map +1 -0
  98. package/dist/esm/components/Control/index.mjs +2 -0
  99. package/dist/esm/components/Control/index.mjs.map +1 -0
  100. package/dist/esm/components/Ellipse/index.mjs +2 -0
  101. package/dist/esm/components/Ellipse/index.mjs.map +1 -0
  102. package/dist/esm/components/Group/index.mjs +2 -0
  103. package/dist/esm/components/Group/index.mjs.map +1 -0
  104. package/dist/esm/components/Line/index.mjs +2 -0
  105. package/dist/esm/components/Line/index.mjs.map +1 -0
  106. package/dist/esm/components/Loading/index.mjs +2 -0
  107. package/dist/esm/components/Loading/index.mjs.map +1 -0
  108. package/dist/esm/components/NodeToolbarPortal/index.mjs +2 -0
  109. package/dist/esm/components/NodeToolbarPortal/index.mjs.map +1 -0
  110. package/dist/esm/components/Objects/index.mjs +2 -0
  111. package/dist/esm/components/Objects/index.mjs.map +1 -0
  112. package/dist/esm/components/Path/index.mjs +2 -0
  113. package/dist/esm/components/Path/index.mjs.map +1 -0
  114. package/dist/esm/components/ReactFabricProvider.mjs +2 -0
  115. package/dist/esm/components/ReactFabricProvider.mjs.map +1 -0
  116. package/dist/esm/components/Rect/index.mjs +2 -0
  117. package/dist/esm/components/Rect/index.mjs.map +1 -0
  118. package/dist/esm/components/StoreUpdater/index.mjs +2 -0
  119. package/dist/esm/components/StoreUpdater/index.mjs.map +1 -0
  120. package/dist/esm/components/Text/index.mjs +2 -0
  121. package/dist/esm/components/Text/index.mjs.map +1 -0
  122. package/dist/esm/container/ReactFabric/Wrapper.mjs +2 -0
  123. package/dist/esm/container/ReactFabric/Wrapper.mjs.map +1 -0
  124. package/dist/esm/container/ReactFabric/index.mjs +2 -0
  125. package/dist/esm/container/ReactFabric/index.mjs.map +1 -0
  126. package/dist/esm/contexts/StoreContext.mjs +2 -0
  127. package/dist/esm/contexts/StoreContext.mjs.map +1 -0
  128. package/dist/esm/hooks/useCreateObject.mjs +2 -0
  129. package/dist/esm/hooks/useCreateObject.mjs.map +1 -0
  130. package/dist/esm/hooks/useDidUpdate.mjs +2 -0
  131. package/dist/esm/hooks/useDidUpdate.mjs.map +1 -0
  132. package/dist/esm/hooks/useDraggable.mjs +2 -0
  133. package/dist/esm/hooks/useDraggable.mjs.map +1 -0
  134. package/dist/esm/hooks/useReactFabric.mjs +2 -0
  135. package/dist/esm/hooks/useReactFabric.mjs.map +1 -0
  136. package/dist/esm/hooks/useResizeHandler.mjs +2 -0
  137. package/dist/esm/hooks/useResizeHandler.mjs.map +1 -0
  138. package/dist/esm/hooks/useSplitProps.mjs +2 -0
  139. package/dist/esm/hooks/useSplitProps.mjs.map +1 -0
  140. package/dist/esm/hooks/useStore.mjs +2 -0
  141. package/dist/esm/hooks/useStore.mjs.map +1 -0
  142. package/dist/esm/hooks/useZoom.mjs +2 -0
  143. package/dist/esm/hooks/useZoom.mjs.map +1 -0
  144. package/dist/esm/index.mjs +2 -0
  145. package/dist/esm/index.mjs.map +1 -0
  146. package/dist/esm/plugins/FreeRect.mjs +2 -0
  147. package/dist/esm/plugins/FreeRect.mjs.map +1 -0
  148. package/dist/esm/plugins/GridLine.mjs +5 -0
  149. package/dist/esm/plugins/GridLine.mjs.map +1 -0
  150. package/dist/esm/plugins/Pinch.mjs +2 -0
  151. package/dist/esm/plugins/Pinch.mjs.map +1 -0
  152. package/dist/esm/store/index.mjs +2 -0
  153. package/dist/esm/store/index.mjs.map +1 -0
  154. package/dist/esm/store/initialState.mjs +2 -0
  155. package/dist/esm/store/initialState.mjs.map +1 -0
  156. package/dist/esm/toolbar/Vertical/index.mjs +2 -0
  157. package/dist/esm/toolbar/Vertical/index.mjs.map +1 -0
  158. package/dist/esm/utils/constants.mjs +2 -0
  159. package/dist/esm/utils/constants.mjs.map +1 -0
  160. package/dist/esm/utils/events.mjs +2 -0
  161. package/dist/esm/utils/events.mjs.map +1 -0
  162. package/dist/esm/utils/props.mjs +2 -0
  163. package/dist/esm/utils/props.mjs.map +1 -0
  164. package/dist/types/components/BackgroundImage/index.d.ts +19 -0
  165. package/dist/types/components/BackgroundImage/index.d.ts.map +1 -0
  166. package/dist/types/components/Canvas/index.d.ts +11 -0
  167. package/dist/types/components/Canvas/index.d.ts.map +1 -0
  168. package/dist/types/components/Control/index.d.ts +28 -0
  169. package/dist/types/components/Control/index.d.ts.map +1 -0
  170. package/dist/types/components/Ellipse/index.d.ts +19 -0
  171. package/dist/types/components/Ellipse/index.d.ts.map +1 -0
  172. package/dist/types/components/Group/index.d.ts +24 -0
  173. package/dist/types/components/Group/index.d.ts.map +1 -0
  174. package/dist/types/components/Image/index.d.ts +18 -0
  175. package/dist/types/components/Image/index.d.ts.map +1 -0
  176. package/dist/types/components/Line/index.d.ts +11 -0
  177. package/dist/types/components/Line/index.d.ts.map +1 -0
  178. package/dist/types/components/Loading/index.d.ts +3 -0
  179. package/dist/types/components/Loading/index.d.ts.map +1 -0
  180. package/dist/types/components/NodeToolbarPortal/index.d.ts +9 -0
  181. package/dist/types/components/NodeToolbarPortal/index.d.ts.map +1 -0
  182. package/dist/types/components/Objects/index.d.ts +9 -0
  183. package/dist/types/components/Objects/index.d.ts.map +1 -0
  184. package/dist/types/components/Path/index.d.ts +11 -0
  185. package/dist/types/components/Path/index.d.ts.map +1 -0
  186. package/dist/types/components/ReactFabricProvider.d.ts +11 -0
  187. package/dist/types/components/ReactFabricProvider.d.ts.map +1 -0
  188. package/dist/types/components/Rect/index.d.ts +20 -0
  189. package/dist/types/components/Rect/index.d.ts.map +1 -0
  190. package/dist/types/components/StoreUpdater/index.d.ts +8 -0
  191. package/dist/types/components/StoreUpdater/index.d.ts.map +1 -0
  192. package/dist/types/components/Text/index.d.ts +11 -0
  193. package/dist/types/components/Text/index.d.ts.map +1 -0
  194. package/dist/types/constants.d.ts +5 -0
  195. package/dist/types/constants.d.ts.map +1 -0
  196. package/dist/types/container/ReactFabric/Wrapper.d.ts +10 -0
  197. package/dist/types/container/ReactFabric/Wrapper.d.ts.map +1 -0
  198. package/dist/types/container/ReactFabric/index.d.ts +69 -0
  199. package/dist/types/container/ReactFabric/index.d.ts.map +1 -0
  200. package/dist/types/contexts/StoreContext.d.ts +4 -0
  201. package/dist/types/contexts/StoreContext.d.ts.map +1 -0
  202. package/dist/types/hooks/useCreateObject.d.ts +15 -0
  203. package/dist/types/hooks/useCreateObject.d.ts.map +1 -0
  204. package/dist/types/hooks/useDidUpdate.d.ts +9 -0
  205. package/dist/types/hooks/useDidUpdate.d.ts.map +1 -0
  206. package/dist/types/hooks/useDraggable.d.ts +3 -0
  207. package/dist/types/hooks/useDraggable.d.ts.map +1 -0
  208. package/dist/types/hooks/useReactFabric.d.ts +55 -0
  209. package/dist/types/hooks/useReactFabric.d.ts.map +1 -0
  210. package/dist/types/hooks/useResizeHandler.d.ts +3 -0
  211. package/dist/types/hooks/useResizeHandler.d.ts.map +1 -0
  212. package/dist/types/hooks/useSplitProps.d.ts +15 -0
  213. package/dist/types/hooks/useSplitProps.d.ts.map +1 -0
  214. package/dist/types/hooks/useStore.d.ts +13 -0
  215. package/dist/types/hooks/useStore.d.ts.map +1 -0
  216. package/dist/types/hooks/useZoom.d.ts +2 -0
  217. package/dist/types/hooks/useZoom.d.ts.map +1 -0
  218. package/dist/types/index.d.ts +29 -0
  219. package/dist/types/index.d.ts.map +1 -0
  220. package/dist/types/plugins/FreeRect.d.ts +15 -0
  221. package/dist/types/plugins/FreeRect.d.ts.map +1 -0
  222. package/dist/types/plugins/GridLine.d.ts +7 -0
  223. package/dist/types/plugins/GridLine.d.ts.map +1 -0
  224. package/dist/types/plugins/Pinch.d.ts +8 -0
  225. package/dist/types/plugins/Pinch.d.ts.map +1 -0
  226. package/dist/types/store/index.d.ts +10 -0
  227. package/dist/types/store/index.d.ts.map +1 -0
  228. package/dist/types/store/initialState.d.ts +12 -0
  229. package/dist/types/store/initialState.d.ts.map +1 -0
  230. package/dist/types/toolbar/Vertical/index.d.ts +10 -0
  231. package/dist/types/toolbar/Vertical/index.d.ts.map +1 -0
  232. package/dist/types/types/canvas.d.ts +15 -0
  233. package/dist/types/types/canvas.d.ts.map +1 -0
  234. package/dist/types/types/component-props.d.ts +41 -0
  235. package/dist/types/types/component-props.d.ts.map +1 -0
  236. package/dist/types/types/general.d.ts +2 -0
  237. package/dist/types/types/general.d.ts.map +1 -0
  238. package/dist/types/types/nodes.d.ts +91 -0
  239. package/dist/types/types/nodes.d.ts.map +1 -0
  240. package/dist/types/types/object.d.ts +22 -0
  241. package/dist/types/types/object.d.ts.map +1 -0
  242. package/dist/types/types/store.d.ts +59 -0
  243. package/dist/types/types/store.d.ts.map +1 -0
  244. package/dist/types/types/utils.d.ts +6 -0
  245. package/dist/types/types/utils.d.ts.map +1 -0
  246. package/dist/types/utils/constants.d.ts +5 -0
  247. package/dist/types/utils/constants.d.ts.map +1 -0
  248. package/dist/types/utils/dom.d.ts +3 -0
  249. package/dist/types/utils/dom.d.ts.map +1 -0
  250. package/dist/types/utils/events.d.ts +5 -0
  251. package/dist/types/utils/events.d.ts.map +1 -0
  252. package/dist/types/utils/position.d.ts +9 -0
  253. package/dist/types/utils/position.d.ts.map +1 -0
  254. package/dist/types/utils/props.d.ts +4 -0
  255. package/dist/types/utils/props.d.ts.map +1 -0
  256. package/package.json +100 -0
@@ -0,0 +1,59 @@
1
+ import type { Canvas } from 'fabric';
2
+ import type { OnNodeDrag, OnNodesChange, OnNodesDelete } from './component-props';
3
+ import type { InternalNodeBase, Node } from './nodes';
4
+ export type OnError = (id: string, message: string) => void;
5
+ export type ReactFabricStore<NodeType extends Node = Node> = {
6
+ width: number;
7
+ height: number;
8
+ nodes: NodeType[];
9
+ onNodesChange: OnNodesChange | null;
10
+ hasDefaultNodes: boolean;
11
+ hasDefaultSelection: boolean;
12
+ hasDefaultDraggable: boolean;
13
+ domNode: HTMLDivElement | null;
14
+ zoom: number;
15
+ fitZoom: number;
16
+ manualZoom: number;
17
+ minManualZoom: number;
18
+ maxManualZoom: number;
19
+ isDragging: boolean;
20
+ selection?: boolean;
21
+ draggable: boolean;
22
+ lastPosX?: number;
23
+ lastPosY?: number;
24
+ scale: number;
25
+ defaultCentered?: boolean;
26
+ loading: boolean;
27
+ canvas: Canvas | null;
28
+ onNodeDragStart?: OnNodeDrag<NodeType>;
29
+ onNodeDrag?: OnNodeDrag<NodeType>;
30
+ onNodeDragStop?: OnNodeDrag<NodeType>;
31
+ onNodesDelete?: OnNodesDelete<NodeType>;
32
+ debug: boolean;
33
+ zoomable: boolean;
34
+ onError?: OnError;
35
+ };
36
+ export type UpdateNodePositions = (dragItems: Map<string, InternalNodeBase>, dragging?: boolean) => void;
37
+ type Dimensions = {
38
+ width?: number;
39
+ height?: number;
40
+ };
41
+ export type ReactFabricActions = {
42
+ setDimensions: (dimensions: Dimensions) => void;
43
+ setLoading: (loading: boolean) => void;
44
+ setZoom: (zoom: number) => void;
45
+ setMinManualZoom: (minManualZoom: number) => void;
46
+ setMaxManualZoom: (maxManualZoom: number) => void;
47
+ reset: () => void;
48
+ setDraggable: (enable: boolean) => void;
49
+ setFitZoom: (zoom: number) => void;
50
+ setManualZoom: (zoom: number) => void;
51
+ setZoomable: (enable: boolean) => void;
52
+ setSelection: (selection: boolean) => void;
53
+ setDefaultSelection: (selection: boolean | undefined) => void;
54
+ setDefaultDraggable: (draggable: boolean | undefined) => void;
55
+ setIsDragging: (bool: boolean) => void;
56
+ };
57
+ export type ReactFabricState<NodeType extends Node = Node> = ReactFabricStore<NodeType> & ReactFabricActions;
58
+ export {};
59
+ //# sourceMappingURL=store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/types/store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export type Dimensions = {
2
+ width: number;
3
+ height: number;
4
+ };
5
+ export type MyCapitalize<S extends string> = S extends `${infer A}:${infer B}:${infer C}` ? `on${Capitalize<A>}${Capitalize<B>}${Capitalize<C>}` : S extends `${infer A}:${infer B}` ? `on${Capitalize<A>}${Capitalize<B>}` : `on${Capitalize<S>}`;
6
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/types/utils.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG;IACvB,KAAK,EAAE,MAAM,CAAA;IACb,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AAED,MAAM,MAAM,YAAY,CAAC,CAAC,SAAS,MAAM,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,MAAM,CAAC,EAAE,GACrF,KAAK,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,EAAE,GACpD,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,EAAE,GAC/B,KAAK,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,EAAE,GACpC,KAAK,UAAU,CAAC,CAAC,CAAC,EAAE,CAAA"}
@@ -0,0 +1,5 @@
1
+ export type UncontrolledProp = 'left' | 'top' | 'width' | 'height' | 'scaleX' | 'scaleY' | 'angle' | 'points' | 'path' | 'originX' | 'originY';
2
+ export declare const UNCONTROLLED_PROPS: readonly UncontrolledProp[];
3
+ export type DefaultProp = `default${Capitalize<UncontrolledProp>}`;
4
+ export declare const DEFAULT_PROPS: readonly DefaultProp[];
5
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/utils/constants.ts"],"names":[],"mappings":"AACA,MAAM,MAAM,gBAAgB,GACxB,MAAM,GACN,KAAK,GACL,OAAO,GACP,QAAQ,GACR,QAAQ,GACR,QAAQ,GACR,OAAO,GACP,QAAQ,GACR,MAAM,GACN,SAAS,GACT,SAAS,CAAA;AAGb,eAAO,MAAM,kBAAkB,EAY1B,SAAS,gBAAgB,EAAE,CAAA;AAGhC,MAAM,MAAM,WAAW,GAAG,UAAU,UAAU,CAAC,gBAAgB,CAAC,EAAE,CAAA;AAGlE,eAAO,MAAM,aAAa,EAErB,SAAS,WAAW,EAAE,CAAA"}
@@ -0,0 +1,3 @@
1
+ import type { Dimensions } from '../types/utils';
2
+ export declare const getDimensions: (node: HTMLCanvasElement) => Dimensions;
3
+ //# sourceMappingURL=dom.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dom.d.ts","sourceRoot":"","sources":["../../../src/utils/dom.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAEhD,eAAO,MAAM,aAAa,SAAU,iBAAiB,KAAG,UAGtD,CAAA"}
@@ -0,0 +1,5 @@
1
+ import type { CanvasEvents, GroupEvents, ObjectEvents } from 'fabric';
2
+ import type { AllCanvasEvents } from '../types/canvas';
3
+ import type { AllObjectEvents } from '../types/object';
4
+ export declare const bindEvents: <T extends CanvasEvents | ObjectEvents | GroupEvents>(target: any, listeners: Partial<T extends CanvasEvents ? AllCanvasEvents : AllObjectEvents>) => () => void;
5
+ //# sourceMappingURL=events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../src/utils/events.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAA;AACrE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEtD,eAAO,MAAM,UAAU,GAAI,CAAC,SAAS,YAAY,GAAG,YAAY,GAAG,WAAW,UACpE,GAAG,aACA,OAAO,CAAC,CAAC,SAAS,YAAY,GAAG,eAAe,GAAG,eAAe,CAAC,eAkB/E,CAAA"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * 判断sunPosition是否在parentPosition内
3
+ * @param parentPosition 父级位置 (格式: x1,y1,x2,y2,x3,y3,x4,y4)
4
+ * @param sunPosition 子级位置 (格式: x1,y1,x2,y2,x3,y3,x4,y4)
5
+ * @returns boolean
6
+ */
7
+ declare const includes: (parentPosition: string | number[], sunPosition: string | number[]) => boolean;
8
+ export default includes;
9
+ //# sourceMappingURL=position.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"position.d.ts","sourceRoot":"","sources":["../../../src/utils/position.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,QAAA,MAAM,QAAQ,mBAAoB,MAAM,GAAG,MAAM,EAAE,eAAe,MAAM,GAAG,MAAM,EAAE,YAelF,CAAA;AAED,eAAe,QAAQ,CAAA"}
@@ -0,0 +1,4 @@
1
+ import type { AllCanvasEvents } from '../types/canvas';
2
+ export declare const splitListenerProps: <T extends Record<string, any>>(props: T) => [{ [K in keyof AllCanvasEvents]?: AllCanvasEvents[K]; }, Omit<T, keyof AllCanvasEvents>];
3
+ export declare const transformDefaultProps: (defaultValues: Record<string, unknown>) => Record<string, unknown>;
4
+ //# sourceMappingURL=props.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"props.d.ts","sourceRoot":"","sources":["../../../src/utils/props.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEtD,eAAO,MAAM,kBAAkB,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,SACvD,CAAC,KACP,CAAC,GAAG,CAAC,IAAI,MAAM,eAAe,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,GAAE,EAAE,IAAI,CAAC,CAAC,EAAE,MAAM,eAAe,CAAC,CAYxF,CAAA;AAGD,eAAO,MAAM,qBAAqB,kBAAmB,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,4BAY3E,CAAA"}
package/package.json ADDED
@@ -0,0 +1,100 @@
1
+ {
2
+ "name": "@cs-open/react-fabric",
3
+ "type": "module",
4
+ "version": "0.0.3",
5
+ "description": "React Fabric",
6
+ "keywords": [
7
+ "@cs-open/react-fabric",
8
+ "fabric",
9
+ "react-fabric",
10
+ "canvas",
11
+ "fabric.js",
12
+ "fabricjs",
13
+ "react"
14
+ ],
15
+ "repository": {
16
+ "type": "git",
17
+ "url": "https://github.com/cs-open/react-fabric.git",
18
+ "directory": "packages/react"
19
+ },
20
+ "homepage": "https://cs-open.github.io/react-fabric/",
21
+ "bugs": {
22
+ "url": "https://github.com/cs-open/react-fabric/issues"
23
+ },
24
+ "files": [
25
+ "dist"
26
+ ],
27
+ "source": "src/index.ts",
28
+ "main": "dist/cjs/index.cjs",
29
+ "module": "dist/esm/index.mjs",
30
+ "types": "dist/types/index.d.ts",
31
+ "exports": {
32
+ ".": {
33
+ "types": "./dist/types/index.d.ts",
34
+ "import": "./dist/esm/index.mjs",
35
+ "require": "./dist/cjs/index.cjs"
36
+ }
37
+ },
38
+ "sideEffects": [
39
+ "*.css"
40
+ ],
41
+ "license": "MIT",
42
+ "publishConfig": {
43
+ "access": "public"
44
+ },
45
+ "peerDependencies": {
46
+ "@types/hammerjs": "^2.0.46",
47
+ "fabric": "^6.6.1",
48
+ "hammerjs": "^2.0.8",
49
+ "lodash-es": "^4.17.21",
50
+ "react": "^18.3.1",
51
+ "react-dom": "^18.3.1",
52
+ "tailwind-merge": "^3.0.2",
53
+ "use-sync-external-store": "^1.4.0",
54
+ "zustand": "^5.0.3"
55
+ },
56
+ "devDependencies": {
57
+ "@types/fontfaceobserver": "^2.1.3",
58
+ "@types/hammerjs": "^2.0.46",
59
+ "@types/node": "^18.7.16",
60
+ "@types/react": "^18.3.12",
61
+ "@types/react-dom": "^18.3.1",
62
+ "autoprefixer": "^10.4.15",
63
+ "cssnano": "^6.0.1",
64
+ "fabric": "^6.6.1",
65
+ "hammerjs": "^2.0.8",
66
+ "lodash-es": "^4.17.21",
67
+ "postcss": "^8.4.21",
68
+ "postcss-cli": "^11.0.0",
69
+ "postcss-combine-duplicated-selectors": "^10.0.3",
70
+ "postcss-import": "^15.1.0",
71
+ "postcss-nested": "^6.0.0",
72
+ "postcss-rename": "^0.6.1",
73
+ "react": "^18.3.1",
74
+ "react-dom": "^18.3.1",
75
+ "rimraf": "^6.0.1",
76
+ "rollup": "^4.28.1",
77
+ "tailwind-merge": "^3.0.2",
78
+ "use-sync-external-store": "^1.4.0",
79
+ "zustand": "^5.0.3",
80
+ "@cs-open/eslint-config": "0.0.0",
81
+ "@cs-open/rollup-config": "0.0.0",
82
+ "@cs-open/tsconfig": "0.0.0"
83
+ },
84
+ "dependencies": {
85
+ "@ant-design/icons": "^5.5.2",
86
+ "@floating-ui/core": "^1.6.8",
87
+ "@types/lodash-es": "^4.17.12",
88
+ "fontfaceobserver": "^2.3.0"
89
+ },
90
+ "scripts": {
91
+ "dev": "concurrently \"rollup --config node:@cs-open/rollup-config --watch\" \"pnpm typecheck\"",
92
+ "build": "rimraf dist && concurrently \"rollup --config node:@cs-open/rollup-config --environment NODE_ENV:production\" \"pnpm tsc\"",
93
+ "tsc": "tsc -p tsconfig.json --declaration true --emitDeclarationOnly --declarationDir dist/types",
94
+ "clean": "rm -rf .turbo && rm -rf node_modules && rm -rf dist",
95
+ "css": "postcss src/styles/{base,style}.css --config ./../../tooling/postcss-config/ --dir dist ",
96
+ "css-watch": "pnpm css --watch",
97
+ "lint": "eslint --ext .js,.jsx,.ts,.tsx src",
98
+ "typecheck": "tsc --noEmit"
99
+ }
100
+ }