@jotx-labs/editor 2.4.130

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 (261) hide show
  1. package/dist/bridge/BridgeContext.d.ts +14 -0
  2. package/dist/bridge/BridgeContext.d.ts.map +1 -0
  3. package/dist/bridge/BridgeContext.js +20 -0
  4. package/dist/bridge/BridgeContext.js.map +1 -0
  5. package/dist/bridge/bridge-utils.d.ts +24 -0
  6. package/dist/bridge/bridge-utils.d.ts.map +1 -0
  7. package/dist/bridge/bridge-utils.js +77 -0
  8. package/dist/bridge/bridge-utils.js.map +1 -0
  9. package/dist/bridge/types.d.ts +34 -0
  10. package/dist/bridge/types.d.ts.map +1 -0
  11. package/dist/bridge/types.js +27 -0
  12. package/dist/bridge/types.js.map +1 -0
  13. package/dist/bridge/vscode-api.d.ts +13 -0
  14. package/dist/bridge/vscode-api.d.ts.map +1 -0
  15. package/dist/bridge/vscode-api.js +27 -0
  16. package/dist/bridge/vscode-api.js.map +1 -0
  17. package/dist/components/AttachBlockNodeView.d.ts +2 -0
  18. package/dist/components/AttachBlockNodeView.d.ts.map +1 -0
  19. package/dist/components/AttachBlockNodeView.js +37 -0
  20. package/dist/components/AttachBlockNodeView.js.map +1 -0
  21. package/dist/components/BlockMenu.d.ts +11 -0
  22. package/dist/components/BlockMenu.d.ts.map +1 -0
  23. package/dist/components/BlockMenu.js +344 -0
  24. package/dist/components/BlockMenu.js.map +1 -0
  25. package/dist/components/ButtonNodeView.d.ts +17 -0
  26. package/dist/components/ButtonNodeView.d.ts.map +1 -0
  27. package/dist/components/ButtonNodeView.js +55 -0
  28. package/dist/components/ButtonNodeView.js.map +1 -0
  29. package/dist/components/CardNodeView.d.ts +18 -0
  30. package/dist/components/CardNodeView.d.ts.map +1 -0
  31. package/dist/components/CardNodeView.js +46 -0
  32. package/dist/components/CardNodeView.js.map +1 -0
  33. package/dist/components/ChartNodeView.d.ts +4 -0
  34. package/dist/components/ChartNodeView.d.ts.map +1 -0
  35. package/dist/components/ChartNodeView.js +247 -0
  36. package/dist/components/ChartNodeView.js.map +1 -0
  37. package/dist/components/CodeBlockNodeView.d.ts +4 -0
  38. package/dist/components/CodeBlockNodeView.d.ts.map +1 -0
  39. package/dist/components/CodeBlockNodeView.js +105 -0
  40. package/dist/components/CodeBlockNodeView.js.map +1 -0
  41. package/dist/components/CodeReferenceNodeView.d.ts +4 -0
  42. package/dist/components/CodeReferenceNodeView.d.ts.map +1 -0
  43. package/dist/components/CodeReferenceNodeView.js +71 -0
  44. package/dist/components/CodeReferenceNodeView.js.map +1 -0
  45. package/dist/components/DateTimeNodeView.d.ts +3 -0
  46. package/dist/components/DateTimeNodeView.d.ts.map +1 -0
  47. package/dist/components/DateTimeNodeView.js +55 -0
  48. package/dist/components/DateTimeNodeView.js.map +1 -0
  49. package/dist/components/EditorRibbon.d.ts +13 -0
  50. package/dist/components/EditorRibbon.d.ts.map +1 -0
  51. package/dist/components/EditorRibbon.js +12 -0
  52. package/dist/components/EditorRibbon.js.map +1 -0
  53. package/dist/components/FloatImageBlockNodeView.d.ts +6 -0
  54. package/dist/components/FloatImageBlockNodeView.d.ts.map +1 -0
  55. package/dist/components/FloatImageBlockNodeView.js +96 -0
  56. package/dist/components/FloatImageBlockNodeView.js.map +1 -0
  57. package/dist/components/GridCardNodeView.d.ts +13 -0
  58. package/dist/components/GridCardNodeView.d.ts.map +1 -0
  59. package/dist/components/GridCardNodeView.js +31 -0
  60. package/dist/components/GridCardNodeView.js.map +1 -0
  61. package/dist/components/ImageBlockNodeView.d.ts +7 -0
  62. package/dist/components/ImageBlockNodeView.d.ts.map +1 -0
  63. package/dist/components/ImageBlockNodeView.js +132 -0
  64. package/dist/components/ImageBlockNodeView.js.map +1 -0
  65. package/dist/components/ImageToolbar.d.ts +6 -0
  66. package/dist/components/ImageToolbar.d.ts.map +1 -0
  67. package/dist/components/ImageToolbar.js +67 -0
  68. package/dist/components/ImageToolbar.js.map +1 -0
  69. package/dist/components/JotxEditor.d.ts +17 -0
  70. package/dist/components/JotxEditor.d.ts.map +1 -0
  71. package/dist/components/JotxEditor.js +1121 -0
  72. package/dist/components/JotxEditor.js.map +1 -0
  73. package/dist/components/JotxLinkNodeView.d.ts +4 -0
  74. package/dist/components/JotxLinkNodeView.d.ts.map +1 -0
  75. package/dist/components/JotxLinkNodeView.js +123 -0
  76. package/dist/components/JotxLinkNodeView.js.map +1 -0
  77. package/dist/components/LinkDialog.d.ts +14 -0
  78. package/dist/components/LinkDialog.d.ts.map +1 -0
  79. package/dist/components/LinkDialog.js +33 -0
  80. package/dist/components/LinkDialog.js.map +1 -0
  81. package/dist/components/MathNodeView.d.ts +3 -0
  82. package/dist/components/MathNodeView.d.ts.map +1 -0
  83. package/dist/components/MathNodeView.js +67 -0
  84. package/dist/components/MathNodeView.js.map +1 -0
  85. package/dist/components/MermaidNodeView.d.ts +4 -0
  86. package/dist/components/MermaidNodeView.d.ts.map +1 -0
  87. package/dist/components/MermaidNodeView.js +442 -0
  88. package/dist/components/MermaidNodeView.js.map +1 -0
  89. package/dist/components/NodePickerDialog.d.ts +12 -0
  90. package/dist/components/NodePickerDialog.d.ts.map +1 -0
  91. package/dist/components/NodePickerDialog.js +90 -0
  92. package/dist/components/NodePickerDialog.js.map +1 -0
  93. package/dist/components/ReadonlyBlockRenderer.d.ts +13 -0
  94. package/dist/components/ReadonlyBlockRenderer.d.ts.map +1 -0
  95. package/dist/components/ReadonlyBlockRenderer.js +78 -0
  96. package/dist/components/ReadonlyBlockRenderer.js.map +1 -0
  97. package/dist/components/ReadonlyMermaid.d.ts +10 -0
  98. package/dist/components/ReadonlyMermaid.d.ts.map +1 -0
  99. package/dist/components/ReadonlyMermaid.js +70 -0
  100. package/dist/components/ReadonlyMermaid.js.map +1 -0
  101. package/dist/components/SearchBar.d.ts +16 -0
  102. package/dist/components/SearchBar.d.ts.map +1 -0
  103. package/dist/components/SearchBar.js +52 -0
  104. package/dist/components/SearchBar.js.map +1 -0
  105. package/dist/components/SectionNodeView.d.ts +4 -0
  106. package/dist/components/SectionNodeView.d.ts.map +1 -0
  107. package/dist/components/SectionNodeView.js +39 -0
  108. package/dist/components/SectionNodeView.js.map +1 -0
  109. package/dist/components/SlashMenu.d.ts +21 -0
  110. package/dist/components/SlashMenu.d.ts.map +1 -0
  111. package/dist/components/SlashMenu.js +356 -0
  112. package/dist/components/SlashMenu.js.map +1 -0
  113. package/dist/components/TableToolbar.d.ts +10 -0
  114. package/dist/components/TableToolbar.d.ts.map +1 -0
  115. package/dist/components/TableToolbar.js +189 -0
  116. package/dist/components/TableToolbar.js.map +1 -0
  117. package/dist/components/ToggleNodeView.d.ts +4 -0
  118. package/dist/components/ToggleNodeView.d.ts.map +1 -0
  119. package/dist/components/ToggleNodeView.js +39 -0
  120. package/dist/components/ToggleNodeView.js.map +1 -0
  121. package/dist/components/UrlInputDialog.d.ts +13 -0
  122. package/dist/components/UrlInputDialog.d.ts.map +1 -0
  123. package/dist/components/UrlInputDialog.js +39 -0
  124. package/dist/components/UrlInputDialog.js.map +1 -0
  125. package/dist/components/VideoBlockNodeView.d.ts +12 -0
  126. package/dist/components/VideoBlockNodeView.d.ts.map +1 -0
  127. package/dist/components/VideoBlockNodeView.js +97 -0
  128. package/dist/components/VideoBlockNodeView.js.map +1 -0
  129. package/dist/contexts/NodeManagerContext.d.ts +34 -0
  130. package/dist/contexts/NodeManagerContext.d.ts.map +1 -0
  131. package/dist/contexts/NodeManagerContext.js +31 -0
  132. package/dist/contexts/NodeManagerContext.js.map +1 -0
  133. package/dist/extensions/AttachNode.d.ts +7 -0
  134. package/dist/extensions/AttachNode.d.ts.map +1 -0
  135. package/dist/extensions/AttachNode.js +50 -0
  136. package/dist/extensions/AttachNode.js.map +1 -0
  137. package/dist/extensions/BlockOpsExtension.d.ts +17 -0
  138. package/dist/extensions/BlockOpsExtension.d.ts.map +1 -0
  139. package/dist/extensions/BlockOpsExtension.js +248 -0
  140. package/dist/extensions/BlockOpsExtension.js.map +1 -0
  141. package/dist/extensions/ButtonNode.d.ts +7 -0
  142. package/dist/extensions/ButtonNode.d.ts.map +1 -0
  143. package/dist/extensions/ButtonNode.js +59 -0
  144. package/dist/extensions/ButtonNode.js.map +1 -0
  145. package/dist/extensions/CalloutActionsExtension.d.ts +3 -0
  146. package/dist/extensions/CalloutActionsExtension.d.ts.map +1 -0
  147. package/dist/extensions/CalloutActionsExtension.js +41 -0
  148. package/dist/extensions/CalloutActionsExtension.js.map +1 -0
  149. package/dist/extensions/CalloutNode.d.ts +7 -0
  150. package/dist/extensions/CalloutNode.d.ts.map +1 -0
  151. package/dist/extensions/CalloutNode.js +48 -0
  152. package/dist/extensions/CalloutNode.js.map +1 -0
  153. package/dist/extensions/CardNode.d.ts +7 -0
  154. package/dist/extensions/CardNode.d.ts.map +1 -0
  155. package/dist/extensions/CardNode.js +64 -0
  156. package/dist/extensions/CardNode.js.map +1 -0
  157. package/dist/extensions/ChartNode.d.ts +3 -0
  158. package/dist/extensions/ChartNode.d.ts.map +1 -0
  159. package/dist/extensions/ChartNode.js +60 -0
  160. package/dist/extensions/ChartNode.js.map +1 -0
  161. package/dist/extensions/CodeBlockNode.d.ts +7 -0
  162. package/dist/extensions/CodeBlockNode.d.ts.map +1 -0
  163. package/dist/extensions/CodeBlockNode.js +57 -0
  164. package/dist/extensions/CodeBlockNode.js.map +1 -0
  165. package/dist/extensions/CodeReferenceNode.d.ts +3 -0
  166. package/dist/extensions/CodeReferenceNode.d.ts.map +1 -0
  167. package/dist/extensions/CodeReferenceNode.js +46 -0
  168. package/dist/extensions/CodeReferenceNode.js.map +1 -0
  169. package/dist/extensions/DateTimeNode.d.ts +3 -0
  170. package/dist/extensions/DateTimeNode.d.ts.map +1 -0
  171. package/dist/extensions/DateTimeNode.js +43 -0
  172. package/dist/extensions/DateTimeNode.js.map +1 -0
  173. package/dist/extensions/FloatImageBlockNode.d.ts +7 -0
  174. package/dist/extensions/FloatImageBlockNode.d.ts.map +1 -0
  175. package/dist/extensions/FloatImageBlockNode.js +73 -0
  176. package/dist/extensions/FloatImageBlockNode.js.map +1 -0
  177. package/dist/extensions/GridCardNode.d.ts +7 -0
  178. package/dist/extensions/GridCardNode.d.ts.map +1 -0
  179. package/dist/extensions/GridCardNode.js +56 -0
  180. package/dist/extensions/GridCardNode.js.map +1 -0
  181. package/dist/extensions/ImageBlockNode.d.ts +7 -0
  182. package/dist/extensions/ImageBlockNode.d.ts.map +1 -0
  183. package/dist/extensions/ImageBlockNode.js +76 -0
  184. package/dist/extensions/ImageBlockNode.js.map +1 -0
  185. package/dist/extensions/ImageNode.d.ts +10 -0
  186. package/dist/extensions/ImageNode.d.ts.map +1 -0
  187. package/dist/extensions/ImageNode.js +67 -0
  188. package/dist/extensions/ImageNode.js.map +1 -0
  189. package/dist/extensions/JotxLinkNode.d.ts +3 -0
  190. package/dist/extensions/JotxLinkNode.d.ts.map +1 -0
  191. package/dist/extensions/JotxLinkNode.js +43 -0
  192. package/dist/extensions/JotxLinkNode.js.map +1 -0
  193. package/dist/extensions/JotxTable.d.ts +9 -0
  194. package/dist/extensions/JotxTable.d.ts.map +1 -0
  195. package/dist/extensions/JotxTable.js +40 -0
  196. package/dist/extensions/JotxTable.js.map +1 -0
  197. package/dist/extensions/LinkNode.d.ts +7 -0
  198. package/dist/extensions/LinkNode.d.ts.map +1 -0
  199. package/dist/extensions/LinkNode.js +54 -0
  200. package/dist/extensions/LinkNode.js.map +1 -0
  201. package/dist/extensions/MathNode.d.ts +3 -0
  202. package/dist/extensions/MathNode.d.ts.map +1 -0
  203. package/dist/extensions/MathNode.js +61 -0
  204. package/dist/extensions/MathNode.js.map +1 -0
  205. package/dist/extensions/MermaidNode.d.ts +3 -0
  206. package/dist/extensions/MermaidNode.d.ts.map +1 -0
  207. package/dist/extensions/MermaidNode.js +59 -0
  208. package/dist/extensions/MermaidNode.js.map +1 -0
  209. package/dist/extensions/SearchExtension.d.ts +40 -0
  210. package/dist/extensions/SearchExtension.d.ts.map +1 -0
  211. package/dist/extensions/SearchExtension.js +186 -0
  212. package/dist/extensions/SearchExtension.js.map +1 -0
  213. package/dist/extensions/SectionNode.d.ts +11 -0
  214. package/dist/extensions/SectionNode.d.ts.map +1 -0
  215. package/dist/extensions/SectionNode.js +58 -0
  216. package/dist/extensions/SectionNode.js.map +1 -0
  217. package/dist/extensions/SlashMenuExtension.d.ts +17 -0
  218. package/dist/extensions/SlashMenuExtension.d.ts.map +1 -0
  219. package/dist/extensions/SlashMenuExtension.js +146 -0
  220. package/dist/extensions/SlashMenuExtension.js.map +1 -0
  221. package/dist/extensions/SpellCheckExtension.d.ts +14 -0
  222. package/dist/extensions/SpellCheckExtension.d.ts.map +1 -0
  223. package/dist/extensions/SpellCheckExtension.js +278 -0
  224. package/dist/extensions/SpellCheckExtension.js.map +1 -0
  225. package/dist/extensions/TableFilterExtension.d.ts +12 -0
  226. package/dist/extensions/TableFilterExtension.d.ts.map +1 -0
  227. package/dist/extensions/TableFilterExtension.js +75 -0
  228. package/dist/extensions/TableFilterExtension.js.map +1 -0
  229. package/dist/extensions/ToggleNode.d.ts +11 -0
  230. package/dist/extensions/ToggleNode.d.ts.map +1 -0
  231. package/dist/extensions/ToggleNode.js +58 -0
  232. package/dist/extensions/ToggleNode.js.map +1 -0
  233. package/dist/extensions/VideoBlockNode.d.ts +7 -0
  234. package/dist/extensions/VideoBlockNode.d.ts.map +1 -0
  235. package/dist/extensions/VideoBlockNode.js +95 -0
  236. package/dist/extensions/VideoBlockNode.js.map +1 -0
  237. package/dist/extensions/formatting.d.ts +2 -0
  238. package/dist/extensions/formatting.d.ts.map +1 -0
  239. package/dist/extensions/formatting.js +10 -0
  240. package/dist/extensions/formatting.js.map +1 -0
  241. package/dist/index.d.ts +61 -0
  242. package/dist/index.d.ts.map +1 -0
  243. package/dist/index.js +132 -0
  244. package/dist/index.js.map +1 -0
  245. package/dist/services/ImageStorage.d.ts +38 -0
  246. package/dist/services/ImageStorage.d.ts.map +1 -0
  247. package/dist/services/ImageStorage.js +32 -0
  248. package/dist/services/ImageStorage.js.map +1 -0
  249. package/dist/services/SpellCheckService 2.d.ts +50 -0
  250. package/dist/services/SpellCheckService 2.d.ts.map +1 -0
  251. package/dist/services/SpellCheckService 2.js +131 -0
  252. package/dist/services/SpellCheckService 2.js.map +1 -0
  253. package/dist/services/SpellCheckService.d.ts +50 -0
  254. package/dist/services/SpellCheckService.d.ts.map +1 -0
  255. package/dist/services/SpellCheckService.js +131 -0
  256. package/dist/services/SpellCheckService.js.map +1 -0
  257. package/dist/utils/logger.d.ts +14 -0
  258. package/dist/utils/logger.d.ts.map +1 -0
  259. package/dist/utils/logger.js +25 -0
  260. package/dist/utils/logger.js.map +1 -0
  261. package/package.json +56 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FloatImageBlockNodeView.d.ts","sourceRoot":"","sources":["../../src/components/FloatImageBlockNodeView.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAoC,aAAa,EAAE,MAAM,eAAe,CAAA;AAI/E,wBAAgB,uBAAuB,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,EAAE,aAAa,2CA4L1F"}
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FloatImageBlockNodeView = FloatImageBlockNodeView;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ /**
6
+ * Float Image Block NodeView - CONTAINER with floating image + editable content
7
+ */
8
+ const react_1 = require("react");
9
+ const react_2 = require("@tiptap/react");
10
+ const ImageStorage_1 = require("../services/ImageStorage");
11
+ const logger_1 = require("../utils/logger");
12
+ function FloatImageBlockNodeView({ node, updateAttributes, selected }) {
13
+ logger_1.logger.log('🎨 FloatImageBlockNodeView RENDERING', { node: node.attrs, selected });
14
+ const [uploading, setUploading] = (0, react_1.useState)(false);
15
+ const [error, setError] = (0, react_1.useState)('');
16
+ const [showUrlInput, setShowUrlInput] = (0, react_1.useState)(false);
17
+ const [urlInput, setUrlInput] = (0, react_1.useState)('');
18
+ const fileInputRef = (0, react_1.useRef)(null);
19
+ const { src, alt, width, height, float: floatPos, caption } = node.attrs;
20
+ logger_1.logger.log('🔍 FloatImageBlockNodeView attrs:', { src, alt, width, height, float: floatPos, caption });
21
+ const handleFileSelect = async (event) => {
22
+ const file = event.target.files?.[0];
23
+ if (!file)
24
+ return;
25
+ setUploading(true);
26
+ setError('');
27
+ try {
28
+ const reader = new FileReader();
29
+ reader.onload = async (e) => {
30
+ const base64 = (e.target?.result).split(',')[1];
31
+ try {
32
+ const relativePath = await ImageStorage_1.ImageStorage.saveImage({
33
+ base64,
34
+ mime: file.type,
35
+ fileName: file.name
36
+ });
37
+ updateAttributes({ src: relativePath });
38
+ }
39
+ catch (err) {
40
+ setError(err.message || 'Failed to upload image');
41
+ }
42
+ finally {
43
+ setUploading(false);
44
+ }
45
+ };
46
+ reader.readAsDataURL(file);
47
+ }
48
+ catch (err) {
49
+ setError(err.message || 'Failed to read file');
50
+ setUploading(false);
51
+ }
52
+ };
53
+ const handleUrlSubmit = () => {
54
+ const trimmedUrl = urlInput.trim();
55
+ if (!trimmedUrl) {
56
+ setError('Please enter a valid URL');
57
+ return;
58
+ }
59
+ // Basic URL validation
60
+ try {
61
+ new URL(trimmedUrl);
62
+ updateAttributes({ src: trimmedUrl });
63
+ setUrlInput('');
64
+ setShowUrlInput(false);
65
+ setError('');
66
+ }
67
+ catch {
68
+ setError('Invalid URL format');
69
+ }
70
+ };
71
+ if (!src) {
72
+ return ((0, jsx_runtime_1.jsx)(react_2.NodeViewWrapper, { children: (0, jsx_runtime_1.jsxs)("div", { className: `jotx-float-image-empty ${selected ? 'selected' : ''}`, children: [(0, jsx_runtime_1.jsx)("input", { ref: fileInputRef, type: "file", accept: "image/*", onChange: handleFileSelect, style: { display: 'none' } }), !showUrlInput ? ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', gap: '8px' }, children: [(0, jsx_runtime_1.jsx)("button", { onClick: () => fileInputRef.current?.click(), disabled: uploading, children: uploading ? 'Uploading...' : '📷 Upload Image' }), (0, jsx_runtime_1.jsx)("button", { onClick: () => setShowUrlInput(true), disabled: uploading, children: "\uD83D\uDD17 Image URL" })] })) : ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', gap: '8px', width: '100%', maxWidth: '500px' }, children: [(0, jsx_runtime_1.jsx)("input", { type: "text", placeholder: "Paste image URL (https://...)", value: urlInput, onChange: (e) => setUrlInput(e.target.value), onKeyDown: (e) => {
73
+ if (e.key === 'Enter') {
74
+ e.preventDefault();
75
+ handleUrlSubmit();
76
+ }
77
+ else if (e.key === 'Escape') {
78
+ setShowUrlInput(false);
79
+ setUrlInput('');
80
+ setError('');
81
+ }
82
+ }, style: {
83
+ flex: 1,
84
+ padding: '8px 12px',
85
+ border: '1px solid var(--jotx-border)',
86
+ borderRadius: '4px',
87
+ fontSize: '14px'
88
+ }, autoFocus: true }), (0, jsx_runtime_1.jsx)("button", { onClick: handleUrlSubmit, style: { padding: '8px 16px' }, children: "Add" }), (0, jsx_runtime_1.jsx)("button", { onClick: () => {
89
+ setShowUrlInput(false);
90
+ setUrlInput('');
91
+ setError('');
92
+ }, style: { padding: '8px 16px' }, children: "Cancel" })] })), error && (0, jsx_runtime_1.jsx)("div", { className: "jotx-image-error", children: error })] }) }));
93
+ }
94
+ return ((0, jsx_runtime_1.jsx)(react_2.NodeViewWrapper, { children: (0, jsx_runtime_1.jsxs)("div", { className: `jotx-float-image-container ${selected ? 'selected' : ''}`, children: [(0, jsx_runtime_1.jsxs)("div", { className: `jotx-float-image-wrapper jotx-float-${floatPos}`, contentEditable: false, children: [(0, jsx_runtime_1.jsx)("img", { src: src, alt: alt, style: { width: width ? `${width}px` : 'auto', height: height !== 'auto' ? `${height}px` : 'auto' }, draggable: false }), selected && ((0, jsx_runtime_1.jsxs)("div", { className: "jotx-image-controls", children: [(0, jsx_runtime_1.jsx)("button", { onClick: () => fileInputRef.current?.click(), children: "Change" }), (0, jsx_runtime_1.jsxs)("select", { value: floatPos, onChange: (e) => updateAttributes({ float: e.target.value }), children: [(0, jsx_runtime_1.jsx)("option", { value: "left", children: "Float Left" }), (0, jsx_runtime_1.jsx)("option", { value: "right", children: "Float Right" })] }), (0, jsx_runtime_1.jsx)("input", { type: "number", value: width, onChange: (e) => updateAttributes({ width: parseInt(e.target.value) || 400 }), placeholder: "Width", style: { width: '80px' } })] })), (caption || selected) && ((0, jsx_runtime_1.jsx)("input", { type: "text", className: "jotx-image-caption", value: caption, onChange: (e) => updateAttributes({ caption: e.target.value }), placeholder: "Add a caption..." }))] }), (0, jsx_runtime_1.jsx)(react_2.NodeViewContent, { className: "jotx-float-image-content" }), (0, jsx_runtime_1.jsx)("div", { style: { clear: 'both' } }), (0, jsx_runtime_1.jsx)("input", { ref: fileInputRef, type: "file", accept: "image/*", onChange: handleFileSelect, style: { display: 'none' } })] }) }));
95
+ }
96
+ //# sourceMappingURL=FloatImageBlockNodeView.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FloatImageBlockNodeView.js","sourceRoot":"","sources":["../../src/components/FloatImageBlockNodeView.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import './GridCardNodeView.css';
2
+ interface GridCardNodeViewProps {
3
+ node: {
4
+ attrs: {
5
+ layout?: string;
6
+ blockId?: string;
7
+ };
8
+ };
9
+ updateAttributes: (attrs: Record<string, any>) => void;
10
+ }
11
+ export declare function GridCardNodeView({ node, updateAttributes }: GridCardNodeViewProps): import("react/jsx-runtime").JSX.Element;
12
+ export {};
13
+ //# sourceMappingURL=GridCardNodeView.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GridCardNodeView.d.ts","sourceRoot":"","sources":["../../src/components/GridCardNodeView.tsx"],"names":[],"mappings":"AAEA,OAAO,wBAAwB,CAAA;AAE/B,UAAU,qBAAqB;IAC3B,IAAI,EAAE;QACF,KAAK,EAAE;YACH,MAAM,CAAC,EAAE,MAAM,CAAA;YACf,OAAO,CAAC,EAAE,MAAM,CAAA;SACnB,CAAA;KACJ,CAAA;IACD,gBAAgB,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAA;CACzD;AAcD,wBAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,EAAE,qBAAqB,2CAqCjF"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GridCardNodeView = GridCardNodeView;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("@tiptap/react");
6
+ require("./GridCardNodeView.css");
7
+ // Available layouts from 1x2 to 3x3
8
+ const LAYOUT_OPTIONS = [
9
+ { value: '1x2', label: '1×2' },
10
+ { value: '1x3', label: '1×3' },
11
+ { value: '2x1', label: '2×1' },
12
+ { value: '2x2', label: '2×2' },
13
+ { value: '2x3', label: '2×3' },
14
+ { value: '3x1', label: '3×1' },
15
+ { value: '3x2', label: '3×2' },
16
+ { value: '3x3', label: '3×3' },
17
+ ];
18
+ function GridCardNodeView({ node, updateAttributes }) {
19
+ const layout = node.attrs.layout || '2x2';
20
+ // Parse layout to get columns
21
+ const [cols] = layout.split('x').map(Number);
22
+ const handleLayoutChange = (e) => {
23
+ updateAttributes({ layout: e.target.value });
24
+ };
25
+ return ((0, jsx_runtime_1.jsxs)(react_1.NodeViewWrapper, { className: "gridcard-wrapper", children: [(0, jsx_runtime_1.jsx)("div", { className: "gridcard-controls", children: (0, jsx_runtime_1.jsx)("select", { value: layout, onChange: handleLayoutChange, className: "gridcard-layout-select", title: "Grid Layout", children: LAYOUT_OPTIONS.map(opt => ((0, jsx_runtime_1.jsx)("option", { value: opt.value, children: opt.label }, opt.value))) }) }), (0, jsx_runtime_1.jsx)("div", { className: "gridcard", "data-layout": layout, style: {
26
+ display: 'grid',
27
+ gridTemplateColumns: `repeat(${cols}, 1fr)`,
28
+ gap: '12px'
29
+ }, children: (0, jsx_runtime_1.jsx)(react_1.NodeViewContent, { className: "gridcard-content" }) })] }));
30
+ }
31
+ //# sourceMappingURL=GridCardNodeView.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GridCardNodeView.js","sourceRoot":"","sources":["../../src/components/GridCardNodeView.tsx"],"names":[],"mappings":";;AA0BA,4CAqCC;;AA9DD,yCAAgE;AAChE,kCAA+B;AAY/B,oCAAoC;AACpC,MAAM,cAAc,GAAG;IACnB,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;IAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;CACjC,CAAA;AAED,SAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAyB;IAC9E,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,KAAK,CAAA;IAEzC,8BAA8B;IAC9B,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAE5C,MAAM,kBAAkB,GAAG,CAAC,CAAuC,EAAE,EAAE;QACnE,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAA;IAChD,CAAC,CAAA;IAED,OAAO,CACH,wBAAC,uBAAe,IAAC,SAAS,EAAC,kBAAkB,aACzC,gCAAK,SAAS,EAAC,mBAAmB,YAC9B,mCACI,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,kBAAkB,EAC5B,SAAS,EAAC,wBAAwB,EAClC,KAAK,EAAC,aAAa,YAElB,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CACvB,mCAAwB,KAAK,EAAE,GAAG,CAAC,KAAK,YAAG,GAAG,CAAC,KAAK,IAAvC,GAAG,CAAC,KAAK,CAAwC,CACjE,CAAC,GACG,GACP,EACN,gCACI,SAAS,EAAC,UAAU,iBACP,MAAM,EACnB,KAAK,EAAE;oBACH,OAAO,EAAE,MAAM;oBACf,mBAAmB,EAAE,UAAU,IAAI,QAAQ;oBAC3C,GAAG,EAAE,MAAM;iBACd,YAED,uBAAC,uBAAe,IAAC,SAAS,EAAC,kBAAkB,GAAG,GAC9C,IACQ,CACrB,CAAA;AACL,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Image Block NodeView - Regular image with text below
3
+ * Features: Upload, resize, caption, alignment
4
+ */
5
+ import { NodeViewProps } from '@tiptap/react';
6
+ export declare function ImageBlockNodeView({ node, updateAttributes, selected, editor }: NodeViewProps): import("react/jsx-runtime").JSX.Element;
7
+ //# sourceMappingURL=ImageBlockNodeView.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageBlockNodeView.d.ts","sourceRoot":"","sources":["../../src/components/ImageBlockNodeView.tsx"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAmB,aAAa,EAAE,MAAM,eAAe,CAAA;AAI9D,wBAAgB,kBAAkB,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,aAAa,2CAwO7F"}
@@ -0,0 +1,132 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ImageBlockNodeView = ImageBlockNodeView;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ /**
6
+ * Image Block NodeView - Regular image with text below
7
+ * Features: Upload, resize, caption, alignment
8
+ */
9
+ const react_1 = require("react");
10
+ const react_2 = require("@tiptap/react");
11
+ const ImageStorage_1 = require("../services/ImageStorage");
12
+ const logger_1 = require("../utils/logger");
13
+ function ImageBlockNodeView({ node, updateAttributes, selected, editor }) {
14
+ logger_1.logger.log('🎨 ImageBlockNodeView RENDERING', { node: node.attrs, selected });
15
+ const [uploading, setUploading] = (0, react_1.useState)(false);
16
+ const [error, setError] = (0, react_1.useState)('');
17
+ const [showUrlInput, setShowUrlInput] = (0, react_1.useState)(false);
18
+ const [urlInput, setUrlInput] = (0, react_1.useState)('');
19
+ const [captionFocused, setCaptionFocused] = (0, react_1.useState)(false);
20
+ const fileInputRef = (0, react_1.useRef)(null);
21
+ const { src, alt, width, height, align, caption } = node.attrs;
22
+ logger_1.logger.log('🔍 ImageBlockNodeView attrs:', { src, alt, width, height, align, caption });
23
+ const handleFileSelect = async (event) => {
24
+ const file = event.target.files?.[0];
25
+ if (!file)
26
+ return;
27
+ setUploading(true);
28
+ setError('');
29
+ try {
30
+ // Read file as base64
31
+ const reader = new FileReader();
32
+ reader.onload = async (e) => {
33
+ const base64 = (e.target?.result).split(',')[1];
34
+ try {
35
+ const relativePath = await ImageStorage_1.ImageStorage.saveImage({
36
+ base64,
37
+ mime: file.type,
38
+ fileName: file.name
39
+ });
40
+ updateAttributes({ src: relativePath });
41
+ }
42
+ catch (err) {
43
+ setError(err.message || 'Failed to upload image');
44
+ }
45
+ finally {
46
+ setUploading(false);
47
+ }
48
+ };
49
+ reader.readAsDataURL(file);
50
+ }
51
+ catch (err) {
52
+ setError(err.message || 'Failed to read file');
53
+ setUploading(false);
54
+ }
55
+ };
56
+ const handlePaste = async (e) => {
57
+ const items = e.clipboardData?.items;
58
+ if (!items)
59
+ return;
60
+ for (const item of Array.from(items)) {
61
+ if (item.type.startsWith('image/')) {
62
+ e.preventDefault();
63
+ const file = item.getAsFile();
64
+ if (!file)
65
+ continue;
66
+ setUploading(true);
67
+ const reader = new FileReader();
68
+ reader.onload = async (event) => {
69
+ const base64 = (event.target?.result).split(',')[1];
70
+ try {
71
+ const relativePath = await ImageStorage_1.ImageStorage.saveImage({
72
+ base64,
73
+ mime: file.type
74
+ });
75
+ updateAttributes({ src: relativePath });
76
+ }
77
+ catch (err) {
78
+ setError(err.message || 'Failed to save pasted image');
79
+ }
80
+ finally {
81
+ setUploading(false);
82
+ }
83
+ };
84
+ reader.readAsDataURL(file);
85
+ break;
86
+ }
87
+ }
88
+ };
89
+ const handleUrlSubmit = () => {
90
+ const trimmedUrl = urlInput.trim();
91
+ if (!trimmedUrl) {
92
+ setError('Please enter a valid URL');
93
+ return;
94
+ }
95
+ // Basic URL validation
96
+ try {
97
+ new URL(trimmedUrl);
98
+ updateAttributes({ src: trimmedUrl });
99
+ setUrlInput('');
100
+ setShowUrlInput(false);
101
+ setError('');
102
+ }
103
+ catch {
104
+ setError('Invalid URL format');
105
+ }
106
+ };
107
+ if (!src) {
108
+ return ((0, jsx_runtime_1.jsx)(react_2.NodeViewWrapper, { children: (0, jsx_runtime_1.jsxs)("div", { className: `jotx-image-block-empty ${selected ? 'selected' : ''}`, onPaste: handlePaste, children: [(0, jsx_runtime_1.jsx)("input", { ref: fileInputRef, type: "file", accept: "image/*", onChange: handleFileSelect, style: { display: 'none' } }), !showUrlInput ? ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', gap: '8px', flexDirection: 'column', alignItems: 'center' }, children: [(0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', gap: '8px' }, children: [(0, jsx_runtime_1.jsx)("button", { className: "jotx-image-upload-button", onClick: () => fileInputRef.current?.click(), disabled: uploading, children: uploading ? 'Uploading...' : '📷 Upload Image' }), (0, jsx_runtime_1.jsx)("button", { className: "jotx-image-upload-button", onClick: () => setShowUrlInput(true), disabled: uploading, children: "\uD83D\uDD17 Image URL" })] }), (0, jsx_runtime_1.jsx)("span", { style: { fontSize: '12px', color: 'var(--jotx-text-muted)' }, children: "or paste image" })] })) : ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', gap: '8px', width: '100%', maxWidth: '500px' }, children: [(0, jsx_runtime_1.jsx)("input", { type: "text", placeholder: "Paste image URL (https://...)", value: urlInput, onChange: (e) => setUrlInput(e.target.value), onKeyDown: (e) => {
109
+ if (e.key === 'Enter') {
110
+ e.preventDefault();
111
+ handleUrlSubmit();
112
+ }
113
+ else if (e.key === 'Escape') {
114
+ setShowUrlInput(false);
115
+ setUrlInput('');
116
+ setError('');
117
+ }
118
+ }, style: {
119
+ flex: 1,
120
+ padding: '8px 12px',
121
+ border: '1px solid var(--jotx-border)',
122
+ borderRadius: '4px',
123
+ fontSize: '14px'
124
+ }, autoFocus: true }), (0, jsx_runtime_1.jsx)("button", { onClick: handleUrlSubmit, style: { padding: '8px 16px' }, children: "Add" }), (0, jsx_runtime_1.jsx)("button", { onClick: () => {
125
+ setShowUrlInput(false);
126
+ setUrlInput('');
127
+ setError('');
128
+ }, style: { padding: '8px 16px' }, children: "Cancel" })] })), error && (0, jsx_runtime_1.jsx)("div", { className: "jotx-image-error", children: error })] }) }));
129
+ }
130
+ return ((0, jsx_runtime_1.jsx)(react_2.NodeViewWrapper, { children: (0, jsx_runtime_1.jsxs)("div", { className: `jotx-image-block jotx-image-align-${align} ${selected ? 'selected' : ''}`, contentEditable: false, children: [(0, jsx_runtime_1.jsxs)("div", { className: "jotx-image-wrapper", children: [(0, jsx_runtime_1.jsx)("img", { src: src, alt: alt, style: { width: width ? `${width}px` : 'auto', height: height !== 'auto' ? `${height}px` : 'auto' }, draggable: false }), selected && !captionFocused && ((0, jsx_runtime_1.jsxs)("div", { className: "jotx-image-controls", children: [(0, jsx_runtime_1.jsx)("button", { onClick: () => fileInputRef.current?.click(), children: "Change" }), (0, jsx_runtime_1.jsxs)("select", { value: align, onChange: (e) => updateAttributes({ align: e.target.value }), children: [(0, jsx_runtime_1.jsx)("option", { value: "left", children: "Left" }), (0, jsx_runtime_1.jsx)("option", { value: "center", children: "Center" }), (0, jsx_runtime_1.jsx)("option", { value: "right", children: "Right" }), (0, jsx_runtime_1.jsx)("option", { value: "full", children: "Full Width" })] }), (0, jsx_runtime_1.jsx)("input", { type: "number", value: width, onChange: (e) => updateAttributes({ width: parseInt(e.target.value) || 800 }), placeholder: "Width", style: { width: '80px' } })] }))] }), (caption || selected) && ((0, jsx_runtime_1.jsx)("input", { type: "text", className: "jotx-image-caption", value: caption, onChange: (e) => updateAttributes({ caption: e.target.value }), onFocus: () => setCaptionFocused(true), onBlur: () => setCaptionFocused(false), placeholder: "Add a caption..." })), (0, jsx_runtime_1.jsx)("input", { ref: fileInputRef, type: "file", accept: "image/*", onChange: handleFileSelect, style: { display: 'none' } })] }) }));
131
+ }
132
+ //# sourceMappingURL=ImageBlockNodeView.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageBlockNodeView.js","sourceRoot":"","sources":["../../src/components/ImageBlockNodeView.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { Editor } from '@tiptap/react';
2
+ import './ImageToolbar.css';
3
+ export declare function ImageToolbar({ editor }: {
4
+ editor: Editor;
5
+ }): import("react/jsx-runtime").JSX.Element;
6
+ //# sourceMappingURL=ImageToolbar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageToolbar.d.ts","sourceRoot":"","sources":["../../src/components/ImageToolbar.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AAEtC,OAAO,oBAAoB,CAAA;AAQ3B,wBAAgB,YAAY,CAAC,EAAE,MAAM,EAAE,EAAE;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,2CAwG1D"}
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ImageToolbar = ImageToolbar;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const lucide_react_1 = require("lucide-react");
7
+ require("./ImageToolbar.css");
8
+ function clamp(n, min, max) {
9
+ return Math.max(min, Math.min(max, n));
10
+ }
11
+ function ImageToolbar({ editor }) {
12
+ const [pos, setPos] = (0, react_1.useState)({ visible: false, x: 0, y: 0 });
13
+ const [align, setAlign] = (0, react_1.useState)('left');
14
+ const [width, setWidth] = (0, react_1.useState)(100);
15
+ (0, react_1.useEffect)(() => {
16
+ const update = () => {
17
+ if (!editor.isActive('image')) {
18
+ setPos((p) => (p.visible ? { ...p, visible: false } : p));
19
+ return;
20
+ }
21
+ // Read current image attrs
22
+ const attrs = editor.getAttributes('image');
23
+ const a = attrs?.align || 'left';
24
+ const wRaw = typeof attrs?.width === 'number' ? attrs.width : parseInt(String(attrs?.width || ''), 10);
25
+ const w = Number.isFinite(wRaw) ? clamp(wRaw, 10, 100) : 100;
26
+ setAlign(a);
27
+ setWidth(w);
28
+ try {
29
+ const sel = editor.state.selection;
30
+ const from = typeof sel?.from === 'number' ? sel.from : 0;
31
+ const dom = (from ? editor.view.nodeDOM(from) : null);
32
+ if (dom && typeof dom.getBoundingClientRect === 'function') {
33
+ const r = dom.getBoundingClientRect();
34
+ const x = clamp(r.left + r.width / 2 - 160, 12, window.innerWidth - 360);
35
+ const y = clamp(r.top - 54, 12, window.innerHeight - 54);
36
+ setPos({ visible: true, x, y });
37
+ return;
38
+ }
39
+ // Fallback to selection coords
40
+ const coords = editor.view.coordsAtPos(sel.to);
41
+ const x = clamp(coords.left - 120, 12, window.innerWidth - 360);
42
+ const y = clamp(coords.top - 54, 12, window.innerHeight - 54);
43
+ setPos({ visible: true, x, y });
44
+ }
45
+ catch {
46
+ setPos((p) => (p.visible ? { ...p, visible: false } : p));
47
+ }
48
+ };
49
+ update();
50
+ editor.on('selectionUpdate', update);
51
+ editor.on('transaction', update);
52
+ return () => {
53
+ editor.off('selectionUpdate', update);
54
+ editor.off('transaction', update);
55
+ };
56
+ }, [editor]);
57
+ if (!pos.visible)
58
+ return null;
59
+ const setImageAlign = (a) => {
60
+ editor.chain().focus().updateAttributes('image', { align: a }).run();
61
+ };
62
+ const setImageWidth = (w) => {
63
+ editor.chain().focus().updateAttributes('image', { width: clamp(w, 10, 100) }).run();
64
+ };
65
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "jotx-image-toolbar jotx-image-toolbar-floating", style: { left: `${pos.x}px`, top: `${pos.y}px` }, role: "toolbar", children: [(0, jsx_runtime_1.jsx)("button", { className: `jotx-image-toolbar-btn ${align === 'left' ? 'active' : ''}`, title: "Align left", onMouseDown: (e) => e.preventDefault(), onClick: () => setImageAlign('left'), children: (0, jsx_runtime_1.jsx)(lucide_react_1.AlignLeft, { size: 16 }) }), (0, jsx_runtime_1.jsx)("button", { className: `jotx-image-toolbar-btn ${align === 'center' ? 'active' : ''}`, title: "Align center", onMouseDown: (e) => e.preventDefault(), onClick: () => setImageAlign('center'), children: (0, jsx_runtime_1.jsx)(lucide_react_1.AlignCenter, { size: 16 }) }), (0, jsx_runtime_1.jsx)("button", { className: `jotx-image-toolbar-btn ${align === 'right' ? 'active' : ''}`, title: "Align right", onMouseDown: (e) => e.preventDefault(), onClick: () => setImageAlign('right'), children: (0, jsx_runtime_1.jsx)(lucide_react_1.AlignRight, { size: 16 }) }), (0, jsx_runtime_1.jsx)("div", { className: "jotx-image-toolbar-sep" }), (0, jsx_runtime_1.jsxs)("div", { className: "jotx-image-toolbar-size", title: "Image width", children: [(0, jsx_runtime_1.jsx)("input", { type: "range", min: 10, max: 100, step: 5, value: width, onMouseDown: (e) => e.stopPropagation(), onChange: (e) => setImageWidth(parseInt(e.target.value, 10)) }), (0, jsx_runtime_1.jsxs)("span", { className: "jotx-image-toolbar-size-label", children: [width, "%"] })] })] }));
66
+ }
67
+ //# sourceMappingURL=ImageToolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageToolbar.js","sourceRoot":"","sources":["../../src/components/ImageToolbar.tsx"],"names":[],"mappings":";;AAWA,oCAwGC;;AAnHD,iCAAkD;AAElD,+CAAiE;AACjE,8BAA2B;AAI3B,SAAS,KAAK,CAAC,CAAS,EAAE,GAAW,EAAE,GAAW;IAChD,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAA;AACxC,CAAC;AAED,SAAgB,YAAY,CAAC,EAAE,MAAM,EAAsB;IACzD,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,IAAA,gBAAQ,EAA6C,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;IAC1G,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAQ,MAAM,CAAC,CAAA;IACjD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAS,GAAG,CAAC,CAAA;IAE/C,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,MAAM,GAAG,GAAG,EAAE;YAClB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC9B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;gBACzD,OAAM;YACR,CAAC;YAED,2BAA2B;YAC3B,MAAM,KAAK,GAAG,MAAM,CAAC,aAAa,CAAC,OAAO,CAAQ,CAAA;YAClD,MAAM,CAAC,GAAW,KAAK,EAAE,KAAe,IAAI,MAAM,CAAA;YAClD,MAAM,IAAI,GAAG,OAAO,KAAK,EAAE,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAA;YACtG,MAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAA;YAC5D,QAAQ,CAAC,CAAC,CAAC,CAAA;YACX,QAAQ,CAAC,CAAC,CAAC,CAAA;YAEX,IAAI,CAAC;gBACH,MAAM,GAAG,GAAQ,MAAM,CAAC,KAAK,CAAC,SAAgB,CAAA;gBAC9C,MAAM,IAAI,GAAG,OAAO,GAAG,EAAE,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;gBACzD,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC,CAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAS,CAAC,CAAC,CAAC,IAAI,CAAuB,CAAA;gBACpF,IAAI,GAAG,IAAI,OAAO,GAAG,CAAC,qBAAqB,KAAK,UAAU,EAAE,CAAC;oBAC3D,MAAM,CAAC,GAAG,GAAG,CAAC,qBAAqB,EAAE,CAAA;oBACrC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,GAAG,GAAG,EAAE,EAAE,EAAE,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC,CAAA;oBACxE,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,WAAW,GAAG,EAAE,CAAC,CAAA;oBACxD,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;oBAC/B,OAAM;gBACR,CAAC;gBAED,+BAA+B;gBAC/B,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;gBAC9C,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,GAAG,GAAG,EAAE,EAAE,EAAE,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC,CAAA;gBAC/D,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,GAAG,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,WAAW,GAAG,EAAE,CAAC,CAAA;gBAC7D,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;YACjC,CAAC;YAAC,MAAM,CAAC;gBACP,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YAC3D,CAAC;QACH,CAAC,CAAA;QAED,MAAM,EAAE,CAAA;QACR,MAAM,CAAC,EAAE,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAA;QACpC,MAAM,CAAC,EAAE,CAAC,aAAa,EAAE,MAAM,CAAC,CAAA;QAChC,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,GAAG,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAA;YACrC,MAAM,CAAC,GAAG,CAAC,aAAa,EAAE,MAAM,CAAC,CAAA;QACnC,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,IAAI,CAAC,GAAG,CAAC,OAAO;QAAE,OAAO,IAAI,CAAA;IAE7B,MAAM,aAAa,GAAG,CAAC,CAAQ,EAAE,EAAE;QACjC,MAAM,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAA;IACtE,CAAC,CAAA;IAED,MAAM,aAAa,GAAG,CAAC,CAAS,EAAE,EAAE;QAClC,MAAM,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAA;IACtF,CAAC,CAAA;IAED,OAAO,CACL,iCAAK,SAAS,EAAC,gDAAgD,EAAC,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,IAAI,EAAC,SAAS,aAC9H,mCACE,SAAS,EAAE,0BAA0B,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACvE,KAAK,EAAC,YAAY,EAClB,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EACtC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,YAEpC,uBAAC,wBAAS,IAAC,IAAI,EAAE,EAAE,GAAI,GAChB,EACT,mCACE,SAAS,EAAE,0BAA0B,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACzE,KAAK,EAAC,cAAc,EACpB,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EACtC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,YAEtC,uBAAC,0BAAW,IAAC,IAAI,EAAE,EAAE,GAAI,GAClB,EACT,mCACE,SAAS,EAAE,0BAA0B,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACxE,KAAK,EAAC,aAAa,EACnB,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE,EACtC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,YAErC,uBAAC,yBAAU,IAAC,IAAI,EAAE,EAAE,GAAI,GACjB,EAET,gCAAK,SAAS,EAAC,wBAAwB,GAAG,EAE1C,iCAAK,SAAS,EAAC,yBAAyB,EAAC,KAAK,EAAC,aAAa,aAC1D,kCACE,IAAI,EAAC,OAAO,EACZ,GAAG,EAAE,EAAE,EACP,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,CAAC,EACP,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,EACvC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,GAC5D,EACF,kCAAM,SAAS,EAAC,+BAA+B,aAAE,KAAK,SAAS,IAC3D,IACF,CACP,CAAA;AACH,CAAC"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * JotxEditor - Main Tiptap editor with block support
3
+ * Modular, extensible, beautiful
4
+ */
5
+ import './JotxEditor.css';
6
+ import './ImageVideoBlocks.css';
7
+ import './SearchHighlight.css';
8
+ import './SpellCheck.css';
9
+ export interface JotxEditorProps {
10
+ documentId: string;
11
+ documentType: 'page' | 'meeting' | 'tasklist';
12
+ tiptapDoc: any;
13
+ onChange?: (tiptapJson: string) => void;
14
+ ribbonExpanded?: boolean;
15
+ }
16
+ export declare function JotxEditor({ documentId, documentType, tiptapDoc, onChange, ribbonExpanded }: JotxEditorProps): import("react/jsx-runtime").JSX.Element;
17
+ //# sourceMappingURL=JotxEditor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JotxEditor.d.ts","sourceRoot":"","sources":["../../src/components/JotxEditor.tsx"],"names":[],"mappings":"AAAA;;;GAGG;AA0EH,OAAO,kBAAkB,CAAA;AACzB,OAAO,wBAAwB,CAAA;AAW/B,OAAO,uBAAuB,CAAA;AAC9B,OAAO,kBAAkB,CAAA;AAEzB,MAAM,WAAW,eAAe;IAC9B,UAAU,EAAE,MAAM,CAAA;IAClB,YAAY,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,CAAA;IAC7C,SAAS,EAAE,GAAG,CAAA;IACd,QAAQ,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAA;IACvC,cAAc,CAAC,EAAE,OAAO,CAAA;CACzB;AAED,wBAAgB,UAAU,CAAC,EACzB,UAAU,EACV,YAAY,EACZ,SAAS,EACT,QAAQ,EACR,cAAsB,EACvB,EAAE,eAAe,2CAqpCjB"}