Add new code new version
[sdc.git] / openecomp-ui / src / sdc-app / onboarding / licenseModel / featureGroups / FeatureGroupListEditor.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 FeatureGroupsActionHelper  from './FeatureGroupsActionHelper.js';
23 import FeatureGroupListEditorView from './FeatureGroupListEditorView.jsx';
24 import VersionControllerUtils from 'nfvo-components/panel/versionController/VersionControllerUtils.js';
25
26 const mapStateToProps = ({licenseModel: {featureGroup, licenseModelEditor}}) => {
27         const {featureGroupEditor: {data}, featureGroupsList} = featureGroup;
28         let {vendorName} = licenseModelEditor.data;
29         let isReadOnlyMode = VersionControllerUtils.isReadOnly(licenseModelEditor.data);
30
31         return {
32                 vendorName,
33                 featureGroupsModal: {
34                         show: Boolean(data),
35                         editMode: Boolean(data && data.id)
36                 },
37                 featureGroupsList,
38                 isReadOnlyMode
39         };
40 };
41
42
43 const mapActionsToProps = (dispatch, {licenseModelId}) => {
44         return {
45                 onDeleteFeatureGroupClick: (featureGroup) => FeatureGroupsActionHelper.openDeleteFeatureGroupConfirm(dispatch, {licenseModelId, featureGroup}),
46                 onCancelFeatureGroupsEditor: () => FeatureGroupsActionHelper.closeFeatureGroupsEditor(dispatch),
47
48                 onAddFeatureGroupClick: () => FeatureGroupsActionHelper.openFeatureGroupsEditor(dispatch, {licenseModelId}),
49                 onEditFeatureGroupClick: featureGroup => FeatureGroupsActionHelper.openFeatureGroupsEditor(dispatch, {
50                         featureGroup,
51                         licenseModelId
52                 })
53         };
54 };
55
56 export default connect(mapStateToProps, mapActionsToProps)(FeatureGroupListEditorView);