summaryrefslogtreecommitdiffstats
path: root/openecomp-ui/src/sdc-app/onboarding/softwareProduct/components/images/SoftwareProductComponentsImageEditorView.jsx
blob: 3670ab910d133cf3deedd199f79b7d6a4cbcf4c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*!
 * 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
 *
 * 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.
 */
import React from 'react';
import PropTypes from 'prop-types';

import i18n from 'nfvo-utils/i18n/i18n.js';
import Form from 'nfvo-components/input/validation/Form.jsx';

import FileDetails from './imagesEditorComponents/FileDetails.jsx';
import ImageDetails from './imagesEditorComponents/ImageDetails.jsx';
import { imageCustomValidations } from './ImageValidations.js';

class SoftwareProductComponentsImageEditorView extends React.Component {
    static propTypes = {
        onDataChanged: PropTypes.func.isRequired,
        onSubmit: PropTypes.func.isRequired,
        onCancel: PropTypes.func.isRequired
    };

    render() {
        let {
            onCancel,
            onValidateForm,
            isReadOnlyMode,
            isFormValid,
            formReady,
            data = {},
            genericFieldInfo,
            qgenericFieldInfo,
            dataMap,
            onDataChanged,
            isManual,
            onQDataChanged
        } = this.props;
        let { id, fileName } = data;
        let editingMode = Boolean(id);
        return (
            <div>
                {genericFieldInfo && (
                    <Form
                        ref={form => {
                            this.form = form;
                        }}
                        hasButtons={true}
                        onSubmit={() => this.submit()}
                        onReset={() => onCancel()}
                        labledButtons={true}
                        isReadOnlyMode={isReadOnlyMode}
                        isValid={isFormValid}
                        formReady={formReady}
                        submitButtonText={
                            editingMode ? i18n('Save') : i18n('Create')
                        }
                        onValidateForm={() =>
                            onValidateForm(imageCustomValidations)
                        }
                        className="vsp-components-image-editor">
                        <div className="editor-data">
                            <FileDetails
                                editingMode={editingMode}
                                genericFieldInfo={genericFieldInfo}
                                qgenericFieldInfo={qgenericFieldInfo}
                                fileName={fileName}
                                onDataChanged={onDataChanged}
                                isManual={isManual}
                                dataMap={dataMap}
                                onQDataChanged={onQDataChanged}
                            />
                            {editingMode && (
                                <ImageDetails
                                    dataMap={dataMap}
                                    qgenericFieldInfo={qgenericFieldInfo}
                                    onQDataChanged={onQDataChanged}
                                />
                            )}
                        </div>
                    </Form>
                )}
            </div>
        );
    }
    submit() {
        let { data, qdata, onSubmit, version } = this.props;
        onSubmit({ data, qdata, version });
    }
}

export default SoftwareProductComponentsImageEditorView;