@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.
- package/dist/bridge/BridgeContext.d.ts +14 -0
- package/dist/bridge/BridgeContext.d.ts.map +1 -0
- package/dist/bridge/BridgeContext.js +20 -0
- package/dist/bridge/BridgeContext.js.map +1 -0
- package/dist/bridge/bridge-utils.d.ts +24 -0
- package/dist/bridge/bridge-utils.d.ts.map +1 -0
- package/dist/bridge/bridge-utils.js +77 -0
- package/dist/bridge/bridge-utils.js.map +1 -0
- package/dist/bridge/types.d.ts +34 -0
- package/dist/bridge/types.d.ts.map +1 -0
- package/dist/bridge/types.js +27 -0
- package/dist/bridge/types.js.map +1 -0
- package/dist/bridge/vscode-api.d.ts +13 -0
- package/dist/bridge/vscode-api.d.ts.map +1 -0
- package/dist/bridge/vscode-api.js +27 -0
- package/dist/bridge/vscode-api.js.map +1 -0
- package/dist/components/AttachBlockNodeView.d.ts +2 -0
- package/dist/components/AttachBlockNodeView.d.ts.map +1 -0
- package/dist/components/AttachBlockNodeView.js +37 -0
- package/dist/components/AttachBlockNodeView.js.map +1 -0
- package/dist/components/BlockMenu.d.ts +11 -0
- package/dist/components/BlockMenu.d.ts.map +1 -0
- package/dist/components/BlockMenu.js +344 -0
- package/dist/components/BlockMenu.js.map +1 -0
- package/dist/components/ButtonNodeView.d.ts +17 -0
- package/dist/components/ButtonNodeView.d.ts.map +1 -0
- package/dist/components/ButtonNodeView.js +55 -0
- package/dist/components/ButtonNodeView.js.map +1 -0
- package/dist/components/CardNodeView.d.ts +18 -0
- package/dist/components/CardNodeView.d.ts.map +1 -0
- package/dist/components/CardNodeView.js +46 -0
- package/dist/components/CardNodeView.js.map +1 -0
- package/dist/components/ChartNodeView.d.ts +4 -0
- package/dist/components/ChartNodeView.d.ts.map +1 -0
- package/dist/components/ChartNodeView.js +247 -0
- package/dist/components/ChartNodeView.js.map +1 -0
- package/dist/components/CodeBlockNodeView.d.ts +4 -0
- package/dist/components/CodeBlockNodeView.d.ts.map +1 -0
- package/dist/components/CodeBlockNodeView.js +105 -0
- package/dist/components/CodeBlockNodeView.js.map +1 -0
- package/dist/components/CodeReferenceNodeView.d.ts +4 -0
- package/dist/components/CodeReferenceNodeView.d.ts.map +1 -0
- package/dist/components/CodeReferenceNodeView.js +71 -0
- package/dist/components/CodeReferenceNodeView.js.map +1 -0
- package/dist/components/DateTimeNodeView.d.ts +3 -0
- package/dist/components/DateTimeNodeView.d.ts.map +1 -0
- package/dist/components/DateTimeNodeView.js +55 -0
- package/dist/components/DateTimeNodeView.js.map +1 -0
- package/dist/components/EditorRibbon.d.ts +13 -0
- package/dist/components/EditorRibbon.d.ts.map +1 -0
- package/dist/components/EditorRibbon.js +12 -0
- package/dist/components/EditorRibbon.js.map +1 -0
- package/dist/components/FloatImageBlockNodeView.d.ts +6 -0
- package/dist/components/FloatImageBlockNodeView.d.ts.map +1 -0
- package/dist/components/FloatImageBlockNodeView.js +96 -0
- package/dist/components/FloatImageBlockNodeView.js.map +1 -0
- package/dist/components/GridCardNodeView.d.ts +13 -0
- package/dist/components/GridCardNodeView.d.ts.map +1 -0
- package/dist/components/GridCardNodeView.js +31 -0
- package/dist/components/GridCardNodeView.js.map +1 -0
- package/dist/components/ImageBlockNodeView.d.ts +7 -0
- package/dist/components/ImageBlockNodeView.d.ts.map +1 -0
- package/dist/components/ImageBlockNodeView.js +132 -0
- package/dist/components/ImageBlockNodeView.js.map +1 -0
- package/dist/components/ImageToolbar.d.ts +6 -0
- package/dist/components/ImageToolbar.d.ts.map +1 -0
- package/dist/components/ImageToolbar.js +67 -0
- package/dist/components/ImageToolbar.js.map +1 -0
- package/dist/components/JotxEditor.d.ts +17 -0
- package/dist/components/JotxEditor.d.ts.map +1 -0
- package/dist/components/JotxEditor.js +1121 -0
- package/dist/components/JotxEditor.js.map +1 -0
- package/dist/components/JotxLinkNodeView.d.ts +4 -0
- package/dist/components/JotxLinkNodeView.d.ts.map +1 -0
- package/dist/components/JotxLinkNodeView.js +123 -0
- package/dist/components/JotxLinkNodeView.js.map +1 -0
- package/dist/components/LinkDialog.d.ts +14 -0
- package/dist/components/LinkDialog.d.ts.map +1 -0
- package/dist/components/LinkDialog.js +33 -0
- package/dist/components/LinkDialog.js.map +1 -0
- package/dist/components/MathNodeView.d.ts +3 -0
- package/dist/components/MathNodeView.d.ts.map +1 -0
- package/dist/components/MathNodeView.js +67 -0
- package/dist/components/MathNodeView.js.map +1 -0
- package/dist/components/MermaidNodeView.d.ts +4 -0
- package/dist/components/MermaidNodeView.d.ts.map +1 -0
- package/dist/components/MermaidNodeView.js +442 -0
- package/dist/components/MermaidNodeView.js.map +1 -0
- package/dist/components/NodePickerDialog.d.ts +12 -0
- package/dist/components/NodePickerDialog.d.ts.map +1 -0
- package/dist/components/NodePickerDialog.js +90 -0
- package/dist/components/NodePickerDialog.js.map +1 -0
- package/dist/components/ReadonlyBlockRenderer.d.ts +13 -0
- package/dist/components/ReadonlyBlockRenderer.d.ts.map +1 -0
- package/dist/components/ReadonlyBlockRenderer.js +78 -0
- package/dist/components/ReadonlyBlockRenderer.js.map +1 -0
- package/dist/components/ReadonlyMermaid.d.ts +10 -0
- package/dist/components/ReadonlyMermaid.d.ts.map +1 -0
- package/dist/components/ReadonlyMermaid.js +70 -0
- package/dist/components/ReadonlyMermaid.js.map +1 -0
- package/dist/components/SearchBar.d.ts +16 -0
- package/dist/components/SearchBar.d.ts.map +1 -0
- package/dist/components/SearchBar.js +52 -0
- package/dist/components/SearchBar.js.map +1 -0
- package/dist/components/SectionNodeView.d.ts +4 -0
- package/dist/components/SectionNodeView.d.ts.map +1 -0
- package/dist/components/SectionNodeView.js +39 -0
- package/dist/components/SectionNodeView.js.map +1 -0
- package/dist/components/SlashMenu.d.ts +21 -0
- package/dist/components/SlashMenu.d.ts.map +1 -0
- package/dist/components/SlashMenu.js +356 -0
- package/dist/components/SlashMenu.js.map +1 -0
- package/dist/components/TableToolbar.d.ts +10 -0
- package/dist/components/TableToolbar.d.ts.map +1 -0
- package/dist/components/TableToolbar.js +189 -0
- package/dist/components/TableToolbar.js.map +1 -0
- package/dist/components/ToggleNodeView.d.ts +4 -0
- package/dist/components/ToggleNodeView.d.ts.map +1 -0
- package/dist/components/ToggleNodeView.js +39 -0
- package/dist/components/ToggleNodeView.js.map +1 -0
- package/dist/components/UrlInputDialog.d.ts +13 -0
- package/dist/components/UrlInputDialog.d.ts.map +1 -0
- package/dist/components/UrlInputDialog.js +39 -0
- package/dist/components/UrlInputDialog.js.map +1 -0
- package/dist/components/VideoBlockNodeView.d.ts +12 -0
- package/dist/components/VideoBlockNodeView.d.ts.map +1 -0
- package/dist/components/VideoBlockNodeView.js +97 -0
- package/dist/components/VideoBlockNodeView.js.map +1 -0
- package/dist/contexts/NodeManagerContext.d.ts +34 -0
- package/dist/contexts/NodeManagerContext.d.ts.map +1 -0
- package/dist/contexts/NodeManagerContext.js +31 -0
- package/dist/contexts/NodeManagerContext.js.map +1 -0
- package/dist/extensions/AttachNode.d.ts +7 -0
- package/dist/extensions/AttachNode.d.ts.map +1 -0
- package/dist/extensions/AttachNode.js +50 -0
- package/dist/extensions/AttachNode.js.map +1 -0
- package/dist/extensions/BlockOpsExtension.d.ts +17 -0
- package/dist/extensions/BlockOpsExtension.d.ts.map +1 -0
- package/dist/extensions/BlockOpsExtension.js +248 -0
- package/dist/extensions/BlockOpsExtension.js.map +1 -0
- package/dist/extensions/ButtonNode.d.ts +7 -0
- package/dist/extensions/ButtonNode.d.ts.map +1 -0
- package/dist/extensions/ButtonNode.js +59 -0
- package/dist/extensions/ButtonNode.js.map +1 -0
- package/dist/extensions/CalloutActionsExtension.d.ts +3 -0
- package/dist/extensions/CalloutActionsExtension.d.ts.map +1 -0
- package/dist/extensions/CalloutActionsExtension.js +41 -0
- package/dist/extensions/CalloutActionsExtension.js.map +1 -0
- package/dist/extensions/CalloutNode.d.ts +7 -0
- package/dist/extensions/CalloutNode.d.ts.map +1 -0
- package/dist/extensions/CalloutNode.js +48 -0
- package/dist/extensions/CalloutNode.js.map +1 -0
- package/dist/extensions/CardNode.d.ts +7 -0
- package/dist/extensions/CardNode.d.ts.map +1 -0
- package/dist/extensions/CardNode.js +64 -0
- package/dist/extensions/CardNode.js.map +1 -0
- package/dist/extensions/ChartNode.d.ts +3 -0
- package/dist/extensions/ChartNode.d.ts.map +1 -0
- package/dist/extensions/ChartNode.js +60 -0
- package/dist/extensions/ChartNode.js.map +1 -0
- package/dist/extensions/CodeBlockNode.d.ts +7 -0
- package/dist/extensions/CodeBlockNode.d.ts.map +1 -0
- package/dist/extensions/CodeBlockNode.js +57 -0
- package/dist/extensions/CodeBlockNode.js.map +1 -0
- package/dist/extensions/CodeReferenceNode.d.ts +3 -0
- package/dist/extensions/CodeReferenceNode.d.ts.map +1 -0
- package/dist/extensions/CodeReferenceNode.js +46 -0
- package/dist/extensions/CodeReferenceNode.js.map +1 -0
- package/dist/extensions/DateTimeNode.d.ts +3 -0
- package/dist/extensions/DateTimeNode.d.ts.map +1 -0
- package/dist/extensions/DateTimeNode.js +43 -0
- package/dist/extensions/DateTimeNode.js.map +1 -0
- package/dist/extensions/FloatImageBlockNode.d.ts +7 -0
- package/dist/extensions/FloatImageBlockNode.d.ts.map +1 -0
- package/dist/extensions/FloatImageBlockNode.js +73 -0
- package/dist/extensions/FloatImageBlockNode.js.map +1 -0
- package/dist/extensions/GridCardNode.d.ts +7 -0
- package/dist/extensions/GridCardNode.d.ts.map +1 -0
- package/dist/extensions/GridCardNode.js +56 -0
- package/dist/extensions/GridCardNode.js.map +1 -0
- package/dist/extensions/ImageBlockNode.d.ts +7 -0
- package/dist/extensions/ImageBlockNode.d.ts.map +1 -0
- package/dist/extensions/ImageBlockNode.js +76 -0
- package/dist/extensions/ImageBlockNode.js.map +1 -0
- package/dist/extensions/ImageNode.d.ts +10 -0
- package/dist/extensions/ImageNode.d.ts.map +1 -0
- package/dist/extensions/ImageNode.js +67 -0
- package/dist/extensions/ImageNode.js.map +1 -0
- package/dist/extensions/JotxLinkNode.d.ts +3 -0
- package/dist/extensions/JotxLinkNode.d.ts.map +1 -0
- package/dist/extensions/JotxLinkNode.js +43 -0
- package/dist/extensions/JotxLinkNode.js.map +1 -0
- package/dist/extensions/JotxTable.d.ts +9 -0
- package/dist/extensions/JotxTable.d.ts.map +1 -0
- package/dist/extensions/JotxTable.js +40 -0
- package/dist/extensions/JotxTable.js.map +1 -0
- package/dist/extensions/LinkNode.d.ts +7 -0
- package/dist/extensions/LinkNode.d.ts.map +1 -0
- package/dist/extensions/LinkNode.js +54 -0
- package/dist/extensions/LinkNode.js.map +1 -0
- package/dist/extensions/MathNode.d.ts +3 -0
- package/dist/extensions/MathNode.d.ts.map +1 -0
- package/dist/extensions/MathNode.js +61 -0
- package/dist/extensions/MathNode.js.map +1 -0
- package/dist/extensions/MermaidNode.d.ts +3 -0
- package/dist/extensions/MermaidNode.d.ts.map +1 -0
- package/dist/extensions/MermaidNode.js +59 -0
- package/dist/extensions/MermaidNode.js.map +1 -0
- package/dist/extensions/SearchExtension.d.ts +40 -0
- package/dist/extensions/SearchExtension.d.ts.map +1 -0
- package/dist/extensions/SearchExtension.js +186 -0
- package/dist/extensions/SearchExtension.js.map +1 -0
- package/dist/extensions/SectionNode.d.ts +11 -0
- package/dist/extensions/SectionNode.d.ts.map +1 -0
- package/dist/extensions/SectionNode.js +58 -0
- package/dist/extensions/SectionNode.js.map +1 -0
- package/dist/extensions/SlashMenuExtension.d.ts +17 -0
- package/dist/extensions/SlashMenuExtension.d.ts.map +1 -0
- package/dist/extensions/SlashMenuExtension.js +146 -0
- package/dist/extensions/SlashMenuExtension.js.map +1 -0
- package/dist/extensions/SpellCheckExtension.d.ts +14 -0
- package/dist/extensions/SpellCheckExtension.d.ts.map +1 -0
- package/dist/extensions/SpellCheckExtension.js +278 -0
- package/dist/extensions/SpellCheckExtension.js.map +1 -0
- package/dist/extensions/TableFilterExtension.d.ts +12 -0
- package/dist/extensions/TableFilterExtension.d.ts.map +1 -0
- package/dist/extensions/TableFilterExtension.js +75 -0
- package/dist/extensions/TableFilterExtension.js.map +1 -0
- package/dist/extensions/ToggleNode.d.ts +11 -0
- package/dist/extensions/ToggleNode.d.ts.map +1 -0
- package/dist/extensions/ToggleNode.js +58 -0
- package/dist/extensions/ToggleNode.js.map +1 -0
- package/dist/extensions/VideoBlockNode.d.ts +7 -0
- package/dist/extensions/VideoBlockNode.d.ts.map +1 -0
- package/dist/extensions/VideoBlockNode.js +95 -0
- package/dist/extensions/VideoBlockNode.js.map +1 -0
- package/dist/extensions/formatting.d.ts +2 -0
- package/dist/extensions/formatting.d.ts.map +1 -0
- package/dist/extensions/formatting.js +10 -0
- package/dist/extensions/formatting.js.map +1 -0
- package/dist/index.d.ts +61 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +132 -0
- package/dist/index.js.map +1 -0
- package/dist/services/ImageStorage.d.ts +38 -0
- package/dist/services/ImageStorage.d.ts.map +1 -0
- package/dist/services/ImageStorage.js +32 -0
- package/dist/services/ImageStorage.js.map +1 -0
- package/dist/services/SpellCheckService 2.d.ts +50 -0
- package/dist/services/SpellCheckService 2.d.ts.map +1 -0
- package/dist/services/SpellCheckService 2.js +131 -0
- package/dist/services/SpellCheckService 2.js.map +1 -0
- package/dist/services/SpellCheckService.d.ts +50 -0
- package/dist/services/SpellCheckService.d.ts.map +1 -0
- package/dist/services/SpellCheckService.js +131 -0
- package/dist/services/SpellCheckService.js.map +1 -0
- package/dist/utils/logger.d.ts +14 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +25 -0
- package/dist/utils/logger.js.map +1 -0
- 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 @@
|
|
|
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":"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"}
|
|
@@ -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"}
|