SU-SWS/react_paragraphs

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

Summary

Maintainability
A
0 mins
Test Coverage
import React, {useState} from 'react';
import {Draggable} from "react-beautiful-dnd";
import styled from 'styled-components';
import {ParagraphForm} from "./ParagraphForm";
import {WidgetContext} from "../Contexts/WidgetManager";
import {DropButtons} from "./DropButtons"
import {ConfirmDialog} from "./Atoms/ConfirmDialog";

const ParagraphWrapper = styled.div`
  margin: 5px;
  border: 1px solid #BDBDBD;
  width: 0;
  height: 80px;
  line-height: 80px;
  padding: 0px 85px 0px 20px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  position: relative;
  flex: ${props => props.itemWidth} 1 0;
  background: ${props => props.isDragging ? '#dafcdf' : '#fff'};

  .dropbutton-wrapper {
    position: absolute;
    top: calc(50% - 13px);
    right: 5px;
  }
`;

export const RowItem = ({item, id, isDraggable, index}) => {

  const [modalOpen, setModalOpen] = useState(typeof item.isNew === 'undefined' ? false : true);
  const [deleteConfirmOpen, setDeleteConfirmOpen] = useState(false);

  const getItemIcon = (availableTools) => {
    let iconSrc = '';

    const tool = availableTools.find(tool => tool.id === item.entity.type[0].target_id);
    iconSrc = tool?.icon;

    return <img
      className="max-h-9 max-w-9 mr-0.5 align-middle"
      role="presentation"
      alt=""
      src={iconSrc}
    />;
  };

  /**
   * Get the label of the entity type for the current item
   *
   * @param widgetContext
   * @returns {*}
   */
  const getToolLabel = (widgetContext) => {
    try {
      const toolInfo = widgetContext.getToolInformation(item.entity.type[0].target_id);
      return toolInfo.label;
    }
    catch (e) {
      console.error('Unknown error occurred: ' + e);
      return null;
    }
  }

  return (
    <Draggable
      draggableId={id}
      index={index}
      isDragDisabled={!isDraggable}
    >
      {(provided, snapshot) =>
        <WidgetContext.Consumer>
          {widgetContext =>
            <ParagraphWrapper
              ref={provided.innerRef}
              {...provided.draggableProps}
              {...provided.dragHandleProps}
              isDragging={snapshot.isDragging}
              itemWidth={item.width}
              id={id}
              // className={classes}
            >
              <span className="inline-block h-full align-middle"></span>
              {getItemIcon(widgetContext.tools)}
              {item.admin_title}

              <DropButtons
                style={{marginRight: '6px'}}
                buttons={[
                  <button
                    type="button"
                    className="button"
                    onClick={() => setModalOpen(!modalOpen)}
                  >
                    Edit<span
                    className="visually-hidden">{item.admin_title}</span>
                  </button>,
                  <button
                    type="button"
                    className="button"
                    onClick={() => setDeleteConfirmOpen(true)}
                  >
                    Delete
                  </button>,
                ]}
              />

              <ParagraphForm
                open={modalOpen}
                item={item}
                onClose={setModalOpen}
                widgetContext={widgetContext}
                typeLabel={getToolLabel(widgetContext)}
              />

              <ConfirmDialog
                open={deleteConfirmOpen}
                title={`Delete ${item.admin_title}?`}
                dialog="This action can not be undone."
                onCancel={() => setDeleteConfirmOpen(false)}
                onConfirm={() => {
                  setDeleteConfirmOpen(false);
                  widgetContext.removeRowItem(id)
                }}
              />

            </ParagraphWrapper>
          }
        </WidgetContext.Consumer>
      }
    </Draggable>
  )
};