X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=skyquake%2Fplugins%2Fcomposer%2Fsrc%2Fsrc%2Flibraries%2Fmodel%2FDescriptorModelMetaProperty.js;h=8fe51d9aca62838bf4a107cb06b0f65c6b4ba8bc;hb=2ff1ddba3d20163b110f27abfe7875d6edf2255c;hp=67f34e29bdc889e8d14d7f221d94f393a8da528b;hpb=8a726817e3e9acdaaa8e669bcea0e3eb56ba1372;p=osm%2FUI.git diff --git a/skyquake/plugins/composer/src/src/libraries/model/DescriptorModelMetaProperty.js b/skyquake/plugins/composer/src/src/libraries/model/DescriptorModelMetaProperty.js index 67f34e29b..8fe51d9ac 100644 --- a/skyquake/plugins/composer/src/src/libraries/model/DescriptorModelMetaProperty.js +++ b/skyquake/plugins/composer/src/src/libraries/model/DescriptorModelMetaProperty.js @@ -29,8 +29,12 @@ import changeCase from 'change-case' import InstanceCounter from './../InstanceCounter' import DescriptorModelFields from './DescriptorModelFields' import DescriptorTemplateFactory from './DescriptorTemplateFactory' +import utils from '../utils' export default { + isBoolean(property = {}) { + return (typeof(property['data-type']) == 'string') && (property['data-type'].toLowerCase() == 'boolean') + }, isLeaf(property = {}) { return /leaf|choice/.test(property.type); }, @@ -40,6 +44,10 @@ export default { isLeafList(property = {}) { return property.type === 'leaf_list'; }, + isLeafRef(property = {}) { + const type = property['data-type'] || {}; + return type.hasOwnProperty('leafref'); + }, isArray(property = {}) { // give '1' or '0..N' or '0..1' or '0..5' determine if represents an array // '0..1' is not an array @@ -61,7 +69,7 @@ export default { return !/^(leaf|leaf_list)$/.test(property.type); }, isSimpleList(property = {}) { - return _.contains(DescriptorModelFields.simpleList, property.name); + return _.includes(DescriptorModelFields.simpleList, property.name); }, isPrimativeDataType(property = {}) { const Property = this; @@ -107,6 +115,30 @@ export default { return {name: enumName, value: enumValue, isSelected: String(enumValue) === String(value)}; }); }, + getLeafRef(property = {}, path, value, fullFieldKey, transientCatalogs, container) { + const leafRefPath = property['data-type']['leafref']['path']; + + const transientCatalogHash = {}; + + transientCatalogs.map((catalog) => { + transientCatalogHash[catalog.type + '-catalog'] = {}; + transientCatalogHash[catalog.type + '-catalog'][catalog.type] = catalog['descriptors']; + }); + + let leafRefPathValues = utils.resolveLeafRefPath(transientCatalogHash, leafRefPath, fullFieldKey, path, container); + + let leafRefObjects = []; + + leafRefPathValues && leafRefPathValues.map((leafRefPathValue) => { + leafRefObjects.push({ + name: leafRefPathValue, + value: leafRefPathValue, + isSelected: String(leafRefPathValue) === String(value) + }); + }); + + return leafRefObjects; + }, isGuid(property = {}) { const type = property['data-type']; if (typeof type === 'object' && type.leafref && type.leafref.path) { @@ -123,7 +155,7 @@ export default { if (uiState.name === 'name') { return changeCase.param(parentMeta.name) + '-' + InstanceCounter.count(parentMeta[':qualified-type']); } - if (_.isArray(parentMeta.key) && _.contains(parentMeta.key, uiState.name)) { + if (_.isArray(parentMeta.key) && _.includes(parentMeta.key, uiState.name)) { if (/uuid/.test(uiState['data-type'])) { return guid(); }