1 import {connect} from 'react-redux';
2 import React from 'react';
3 import i18n from 'nfvo-utils/i18n/i18n.js';
5 import SoftwareProductComponentsList from './SoftwareProductComponentsList.js';
6 import OnboardingActionHelper from 'sdc-app/onboarding/OnboardingActionHelper.js';
7 import VersionControllerUtils from 'nfvo-components/panel/versionController/VersionControllerUtils.js';
8 import SoftwareProductComponentsActionHelper from '../components/SoftwareProductComponentsActionHelper.js';
9 import {onboardingMethod} from '../SoftwareProductConstants.js';
10 import ConfirmationModalConstants from 'nfvo-components/modal/GlobalModalConstants.js';
12 const generateMessage = (name) => {
13 return i18n(`Are you sure you want to delete ${name}?`);
16 const mapStateToProps = ({softwareProduct}) => {
17 let {softwareProductEditor: {data: currentSoftwareProduct}, softwareProductComponents} = softwareProduct;
18 let {componentsList} = softwareProductComponents;
19 let isReadOnlyMode = VersionControllerUtils.isReadOnly(currentSoftwareProduct);
22 currentSoftwareProduct,
25 isManual: currentSoftwareProduct.onboardingMethod === onboardingMethod.MANUAL
30 class SoftwareProductComponentsView extends React.Component {
32 let {currentSoftwareProduct, isReadOnlyMode, componentsList, isManual, onDeleteComponent} = this.props;
34 <SoftwareProductComponentsList
35 isReadOnlyMode={isReadOnlyMode}
36 componentsList={componentsList}
37 onDeleteComponent={onDeleteComponent}
39 currentSoftwareProduct={currentSoftwareProduct}/>);
44 const mapActionToProps = (dispatch) => {
46 onComponentSelect: ({id: softwareProductId, componentId, version}) => {
47 OnboardingActionHelper.navigateToSoftwareProductComponentGeneralAndUpdateLeftPanel(dispatch, {softwareProductId, componentId, version });
49 onAddComponent: (softwareProductId) => SoftwareProductComponentsActionHelper.addComponent(dispatch, {softwareProductId}),
50 onDeleteComponent: (component, softwareProductId, version) => dispatch({
51 type: ConfirmationModalConstants.GLOBAL_MODAL_WARNING,
53 msg: generateMessage(component.displayName),
54 onConfirmed: ()=>SoftwareProductComponentsActionHelper.deleteComponent(dispatch,
57 componentId: component.id,
65 export default connect(mapStateToProps, mapActionToProps, null, {withRef: true})(SoftwareProductComponentsView);