import { flatMap } from "lodash"; import { observer } from "mobx-react"; import * as moment from "moment"; import * as React from "react"; import { Button, Table } from "semantic-ui-react"; import { Duration } from "@common/Duration"; import { Program, Schedule, TimeOfDay, Weekday, DateOfYear, Section } from "@common/sprinklers"; function timeToString(time: TimeOfDay) { return moment(time).format("LTS"); } function formatDateOfYear(day: DateOfYear | null, prefix: string) { if (day == null) { return null; } return prefix + moment(day).format("l"); } @observer export class ScheduleView extends React.Component<{ schedule: Schedule }> { render() { const { schedule } = this.props; const times = schedule.times.map((time, i) => timeToString(time)) .join(", "); const weekdays = schedule.weekdays.map((weekday) => Weekday[weekday]).join(", "); const from = formatDateOfYear(schedule.from, "From "); const to = formatDateOfYear(schedule.to, "To "); return (
At {times}
On {weekdays}
{from}
{to}
); } } @observer export default class ProgramTable extends React.Component<{ programs: Program[], sections: Section[] }> { render() { const programRows = Array.prototype.concat.apply([], this.props.programs.map(this.renderRows)); return ( Programs # Name Running? Enabled? {programRows}
); } private renderRows = (program: Program, i: number): JSX.Element[] | null => { if (!program) { return null; } const { name, running, enabled, schedule, sequence } = program; const sequenceItems = flatMap(sequence, (item, index) => { const section = this.props.sections[item.section]; const duration = Duration.fromSeconds(item.duration); return [ "{section.name}", ` for ${duration.toString()}, `, ]; }); const cancelOrRun = () => running ? program.cancel() : program.run(); return [( {"" + (i + 1)} {name} {running ? "Running" : "Not running"} {enabled ? "Enabled" : "Not enabled"} ), (

Sequence:

{sequenceItems}

Schedule:

)]; } }