Add new code new version
[sdc.git] / openecomp-ui / src / sdc-app / onboarding / softwareProduct / components / SoftwareProductComponentEditorReducer.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 {actionTypes} from './SoftwareProductComponentsConstants.js';
22
23 export default (state = {}, action) => {
24         switch (action.type) {
25                 case actionTypes.COMPONENT_UPDATE:
26                         return {
27                                 ...state,
28                                 data: action.component
29                         };
30                 case actionTypes.COMPONENT_QUESTIONNAIRE_UPDATE:
31                         return {
32                                 ...state,
33                                 qdata: action.payload.qdata || state.qdata,
34                                 qschema: action.payload.qschema || state.qschema
35                         };
36                 case actionTypes.COMPONENT_DATA_CHANGED:
37                         return {
38                                 ...state,
39                                 data: {
40                                         ...state.data,
41                                         ...action.deltaData
42                                 }
43                         };
44                 default:
45                         return state;
46         }
47 };