summaryrefslogtreecommitdiffstats
path: root/sdc-workflow-designer-ui/src/app/components/menus/rest-config/rest-config-detail/rest-config-detail.component.ts
blob: e4d43d8cb740b1c7f541dea1a5f3747ef6a15dd7 (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
/**
 * Copyright (c) 2017 ZTE Corporation.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and the Apache License 2.0 which both accompany this distribution,
 * and are available at http://www.eclipse.org/legal/epl-v10.html
 * and http://www.apache.org/licenses/LICENSE-2.0
 *
 * Contributors:
 *     ZTE - initial API and implementation and/or initial documentation
 */

import { Component, Input, OnChanges } from '@angular/core';
import { ModalDirective } from 'ngx-bootstrap/modal';

import { Swagger } from '../../../../model/swagger';
import { RestConfig } from '../../../../model/rest-config';
import { RestService } from '../../../../services/rest.service';

/**
 * toolbar component contains some basic operations(save) and all of the supported workflow nodes.
 * The supported nodes can be dragged to container component. which will add a new node to the workflow.
 */
@Component({
    selector: 'wfm-rest-config-detail',
    templateUrl: 'rest-config-detail.component.html',
})
export class RestConfigDetailComponent implements OnChanges {
    @Input() restConfig: RestConfig;

    public detail: string;

    constructor(private restService: RestService) {
    }

    public ngOnChanges() {
        if (this.restConfig == null) {
            this.restConfig = new RestConfig('', '', '', '');
        }
        this.parseSwagger2String();
    }

    private parseSwagger2String() {
        if (this.restConfig.swagger) {
            this.detail = JSON.stringify(this.restConfig.swagger);
        } else {
            this.detail = '';
        }
    }

    public onDetailChanged(detail: string) {
        this.detail = detail;

        let swagger: Swagger = null;
        try {
            swagger = new Swagger(JSON.parse(detail));
            console.log(swagger);
        } catch (e) {
            console.log('detail transfer error');
            console.error(e);
        }
        this.restConfig.swagger = swagger;
    }

    public toggleDynamic(dynamic: boolean) {
        // this.restConfig.dynamic = dynamic;

        // if (this.restConfig.dynamic && this.restConfig.definition) {
        //     this.restService.getDynamicSwaggerInfo(this.restConfig.definition)
        //         .subscribe(response => {
        //             try {
        //                 this.restConfig.swagger = new Swagger(response);
        //                 this.parseSwagger2String();
        //             } catch (e) {
        //                 console.log('detail transfer error');
        //                 console.error(e);
        //             }

        //         });
        // }
    }

}