Sha256: 28302ebb7a22d661363447edb97b6656828193e72097c694ef1dc43d8164f005
Contents?: true
Size: 1.47 KB
Versions: 5
Compression:
Stored size: 1.47 KB
Contents
import Paper from '@material-ui/core/Paper'; import Table from '@material-ui/core/Table'; import TableBody from '@material-ui/core/TableBody'; import TableCell from '@material-ui/core/TableCell'; import TableHead from '@material-ui/core/TableHead'; import TableRow from '@material-ui/core/TableRow'; import * as React from 'react'; import { Link } from "react-router-dom"; import { IGlobalWindow } from './interfaces'; declare var window: IGlobalWindow interface IModelsState { models: string[] } class Models extends React.Component<any, IModelsState> { constructor(props: any) { super(props) this.state = {models: []} } public componentDidMount() { this.fetchModels(); } public fetchModels(): void { fetch(`${window.mountPath}/models.json`) .then((res) => res.json()) .then((data) => { this.setState(data); }).catch((err) => { console.error(err); }); } public render() { return ( <Paper className="models-container"> <Table className="models"> <TableHead> <TableRow> <TableCell>Model Name</TableCell> </TableRow> </TableHead> <TableBody> {this.state.models.map((model) => ( <TableRow key={model}> <TableCell><Link to={`/models/${model}`}>{model}</Link></TableCell> </TableRow> ))} </TableBody> </Table> </Paper> ) } } export default Models;
Version data entries
5 entries across 5 versions & 1 rubygems