/*!
* Copyright © 2016-2018 European Support Limited
* Modifications Copyright (C) 2021 Nordix Foundation.
*
* 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, { string } from 'prop-types';
import i18n from 'nfvo-utils/i18n/i18n.js';
import Validator from 'nfvo-utils/Validator.js';
import Input from 'nfvo-components/input/validation/Input.jsx';
import Form from 'nfvo-components/input/validation/Form.jsx';
import GridSection from 'nfvo-components/grid/GridSection.jsx';
import GridItem from 'nfvo-components/grid/GridItem.jsx';
import { SP_CREATION_FORM_NAME } from './SoftwareProductCreationConstants.js';
import sortByStringProperty from 'nfvo-utils/sortByStringProperty.js';
import SoftwareProductCategoriesHelper from 'sdc-app/onboarding/softwareProduct/SoftwareProductCategoriesHelper.js';
import {
ModelOption,
onboardingMethod as onboardingMethodConst
} from '../SoftwareProductConstants.js';
import SelectInput from 'nfvo-components/input/SelectInput.jsx';
const SoftwareProductPropType = PropTypes.shape({
id: PropTypes.string,
name: PropTypes.string,
description: PropTypes.string,
category: PropTypes.string,
subCategory: PropTypes.string,
vendorId: PropTypes.string,
selectedModelList: PropTypes.arrayOf(string)
});
class SoftwareProductCreationView extends React.Component {
static propTypes = {
data: SoftwareProductPropType,
finalizedLicenseModelList: PropTypes.array,
softwareProductCategories: PropTypes.array,
VSPNames: PropTypes.object,
usersList: PropTypes.array,
modelList: PropTypes.array,
onDataChanged: PropTypes.func.isRequired,
onSubmit: PropTypes.func.isRequired,
onCancel: PropTypes.func.isRequired
};
render() {
let {
softwareProductCategories,
data = {},
onDataChanged,
onCancel,
genericFieldInfo,
disableVendor,
modelList
} = this.props;
let {
name,
description,
vendorId,
subCategory,
onboardingMethod,
modelOption,
selectedModelList
} = data;
const vendorList = this.getVendorList();
return (
{genericFieldInfo && (
)}
);
}
getVendorList() {
let { vendorList } = this.props;
return [{ enum: '', title: i18n('please select...') }].concat(
sortByStringProperty(vendorList, 'name').map(vendor => {
return {
enum: vendor.id,
title: vendor.name
};
})
);
}
onSelectVendor(e) {
const selectedIndex = e.target.selectedIndex;
const vendorId = e.target.options[selectedIndex].value;
this.props.onDataChanged({ vendorId }, SP_CREATION_FORM_NAME);
}
onSelectSubCategory(e) {
const selectedIndex = e.target.selectedIndex;
const subCategory = e.target.options[selectedIndex].value;
let { softwareProductCategories, onDataChanged } = this.props;
let category = SoftwareProductCategoriesHelper.getCurrentCategoryOfSubCategory(
subCategory,
softwareProductCategories
);
onDataChanged({ category, subCategory }, SP_CREATION_FORM_NAME);
}
submit() {
let { finalizedLicenseModelList, usersList } = this.props;
const softwareProduct = { ...this.props.data };
softwareProduct.vendorName = finalizedLicenseModelList.find(
vendor => vendor.id === softwareProduct.vendorId
).name;
delete softwareProduct.modelOption;
this.props.onSubmit(softwareProduct, usersList);
}
validateName(value) {
const { data: { id }, VSPNames } = this.props;
const isExists = Validator.isItemNameAlreadyExistsInList({
itemId: id,
itemName: value,
list: VSPNames
});
return !isExists
? { isValid: true, errorText: '' }
: {
isValid: false,
errorText: i18n(
"Software product by the name '" +
value +
"' already exists. Software product name must be unique"
)
};
}
validateIsNameUnique = e => {
const value = e.target.value;
if (value) {
this.props.isNameUnique(value, 'name', SP_CREATION_FORM_NAME);
}
};
validate() {
this.props.onValidateForm(SP_CREATION_FORM_NAME);
}
}
const OnboardingProcedure = ({
onboardingMethod,
onDataChanged,
genericFieldInfo
}) => {
return (
onDataChanged(
{
onboardingMethod:
onboardingMethodConst.NETWORK_PACKAGE
},
SP_CREATION_FORM_NAME
)
}
type="radio"
data-test-id="new-vsp-creation-procedure-heat"
/>
onDataChanged(
{ onboardingMethod: onboardingMethodConst.MANUAL },
SP_CREATION_FORM_NAME
)
}
type="radio"
data-test-id="new-vsp-creation-procedure-manual"
groupClassName="no-bottom-margin"
/>
);
};
const ModelSelection = ({
modelOption,
onDataChanged,
genericFieldInfo,
modelList = [],
selectedModelList = []
}) => {
function onSelectChanged(selectedValueList) {
let modelList1 = [];
if (selectedValueList) {
modelList1 = selectedValueList.map(item => item.value);
}
onDataChanged({ selectedModelList: modelList1 }, SP_CREATION_FORM_NAME);
}
function selectDefaultModel() {
return () => {
onDataChanged(
{ modelOption: ModelOption.DEFAULT },
SP_CREATION_FORM_NAME
);
onDataChanged({ selectedModelList: [] }, SP_CREATION_FORM_NAME);
};
}
return (
onDataChanged(
{ modelOption: ModelOption.SELECTED },
SP_CREATION_FORM_NAME
)
}
type="radio"
data-test-id="model-option-other"
groupClassName="no-bottom-margin"
/>
{modelOption === ModelOption.SELECTED &&
}
{modelOption === ModelOption.SELECTED && (
({
label: model.name,
value: model.name
}))}
onMultiSelectChanged={onSelectChanged}
value={selectedModelList}
clearable={true}
data-test-id="model-option-select"
placeholder={i18n('vsp.model.select.label')}
multi
/>
)}
{modelOption === ModelOption.SELECTED &&
}
);
};
export default SoftwareProductCreationView;