[SDC-29] Amdocs OnBoard 1707 initial commit.
[sdc.git] / openecomp-ui / src / sdc-app / flows / FlowsEditorModal.js
index eff1c36..f9585f9 100644 (file)
@@ -1,42 +1,43 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
+/*!
  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
+ *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
  * You may obtain a copy of the License at
- * 
- *      http://www.apache.org/licenses/LICENSE-2.0
- * 
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
  * Unless required by applicable law or agreed to in writing, software
  * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
+ * or implied. See the License for the specific language governing
+ * permissions and limitations under the License.
  */
-
 import {connect} from 'react-redux';
 import FlowsEditorModalView from './FlowsEditorModalView.jsx';
 import FlowsActions from './FlowsActions.js';
+import {FLOWS_EDITOR_FORM} from './FlowsConstants.js';
+import ValidationHelper from 'sdc-app/common/helpers/ValidationHelper.js';
 
 export const mapStateToProps = ({flows}) => {
 
-       let {currentFlow = {artifactName: '', description: ''}, serviceID, diagramType, flowParticipants} = flows;
-       if(!currentFlow.serviceID){
-               currentFlow.serviceID = serviceID;
+       let {data = {artifactName: '', description: ''}, serviceID, diagramType, flowParticipants, genericFieldInfo, formReady} = flows;
+       if(!data.serviceID){
+               data.serviceID = serviceID;
        }
-       if(!currentFlow.artifactType){
-               currentFlow.artifactType = diagramType;
+       if(!data.artifactType){
+               data.artifactType = diagramType;
        }
-       if(!currentFlow.participants){
-               currentFlow.participants = flowParticipants;
+       if(!data.participants){
+               data.participants = flowParticipants;
        }
+       let isFormValid = ValidationHelper.checkFormValid(genericFieldInfo);
 
        return {
-               currentFlow
+               currentFlow: data,
+               genericFieldInfo,
+               isFormValid,
+               formReady
        };
 };
 
@@ -47,7 +48,8 @@ const mapActionsToProps = (dispatch, {isNewArtifact}) => {
                        FlowsActions.createOrUpdateFlow(dispatch, {flow}, isNewArtifact);
                },
                onCancel: () => FlowsActions.closeFlowDetailsEditor(dispatch),
-               onDataChanged: deltaData => FlowsActions.flowDetailsDataChanged(dispatch, {deltaData})
+               onDataChanged: deltaData => ValidationHelper.dataChanged(dispatch, {deltaData, formName: FLOWS_EDITOR_FORM}),
+               onValidateForm: () => ValidationHelper.validateForm(dispatch, FLOWS_EDITOR_FORM)
        };
 };