LiberTEM/LiberTEM

View on GitHub
client/src/job/components/Result.tsx

Summary

Maintainability
A
0 mins
Test Coverage
import * as React from "react";
import { connect } from "react-redux";
import styled from 'styled-components';
import BusyWrapper from "../../widgets/BusyWrapper";
import HandleParent from "../../widgets/HandleParent";
import { HandleRenderFunction } from "../../widgets/types";
import { JobRunning, JobState } from "../types";
import ResultImage from "./ResultImage";

interface ResultProps {
    width: number,
    height: number,
    job: JobState,
    extraHandles?: HandleRenderFunction,
    extraWidgets?: React.ReactElement<SVGElement>,
    channel: number,
}

const ResultWrapper = styled.svg`
    display: block;
    border: 1px solid black;
    width: 100%;
    height: auto;
`;

type MergedProps = ResultProps;

class Result extends React.Component<MergedProps> {
    public renderHandles() {
        const { width, height, extraHandles } = this.props;
        let handles: HandleRenderFunction[] = [];
        if (extraHandles) {
            handles = [...handles, extraHandles];
        }

        return (
            <HandleParent width={width} height={height} handles={handles} />
        )
    }

    public render() {
        const { job, channel, width, height, extraWidgets } = this.props;
        const busy = job.running !== JobRunning.DONE;

        return (
            <BusyWrapper busy={busy}>
                <ResultWrapper width={width} height={height} viewBox={`0 0 ${width} ${height}`}>
                    <ResultImage job={job} channel={channel} width={width} height={height} />
                    {extraWidgets}
                    {this.renderHandles()}
                </ResultWrapper>
            </BusyWrapper>
        );
    }
}

export default connect(null, null)(Result);