Farmbot-Web-App/frontend/devices/pin_bindings/pin_bindings.tsx

112 lines
3.8 KiB
TypeScript
Raw Normal View History

2018-07-17 23:08:27 -06:00
import * as React from "react";
2020-02-15 11:29:09 -07:00
import { Row, Col, Help } from "../../ui";
2020-04-14 16:46:39 -06:00
import { ToolTips, DeviceSetting } from "../../constants";
2018-07-17 23:08:27 -06:00
import { selectAllPinBindings } from "../../resources/selectors";
2020-02-15 11:29:09 -07:00
import { PinBindingsContentProps, PinBindingListItems } from "./interfaces";
2018-07-17 23:08:27 -06:00
import { PinBindingsList } from "./pin_bindings_list";
import { PinBindingInputGroup } from "./pin_binding_input_group";
2018-07-20 19:52:41 -06:00
import {
2020-02-28 09:35:32 -07:00
StockPinBindingsButton, sysBtnBindingData,
2018-07-20 19:52:41 -06:00
} from "./tagged_pin_binding_init";
import { ResourceIndex } from "../../resources/interfaces";
import { Popover, Position, PopoverInteractionKind } from "@blueprintjs/core";
2018-08-02 15:46:58 -06:00
import {
PinBindingSpecialAction,
PinBindingType,
2020-02-28 09:35:32 -07:00
PinBinding,
2018-08-02 15:46:58 -06:00
} from "farmbot/dist/resources/api_resources";
2019-04-02 13:59:37 -06:00
import { t } from "../../i18next_wrapper";
2020-03-13 15:06:40 -06:00
import { DevSettings } from "../../account/dev/dev_support";
2020-04-14 16:46:39 -06:00
import { Highlight } from "../components/maybe_highlight";
2018-07-17 23:08:27 -06:00
2018-07-18 19:35:01 -06:00
/** Width of UI columns in Pin Bindings widget. */
2018-07-17 23:08:27 -06:00
export enum PinBindingColWidth {
pin = 4,
2020-02-15 11:29:09 -07:00
type = 6,
button = 2
2018-07-17 23:08:27 -06:00
}
2018-07-18 19:35:01 -06:00
/** Use binding type to return a sequence ID or a special action. */
2018-07-17 23:08:27 -06:00
const getBindingTarget = (bindingBody: PinBinding): {
sequence_id: number | undefined,
special_action: PinBindingSpecialAction | undefined
} => {
return bindingBody.binding_type == PinBindingType.special
? { sequence_id: undefined, special_action: bindingBody.special_action }
: { sequence_id: bindingBody.sequence_id, special_action: undefined };
};
2018-07-20 19:52:41 -06:00
/** Return API pin binding data. */
const apiPinBindings = (resources: ResourceIndex): PinBindingListItems[] => {
const userBindings: PinBindingListItems[] = selectAllPinBindings(resources)
.map(binding => {
const { uuid, body } = binding;
const sequence_id = getBindingTarget(body).sequence_id;
const special_action = getBindingTarget(body).special_action;
return {
pin_number: body.pin_num,
sequence_id,
special_action,
binding_type: body.binding_type,
uuid: uuid
};
});
return userBindings.concat(sysBtnBindingData);
};
2019-01-28 17:04:27 -07:00
const PinBindingsListHeader = () =>
<Row>
<Col xs={PinBindingColWidth.pin}>
<label>
{t("Pin Number")}
</label>
</Col>
<Col xs={PinBindingColWidth.type}>
<label>
{t("Binding")}
</label>
2020-02-15 11:29:09 -07:00
<Help text={ToolTips.PIN_BINDINGS} />
2019-01-28 17:04:27 -07:00
</Col>
</Row>;
2018-07-20 19:52:41 -06:00
2020-02-15 11:29:09 -07:00
export const PinBindingsContent = (props: PinBindingsContentProps) => {
2020-02-26 11:10:59 -07:00
const { dispatch, resources, firmwareHardware } = props;
2019-01-28 17:04:27 -07:00
const pinBindings = apiPinBindings(resources);
2020-03-13 15:06:40 -06:00
const newFormat = DevSettings.futureFeaturesEnabled();
2020-02-15 11:29:09 -07:00
return <div className="pin-bindings">
2020-04-14 16:46:39 -06:00
<Highlight settingName={DeviceSetting.pinBindings}>
<Row>
{newFormat && <Help text={ToolTips.PIN_BINDINGS}
position={Position.TOP_RIGHT} />}
<StockPinBindingsButton
dispatch={dispatch} firmwareHardware={firmwareHardware} />
<Popover
position={Position.TOP_RIGHT}
interactionKind={PopoverInteractionKind.HOVER}
portalClassName={"bindings-warning-icon"}
popoverClassName={"help"}>
<i className="fa fa-exclamation-triangle" />
<div className={"pin-binding-warning"}>
{t(ToolTips.PIN_BINDING_WARNING)}
</div>
</Popover>
</Row>
</Highlight>
2020-02-28 09:34:28 -07:00
<div className={"pin-bindings-list-and-input"}>
2020-03-13 15:06:40 -06:00
{!newFormat && <PinBindingsListHeader />}
2020-04-14 16:46:39 -06:00
<Highlight settingName={DeviceSetting.savedPinBindings}>
<PinBindingsList
pinBindings={pinBindings}
dispatch={dispatch}
resources={resources} />
</Highlight>
<Highlight settingName={DeviceSetting.addNewPinBinding}>
<PinBindingInputGroup
pinBindings={pinBindings}
dispatch={dispatch}
resources={resources} />
</Highlight>
2020-02-15 11:29:09 -07:00
</div>
</div>;
2018-07-17 23:08:27 -06:00
};