aboutsummaryrefslogtreecommitdiffstats
path: root/cds-ui/designer-client/src/app/modules/feature-modules/resource-dictionary/resource-dictionary-creation/dictionary-metadata/dictionary-metadata.component.ts
blob: 01df118d2919746ce5c416db77acf240dffb6eac (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
/*
* ============LICENSE_START=======================================================
* ONAP : CDS
* ================================================================================
* Copyright (C) 2020 TechMahindra
*=================================================================================
* 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 { Component, OnInit } from '@angular/core';
import { ActivatedRoute } from '@angular/router';
import { DictionaryModel } from '../../model/dictionary.model';
import { DictionaryCreationService } from '../dictionary-creation.service';
import { DictionaryCreationStore } from '../dictionary-creation.store';
import { MetaData } from '../../model/metaData.model';

@Component({
    selector: 'app-dictionary-metadata',
    templateUrl: './dictionary-metadata.component.html',
    styleUrls: ['./dictionary-metadata.component.css']
})
export class DictionaryMetadataComponent implements OnInit {
    packageNameAndVersionEnables = true;
    counter = 0;
    tags = new Set<string>();
    metaDataTab: MetaData = new MetaData();
    errorMessage: string;

    constructor(
        private dictionaryCreationStore: DictionaryCreationStore
    ) { }

    ngOnInit() {
        this.dictionaryCreationStore.state$.subscribe(element => {
            console.log(this.metaDataTab);
            if (element && element.metaData) {
                this.metaDataTab = element.metaData;
                this.metaDataTab.property.entry_schema = element.metaData.property.entry_schema;
                this.tags = new Set(element.metaData.tags.split(','));
                this.tags.delete('');
                this.tags.delete(' ');

                //  console.log(element);
                // console.log(element.metaData.property['entry_schema']);
            }
        });

    }

    // getSources() {
    //     this.dictionaryCreationService.getSources().subscribe(res => {
    //         console.log(res);
    //     });
    // }

    removeTag(value) {
        this.tags.delete(value);
        this.mergeTags();
    }


    addTag(event) {
        const value = event.target.value;
        console.log(value);
        if (value && value.trim().length > 0) {
            event.target.value = '';
            this.tags.add(value);
            // merge
            this.mergeTags();
        }
    }

    mergeTags() {
        let tag = '';
        this.tags.forEach((val, index) => {
            tag += val + ', ';
        });
        this.metaDataTab.tags = tag.trim();
        this.saveMetaDataToStore();
    }

    saveMetaDataToStore() {
        console.log(this.metaDataTab);
        this.dictionaryCreationStore.changeMetaData(this.metaDataTab);
    }
}