Pman.Dialog.CoreCompanies.bjs
[Pman.Core] / Pman.Dialog.CoreCompanies.js
1 //<script type="text/javascript">
2
3 // Auto generated file - created by app.Builder.js- do not edit directly (at present!)
4
5 Roo.namespace('Pman.Dialog');
6
7 Pman.Dialog.CoreCompanies = {
8
9  _strings : {
10   'ce8ae9da5b7cd6c3df2929543a9af92d' :"Email",
11   '231bc72756b5e6de492aaaa1577f61b1' :"Remarks",
12   'b33457e7e1cd5dbf1db34a0c60fcb75f' :"Company ID (for filing Ref.)",
13   '023a5dfa857c4aa0156e6685231a1dbd' :"Select Type",
14   '8535bcc0f05358a583bb432bbadf7e0d' :"Select type",
15   '733640ec0c9367df1b4d85eb286ed9ae' :"Enter code",
16   '8c04eb09879a05470fae436ba76e3bb9' :"Enter Url",
17   '4ef6052d74436756f08e95fd63949653' :"Enter Company Name",
18   'c54b90756cfbeff9217293b567cb2eb0' :"Enter remarks",
19   '1243daf593fa297e07ab03bf06d925af' :"Searching...",
20   'bcc254b55c4a1babdf1dcb82c207506b' :"Phone",
21   'cf3a5d25d39613ad5bbc2f5eb0f9b675' :"Enter Fax Number",
22   '9f86c00615b1a210935ac28ff8ebbb22' :"Enter Email Address",
23   'e7b47c58815acf1d3afa59a84b5db7fb' :"Company Name",
24   'ea4788705e6873b424c65e91c2846b19' :"Cancel",
25   '32c4e9483403d60115b21519178e5384' :"Enter Address",
26   'b9c49611cfda3259a2b837b39489e650' :"Add Image",
27   '72b9d3d2e231f1de7a2bd70737f644aa' :"Add / Edit Organization",
28   'a1fa27779242b4902f7ae3bdd5c6d508' :"Type",
29   '02a3a357710cc2a5dfdfb74ed012fb59' :"Url",
30   'dd7bf230fde8d4836917806aff6a6b27' :"Address",
31   'c9cc8cce247e49bae79f15173ce97354' :"Save",
32   'bc3a4c40d007b8d610a16312970e5cb3' :"Enter Phone Number",
33   '9810aa2b9f44401be4bf73188ef2b67d' :"Fax",
34   '35cb9e66ff801a819684ee0fbeabaeeb' :"Background Colour",
35   'bc87ef2144ae15ef4f78211e73948051' :"Logo Image"
36  },
37
38  dialog : false,
39  callback:  false,
40
41  show : function(data, cb)
42  {
43   if (!this.dialog) {
44    this.create();
45   }
46
47   this.callback = cb;
48   this.data = data;
49   this.dialog.show(this.data._el);
50   if (this.form) {
51    this.form.reset();
52    this.form.setValues(data);
53    this.form.fireEvent('actioncomplete', this.form,  { type: 'setdata', data: data });
54   }
55
56  },
57
58  create : function()
59  {
60    var _this = this;
61    this.dialog = Roo.factory({
62     xtype : 'LayoutDialog',
63     autoCreate : true,
64     closable : false,
65     collapsible : false,
66     draggable : false,
67     height : 400,
68     modal : true,
69     shadow : true,
70     title : _this._strings['72b9d3d2e231f1de7a2bd70737f644aa'] /* Add / Edit Organization */,
71     width : 750,
72     xns : Roo,
73     '|xns' : 'Roo',
74     center : {
75      xtype : 'LayoutRegion',
76      alwaysShowTabs : false,
77      autoScroll : false,
78      closeOnTab : true,
79      hideTabs : true,
80      titlebar : false,
81      xns : Roo,
82      '|xns' : 'Roo'
83     },
84     buttons : [
85      {
86       xtype : 'Button',
87       text : _this._strings['ea4788705e6873b424c65e91c2846b19'] /* Cancel */,
88       listeners : {
89        click : function (_self, e)
90         {
91             _this.dialog.hide();
92         }
93       },
94       xns : Roo,
95       '|xns' : 'Roo'
96      },
97      {
98       xtype : 'Button',
99       text : _this._strings['c9cc8cce247e49bae79f15173ce97354'] /* Save */,
100       listeners : {
101        click : function (_self, e)
102         {
103             // do some checks?
104             
105             
106             
107             _this.dialog.el.mask("Saving");
108             _this.form.doAction("submit");
109         
110         }
111       },
112       xns : Roo,
113       '|xns' : 'Roo'
114      }
115     ],
116     items  : [
117      {
118       xtype : 'ContentPanel',
119       autoCreate : true,
120       fitToFrame : true,
121       region : 'center',
122       xns : Roo,
123       '|xns' : 'Roo',
124       items  : [
125        {
126         xtype : 'Form',
127         fileUpload : true,
128         labelWidth : 160,
129         url : baseURL + '/Roo/Companies.php',
130         listeners : {
131          actioncomplete : function(f, act) {
132               _this.dialog.el.unmask();
133               //console.log('load completed'); 
134               // error messages?????
135               if(act.type == 'setdata'){
136                   this.load({ method: 'GET', params: { '_id' : _this.data.id }});
137                   return;
138               }
139              
140               if (act.type == 'load') {
141                   _this.data = act.result.data;
142                   var meth = _this.data.comptype == 'OWNER' ? 'disable' : 'enable';
143                
144                       
145                   if (_this.form.findField('comptype')) {
146                       _this.form.findField('comptype')[meth]();
147                   }
148                    
149                  // _this.loaded();
150                   return;
151               }
152               
153               
154               if (act.type == 'submit') { // only submitted here if we are 
155                   _this.dialog.hide();
156                  
157                   if (_this.callback) {
158                       _this.callback.call(this, act.result.data);
159                   }
160                   return; 
161               }
162               // unmask?? 
163           },
164          actionfailed : function(f, act) {
165               _this.dialog.el.unmask();
166               // error msg???
167               Pman.standardActionFailed(f,act);
168                         
169           },
170          rendered : function (form)
171           {
172               _this.form = form;
173           }
174         },
175         xns : Roo.form,
176         '|xns' : 'Roo.form',
177         items  : [
178          {
179           xtype : 'Column',
180           width : 500,
181           xns : Roo.form,
182           '|xns' : 'Roo.form',
183           items  : [
184            {
185             xtype : 'TextField',
186             allowBlank : true,
187             fieldLabel : _this._strings['b33457e7e1cd5dbf1db34a0c60fcb75f'] /* Company ID (for filing Ref.) */,
188             name : 'code',
189             qtip : _this._strings['733640ec0c9367df1b4d85eb286ed9ae'] /* Enter code */,
190             width : 100,
191             xns : Roo.form,
192             '|xns' : 'Roo.form'
193            },
194            {
195             xtype : 'ComboBox',
196             alwaysQuery : true,
197             displayField : 'display_name',
198             emptyText : _this._strings['023a5dfa857c4aa0156e6685231a1dbd'] /* Select Type */,
199             fieldLabel : _this._strings['a1fa27779242b4902f7ae3bdd5c6d508'] /* Type */,
200             forceSelection : true,
201             hiddenName : 'comptype',
202             listWidth : 250,
203             loadingText : _this._strings['1243daf593fa297e07ab03bf06d925af'] /* Searching... */,
204             minChars : 2,
205             name : 'comptype_display_name',
206             pageSize : 20,
207             qtip : _this._strings['8535bcc0f05358a583bb432bbadf7e0d'] /* Select type */,
208             queryParam : 'query[name]',
209             selectOnFocus : true,
210             tpl : '<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> : {display_name}</div>',
211             triggerAction : 'all',
212             typeAhead : false,
213             valueField : 'name',
214             width : 200,
215             listeners : {
216              render : function (_self)
217               {
218                   _this.etypeCombo = _self;
219               }
220             },
221             xns : Roo.form,
222             '|xns' : 'Roo.form',
223             store : {
224              xtype : 'Store',
225              remoteSort : true,
226              sortInfo : { direction : 'ASC', field: 'id' },
227              listeners : {
228               beforeload : function (_self, o){
229                    o.params = o.params || {};
230                    // set more here
231                    //o.params['query[empty_etype]'] = 1;
232                    o.params.etype = 'COMPTYPE';
233                }
234              },
235              xns : Roo.data,
236              '|xns' : 'Roo.data',
237              proxy : {
238               xtype : 'HttpProxy',
239               method : 'GET',
240               url : baseURL + '/Roo/core_enum.php',
241               xns : Roo.data,
242               '|xns' : 'Roo.data'
243              },
244              reader : {
245               xtype : 'JsonReader',
246               fields : [{"name":"id","type":"int"},{"name":"name","type":"string"}],
247               id : 'id',
248               root : 'data',
249               totalProperty : 'total',
250               xns : Roo.data,
251               '|xns' : 'Roo.data'
252              }
253             }
254            },
255            {
256             xtype : 'TextField',
257             allowBlank : true,
258             fieldLabel : _this._strings['e7b47c58815acf1d3afa59a84b5db7fb'] /* Company Name */,
259             name : 'name',
260             qtip : _this._strings['4ef6052d74436756f08e95fd63949653'] /* Enter Company Name */,
261             width : 300,
262             xns : Roo.form,
263             '|xns' : 'Roo.form'
264            },
265            {
266             xtype : 'TextField',
267             allowBlank : true,
268             fieldLabel : _this._strings['bcc254b55c4a1babdf1dcb82c207506b'] /* Phone */,
269             name : 'tel',
270             qtip : _this._strings['bc3a4c40d007b8d610a16312970e5cb3'] /* Enter Phone Number */,
271             width : 300,
272             xns : Roo.form,
273             '|xns' : 'Roo.form'
274            },
275            {
276             xtype : 'TextField',
277             allowBlank : true,
278             fieldLabel : _this._strings['9810aa2b9f44401be4bf73188ef2b67d'] /* Fax */,
279             name : 'fax',
280             qtip : _this._strings['cf3a5d25d39613ad5bbc2f5eb0f9b675'] /* Enter Fax Number */,
281             width : 300,
282             xns : Roo.form,
283             '|xns' : 'Roo.form'
284            },
285            {
286             xtype : 'TextField',
287             allowBlank : true,
288             fieldLabel : _this._strings['ce8ae9da5b7cd6c3df2929543a9af92d'] /* Email */,
289             name : 'email',
290             qtip : _this._strings['9f86c00615b1a210935ac28ff8ebbb22'] /* Enter Email Address */,
291             width : 300,
292             xns : Roo.form,
293             '|xns' : 'Roo.form'
294            },
295            {
296             xtype : 'TextField',
297             allowBlank : true,
298             fieldLabel : _this._strings['02a3a357710cc2a5dfdfb74ed012fb59'] /* Url */,
299             name : 'url',
300             qtip : _this._strings['8c04eb09879a05470fae436ba76e3bb9'] /* Enter Url */,
301             width : 300,
302             xns : Roo.form,
303             '|xns' : 'Roo.form'
304            },
305            {
306             xtype : 'TextField',
307             allowBlank : true,
308             fieldLabel : _this._strings['dd7bf230fde8d4836917806aff6a6b27'] /* Address */,
309             name : 'address',
310             qtip : _this._strings['32c4e9483403d60115b21519178e5384'] /* Enter Address */,
311             width : 300,
312             xns : Roo.form,
313             '|xns' : 'Roo.form'
314            },
315            {
316             xtype : 'TextArea',
317             allowBlank : true,
318             fieldLabel : _this._strings['231bc72756b5e6de492aaaa1577f61b1'] /* Remarks */,
319             height : 120,
320             name : 'remarks',
321             qtip : _this._strings['c54b90756cfbeff9217293b567cb2eb0'] /* Enter remarks */,
322             width : 300,
323             xns : Roo.form,
324             '|xns' : 'Roo.form'
325            }
326           ]
327          },
328          {
329           xtype : 'Column',
330           labelAlign : 'top',
331           width : 200,
332           xns : Roo.form,
333           '|xns' : 'Roo.form',
334           items  : [
335            {
336             xtype : 'ColorField',
337             fieldLabel : _this._strings['35cb9e66ff801a819684ee0fbeabaeeb'] /* Background Colour */,
338             name : 'background_color',
339             xns : Roo.form,
340             '|xns' : 'Roo.form'
341            },
342            {
343             xtype : 'DisplayField',
344             fieldLabel : _this._strings['bc87ef2144ae15ef4f78211e73948051'] /* Logo Image */,
345             height : 170,
346             icon : 'rootURL + \'images/default/dd/drop-add.gif\'',
347             name : 'logo_id',
348             style : 'border: 1px solid #ccc;',
349             valueRenderer : function(v) {
350                 //var vp = v ? v : 'Companies:' + _this.data.id + ':-LOGO';
351                 if (!v) {
352                     return "No Image Available" + '<BR/>';
353                 }
354                 return String.format('<a target="_new" href="{1}"><img src="{0}" width="150"></a>', 
355                         baseURL + '/Images/Thumb/150x150/' + v + '/logo.jpg',
356                         baseURL + '/Images/'+v+'/logo.jpg'           // fixme - put escaped company name..
357                 );
358             },
359             width : 170,
360             xns : Roo.form,
361             '|xns' : 'Roo.form'
362            },
363            {
364             xtype : 'Button',
365             text : _this._strings['b9c49611cfda3259a2b837b39489e650'] /* Add Image */,
366             listeners : {
367              click : function (_self, e)
368               {
369                   var _t = _this.form.findField('logo_id');
370                                        
371                   Pman.Dialog.Image.show({
372                       onid :_this.data.id,
373                       ontable : 'Companies',
374                       imgtype : 'LOGO'
375                   }, function(data) {
376                       if  (data) {
377                           _t.setValue(data.id);
378                       }
379                       
380                   });
381               }
382             },
383             xns : Roo,
384             '|xns' : 'Roo'
385            }
386           ]
387          },
388          {
389           xtype : 'Hidden',
390           name : 'id',
391           xns : Roo.form,
392           '|xns' : 'Roo.form'
393          }
394         ]
395        }
396       ]
397      }
398     ]
399    });
400  }
401 };