Blob Blame History Raw
import React from "react";
import PropTypes from "prop-types";
import FilterInput from "./FilterInput";
import ToolbarLayout from "./ToolbarLayout";

const BlueprintToolbar = (props) => (
  <ToolbarLayout
    filters={props.filters}
    filterRemoveValue={props.filterRemoveValue}
    filterClearValues={props.filterClearValues}
  >
    <FilterInput emptyState={props.emptyState} filters={props.filters} filterAddValue={props.filterAddValue} />
    <div className="form-group">
      {(props.componentsSortKey === "name" && props.componentsSortValue === "DESC" && (
        <button
          className="btn btn-link"
          type="button"
          disabled={props.emptyState}
          onClick={() => {
            props.componentsSortSetValue("ASC");
            props.dependenciesSortSetValue("ASC");
          }}
        >
          <span className="fa fa-sort-alpha-asc" />
        </button>
      )) ||
        (props.componentsSortKey === "name" && props.componentsSortValue === "ASC" && (
          <button
            className="btn btn-link"
            type="button"
            disabled={props.emptyState}
            onClick={() => {
              props.componentsSortSetValue("DESC");
              props.dependenciesSortSetValue("DESC");
            }}
          >
            <span className="fa fa-sort-alpha-desc" />
          </button>
        ))}
    </div>
    {props.undo !== undefined && (
      <div className="form-group">
        {(props.pastLength > 0 && (
          <button
            className="btn btn-link"
            type="button"
            onClick={() => {
              props.undo();
            }}
            data-button="undo"
          >
            <span className="fa fa-undo" aria-hidden="true" />
          </button>
        )) || (
          <button className="btn btn-link disabled" type="button" data-button="undo">
            <span className="fa fa-undo" aria-hidden="true" />
          </button>
        )}
        {(props.futureLength > 0 && (
          <button
            className="btn btn-link"
            type="button"
            onClick={() => {
              props.redo(props.blueprintId, false);
            }}
            data-button="redo"
          >
            <span className="fa fa-repeat" aria-hidden="true" />
          </button>
        )) || (
          <button className="btn btn-link disabled" type="button" data-button="redo">
            <span className="fa fa-repeat" aria-hidden="true" />
          </button>
        )}
      </div>
    )}
  </ToolbarLayout>
);

BlueprintToolbar.propTypes = {
  filters: PropTypes.shape({
    defaultFilterType: PropTypes.string,
    filterTypes: PropTypes.arrayOf(PropTypes.object),
    filterValues: PropTypes.arrayOf(PropTypes.object),
  }),
  filterAddValue: PropTypes.func,
  filterRemoveValue: PropTypes.func,
  filterClearValues: PropTypes.func,
  emptyState: PropTypes.bool,
  componentsSortKey: PropTypes.string,
  componentsSortSetValue: PropTypes.func,
  componentsSortValue: PropTypes.string,
  dependenciesSortSetValue: PropTypes.func,
  undo: PropTypes.func,
  pastLength: PropTypes.number,
  futureLength: PropTypes.number,
  redo: PropTypes.func,
  blueprintId: PropTypes.string,
};

BlueprintToolbar.defaultProps = {
  filters: {},
  filterAddValue() {},
  filterRemoveValue() {},
  filterClearValues() {},
  emptyState: false,
  componentsSortKey: "",
  componentsSortSetValue() {},
  componentsSortValue: "",
  dependenciesSortSetValue() {},
  undo() {},
  pastLength: 0,
  futureLength: 0,
  redo() {},
  blueprintId: "",
};

export default BlueprintToolbar;