63 lines
1.6 KiB
TypeScript
63 lines
1.6 KiB
TypeScript
import {
|
|
KEYS,
|
|
CANVAS_SEARCH_TAB,
|
|
CLASSES,
|
|
DEFAULT_SIDEBAR,
|
|
} from "@excalidraw/common";
|
|
|
|
import { searchIcon } from "../components/icons";
|
|
import { CaptureUpdateAction } from "../store";
|
|
|
|
import { register } from "./register";
|
|
|
|
import type { AppState } from "../types";
|
|
|
|
export const actionToggleSearchMenu = register({
|
|
name: "searchMenu",
|
|
icon: searchIcon,
|
|
keywords: ["search", "find"],
|
|
label: "search.title",
|
|
viewMode: true,
|
|
trackEvent: {
|
|
category: "search_menu",
|
|
action: "toggle",
|
|
predicate: (appState) => appState.gridModeEnabled,
|
|
},
|
|
perform(elements, appState, _, app) {
|
|
if (
|
|
appState.openSidebar?.name === DEFAULT_SIDEBAR.name &&
|
|
appState.openSidebar.tab === CANVAS_SEARCH_TAB
|
|
) {
|
|
const searchInput =
|
|
app.excalidrawContainerValue.container?.querySelector<HTMLInputElement>(
|
|
`.${CLASSES.SEARCH_MENU_INPUT_WRAPPER} input`,
|
|
);
|
|
|
|
if (searchInput?.matches(":focus")) {
|
|
return {
|
|
appState: { ...appState, openSidebar: null },
|
|
captureUpdate: CaptureUpdateAction.EVENTUALLY,
|
|
};
|
|
}
|
|
|
|
searchInput?.focus();
|
|
searchInput?.select();
|
|
return false;
|
|
}
|
|
|
|
return {
|
|
appState: {
|
|
...appState,
|
|
openSidebar: { name: DEFAULT_SIDEBAR.name, tab: CANVAS_SEARCH_TAB },
|
|
openDialog: null,
|
|
},
|
|
captureUpdate: CaptureUpdateAction.EVENTUALLY,
|
|
};
|
|
},
|
|
checked: (appState: AppState) => appState.gridModeEnabled,
|
|
predicate: (element, appState, props) => {
|
|
return props.gridModeEnabled === undefined;
|
|
},
|
|
keyTest: (event) => event[KEYS.CTRL_OR_CMD] && event.key === KEYS.F,
|
|
});
|