Add new code new version
[sdc.git] / openecomp-ui / src / sdc-app / onboarding / softwareProduct / components / general / SoftwareProductComponentsGeneral.js
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 import {connect} from 'react-redux';
22 import SoftwareProductComponentsGeneralView from './SoftwareProductComponentsGeneralView.jsx';
23 import SoftwareProductComponentsActionHelper from '../SoftwareProductComponentsActionHelper.js';
24 import VersionControllerUtils from 'nfvo-components/panel/versionController/VersionControllerUtils.js';
25
26 export const mapStateToProps = ({softwareProduct}) => {
27         let {softwareProductEditor: {data: currentVSP}, softwareProductComponents} = softwareProduct;
28         let {componentEditor: {data: componentData = {} , qdata, qschema}} = softwareProductComponents;
29
30         let isReadOnlyMode = VersionControllerUtils.isReadOnly(currentVSP);
31
32         return {
33                 componentData,
34                 qdata,
35                 qschema,
36                 isReadOnlyMode
37         };
38 };
39
40
41 const mapActionsToProps = (dispatch, {softwareProductId, componentId}) => {
42         return {
43                 onDataChanged: deltaData => SoftwareProductComponentsActionHelper.componentDataChanged(dispatch, {deltaData}),
44                 onQDataChanged: ({data}) => SoftwareProductComponentsActionHelper.componentQuestionnaireUpdated(dispatch, {data}),
45                 onSubmit: ({componentData, qdata}) => { return SoftwareProductComponentsActionHelper.updateSoftwareProductComponent(dispatch,
46                         {softwareProductId, vspComponentId: componentId, componentData, qdata});
47                 }
48         };
49
50 };
51
52 export default connect(mapStateToProps, mapActionsToProps, null, {withRef: true})(SoftwareProductComponentsGeneralView);