Blame view

js/app/views/StatisticsUI.js 11.8 KB
d18b535d   elena   catalog draft + c...
1
2
3
4
5
6
7
8
9
/**
 * Project       AMDA-NG
 * Name          StatisticsUI.js
 * @class 	 amdaUI.statisticsUI
 * @extends      Ext.container.Container
 * @brief	 Statistics Module UI definition (View)
 * @author 	 elena
 */

23769849   Elena.Budnik   LoadObject in Sta...
10
11
Ext.define('amdaUI.StatisticsUI', 
{
d18b535d   elena   catalog draft + c...
12
13
14
15
	extend: 'Ext.container.Container',
	alias: 'widget.panelStatistics',
	
	requires : [	
23769849   Elena.Budnik   LoadObject in Sta...
16
			//'amdaModel.Function'
d80af896   Elena.Budnik   args for Statistics
17
18
19
			'amdaUI.TimeSelectorUI',
			'amdaUI.ParamArgumentsPlug',
			'amdaModel.DownloadParam'
d18b535d   elena   catalog draft + c...
20
21
	],
	
23769849   Elena.Budnik   LoadObject in Sta...
22
23
	statics : 
	{	 
d80af896   Elena.Budnik   args for Statistics
24
	//	  functionStore : null
d18b535d   elena   catalog draft + c...
25
26
	},
		
3ab0bee9   Elena.Budnik   aprams with args ...
27
28
	constructor: function(config) 
	{
d80af896   Elena.Budnik   args for Statistics
29
		this.init(config); 
d18b535d   elena   catalog draft + c...
30
		this.callParent(arguments);
23769849   Elena.Budnik   LoadObject in Sta...
31
32
		this.loadObject();
				 
d80af896   Elena.Budnik   args for Statistics
33
34
35
		var paramArgsPlug = this.getPlugin('statistics-param-arguments-plugin');
		if (paramArgsPlug)
			paramArgsPlug.onApply = this.onApplyParameterArgs;
d18b535d   elena   catalog draft + c...
36
	},
23769849   Elena.Budnik   LoadObject in Sta...
37
38
39
40
41
42
43
44
45
46
	
	loadObject : function()
	{
		// load object into form	
		var basicForm = this.formPanel.items.items[0].getForm();
		
		basicForm.loadRecord(this.object);
		
	},
	
3ab0bee9   Elena.Budnik   aprams with args ...
47
48
	onApplyParameterArgs : function(parentUI, paramObject) 
	{
d80af896   Elena.Budnik   args for Statistics
49
50
		parentUI.paramGrid.getView().refresh();
	}, 
d18b535d   elena   catalog draft + c...
51
	
d80af896   Elena.Budnik   args for Statistics
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
	addParam : function(paramId, isLeaf, needArgs, components) 
	{
		// adding the parameter to the  paramGrid	
		var paramObj = {
			paramid: paramId,
			type: 0,
			'dim1-is-range': false,
			'dim1-min-range': 0.,
			'dim1-max-range': 0.,
			'dim1-index': '*',
			'dim2-is-range': false,
			'dim2-min-range': 0.,
			'dim2-max-range': 0.,
			'dim2-index': '*',
			template_args: {}
		};
        	
96cdc664   Elena.Budnik   new record type i...
69
70
		if (components) {
			if (components['index1']) {
3ab0bee9   Elena.Budnik   aprams with args ...
71
				paramObj['dim1-index'] = components['index1'];
96cdc664   Elena.Budnik   new record type i...
72
73
74
75
				++paramObj['type'];
			}
			
			if (components['index2']) {
3ab0bee9   Elena.Budnik   aprams with args ...
76
				paramObj['dim2-index'] = components['index2'];
96cdc664   Elena.Budnik   new record type i...
77
78
79
				++paramObj['type'];
			}
		}
d80af896   Elena.Budnik   args for Statistics
80
        	
96cdc664   Elena.Budnik   new record type i...
81
		var r = Ext.create('amdaModel.DownloadParam', paramObj);		
d80af896   Elena.Budnik   args for Statistics
82
		this.paramGrid.getStore().add(r);
23769849   Elena.Budnik   LoadObject in Sta...
83
		this.paramGrid.getSelectionModel().select(this.paramGrid.getStore().getCount()-1);  
d80af896   Elena.Budnik   args for Statistics
84
85
86
87
88
89
90
91
	//	var pos = this.paramGrid.store.getCount();
	//	this.paramGrid.store.insert(pos,r); 
		this.paramGrid.getView().refresh();
		
		if (needArgs)
			this.editParameterArgs(r);
	},

23769849   Elena.Budnik   LoadObject in Sta...
92
93
	editParameterArgs: function(record) 
	{
d80af896   Elena.Budnik   args for Statistics
94
95
96
97
98
		var paramArgsPlug = this.getPlugin('statistics-param-arguments-plugin');
		
		if (paramArgsPlug)
			paramArgsPlug.show('statistics-param-arguments-plugin', record);
	},
d18b535d   elena   catalog draft + c...
99
100
101
	
	addTT : function(TTname,TTid)
	{ 
23769849   Elena.Budnik   LoadObject in Sta...
102
		this.timeSelector.addTT(TTname, TTid); ; 	 
d18b535d   elena   catalog draft + c...
103
104
	},
	 
23769849   Elena.Budnik   LoadObject in Sta...
105
106
107
108
109
	generateCatalog : function()
	{	     
		var module = myDesktopApp.getLoadedModule(myDesktopApp.dynamicModules.statistics.id);
		if (module) 
			module.linkedNode.execute();	     
d18b535d   elena   catalog draft + c...
110
111
	},
	
23769849   Elena.Budnik   LoadObject in Sta...
112
113
114
115
116
/*
* Update this.object from form
*/	
	updateObject : function()
	{    
96cdc664   Elena.Budnik   new record type i...
117
		// get the basic form of the left 
d80af896   Elena.Budnik   args for Statistics
118
119
120
121
		var basicForm = this.formPanel.items.items[0].getForm();
		var updateStatus = true;
		
		var formValues = basicForm.getValues();
23769849   Elena.Budnik   LoadObject in Sta...
122
123
		//this.object.set('name',formValues.name);
		this.object.set('description',formValues.description);
94a05aa2   Elena.Budnik   update object in ...
124
     	    	    
d80af896   Elena.Budnik   args for Statistics
125
126
127
		var recs = this.paramGrid.getStore().getNewRecords();
		var paramArr = new Array();
		
96cdc664   Elena.Budnik   new record type i...
128
		Ext.Array.each(recs, function(rec, index, allItems)
3ab0bee9   Elena.Budnik   aprams with args ...
129
130
131
		{			 			
			var obj = Ext.clone(rec.data);
			 
d80af896   Elena.Budnik   args for Statistics
132
133
134
135
136
137
138
139
			if (obj.function == null) 
			{				
				myDesktopApp.warningMsg('Please select function : `click to select`'); 
				updateStatus = false;
				return;                     
			}
			paramArr.push(obj);            	      
		});
94a05aa2   Elena.Budnik   update object in ...
140
	    
d80af896   Elena.Budnik   args for Statistics
141
		this.object.set('parameter', paramArr);
d18b535d   elena   catalog draft + c...
142
	    
d80af896   Elena.Budnik   args for Statistics
143
		var timeSource = this.timeSelector.getActiveTimeSource(); 
94a05aa2   Elena.Budnik   update object in ...
144
 
d80af896   Elena.Budnik   args for Statistics
145
146
147
148
149
150
151
		if (timeSource === amdaModel.AmdaTimeObject.inputTimeSrc[0] // timeSource  'TimeTable'
							&& this.timeSelector.TTGrid.getStore().count() == 0) 
		{
			myDesktopApp.warningMsg('You\'ve chosen Time Selection `by TimeTable` but no timeTable was added!'
						+'<br>You must add one or choose Time Selection `by Interval`'); 
			return false;    
		}
d18b535d   elena   catalog draft + c...
152
             
d80af896   Elena.Budnik   args for Statistics
153
		basicForm.updateRecord(this.object);
94a05aa2   Elena.Budnik   update object in ...
154
	    
d80af896   Elena.Budnik   args for Statistics
155
156
157
158
		this.object.set('timesrc', timeSource);
		// set valid intervals into TimeTable object
		if (timeSource === amdaModel.AmdaTimeObject.inputTimeSrc[0])
			this.object.set('timeTables',this.timeSelector.TTGrid.getStore().data.items);          
96cdc664   Elena.Budnik   new record type i...
159
	 	      
d80af896   Elena.Budnik   args for Statistics
160
		return updateStatus;	    
d18b535d   elena   catalog draft + c...
161
162
163
164
165
166
	},
	
	/**
	 * Check if changes were made before closing window 
	 * @return true if changes
	 */	
23769849   Elena.Budnik   LoadObject in Sta...
167
168
	fclose : function() 
	{
d18b535d   elena   catalog draft + c...
169
170
171
172
173
174
175
176
177
178
		if (this.status == null)
			return false;
		
		var isDirty = this.formPanel.getForm().isDirty() || (this.status.isModified) || (this.status.nbModified > 0) || (this.status.nbNew > 0);
		return isDirty;
	},
	
	/**
	 * View configuration
	 */
23769849   Elena.Budnik   LoadObject in Sta...
179
180
	init : function (config) 
	{	  
d18b535d   elena   catalog draft + c...
181
182
183
184
185
186
187
188
189
// 	  var functions = Ext.create('Ext.data.Store', {
// 	    fields: ['id', 'name'],
// 	    data : [
// 		{"id":"min", "name":"MIN"},
// 		{"id":"max", "name":"MAX"},
// 		{"id":"mean","name":"MEAN"}        
// 	    ]
// 	    });
	     
d80af896   Elena.Budnik   args for Statistics
190
191
192
193
194
195
196
197
198
199
200
201
202
203
		this.fieldName = new Ext.form.field.Text({
				fieldLabel: 'Catalog Name',
				allowBlank : false,
				stripCharsRe: /(^\s+|\s+$)/g,
				emptyText: 'Please no spaces!',
				name: 'name',
	//	      anchor: '100%',
				validateOnChange: false,
				validateOnBlur: false,
				validFlag: false,
				validator : function() {
					return this.validFlag;
			}
		});
d18b535d   elena   catalog draft + c...
204
	  
d80af896   Elena.Budnik   args for Statistics
205
206
207
208
209
210
		var ttStore = Ext.create('Ext.data.Store', 
		{
			fields: [ 'name', 'hidden_id']	
		});
		
		this.timeSelector = new amdaUI.TimeSelectorUI({id: 'statisticsTimeSelector', height : 160}); 
d18b535d   elena   catalog draft + c...
211
	
d80af896   Elena.Budnik   args for Statistics
212
213
214
215
		var store = Ext.create('Ext.data.Store', 
			{
					fields: ['name', 'function'] 
			});
d18b535d   elena   catalog draft + c...
216
	
23769849   Elena.Budnik   LoadObject in Sta...
217
		this.paramGrid = Ext.create('Ext.grid.Panel', 
d80af896   Elena.Budnik   args for Statistics
218
			{ 
23769849   Elena.Budnik   LoadObject in Sta...
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
				title: 'Select Parameter & Apply Function',
				selType : 'rowmodel',
	//	      flex: 2,
				height :250,
				store : store, 
				columns: [
					{ xtype: 'rownumberer' },
					{ 
						header: "Parameter Name", 
						dataIndex: 'name', 
						flex:1, 
						sortable: false, 
						menuDisabled : true ,
						renderer: function (val, meta, rec) {
							return rec.getParamFullName();
						}
					},
					//	{ header: 'parameter',  dataIndex: 'name', menuDisabled : true, sortable : false },
					{ header: 'function',  dataIndex: 'function', menuDisabled : true, sortable : false,
						editor: 
						{
							xtype: 'combo', queryMode : 'local',		    
							//emptyText : 'please click to select function',
							store: [ 'min', 'max', 'mean' ],
							triggerAction: 'all',  		         
							//lazyInit: false,
							listeners: {
								focus: function(obj) {
									obj.expand();
								}
							}
						},
						renderer: function(v)
						{
							if(v != null && v.length > 0 )
									return v;
							else
									return 'click to select';                    
						} 	  
					},
					{ menuDisabled : true, width: 30, renderer: function(){
							return '<div class="icon-remover" style="width: 15px; height: 15px;"></div>';
d80af896   Elena.Budnik   args for Statistics
261
262
						}
					}
23769849   Elena.Budnik   LoadObject in Sta...
263
264
265
				], 
				plugins: [ Ext.create('Ext.grid.plugin.CellEditing', { clicksToEdit: 1 })],
				listeners :
d80af896   Elena.Budnik   args for Statistics
266
				{
23769849   Elena.Budnik   LoadObject in Sta...
267
					render : function(o,op)
3ab0bee9   Elena.Budnik   aprams with args ...
268
					{
23769849   Elena.Budnik   LoadObject in Sta...
269
270
271
272
273
274
275
276
277
						var me = this;
						var el = me.body.dom;
						var dropTarget = Ext.create('Ext.dd.DropTarget', el, {
							ddGroup: 'explorerTree',		    
							notifyOver  : function(ddSource, e, data)
							{                                    
								if (data.records[0].data.nodeType == 'localParam' && data.records[0].get('notyet')) {
										this.valid = false;
										return this.dropNotAllowed;   
3ab0bee9   Elena.Budnik   aprams with args ...
278
								}	
23769849   Elena.Budnik   LoadObject in Sta...
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
								if (((data.records[0].data.nodeType == 'localParam')   ||
											(data.records[0].data.nodeType == 'remoteParam') || 
											(data.records[0].data.nodeType == 'remoteSimuParam') ||
											(data.records[0].data.nodeType == 'derivedParam') || 
											(data.records[0].data.nodeType == 'myDataParam') ||
											(data.records[0].data.nodeType == 'alias'))&&
											(data.records[0].isLeaf() || data.records[0].data.isParameter) &&
											!data.records[0].data.disable)
								{
										this.valid = true;
										return this.dropAllowed;
								}
					
								this.valid = false;
								return this.dropNotAllowed;
							},
							notifyDrop  : function(ddSource, e, data)
							{
								if (!this.valid)
								return false;
								var nameToSent;
								var components = null;
						
								switch (data.records[0].data.nodeType)
								{
									case 'localParam' :
									case 'remoteParam':
									case 'remoteSimuParam':                                           
										nameToSent = data.records[0].get('id');
										if (data.records[0].get('alias')!= "" )
											var nameToSent = "#"+data.records[0].get('alias');
										var component_info = data.records[0].get('component_info');
										if (component_info && component_info.parentId) 
										{													
											if ( component_info.index1 && component_info.index2 )
											{															 
												nameToSent = component_info.parentId;
												components = [];												
												if (component_info.index1)
													components['index1'] = component_info.index1;
												if (component_info.index2)
													components['index2'] = component_info.index2;
											}	
											if ( data.records[0].get('needsArgs') )
											{															
												nameToSent = component_info.parentId;	
												if (component_info.index1)
												{
													components = [];	
													components['index1'] = component_info.index1;
												}
											}													
										}
										break;
									case 'alias' :
										nameToSent = "#"+data.records[0].get('text');
										break;
									case 'derivedParam' :
										nameToSent = "ws_"+data.records[0].get('text');
										break;
									case 'myDataParam' :
										nameToSent = "wsd_"+data.records[0].get('text');
										break;
									default :
										return false;
								}
								var module = myDesktopApp.getLoadedModule(myDesktopApp.dynamicModules.statistics.id);
								if (module)
								{			     
									module.addParam(nameToSent, data.records[0].get('leaf'), data.records[0].get('needsArgs'), components);   			    				     
								}
								return true;
3ab0bee9   Elena.Budnik   aprams with args ...
351
							}
23769849   Elena.Budnik   LoadObject in Sta...
352
353
354
355
356
						});
					},	
					cellclick : function(grid, cell, cellIndex, record){		     
							if (cellIndex == 3) 
							grid.getStore().remove(record);
3ab0bee9   Elena.Budnik   aprams with args ...
357
					}
23769849   Elena.Budnik   LoadObject in Sta...
358
359
				}    
			}); 
d18b535d   elena   catalog draft + c...
360
361
      	
 
23769849   Elena.Budnik   LoadObject in Sta...
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
		this.formPanel =  Ext.create('Ext.form.Panel', 
		{ 
			region: 'center',	     
			layout:  'hbox',
			//bodyStyle: {background : '#dfe8f6'},
			defaults: { bodyStyle: {background : '#dfe8f6'}, padding : '3'},
			fieldDefaults: { labelWidth: 80, labelAlign : 'top' },
			items: [ 	  		    
			{  
				xtype: 'form',
				flex : 1,			    
				layout: {type: 'vbox', pack: 'start', align: 'stretch'},
				items : [
					this.paramGrid,
					this.timeSelector
				]
d18b535d   elena   catalog draft + c...
378
			},
23769849   Elena.Budnik   LoadObject in Sta...
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
			{            
				xtype: 'form', 
				title: 'Additional Information', 
				flex : 1,
				layout: {type: 'vbox', pack: 'start', align: 'stretch', padding : '3'},
				items : [
					this.fieldName,
					{
						xtype: 'textarea',
						name: 'description',
						fieldLabel: 'Description', 			
						height: 200
					}   
				],
				fbar:[
					{   
						type: 'button',			   
						text: 'Generate Catalog',
						scope : this,
						handler: function()
						{
							// update object with user's values
							// if the return is true (object had been updated)
							if(this.updateObject()){ 
								this.updateObject();
								this.generateCatalog();			   			 
							}
						}
					},
					{   
						type: 'button',
						text: 'Reset',
						scope : this,
						handler: function() {}
					}]
			}]  
		}); 
d18b535d   elena   catalog draft + c...
416
	 
23769849   Elena.Budnik   LoadObject in Sta...
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
		var myConf = {
					layout: 'border',
					items: [		   
					this.formPanel, 		     
					{
						xtype: 'panel', 
						region: 'south',
						title: 'Information',
						collapsible: true,
						height: 100,
						autoHide: false,
						bodyStyle: 'padding:5px',
						iconCls: 'icon-information',
						loader: {
							autoLoad: true,
							url: helpDir+'statisticsHOWTO'
						} 
					}],
					plugins: [ {ptype: 'paramArgumentsPlugin', pluginId: 'statistics-param-arguments-plugin'}]
				};
d18b535d   elena   catalog draft + c...
437
	    
23769849   Elena.Budnik   LoadObject in Sta...
438
439
		Ext.apply (this, Ext.apply(arguments, myConf));	
	} 
d18b535d   elena   catalog draft + c...
440
});