import { computed } from "mobx";
import { observer } from "mobx-react";
import * as React from "react";
import { DropdownItemProps, DropdownProps, Form, Header, Segment } from "semantic-ui-react";
import { Duration } from "@common/Duration";
import log from "@common/logger";
import { Section } from "@common/sprinklers";
import DurationInput from "./DurationInput";
@observer
export default class RunSectionForm extends React.Component<{
sections: Section[],
}, {
duration: Duration,
section: number | "",
}> {
constructor() {
super();
this.state = {
duration: new Duration(0, 0),
section: "",
};
}
render() {
const { section, duration } = this.state;
return (
{/*Label must be to align it properly*/}
Run
);
}
private onSectionChange = (e: React.SyntheticEvent, v: DropdownProps) => {
this.setState({ section: v.value as number });
}
private onDurationChange = (newDuration: Duration) => {
this.setState({ duration: newDuration });
}
private run = (e: React.SyntheticEvent) => {
e.preventDefault();
if (typeof this.state.section !== "number") {
return;
}
const section: Section = this.props.sections[this.state.section];
const { duration } = this.state;
section.run(duration.toSeconds())
.then((result) => log.debug({ result }, "requested section run"))
.catch((err) => log.error(err, "error running section"));
}
private get isValid(): boolean {
return typeof this.state.section === "number";
}
@computed
private get sectionOptions(): DropdownItemProps[] {
return this.props.sections.map((s, i) => ({
text: s ? s.name : null,
value: i,
}));
}
}