SU-SWS/react_paragraphs

View on GitHub
js/src/Components/Toolbox.js

Summary

Maintainability
A
0 mins
Test Coverage
import React from 'react';
import {Droppable, Draggable} from "react-beautiful-dnd";
import {WidgetContext} from "../Contexts/WidgetManager";
import {FlexDiv} from "./Atoms/FlexDiv";

export const Toolbox = ({tools}) => {
  return (
    <div className="border border-solid border-[#C0C0C0] bg-[#F0F0EE] p-5 min-h-[calc(100vh-120px)] sticky t-[80px] -mt-8 -mr-5 -mb-5 ml-5 w-52 max-w-52 overflow-auto">
      <h3 className="fieldset-legend">Drag and drop Paragraphs into Rows</h3>
      <Droppable
        droppableId="toolbox"
        type="item"
        direction="horizontal"
        isDropDisabled={true}
      >
        {provided => (
          <div
            {...provided.droppableProps}
            ref={provided.innerRef}
          >
            <FlexDiv column={true}>
              {tools.map((tool, weight) => (
                <Tool
                  key={`tool-${tool.id}`}
                  weight={weight}
                  {...tool}
                />
              ))}
              {provided.placeholder}
            </FlexDiv>
          </div>
        )}
      </Droppable>
    </div>
  )
};

const Tool = ({weight, id, label, icon}) => {

  if (!icon) {
    icon = '';
  }

  return (
    <WidgetContext.Consumer>
      {widgetContext =>

        <Draggable
          draggableId={id}
          index={weight}
        >
          {provided => (
            <div
              ref={provided.innerRef}
              {...provided.draggableProps}
              {...provided.dragHandleProps}
              onDoubleClick={(e) => widgetContext.addToolToBottom(id, e)}
              id={`tool-${id}`}
              className="bg-white m-2.5 p-2.5 border border-solid border-[#ccc] w-[100px] min-h-[75px] text-center text-slate-600 text-base font-semibold shadow-md"
            >
              <img
                className="max-w-[80px] max-h-[40px] mx-auto mt-1"
                src={icon}
                alt=""
              />

              <div className="label">{label}</div>
            </div>
          )}
        </Draggable>

      }
    </WidgetContext.Consumer>
  )

};