From 32e2028e62d7c3273c7303c79fa8700a4e30a58c Mon Sep 17 00:00:00 2001 From: Dmitri Pisarev Date: Wed, 7 Mar 2018 14:47:35 +0300 Subject: [PATCH] BUGFIX: don't show NodeToolbar for document nodes --- packages/neos-ui-guest-frame/src/InlineUI/index.js | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/packages/neos-ui-guest-frame/src/InlineUI/index.js b/packages/neos-ui-guest-frame/src/InlineUI/index.js index 5b725153db..135bda8b65 100644 --- a/packages/neos-ui-guest-frame/src/InlineUI/index.js +++ b/packages/neos-ui-guest-frame/src/InlineUI/index.js @@ -3,11 +3,15 @@ import PropTypes from 'prop-types'; import {connect} from 'react-redux'; import {$transform, $get, $contains} from 'plow-js'; import {actions, selectors} from '@neos-project/neos-ui-redux-store'; +import {neos} from '@neos-project/neos-ui-decorators'; import NodeToolbar from './NodeToolbar/index'; import style from './style.css'; +@neos(globalRegistry => ({ + nodeTypesRegistry: globalRegistry.get('@neos-project/neos-ui-contentrepository') +})) @connect($transform({ focused: $get('cr.nodes.focused'), focusedNode: selectors.CR.Nodes.focusedSelector, @@ -22,6 +26,7 @@ export default class InlineUI extends PureComponent { static propTypes = { focused: PropTypes.object, focusedNode: PropTypes.object, + nodeTypesRegistry: PropTypes.object, destructiveOperationsAreDisabled: PropTypes.bool.isRequired, requestScrollIntoView: PropTypes.func.isRequired, shouldScrollIntoView: PropTypes.bool.isRequired, @@ -32,7 +37,12 @@ export default class InlineUI extends PureComponent { render() { const focused = this.props.focused.toJS(); const focusedNodeContextPath = focused.contextPath; - const {shouldScrollIntoView, requestScrollIntoView, destructiveOperationsAreDisabled, clipboardMode, clipboardNodeContextPath} = this.props; + const {nodeTypesRegistry, focusedNode, shouldScrollIntoView, requestScrollIntoView, destructiveOperationsAreDisabled, clipboardMode, clipboardNodeContextPath} = this.props; + const isDocument = nodeTypesRegistry.hasRole($get('nodeType', focusedNode), 'document'); + // Don't render toolbar for the document nodes + if (isDocument) { + return null; + } const isCut = focusedNodeContextPath === clipboardNodeContextPath && clipboardMode === 'Move'; const isCopied = focusedNodeContextPath === clipboardNodeContextPath && clipboardMode === 'Copy'; const canBeDeleted = $get('policy.canRemove', this.props.focusedNode);