LiberTEM/LiberTEM

View on GitHub
client/src/dataset/components/DatasetList.tsx

Summary

Maintainability
A
0 mins
Test Coverage
import * as React from "react";
import { connect } from "react-redux";
import BrowserWrapper from "../../browser/components/BrowserWrapper";
import { RootReducer } from "../../store";
import { DatasetsState } from "../types";
import Dataset from "./Dataset";
import DatasetOpen from "./DatasetOpen";
import DatasetOpenSpinner from "./DatasetOpenSpinner";

interface DatasetListProps {
    datasets: DatasetsState
}

const mapStateToProps = (state: RootReducer) => ({
    datasets: state.datasets,
    formVisible: state.openDataset.formVisible,
    formPath: state.openDataset.formPath,
});

type MergedProps = DatasetListProps & ReturnType<typeof mapStateToProps>;

class DatasetList extends React.Component<MergedProps> {
    public render() {
        const { formVisible, datasets } = this.props;

        return (
            <>
                {datasets.ids.map((dsId: string) => <Dataset dataset={datasets.byId[dsId]} key={dsId} />)}
                <DatasetOpenSpinner />
                {formVisible && <DatasetOpen />}
                <BrowserWrapper />
            </>
        );
    }
}

export default connect(mapStateToProps)(DatasetList);