Pman.Tab.XtupleCurrency.bjs
[Pman.Xtuple] / Pman.Tab.XtupleCurrency.js
1 //<script type="text/javascript">
2
3 // Auto generated file - created by app.Builder.js- do not edit directly (at present!)
4
5 Pman.Tab.XtupleCurrency = new Roo.XComponent({
6     part     :  ["Xtuple","Currency"],
7     order    : '901-Pman.Tab.XtupleCurrency',
8     region   : 'center',
9     parent   : 'Pman.Tab.XtupleAccountsTab',
10     name     : "Pman.Tab.XtupleCurrency",
11     disabled : false, 
12     permname : '', 
13     _tree : function()
14     {
15         var _this = this;
16         var MODULE = this;
17         return {
18             xtype: 'NestedLayoutPanel',
19             xns: Roo,
20             background : true,
21             region : 'center',
22             title : "Currency / Rates",
23             layout : {
24                 xtype: 'BorderLayout',
25                 xns: Roo,
26                 items : [
27                     {
28                         xtype: 'GridPanel',
29                         xns: Roo,
30                         listeners : {
31                             activate : function() {
32                                 _this.panel = this;
33                                 if (_this.grid) {
34                                     _this.grid.footer.onClick('first');
35                                 }
36                             }
37                         },
38                         background : false,
39                         fitContainer : true,
40                         fitToframe : true,
41                         region : 'west',
42                         tableName : 'curr_symbol',
43                         title : "curr_symbol",
44                         grid : {
45                             xtype: 'Grid',
46                             xns: Roo.grid,
47                             listeners : {
48                                 render : function() 
49                                 {
50                                     _this.grid = this; 
51                                     //_this.dialog = Pman.Dialog.FILL_IN
52                                     if (_this.panel.active) {
53                                        this.footer.onClick('first');
54                                     }
55                                 },
56                                 rowdblclick : function (_self, rowIndex, e)
57                                 {
58                                     Pman.Dialog.XtupleCurrency.show( this.getDataSource().getAt(rowIndex).data, function() {
59                                         _this.grid.footer.onClick('first');
60                                     }); 
61                                 }
62                             },
63                             autoExpandColumn : 'curr_name',
64                             loadMask : true,
65                             sm : {
66                                 xtype: 'RowSelectionModel',
67                                 xns: Roo.grid,
68                                 listeners : {
69                                     afterselectionchange : function (_self)
70                                     {
71                                         _this.rgrid.footer.onClick('first');
72                                     }
73                                 },
74                                 singleSelect : true
75                             },
76                             dataSource : {
77                                 xtype: 'Store',
78                                 xns: Roo.data,
79                                 remoteSort : true,
80                                 sortInfo : { field : 'curr_name', direction: 'ASC' },
81                                 proxy : {
82                                     xtype: 'HttpProxy',
83                                     xns: Roo.data,
84                                     method : 'GET',
85                                     url : baseURL + '/Roo/curr_symbol.php'
86                                 },
87                                 reader : {
88                                     xtype: 'JsonReader',
89                                     xns: Roo.data,
90                                     id : 'id',
91                                     root : 'data',
92                                     totalProperty : 'total',
93                                     fields : [
94                                         {
95                                             'name': 'curr_id',
96                                             'type': 'int'
97                                         },
98                                         {
99                                             'name': 'curr_base',
100                                             'type': 'int'
101                                         },
102                                         {
103                                             'name': 'curr_name',
104                                             'type': 'string'
105                                         },
106                                         {
107                                             'name': 'curr_symbol',
108                                             'type': 'string'
109                                         },
110                                         {
111                                             'name': 'curr_abbr',
112                                             'type': 'string'
113                                         }
114                                     ]
115                                 }
116                             },
117                             footer : {
118                                 xtype: 'PagingToolbar',
119                                 xns: Roo,
120                                 displayInfo : true,
121                                 displayMsg : "{0} - {1} of {2}",
122                                 emptyMsg : "Nothing found",
123                                 pageSize : 25
124                             },
125                             toolbar : {
126                                 xtype: 'Toolbar',
127                                 xns: Roo,
128                                 items : [
129                                     {
130                                         xtype: 'Button',
131                                         xns: Roo.Toolbar,
132                                         listeners : {
133                                             click : function()
134                                             {
135                                                 Pman.Dialog.XtupleCurrency.show( { curr_id : 0 } , function() {
136                                                     _this.grid.footer.onClick('first');
137                                                }); 
138                                             }
139                                         },
140                                         cls : 'x-btn-text-icon',
141                                         text : "Add",
142                                         icon : Roo.rootURL + 'images/default/dd/drop-add.gif'
143                                     },
144                                     {
145                                         xtype: 'Fill',
146                                         xns: Roo.Toolbar
147                                     },
148                                     {
149                                         xtype: 'Button',
150                                         xns: Roo.Toolbar,
151                                         listeners : {
152                                             click : function()
153                                             {
154                                                 var s = _this.grid.getSelectionModel().getSelected();
155                                                 
156                                                 if(!s){
157                                                     Roo.MessageBox.alert("Error", "Please select a currency!");
158                                                     return;
159                                                 }
160                                                     
161                                                 new Pman.Request({
162                                                     method: 'POST',
163                                                     url: baseURL+ '/Roo/curr_symbol',
164                                                     params : {
165                                                         curr_id : s.data.curr_id,
166                                                         _load_rates : 1
167                                                     },
168                                                     success : function() {
169                                                         _this.rgrid.footer.onClick('first');
170                                                     }
171                                                 });
172                                             }
173                                         },
174                                         cls : 'x-btn-text-icon',
175                                         text : "Get this months rates",
176                                         icon : Roo.rootURL + 'images/default/dd/drop-add.gif'
177                                     }
178                                 ]
179                             },
180                             colModel : [
181                                 {
182                                     xtype: 'ColumnModel',
183                                     xns: Roo.grid,
184                                     dataIndex : 'curr_name',
185                                     header : 'Name',
186                                     width : 80,
187                                     renderer : function(v,x,r) { 
188                                     
189                                         return String.format(r.data.curr_base*1 ? '<span style="color:red">{0}</span>' : '{0}', v); 
190                                         
191                                     }
192                                 },
193                                 {
194                                     xtype: 'ColumnModel',
195                                     xns: Roo.grid,
196                                     dataIndex : 'curr_symbol',
197                                     header : 'Symbol',
198                                     width : 80,
199                                     renderer : function(v,x,r) { 
200                                     
201                                         return String.format(r.data.curr_base*1 ? '<span style="color:red">{0}</span>' : '{0}', v); 
202                                         
203                                     }
204                                 },
205                                 {
206                                     xtype: 'ColumnModel',
207                                     xns: Roo.grid,
208                                     dataIndex : 'curr_abbr',
209                                     header : 'Abbr.',
210                                     width : 80,
211                                     renderer : function(v,x,r) { 
212                                     
213                                         return String.format(r.data.curr_base*1 ? '<span style="color:red">{0}</span>' : '{0}', v); 
214                                         
215                                     }
216                                 }
217                             ]
218                         }
219                     },
220                     {
221                         xtype: 'GridPanel',
222                         xns: Roo,
223                         listeners : {
224                             activate : function() {
225                                 _this.rpanel = this;
226                                 if (_this.rgrid) {
227                                     _this.rgrid.footer.onClick('first');
228                                 }
229                             }
230                         },
231                         background : false,
232                         fitContainer : true,
233                         fitToframe : true,
234                         region : 'center',
235                         tableName : 'curr_rate',
236                         title : "curr_rate",
237                         grid : {
238                             xtype: 'Grid',
239                             xns: Roo.grid,
240                             listeners : {
241                                 render : function() 
242                                 {
243                                     _this.rgrid = this; 
244                                     //_this.dialog = Pman.Dialog.FILL_IN
245                                     if (_this.rpanel.active) {
246                                        this.footer.onClick('first');
247                                     }
248                                 }
249                             },
250                             autoExpandColumn : 'curr_rate',
251                             loadMask : true,
252                             toolbar : {
253                                 xtype: 'Toolbar',
254                                 xns: Roo,
255                                 items : [
256                                     {
257                                         xtype: 'Fill',
258                                         xns: Roo.Toolbar
259                                     },
260                                     {
261                                         xtype: 'Button',
262                                         xns: Roo.Toolbar,
263                                         listeners : {
264                                             click : function (_self, e)
265                                             {
266                                                 _this.searchBox.setValue('');\r
267                                                 _this.status_type.setValue('');\r
268                                                 _this.grid.footer.onClick('first');\r
269                                             }
270                                         },
271                                         cls : 'x-btn-icon',
272                                         icon : rootURL + '/Pman/templates/images/edit-clear.gif'
273                                     }
274                                 ]
275                             },
276                             dataSource : {
277                                 xtype: 'Store',
278                                 xns: Roo.data,
279                                 listeners : {
280                                     beforeload : function (_self, options)
281                                     {
282                                         var s = _this.grid.selModel.getSelected();
283                                         if (!s) { 
284                                             this.removeAll();
285                                             return false;
286                                         }
287                                         options.params.curr_id = s.data.curr_id;
288                                         options.params._with_base_symbol  = 1;
289                                     }
290                                 },
291                                 remoteSort : true,
292                                 sortInfo : { field : 'curr_effective', direction: 'DESC' },
293                                 proxy : {
294                                     xtype: 'HttpProxy',
295                                     xns: Roo.data,
296                                     method : 'GET',
297                                     url : baseURL + '/Roo/curr_rate.php'
298                                 },
299                                 reader : {
300                                     xtype: 'JsonReader',
301                                     xns: Roo.data,
302                                     totalProperty : 'total',
303                                     root : 'data',
304                                     id : 'id',
305                                     fields : [
306                                         {
307                                             'name': 'curr_rate_id',
308                                             'type': 'int'
309                                         },
310                                         {
311                                             'name': 'curr_id',
312                                             'type': 'int'
313                                         },
314                                         {
315                                             'name': 'curr_id',
316                                             'type': 'int'
317                                         },
318                                         {
319                                             'name': 'curr_rate',
320                                             'type': 'float'
321                                         },
322                                         {
323                                             'name': 'curr_effective',
324                                             'type': 'date',
325                                             'dateFormat': 'Y-m-d'
326                                         },
327                                         {
328                                             'name': 'curr_expires',
329                                             'type': 'date',
330                                             'dateFormat': 'Y-m-d'
331                                         }
332                                     ]
333                                 }
334                             },
335                             footer : {
336                                 xtype: 'PagingToolbar',
337                                 xns: Roo,
338                                 displayInfo : true,
339                                 displayMsg : "Displaying curr_rate {0} - {1} of {2}",
340                                 emptyMsg : "No curr_rate found",
341                                 pageSize : 25
342                             },
343                             colModel : [
344                                 {
345                                     xtype: 'ColumnModel',
346                                     xns: Roo.grid,
347                                     dataIndex : 'curr_effective',
348                                     header : 'From',
349                                     width : 150,
350                                     renderer : function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }
351                                 },
352                                 {
353                                     xtype: 'ColumnModel',
354                                     xns: Roo.grid,
355                                     dataIndex : 'curr_expires',
356                                     header : 'To',
357                                     width : 150,
358                                     renderer : function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }
359                                 },
360                                 {
361                                     xtype: 'ColumnModel',
362                                     xns: Roo.grid,
363                                     align : 'right',
364                                     dataIndex : 'curr_rate',
365                                     header : 'Rate',
366                                     width : 75,
367                                     renderer : function(v) { return String.format('{0}', v); }
368                                 },
369                                 {
370                                     xtype: 'ColumnModel',
371                                     xns: Roo.grid,
372                                     align : 'right',
373                                     dataIndex : 'curr_rate1',
374                                     header : 'Rate',
375                                     width : 150,
376                                     renderer : function(v,x,r) {
377                                     
378                                          return String.format('{1}1 = {2}{0}', 
379                                             Roo.util.Format.number(r.data.curr_rate,2),
380                                             r.data.base_curr_symbol,
381                                             r.data.curr_id_curr_symbol
382                                         ); 
383                                         
384                                     }
385                                 },
386                                 {
387                                     xtype: 'ColumnModel',
388                                     xns: Roo.grid,
389                                     align : 'right',
390                                     dataIndex : 'curr_rate2',
391                                     header : 'Rate',
392                                     width : 150,
393                                     renderer : function(v,x,r) {    
394                                          return String.format('{2}1 = {1}{0}', 
395                                             Roo.util.Format.number(1.0/r.data.curr_rate,2),
396                                             r.data.base_curr_symbol,
397                                             r.data.curr_id_curr_symbol
398                                         ); 
399                                     }
400                                 }
401                             ]
402                         }
403                     }
404                 ],
405                 west : {
406                     xtype: 'LayoutRegion',
407                     xns: Roo,
408                     split : true,
409                     width : 300
410                 },
411                 center : {
412                     xtype: 'LayoutRegion',
413                     xns: Roo
414                 }
415             }
416         };
417     }
418 });