/* * 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 { connect } from 'react-redux'; import { createStructuredSelector } from 'reselect'; import { ContentPlugin } from '../../../service/plugin/classes'; import Cell from '../../Cell'; import { purifiedEditable } from '../../../selector/editable'; import dimensions from '../../Dimensions'; import { blurAllCells, createFallbackCell } from '../../../actions/cell'; import { enableGlobalBlurring, disableGlobalBlurring } from './blur'; import { EditableComponentState } from '../../../types/editable'; class Inner extends React.PureComponent { componentDidMount() { enableGlobalBlurring(this.props.blurAllCells); this.createFallbackCell(); } componentDidUpdate() { this.createFallbackCell(); } componentWillUnmount() { disableGlobalBlurring(this.props.blurAllCells); } createFallbackCell = () => { const { node, defaultPlugin, id } = this.props; if (!node) { return; } const { cells = [] } = node; if (cells.length === 0) { this.props.createFallbackCell(new ContentPlugin(defaultPlugin), id); } } render() { const { id, containerWidth, containerHeight, node } = this.props; if (!node) { return null; } const { cells = [] } = node; return (
{cells.map((c: string) => ( ))}
); } } const mapStateToProps = createStructuredSelector({ node: purifiedEditable }); const mapDispatchToProps = { blurAllCells, createFallbackCell }; export default dimensions()( connect( mapStateToProps, mapDispatchToProps )(Inner) );