summaryrefslogtreecommitdiffstats
path: root/catalog-ui/src/app/models/graph/nodes/composition-graph-nodes/composition-ci-node-vl.ts
blob: 2407593665b945e8d058106a1763ea7c00f62e7f (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
/*-
 * ============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
 * 
 * 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=========================================================
 */
import * as _ from "lodash";
import {ComponentInstance} from "../../../componentsInstances/componentInstance";
import {ImageCreatorService} from "app/ng2/pages/composition/graph/common/image-creator.service";
import {CompositionCiNodeBase} from "./composition-ci-node-base";
import { ImagesUrl, GraphUIObjects} from "../../../../utils/constants";

export class CompositionCiNodeVl extends CompositionCiNodeBase {
    private toolTipText:string;

    constructor(instance:ComponentInstance, imageCreator:ImageCreatorService) {
        super(instance, imageCreator);
        this.initVl();

    }

    private initVl():void {
        this.type = "basic-small-node";
        this.toolTipText = 'Point to point';
        if(this.componentInstance.capabilities) {
            let key:string = _.find(Object.keys(this.componentInstance.capabilities), (key)=> {
                return _.includes(key.toLowerCase(), 'linkable');
            });
            let linkable = this.componentInstance.capabilities[key];
            if (linkable) {
                if ('UNBOUNDED' == linkable[0].maxOccurrences) {
                    this.toolTipText = 'Multi point';
                }

            }
        }
        this.img = this.imagesPath + ImagesUrl.RESOURCE_ICONS + 'vl.png';
        this.imgWidth = GraphUIObjects.SMALL_RESOURCE_WIDTH;
        this.imagesPath = this.imagesPath + ImagesUrl.RESOURCE_ICONS;

        this.classes = 'vl-node';
        if(this.archived){
            this.classes = this.classes + ' archived';
            return;
        }
        if (!this.certified) {
            this.classes = this.classes + ' not-certified';
        }
    }
}