OSDN Git Service

[Develop] WebSocket is connected.
[eos/zephyr.git] / front-end / app / scripts / directives / Command.ts
1 namespace app.directives {
2     export class Command implements ng.IDirective {
3
4         public restrict: string;
5         public replace: boolean;
6         public templateUrl: string;
7         public scope: boolean;
8         public controller: string;
9         public controllerAs: string;
10         public bindToController: Object;
11
12         /** 
13          * constructor
14          *
15          * @param
16          */
17         constructor() {
18             this.restrict = 'E';
19             this.replace = true; 
20             this.scope = true;
21             this.controller = 'commandController';
22             this.controllerAs = 'ctrl';
23             this.bindToController = {
24                 index: '=',
25                 name: '=',
26                 remove: '&',
27                 list: '='
28             };
29             this.templateUrl = 'templates/command.html';
30         }
31
32         /**
33          * instance生成
34          * @returns {function(): HeaderMenu}
35          * @constructor
36          */
37         public static Factory(): ng.IDirectiveFactory {
38             var directive = () => {
39                 return new Command();
40             };
41             directive.$inject = [];
42             return directive;
43         }
44     }
45
46     export class CommandController {
47
48         public static $inject = ['APIEndPoint', '$scope', 'MyModal', 'WebSocket'];
49
50         // From parent directive bindToController property
51         private index: string;
52         private name: string;
53         private remove: Function;
54         private list: declares.CommandInfo[];
55         private workspace: declares.IFileInfo;
56
57         // property of ui.bootstrap uib-accordion directive
58         private isOpen: boolean;
59         private heading: string;
60
61         // property about Option directive
62         private files: any;
63         private options: declares.IOption[];
64         private dirs: any;
65
66         constructor(private APIEndPoint: services.APIEndPoint, private $scope: ng.IScope, private MyModal: services.MyModal, private WebSocket: services.WebSocket) {
67             var controller = this;
68
69             // Get OptionControlFile and bind it to $scope.options
70             this.APIEndPoint
71             .getOptionControlFile('mrcImageNoiseAdd')
72             .$promise
73             .then(function(result) {
74                 controller.options = result.info;
75             });
76
77             this.APIEndPoint
78             .getDirectories()
79             .$promise
80             .then(function(result) {
81                 controller.dirs = result.info;
82             });
83
84             this.heading = "[" + this.index + "]: dcdFilePring";
85             this.isOpen = true;
86
87             // When call add button at executeController, all accordion close.
88             this.$scope.$on('close', () => {
89                 controller.isOpen = false;
90             });
91
92             this.WebSocket.on('test', function(data) {
93                 console.log("HOGEHOGEHOGEHOHGOEHGOH");
94             });
95         }
96
97         public submit() {
98             var opt = [];
99             angular.forEach(this.options, (option) => {
100
101                 var obj = {
102                     name: option.option,
103                     arguments: []
104                 };
105
106                 angular.forEach(option.arg, (arg) => {
107                     if(arg.input) {
108                         if(typeof arg.input === 'object') {
109                             obj.arguments.push(arg.input.name);
110                         } else {
111                             obj.arguments.push(arg.input);
112                         }
113                     }
114                 });
115
116                 if(obj.arguments.length > 0) {
117                     opt.push(obj);
118                 }
119             });
120
121             var execObj = {
122                 command: this.name,
123                 workspace: this.workspace.fileId,
124                 options: opt
125             };
126
127             //console.log(JSON.stringify(execObj,null,'\t'));
128             this.APIEndPoint
129             .execute(JSON.stringify(execObj))
130             .then((result) => {
131                 console.log(result);
132             })
133         }
134
135         public removeMySelf(index:number) {
136             this.remove()(index,this.list);
137         }
138
139         private reloadFiles() {
140             var fileId = this.workspace.fileId;
141             this.APIEndPoint
142             .getFiles(fileId)
143             .$promise
144             .then((result) => { 
145                 var status = result.status;
146                 if(status === 'success') {
147                     this.files = result.info;
148                 } else {
149                     console.log(result.message);
150                 }
151             });
152         }
153
154         public debug() {
155             this.MyModal.preview();
156         }
157
158         
159     } 
160 }