Add collaboration feature
[sdc.git] / openecomp-ui / src / sdc-app / onboarding / onboard / DetailsCatalogView.jsx
1 /*!
2  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
13  * or implied. See the License for the specific language governing
14  * permissions and limitations under the License.
15  */
16 import React from 'react';
17 import PropTypes from 'prop-types';
18 import {catalogItemTypes} from './onboardingCatalog/OnboardingCatalogConstants.js';
19 import {filterCatalogItemsByType} from './onboardingCatalog/OnboardingCatalogUtils.js';
20 import CatalogList from './CatalogList.jsx';
21 import CatalogItemDetails from './CatalogItemDetails.jsx';
22
23 class DetailsCatalogView extends React.Component{
24
25         static propTypes = {
26                 VLMList: PropTypes.array,
27                 VSPList: PropTypes.array,
28                 onSelectVLM: PropTypes.func.isRequired,
29                 onSelectVSP: PropTypes.func.isRequired,
30                 onAddVLM: PropTypes.func.isRequired,
31                 onAddVSP: PropTypes.func.isRequired,
32                 filter: PropTypes.string.isRequired
33         };
34
35         renderCatalogItems({items, type, filter, onSelect, onMigrate, users}){
36                 return filterCatalogItemsByType({items, filter}).map(item =>
37                         <CatalogItemDetails
38                                 key={item.id}
39                                 catalogItemData={item}
40                                 catalogItemTypeClass={type}
41                                 onMigrate={onMigrate}
42                                 onSelect={() => onSelect(item, users)} />
43                 );
44         }
45
46         render() {
47                 let {VLMList, VSPList, users, onAddVSP, onAddVLM, onSelectVLM, onSelectVSP, filter = '', onMigrate} = this.props;
48                 return (
49                         <CatalogList onAddVLM={onAddVLM} onAddVSP={onAddVSP}>
50                                 {this.renderCatalogItems({items: VLMList, type: catalogItemTypes.LICENSE_MODEL, filter, onSelect: onSelectVLM, onMigrate, users})}
51                                 {this.renderCatalogItems({items: VSPList, type: catalogItemTypes.SOFTWARE_PRODUCT, filter, onSelect: onSelectVSP, onMigrate, users})}
52                         </CatalogList>
53                 );
54         }
55 }
56 export default DetailsCatalogView;