Add new code new version
[sdc.git] / openecomp-ui / src / sdc-app / onboarding / licenseModel / licenseAgreement / LicenseAgreementEditor.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 LicenseAgreementActionHelper from './LicenseAgreementActionHelper.js';
23 import LicenseAgreementEditorView from './LicenseAgreementEditorView.jsx';
24
25 export const mapStateToProps = ({licenseModel: {licenseAgreement, featureGroup}}) => {
26
27
28         let {data, selectedTab, selectedFeatureGroupsButtonTab} = licenseAgreement.licenseAgreementEditor;
29
30         let previousData;
31         const licenseAgreementId = data ? data.id : null;
32         if(licenseAgreementId) {
33                 previousData = licenseAgreement.licenseAgreementList.find(licenseAgreement => licenseAgreement.id === licenseAgreementId);
34         }
35
36         const {featureGroupsList = []} = featureGroup;
37
38         return {
39                 data,
40                 previousData,
41                 selectedTab,
42                 selectedFeatureGroupsButtonTab,
43                 featureGroupsList
44         };
45 };
46
47 export const mapActionsToProps = (dispatch, {licenseModelId}) => {
48         return {
49                 onDataChanged: deltaData => LicenseAgreementActionHelper.licenseAgreementEditorDataChanged(dispatch, {deltaData}),
50                 onTabSelect: tab => LicenseAgreementActionHelper.selectLicenseAgreementEditorTab(dispatch, {tab}),
51                 onFeatureGroupsButtonTabSelect: buttonTab => LicenseAgreementActionHelper.selectLicenseAgreementEditorFeatureGroupsButtonTab(dispatch, {buttonTab}),
52                 onCancel: () => LicenseAgreementActionHelper.closeLicenseAgreementEditor(dispatch),
53                 onSubmit: ({previousLicenseAgreement, licenseAgreement}) => {
54                         LicenseAgreementActionHelper.closeLicenseAgreementEditor(dispatch);
55                         LicenseAgreementActionHelper.saveLicenseAgreement(dispatch, {licenseModelId, previousLicenseAgreement, licenseAgreement});
56                 }
57         };
58 };
59
60 export default connect(mapStateToProps, mapActionsToProps)(LicenseAgreementEditorView);