128 lines
3.1 KiB
TypeScript
128 lines
3.1 KiB
TypeScript
import * as React from "react";
|
|
import * as _ from "lodash";
|
|
import { t } from "i18next";
|
|
import {
|
|
Hotkey,
|
|
Hotkeys,
|
|
HotkeysTarget,
|
|
IHotkeyProps,
|
|
Overlay,
|
|
Classes
|
|
} from "@blueprintjs/core";
|
|
|
|
import { links } from "./nav/nav_links";
|
|
import { sync } from "./devices/actions";
|
|
import { history, push } from "./history";
|
|
import { Row, Col } from "./ui/index";
|
|
|
|
interface Props {
|
|
dispatch: Function;
|
|
}
|
|
|
|
interface State {
|
|
guideOpen: boolean;
|
|
}
|
|
|
|
let hotkeyGuideClasses = [
|
|
"hotkey-guide",
|
|
"pt-card",
|
|
Classes.ELEVATION_4
|
|
].join(" ");
|
|
|
|
@HotkeysTarget
|
|
export class HotKeys extends React.Component<Props, Partial<State>> {
|
|
|
|
state: State = { guideOpen: false };
|
|
|
|
render() {
|
|
return (
|
|
<div>
|
|
<Overlay
|
|
isOpen={this.state.guideOpen}
|
|
onClose={this.toggle("guideOpen")}>
|
|
<div className={hotkeyGuideClasses}>
|
|
<h3>{t("Hotkeys")}</h3>
|
|
<i
|
|
className="fa fa-times"
|
|
onClick={this.toggle("guideOpen")} />
|
|
{
|
|
this.hotkeys(this.props.dispatch, "")
|
|
.map(hotkey => {
|
|
return (
|
|
<Row key={hotkey.combo}>
|
|
<Col xs={5}>
|
|
<label>{hotkey.label}</label>
|
|
</Col>
|
|
<Col xs={7}>
|
|
<code>{hotkey.combo}</code>
|
|
</Col>
|
|
</Row>
|
|
);
|
|
})
|
|
}
|
|
</div>
|
|
</Overlay>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
toggle = (property: keyof State) => () =>
|
|
this.setState({ [property]: !this.state[property] });
|
|
|
|
hotkeys(dispatch: Function, slug: string) {
|
|
let idx = _.findIndex(links, { slug });
|
|
let right = "/app/" + (links[idx + 1] || links[0]).slug;
|
|
let left = "/app/" + (links[idx - 1] || links[links.length - 1]).slug;
|
|
let hotkeyMap: IHotkeyProps[] = [
|
|
{
|
|
combo: "ctrl + shift + s",
|
|
label: "Sync",
|
|
onKeyDown: () => dispatch(sync())
|
|
},
|
|
{
|
|
combo: "ctrl + shift + right",
|
|
label: "Navigate Right",
|
|
onKeyDown: () => push(right)
|
|
},
|
|
{
|
|
combo: "ctrl + shift + left",
|
|
label: "Navigate Left",
|
|
onKeyDown: () => push(left)
|
|
},
|
|
{
|
|
combo: "ctrl + shift + p",
|
|
label: "Add Plant",
|
|
onKeyDown: () => push("/app/designer/plants/crop_search")
|
|
},
|
|
{
|
|
combo: "ctrl + shift + e",
|
|
label: "Add Farm Event",
|
|
onKeyDown: () => push("/app/designer/farm_events/add")
|
|
},
|
|
{
|
|
combo: "ctrl + shift + /",
|
|
label: "Toggle Guide",
|
|
onKeyDown: () => this.toggle("guideOpen")()
|
|
},
|
|
];
|
|
return hotkeyMap;
|
|
}
|
|
|
|
renderHotkeys() {
|
|
let slug = history.getCurrentLocation().pathname.split("/")[2];
|
|
return <Hotkeys>
|
|
{
|
|
this.hotkeys(this.props.dispatch, slug)
|
|
.map(({ combo, label, onKeyDown }: IHotkeyProps, index: number) => {
|
|
return <Hotkey
|
|
key={index}
|
|
global={true}
|
|
combo={combo}
|
|
label={label}
|
|
onKeyDown={onKeyDown} />;
|
|
})
|
|
}
|
|
</Hotkeys>;
|
|
}
|
|
}
|