excalidraw/src/actions/actionDeleteSelected.tsx

41 lines
1.2 KiB
TypeScript
Raw Normal View History

import { deleteSelectedElements, isSomeElementSelected } from "../scene";
import { KEYS } from "../keys";
import { ToolButton } from "../components/ToolButton";
import React from "react";
import { trash } from "../components/icons";
import { t } from "../i18n";
import { register } from "./register";
export const actionDeleteSelected = register({
name: "deleteSelectedElements",
perform: (elements, appState) => {
const {
elements: nextElements,
appState: nextAppState,
} = deleteSelectedElements(elements, appState);
return {
elements: nextElements,
appState: {
...nextAppState,
elementType: "selection",
multiElement: null,
},
};
},
contextItemLabel: "labels.delete",
contextMenuOrder: 3,
commitToHistory: (appState, elements) =>
isSomeElementSelected(elements, appState),
2020-01-24 12:04:54 +02:00
keyTest: event => event.key === KEYS.BACKSPACE || event.key === KEYS.DELETE,
PanelComponent: ({ elements, appState, updateData }) => (
<ToolButton
type="button"
icon={trash}
title={t("labels.delete")}
aria-label={t("labels.delete")}
onClick={() => updateData(null)}
visible={isSomeElementSelected(elements, appState)}
/>
),
});