2020-04-05 15:58:00 +03:00
|
|
|
import React from "react";
|
2020-04-10 18:09:29 -04:00
|
|
|
import oc from "open-color";
|
2020-04-05 15:58:00 +03:00
|
|
|
import { t } from "../i18n";
|
|
|
|
import { isDarwin } from "../keys";
|
|
|
|
import { Dialog } from "./Dialog";
|
|
|
|
import { getShortcutKey } from "../utils";
|
|
|
|
|
2020-04-09 22:58:29 +03:00
|
|
|
const Columns = (props: { children: React.ReactNode }) => (
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
display: "flex",
|
|
|
|
flexDirection: "row",
|
|
|
|
flexWrap: "wrap",
|
|
|
|
justifyContent: "space-between",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{props.children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
|
|
|
const Column = (props: { children: React.ReactNode }) => (
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
width: "49%",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{props.children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
2020-04-05 15:58:00 +03:00
|
|
|
const ShortcutIsland = (props: {
|
2020-04-07 14:39:06 +03:00
|
|
|
caption: string;
|
2020-04-05 15:58:00 +03:00
|
|
|
children: React.ReactNode;
|
|
|
|
}) => (
|
|
|
|
<div
|
|
|
|
style={{
|
2020-04-10 18:09:29 -04:00
|
|
|
border: `1px solid ${oc.gray[4]}`,
|
2020-04-05 15:58:00 +03:00
|
|
|
marginBottom: "16px",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<h3
|
|
|
|
style={{
|
|
|
|
margin: "0",
|
|
|
|
padding: "4px",
|
2020-04-10 18:09:29 -04:00
|
|
|
backgroundColor: oc.gray[2],
|
2020-04-05 15:58:00 +03:00
|
|
|
textAlign: "center",
|
|
|
|
}}
|
|
|
|
>
|
2020-04-07 14:39:06 +03:00
|
|
|
{props.caption}
|
2020-04-05 15:58:00 +03:00
|
|
|
</h3>
|
|
|
|
{props.children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
2020-04-07 14:39:06 +03:00
|
|
|
const Shortcut = (props: {
|
|
|
|
label: string;
|
|
|
|
shortcuts: string[];
|
|
|
|
isOr: boolean;
|
2020-05-11 00:29:35 +02:00
|
|
|
}) => {
|
|
|
|
const isRTL = document.documentElement.getAttribute("dir") === "rtl";
|
|
|
|
return (
|
2020-04-05 15:58:00 +03:00
|
|
|
<div
|
|
|
|
style={{
|
2020-05-11 00:29:35 +02:00
|
|
|
borderTop: `1px solid ${oc.gray[4]}`,
|
2020-04-05 15:58:00 +03:00
|
|
|
}}
|
|
|
|
>
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
display: "flex",
|
2020-05-11 00:29:35 +02:00
|
|
|
margin: "0",
|
|
|
|
padding: "4px 8px",
|
|
|
|
alignItems: "center",
|
2020-04-05 15:58:00 +03:00
|
|
|
}}
|
|
|
|
>
|
2020-05-11 00:29:35 +02:00
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
lineHeight: 1.4,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{props.label}
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
display: "flex",
|
|
|
|
flex: "0 0 auto",
|
|
|
|
justifyContent: "flex-end",
|
|
|
|
marginLeft: isRTL ? "0em" : "auto",
|
|
|
|
marginRight: isRTL ? "auto" : "0em",
|
|
|
|
minWidth: "30%",
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{props.shortcuts.map((shortcut, index) => (
|
|
|
|
<React.Fragment key={index}>
|
|
|
|
<ShortcutKey>{shortcut}</ShortcutKey>
|
|
|
|
{props.isOr &&
|
|
|
|
index !== props.shortcuts.length - 1 &&
|
|
|
|
t("shortcutsDialog.or")}
|
|
|
|
</React.Fragment>
|
|
|
|
))}
|
|
|
|
</div>
|
2020-04-05 15:58:00 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-05-11 00:29:35 +02:00
|
|
|
);
|
|
|
|
};
|
2020-04-05 15:58:00 +03:00
|
|
|
|
2020-04-07 14:39:06 +03:00
|
|
|
Shortcut.defaultProps = {
|
|
|
|
isOr: true,
|
|
|
|
};
|
|
|
|
|
2020-04-05 15:58:00 +03:00
|
|
|
const ShortcutKey = (props: { children: React.ReactNode }) => (
|
|
|
|
<span
|
|
|
|
style={{
|
2020-04-09 16:23:10 +08:00
|
|
|
wordBreak: "keep-all",
|
2020-04-10 18:09:29 -04:00
|
|
|
border: `1px solid ${oc.gray[4]}`,
|
2020-04-05 15:58:00 +03:00
|
|
|
padding: "2px 8px",
|
2020-05-11 00:29:35 +02:00
|
|
|
margin: "auto 4px",
|
2020-04-10 18:09:29 -04:00
|
|
|
backgroundColor: oc.gray[2],
|
2020-04-05 15:58:00 +03:00
|
|
|
borderRadius: "2px",
|
|
|
|
fontSize: "0.8em",
|
2020-05-11 00:29:35 +02:00
|
|
|
minHeight: "26px",
|
|
|
|
boxSizing: "border-box",
|
|
|
|
display: "flex",
|
|
|
|
alignItems: "center",
|
2020-04-05 15:58:00 +03:00
|
|
|
}}
|
|
|
|
{...props}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
|
|
|
|
const Footer = () => (
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
display: "flex",
|
|
|
|
flexDirection: "row",
|
2020-04-07 14:39:06 +03:00
|
|
|
justifyContent: "space-evenly",
|
2020-04-10 18:09:29 -04:00
|
|
|
borderTop: `1px solid ${oc.gray[4]}`,
|
2020-04-05 15:58:00 +03:00
|
|
|
marginTop: 8,
|
|
|
|
paddingTop: 16,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<a
|
|
|
|
href="https://blog.excalidraw.com"
|
|
|
|
target="_blank"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
>
|
|
|
|
{t("shortcutsDialog.blog")}
|
|
|
|
</a>
|
|
|
|
<a
|
|
|
|
href="https://howto.excalidraw.com"
|
|
|
|
target="_blank"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
>
|
|
|
|
{t("shortcutsDialog.howto")}
|
|
|
|
</a>
|
|
|
|
<a
|
|
|
|
href="https://github.com/excalidraw/excalidraw/issues"
|
|
|
|
target="_blank"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
>
|
|
|
|
{t("shortcutsDialog.github")}
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
|
|
|
export const ShortcutsDialog = ({ onClose }: { onClose?: () => void }) => {
|
|
|
|
const handleClose = React.useCallback(() => {
|
|
|
|
if (onClose) {
|
|
|
|
onClose();
|
|
|
|
}
|
|
|
|
}, [onClose]);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<Dialog
|
2020-05-11 00:29:35 +02:00
|
|
|
maxWidth={900}
|
2020-04-05 15:58:00 +03:00
|
|
|
onCloseRequest={handleClose}
|
|
|
|
title={t("shortcutsDialog.title")}
|
|
|
|
>
|
2020-04-09 22:58:29 +03:00
|
|
|
<Columns>
|
|
|
|
<Column>
|
|
|
|
<ShortcutIsland caption={t("shortcutsDialog.shapes")}>
|
|
|
|
<Shortcut label={t("toolBar.selection")} shortcuts={["S", "1"]} />
|
|
|
|
<Shortcut label={t("toolBar.rectangle")} shortcuts={["R", "2"]} />
|
|
|
|
<Shortcut label={t("toolBar.diamond")} shortcuts={["D", "3"]} />
|
|
|
|
<Shortcut label={t("toolBar.ellipse")} shortcuts={["E", "4"]} />
|
|
|
|
<Shortcut label={t("toolBar.arrow")} shortcuts={["A", "5"]} />
|
|
|
|
<Shortcut label={t("toolBar.line")} shortcuts={["L", "6"]} />
|
2020-05-12 20:10:11 +01:00
|
|
|
<Shortcut label={t("toolBar.draw")} shortcuts={["X", "7"]} />
|
|
|
|
<Shortcut label={t("toolBar.text")} shortcuts={["T", "8"]} />
|
2020-04-09 22:58:29 +03:00
|
|
|
<Shortcut
|
|
|
|
label={t("shortcutsDialog.textNewLine")}
|
|
|
|
shortcuts={[
|
|
|
|
getShortcutKey("Enter"),
|
|
|
|
getShortcutKey("Shift+Enter"),
|
|
|
|
]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("shortcutsDialog.textFinish")}
|
|
|
|
shortcuts={[
|
|
|
|
getShortcutKey("Esc"),
|
|
|
|
getShortcutKey("CtrlOrCmd+Enter"),
|
|
|
|
]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("shortcutsDialog.curvedArrow")}
|
|
|
|
shortcuts={[
|
|
|
|
"A",
|
|
|
|
t("shortcutsDialog.click"),
|
|
|
|
t("shortcutsDialog.click"),
|
|
|
|
t("shortcutsDialog.click"),
|
|
|
|
]}
|
|
|
|
isOr={false}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("shortcutsDialog.curvedLine")}
|
|
|
|
shortcuts={[
|
|
|
|
"L",
|
|
|
|
t("shortcutsDialog.click"),
|
|
|
|
t("shortcutsDialog.click"),
|
|
|
|
t("shortcutsDialog.click"),
|
|
|
|
]}
|
|
|
|
isOr={false}
|
|
|
|
/>
|
|
|
|
<Shortcut label={t("toolBar.lock")} shortcuts={["Q"]} />
|
|
|
|
</ShortcutIsland>
|
|
|
|
<ShortcutIsland caption={t("shortcutsDialog.view")}>
|
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.zoomIn")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd++")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.zoomOut")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+-")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.resetZoom")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+0")]}
|
|
|
|
/>
|
2020-04-18 15:50:30 +02:00
|
|
|
<Shortcut
|
|
|
|
label={t("shortcutsDialog.zoomToFit")}
|
|
|
|
shortcuts={["Shift+1"]}
|
|
|
|
/>
|
2020-04-09 22:58:29 +03:00
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.toggleFullScreen")}
|
|
|
|
shortcuts={["F"]}
|
|
|
|
/>
|
2020-04-25 18:43:02 +05:30
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.toggleZenMode")}
|
2020-05-15 08:51:52 +09:00
|
|
|
shortcuts={[getShortcutKey("Alt+Z")]}
|
2020-04-25 18:43:02 +05:30
|
|
|
/>
|
2020-06-24 00:24:52 +09:00
|
|
|
<Shortcut
|
2020-06-26 23:28:01 +03:00
|
|
|
label={t("labels.toggleGridMode")}
|
2020-06-24 00:24:52 +09:00
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+'")]}
|
|
|
|
/>
|
2020-04-09 22:58:29 +03:00
|
|
|
</ShortcutIsland>
|
|
|
|
</Column>
|
|
|
|
<Column>
|
|
|
|
<ShortcutIsland caption={t("shortcutsDialog.editor")}>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.selectAll")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+A")]}
|
|
|
|
/>
|
2020-07-07 12:24:07 +03:00
|
|
|
<Shortcut
|
|
|
|
label={t("labels.multiSelect")}
|
|
|
|
shortcuts={[
|
|
|
|
getShortcutKey(`Shift+${t("shortcutsDialog.click")}`),
|
|
|
|
]}
|
|
|
|
/>
|
2020-06-19 21:28:13 +01:00
|
|
|
<Shortcut
|
|
|
|
label={t("labels.moveCanvas")}
|
|
|
|
shortcuts={[
|
|
|
|
getShortcutKey(`Space+${t("shortcutsDialog.drag")}`),
|
|
|
|
getShortcutKey(`Wheel+${t("shortcutsDialog.drag")}`),
|
|
|
|
]}
|
|
|
|
isOr={true}
|
|
|
|
/>
|
2020-04-09 22:58:29 +03:00
|
|
|
<Shortcut
|
|
|
|
label={t("labels.copy")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+C")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.paste")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+V")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.copyAsPng")}
|
|
|
|
shortcuts={[getShortcutKey("Shift+Alt+C")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.copyStyles")}
|
2020-07-07 20:22:23 +02:00
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+Alt+C")]}
|
2020-04-09 22:58:29 +03:00
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.pasteStyles")}
|
2020-07-07 20:22:23 +02:00
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+Alt+V")]}
|
2020-04-09 22:58:29 +03:00
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.delete")}
|
|
|
|
shortcuts={[getShortcutKey("Del")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.sendToBack")}
|
|
|
|
shortcuts={[
|
|
|
|
isDarwin
|
|
|
|
? getShortcutKey("CtrlOrCmd+Alt+[")
|
|
|
|
: getShortcutKey("CtrlOrCmd+Shift+["),
|
|
|
|
]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.bringToFront")}
|
|
|
|
shortcuts={[
|
|
|
|
isDarwin
|
|
|
|
? getShortcutKey("CtrlOrCmd+Alt+]")
|
|
|
|
: getShortcutKey("CtrlOrCmd+Shift+]"),
|
|
|
|
]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.sendBackward")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+[")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.bringForward")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+]")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.duplicateSelection")}
|
2020-04-12 00:04:53 +03:00
|
|
|
shortcuts={[
|
|
|
|
getShortcutKey("CtrlOrCmd+D"),
|
|
|
|
getShortcutKey(`Alt+${t("shortcutsDialog.drag")}`),
|
|
|
|
]}
|
2020-04-09 22:58:29 +03:00
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.undo")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+Z")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("buttons.redo")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+Shift+Z")]}
|
|
|
|
/>
|
2020-05-26 13:07:46 -07:00
|
|
|
<Shortcut
|
|
|
|
label={t("labels.group")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+G")]}
|
|
|
|
/>
|
|
|
|
<Shortcut
|
|
|
|
label={t("labels.ungroup")}
|
|
|
|
shortcuts={[getShortcutKey("CtrlOrCmd+Shift+G")]}
|
|
|
|
/>
|
2020-04-09 22:58:29 +03:00
|
|
|
</ShortcutIsland>
|
|
|
|
</Column>
|
|
|
|
</Columns>
|
2020-04-05 15:58:00 +03:00
|
|
|
<Footer />
|
|
|
|
</Dialog>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|