You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
1.1 KiB
35 lines
1.1 KiB
import { observer } from "mobx-react"; |
|
import * as React from "react"; |
|
import { Item, Button } from "semantic-ui-react"; |
|
|
|
import { DeviceView } from "@client/components"; |
|
import { AppState, injectState } from "@client/state"; |
|
|
|
class DevicesPage extends React.Component<{ appState: AppState }> { |
|
refreshDevices = () => { |
|
this.props.appState.sprinklersRpc.doAuthenticate(); |
|
} |
|
|
|
render() { |
|
const { appState } = this.props; |
|
const { userData } = appState.userStore; |
|
let deviceNodes: React.ReactNode; |
|
if (!userData) { |
|
deviceNodes = <span>Not logged in</span>; |
|
} else if (!userData.devices || !userData.devices.length) { |
|
deviceNodes = <span>You have no devices</span>; |
|
} else { |
|
deviceNodes = userData.devices.map(device => ( |
|
<DeviceView key={device.id} deviceId={device.id} inList /> |
|
)); |
|
} |
|
return ( |
|
<React.Fragment> |
|
<h1 className="devices-header">Devices <Button icon="refresh" onClick={this.refreshDevices}></Button></h1> |
|
<Item.Group>{deviceNodes}</Item.Group> |
|
</React.Fragment> |
|
); |
|
} |
|
} |
|
|
|
export default injectState(observer(DevicesPage));
|
|
|