UNPKG

@talend/react-containers

Version:

Provide connected components aka containers for @talend/react-cmf based on @talend/react-components.

78 lines 1.98 kB
import PropTypes from 'prop-types'; import cmf, { cmfConnect } from '@talend/react-cmf'; import getOnClick from '../actionOnClick'; import { ActionSplitDropdown } from "@talend/react-components"; import { jsx as _jsx } from "react/jsx-runtime"; export function mapStateToProps(state, { actionId, actionIds } = {}) { let props = {}; const context = { registry: cmf.registry.getRegistry(), store: { getState: () => state } }; if (actionId) { props = cmf.action.getActionInfo(context, actionId); } if (actionIds) { props.actionIds = actionIds; } if (props.actionIds) { props.items = props.actionIds.map(itemId => cmf.action.getActionInfo(context, itemId)); } return props; } export function mergeProps(stateProps, dispatchProps, ownProps) { const props = { ...ownProps, ...stateProps, ...dispatchProps }; if (props.actionId) { delete props.actionId; } if (props.actionIds) { delete props.actionIds; } return props; } export function ContainerActionSplitDropdown(props) { let newProps = { ...props }; delete newProps.dispatch; delete newProps.dispatchActionCreator; delete newProps.getComponent; delete newProps.actionIds; delete newProps.actionId; newProps = { ...getOnClick(newProps, props), ...newProps }; if (newProps.items) { newProps.items = props.items.map(item => ({ ...getOnClick(item, props), ...item })); } return /*#__PURE__*/_jsx(ActionSplitDropdown, { ...newProps }); } ContainerActionSplitDropdown.displayName = 'Container(ActionSplitDropdown)'; ContainerActionSplitDropdown.propTypes = { items: PropTypes.arrayOf(PropTypes.object) }; export default cmfConnect({ mapStateToProps, mergeProps, omitCMFProps: true, withComponentRegistry: true, withDispatch: true, withDispatchActionCreator: true, withComponentId: true })(ContainerActionSplitDropdown); //# sourceMappingURL=ActionSplitDropdown.connect.js.map