import { assign, merge } from "lodash"; import { observer } from "mobx-react"; import * as qs from "query-string"; import * as React from "react"; import { RouteComponentProps } from "react-router"; import { Button, CheckboxProps, Form, Icon, Input, InputOnChangeData, Menu, Modal } from "semantic-ui-react"; import { ProgramSequenceView, ScheduleView } from "@client/components"; import * as route from "@client/routePaths"; import { AppState, injectState } from "@client/state"; import { ISprinklersDevice } from "@common/httpApi"; import log from "@common/logger"; import { Program, SprinklersDevice } from "@common/sprinklersRpc"; import { action } from "mobx"; interface ProgramPageProps extends RouteComponentProps<{ deviceId: string, programId: string }> { appState: AppState; } @observer class ProgramPage extends React.Component { get isEditing(): boolean { return qs.parse(this.props.location.search).editing != null; } iDevice!: ISprinklersDevice; device!: SprinklersDevice; program!: Program; programView: Program | null = null; renderName(program: Program) { const { name } = program; if (this.isEditing) { return (
({program.id})
); } else { return Program {name} ({program.id}); } } renderActions(program: Program) { const { running } = program; const editing = this.isEditing; let editButtons; if (editing) { editButtons = ( ); } else { editButtons = ( ); } const stopStartButton = ( ); return ( {stopStartButton} {editButtons} ); } render() { const { deviceId: did, programId: pid } = this.props.match.params; const { userStore, sprinklersRpc } = this.props.appState; const deviceId = Number(did); const programId = Number(pid); // tslint:disable-next-line:prefer-conditional-expression if (!this.iDevice || this.iDevice.id !== deviceId) { this.iDevice = userStore.findDevice(deviceId)!; } if (this.iDevice && this.iDevice.deviceId && (!this.device || this.device.id !== this.iDevice.deviceId)) { this.device = sprinklersRpc.getDevice(this.iDevice.deviceId); } // tslint:disable-next-line:prefer-conditional-expression if (!this.program || this.program.id !== programId) { if (this.device.programs.length > programId && programId >= 0) { this.program = this.device.programs[programId]; } else { return null; } } if (this.isEditing) { if (this.programView == null && this.program) { // this.programView = createViewModel(this.program); // this.programView = observable(toJS(this.program)); this.programView = this.program.clone(); } } else { if (this.programView != null) { // this.programView.reset(); this.programView = null; } } const program = this.programView || this.program; const editing = this.isEditing; const { running, enabled, schedule, sequence } = program; return ( {this.renderName(program)}
Schedule} />
{this.renderActions(program)}
); } @action.bound private cancelOrRun() { if (!this.program) { return; } this.program.running ? this.program.cancel() : this.program.run(); } @action.bound private startEditing() { this.props.history.push({ search: qs.stringify({ editing: true }) }); } @action.bound private save() { if (!this.programView || !this.program) { return; } assign(this.program, this.programView); this.program.update() .then((data) => { log.info({ data }, "Program updated"); }, (err) => { log.error({ err }, "error updating Program"); }); this.stopEditing(); } @action.bound private stopEditing() { this.props.history.push({ search: "" }); } @action.bound private close() { const { deviceId } = this.props.match.params; this.props.history.push({ pathname: route.device(deviceId), search: "" }); } @action.bound private onNameChange(e: any, p: InputOnChangeData) { if (this.programView) { this.programView.name = p.value; } } @action.bound private onEnabledChange(e: any, p: CheckboxProps) { if (this.programView) { this.programView.enabled = p.checked!; } } } const DecoratedProgramPage = injectState(observer(ProgramPage)); export default DecoratedProgramPage;