mirror of
https://github.com/streetwriters/notesnook.git
synced 2025-12-16 11:47:54 +01:00
120 lines
6.8 KiB
JavaScript
120 lines
6.8 KiB
JavaScript
var __assign = (this && this.__assign) || function () {
|
|
__assign = Object.assign || function(t) {
|
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
s = arguments[i];
|
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
t[p] = s[p];
|
|
}
|
|
return t;
|
|
};
|
|
return __assign.apply(this, arguments);
|
|
};
|
|
var __read = (this && this.__read) || function (o, n) {
|
|
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
if (!m) return o;
|
|
var i = m.call(o), r, ar = [], e;
|
|
try {
|
|
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
}
|
|
catch (error) { e = { error: error }; }
|
|
finally {
|
|
try {
|
|
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
}
|
|
finally { if (e) throw e.error; }
|
|
}
|
|
return ar;
|
|
};
|
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
import { Box, Flex } from "rebass";
|
|
import { NodeViewWrapper } from "../react";
|
|
import { ThemeProvider } from "emotion-theming";
|
|
import { Resizable } from "re-resizable";
|
|
import { ToolButton } from "../../toolbar/components/tool-button";
|
|
import { useEffect, useRef, useState } from "react";
|
|
import { PopupPresenter } from "../../components/menu/menu";
|
|
import { EmbedPopup } from "../../toolbar/popups/embed-popup";
|
|
export function EmbedComponent(props) {
|
|
var _a = props.node.attrs, src = _a.src, width = _a.width, height = _a.height, align = _a.align;
|
|
var editor = props.editor, updateAttributes = props.updateAttributes;
|
|
var embedRef = useRef();
|
|
var isActive = editor.isActive("embed", { src: src });
|
|
var _b = __read(useState(), 2), isToolbarVisible = _b[0], setIsToolbarVisible = _b[1];
|
|
var theme = editor.storage.theme;
|
|
useEffect(function () {
|
|
setIsToolbarVisible(isActive);
|
|
}, [isActive]);
|
|
return (_jsx(NodeViewWrapper, { children: _jsx(ThemeProvider, __assign({ theme: theme }, { children: _jsx(Box, __assign({ sx: {
|
|
display: "flex",
|
|
justifyContent: align === "center"
|
|
? "center"
|
|
: align === "left"
|
|
? "start"
|
|
: "end",
|
|
} }, { children: _jsxs(Resizable, __assign({ size: {
|
|
height: height || "auto",
|
|
width: width || "auto",
|
|
}, maxWidth: "100%", onResizeStop: function (e, direction, ref, d) {
|
|
updateAttributes({
|
|
width: ref.clientWidth,
|
|
height: ref.clientHeight,
|
|
});
|
|
}, lockAspectRatio: true }, { children: [_jsx(Flex, __assign({ width: "100%", sx: {
|
|
position: "relative",
|
|
justifyContent: "end",
|
|
borderTop: "20px solid var(--bgSecondary)",
|
|
// borderLeft: "20px solid var(--bgSecondary)",
|
|
borderTopLeftRadius: "default",
|
|
borderTopRightRadius: "default",
|
|
borderColor: isActive ? "border" : "bgSecondary",
|
|
cursor: "pointer",
|
|
":hover": {
|
|
borderColor: "border",
|
|
},
|
|
} }, { children: isToolbarVisible && (_jsx(EmbedToolbar, { editor: editor, align: align, height: height || 0, width: width || 0, src: src })) })), _jsx(Box, __assign({ as: "iframe", ref: embedRef, src: src, width: "100%", height: "100%", sx: {
|
|
border: "none",
|
|
// border: isActive
|
|
// ? "2px solid var(--primary)"
|
|
// : "2px solid transparent",
|
|
// borderRadius: "default",
|
|
} }, props))] })) })) })) }));
|
|
}
|
|
function EmbedToolbar(props) {
|
|
var editor = props.editor, height = props.height, width = props.width, src = props.src;
|
|
var _a = __read(useState(false), 2), isOpen = _a[0], setIsOpen = _a[1];
|
|
return (_jsxs(Flex, __assign({ sx: {
|
|
flexDirection: "column",
|
|
position: "absolute",
|
|
top: -40,
|
|
mb: 2,
|
|
zIndex: 9999,
|
|
alignItems: "end",
|
|
} }, { children: [_jsxs(Flex, __assign({ sx: {
|
|
bg: "background",
|
|
boxShadow: "menu",
|
|
flexWrap: "nowrap",
|
|
borderRadius: "default",
|
|
mb: 2,
|
|
} }, { children: [_jsxs(Flex, __assign({ className: "toolbar-group", sx: {
|
|
pr: 1,
|
|
mr: 1,
|
|
borderRight: "1px solid var(--border)",
|
|
":last-of-type": { mr: 0, pr: 0, borderRight: "none" },
|
|
} }, { children: [_jsx(ToolButton, { toggled: false, title: "Align left", id: "alignLeft", icon: "alignLeft", onClick: function () {
|
|
return editor.chain().focus().setEmbedAlignment({ align: "left" }).run();
|
|
} }), _jsx(ToolButton, { toggled: false, title: "Align center", id: "alignCenter", icon: "alignCenter", onClick: function () {
|
|
return editor
|
|
.chain()
|
|
.focus()
|
|
.setEmbedAlignment({ align: "center" })
|
|
.run();
|
|
} }), _jsx(ToolButton, { toggled: false, title: "Align right", id: "alignRight", icon: "alignRight", onClick: function () {
|
|
return editor.chain().focus().setEmbedAlignment({ align: "right" }).run();
|
|
} })] })), _jsx(Flex, __assign({ className: "toolbar-group", sx: {
|
|
pr: 1,
|
|
mr: 1,
|
|
borderRight: "1px solid var(--border)",
|
|
":last-of-type": { mr: 0, pr: 0, borderRight: "none" },
|
|
} }, { children: _jsx(ToolButton, { toggled: isOpen, title: "Embed properties", id: "embedProperties", icon: "more", onClick: function () { return setIsOpen(function (s) { return !s; }); } }) }))] })), _jsx(PopupPresenter, __assign({ isOpen: isOpen, desktop: "none", mobile: "sheet", onClose: function () { return setIsOpen(false); }, blocking: true }, { children: _jsx(EmbedPopup, { title: "Embed properties", icon: "close", onClose: function () { return setIsOpen(false); }, embed: props, onSourceChanged: function (src) { }, onSizeChanged: function (size) { return editor.commands.setEmbedSize(size); } }) }))] })));
|
|
}
|