import React, { useReducer, forwardRef, useMemo, useImperativeHandle } from 'react'; import PropTypes from 'prop-types'; import Tabs from '../Tabs'; import ContentTypes from './ContentTypes'; import PluginsAndSettingsPermissions from './PluginsAndSettingsPermissions'; import { roleTabsLabel } from '../../../utils'; import { useModels } from '../../../hooks'; import PermissionsProvider from './PermissionsProvider'; import reducer, { initialState } from './reducer'; import init from './init'; import { getAllAttributes, formatPermissionsLayout } from './utils'; const Permissions = forwardRef(({ role, permissionsLayout, rolePermissions }, ref) => { const { singleTypes, collectionTypes, components } = useModels(); const [state, dispatch] = useReducer(reducer, initialState, state => init(state, permissionsLayout, rolePermissions, role) ); useImperativeHandle(ref, () => ({ getPermissions: () => { return { contentTypesPermissions: state.contentTypesPermissions, pluginsAndSettingsPermissions: state.pluginsAndSettingsPermissions, }; }, })); const allSingleTypesAttributes = useMemo(() => { return getAllAttributes(singleTypes, components); }, [components, singleTypes]); const allCollectionTypesAttributes = useMemo(() => { return getAllAttributes(collectionTypes, components); }, [components, collectionTypes]); const pluginsPermissionsLayout = useMemo(() => { return formatPermissionsLayout(permissionsLayout.sections.plugins, 'plugin'); }, [permissionsLayout]); const settingsPermissionsLayout = useMemo(() => { return formatPermissionsLayout(permissionsLayout.sections.settings, 'category'); }, [permissionsLayout]); const handleCollapse = (index, value) => { dispatch({ type: 'COLLAPSE_PATH', index, value, }); }; const handleAttributePermissionSelect = ({ subject, action, attribute }) => { dispatch({ type: 'ATTRIBUTE_PERMISSION_SELECT', subject, action, attribute, }); }; const handleSetAttributesPermissions = ({ attributes, action, shouldEnable, hasContentTypeAction, }) => { dispatch({ type: 'SET_ATTRIBUTES_PERMISSIONS', attributes, action, shouldEnable, hasContentTypeAction, }); }; const handleAttributesSelect = ({ subject, action, attributes, shouldEnable, hasContentTypeAction, }) => { dispatch({ type: 'ON_ATTRIBUTES_SELECT', subject, action, attributes, shouldEnable, hasContentTypeAction, }); }; const handleContentTypeActionSelect = ({ subject, action }) => { dispatch({ type: 'CONTENT_TYPE_ACTION_SELECT', subject, action, }); }; const handleAllContentTypeActions = ({ subject, attributes, shouldEnable, shouldSetAllContentTypes, shouldAddDeleteAction, }) => { dispatch({ type: 'ALL_CONTENT_TYPE_PERMISSIONS_SELECT', subject, attributes, shouldEnable, shouldSetAllContentTypes, shouldAddDeleteAction, }); }; const handleGlobalPermissionsActionSelect = ({ contentTypes, action, shouldEnable }) => { dispatch({ type: 'GLOBAL_PERMISSIONS_SELECT', contentTypes, action, shouldEnable, }); }; const handleAllAttributeActionsSelect = ({ subject, attribute, shouldAddDeleteAction }) => { dispatch({ type: 'ALL_ATTRIBUTE_ACTIONS_SELECT', subject, attribute, shouldAddDeleteAction, }); }; const handlePluginSettingPermission = action => { dispatch({ type: 'ON_PLUGIN_SETTING_ACTION', action, }); }; const handlePluginSettingSubCategoryPermission = ({ actions, shouldEnable }) => { dispatch({ type: 'ON_PLUGIN_SETTING_SUB_CATEGORY_ACTIONS', actions, shouldEnable, }); }; const handleContentTypeConditionsSelect = ({ subject, conditions }) => { dispatch({ type: 'ON_CONTENT_TYPE_CONDITIONS_SELECT', subject, conditions, }); }; const handlePluginSettingConditionsSelect = conditions => { dispatch({ type: 'ON_PLUGIN_SETTING_CONDITIONS_SELECT', conditions, }); }; const providerValues = { ...state, components, onCollapse: handleCollapse, onAttributePermissionSelect: handleAttributePermissionSelect, onAllAttributeActionsSelect: handleAllAttributeActionsSelect, onContentTypeActionSelect: handleContentTypeActionSelect, onAttributesSelect: handleAttributesSelect, onAllContentTypeActions: handleAllContentTypeActions, onGlobalPermissionsActionSelect: handleGlobalPermissionsActionSelect, onSetAttributesPermissions: handleSetAttributesPermissions, onPluginSettingPermission: handlePluginSettingPermission, onContentTypeConditionsSelect: handleContentTypeConditionsSelect, onPluginSettingSubCategoryPermission: handlePluginSettingSubCategoryPermission, onPluginSettingConditionsSelect: handlePluginSettingConditionsSelect, }; return ( ); }); Permissions.defaultProps = { role: null, rolePermissions: {}, }; Permissions.propTypes = { permissionsLayout: PropTypes.object.isRequired, rolePermissions: PropTypes.object, role: PropTypes.object, }; export default Permissions;