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

Version Path
crono_trigger-0.8.3 web/app/src/Models.tsx
crono_trigger-0.8.1 web/app/src/Models.tsx
crono_trigger-0.8.0 web/app/src/Models.tsx
crono_trigger-0.7.1 web/app/src/Models.tsx
crono_trigger-0.7.0 web/app/src/Models.tsx