a1f4e57a21
* Update back end to add MQTT and WebSocket support * Update demo project to demonstrate MQTT and WebSockets * Update documentation to describe newly added and modified functionallity * Introduce separate MQTT pub/sub, HTTP get/post and WebSocket rx/tx classes * Significant reanaming - more accurate class names * Use PROGMEM_WWW as default * Update README documenting PROGMEM_WWW as default * Update README with API changes
41 lines
1.2 KiB
TypeScript
41 lines
1.2 KiB
TypeScript
import React from 'react';
|
|
|
|
import { makeStyles, Theme, createStyles } from '@material-ui/core/styles';
|
|
import { LinearProgress, Typography } from '@material-ui/core';
|
|
|
|
import { WebSocketControllerProps } from '.';
|
|
|
|
const useStyles = makeStyles((theme: Theme) =>
|
|
createStyles({
|
|
loadingSettings: {
|
|
margin: theme.spacing(0.5),
|
|
},
|
|
loadingSettingsDetails: {
|
|
margin: theme.spacing(4),
|
|
textAlign: "center"
|
|
}
|
|
})
|
|
);
|
|
|
|
export type WebSocketFormProps<D> = Omit<WebSocketControllerProps<D>, "connected"> & { data: D };
|
|
|
|
interface WebSocketFormLoaderProps<D> extends WebSocketControllerProps<D> {
|
|
render: (props: WebSocketFormProps<D>) => JSX.Element;
|
|
}
|
|
|
|
export default function WebSocketFormLoader<D>(props: WebSocketFormLoaderProps<D>) {
|
|
const { connected, render, data, ...rest } = props;
|
|
const classes = useStyles();
|
|
if (!connected || !data) {
|
|
return (
|
|
<div className={classes.loadingSettings}>
|
|
<LinearProgress className={classes.loadingSettingsDetails} />
|
|
<Typography variant="h6" className={classes.loadingSettingsDetails}>
|
|
Connecting to WebSocket...
|
|
</Typography>
|
|
</div>
|
|
);
|
|
}
|
|
return render({ ...rest, data });
|
|
}
|