/*
* This file is part of ORY Editor.
*
* ORY Editor is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* ORY Editor is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with ORY Editor. If not, see .
*
* @license LGPL-3.0
* @copyright 2016-2018 Aeneas Rekkas
* @author Aeneas Rekkas
*
*/
import * as React from 'react';
import { DropTarget as dropTarget } from 'react-dnd';
import { connect } from 'react-redux';
import { ComponetizedRow } from '../../../types/editable';
import { dragActions } from '../../../actions/cell/drag';
import { insertActions } from '../../../actions/cell/insert';
import { target, connect as monitorConnect } from './dnd';
export type Props = ComponetizedRow & {
children: React.ReactChildren;
isLayoutMode: boolean;
isInsertMode: boolean;
isOverCurrent: boolean;
connectDropTarget(e: T): T;
};
export class Droppable extends React.Component {
render() {
if (!(this.props.isLayoutMode || this.props.isInsertMode)) {
return (
{this.props.children}
);
}
return this.props.connectDropTarget(
{this.props.children}
);
}
}
const mapDispatchToProps = { ...dragActions, ...insertActions };
export default (dropTypes: string[] = ['CELL']) =>
connect(
null,
mapDispatchToProps
)(dropTarget(dropTypes, target, monitorConnect)(Droppable));