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             if(!_this.form.isValid()){
106             
107             }
108             
109             _this.dialog.el.mask("Saving");
110             _this.form.doAction("submit");
111         
112         }
113       },
114       xns : Roo,
115       '|xns' : 'Roo'
116      }
117     ],
118     items  : [
119      {
120       xtype : 'ContentPanel',
121       autoCreate : true,
122       fitToFrame : true,
123       region : 'center',
124       xns : Roo,
125       '|xns' : 'Roo',
126       items  : [
127        {
128         xtype : 'Form',
129         fileUpload : true,
130         labelWidth : 160,
131         url : baseURL + '/Roo/Companies.php',
132         listeners : {
133          actioncomplete : function(f, act) {
134               _this.dialog.el.unmask();
135               //console.log('load completed'); 
136               // error messages?????
137               if(act.type == 'setdata'){
138                   this.load({ method: 'GET', params: { '_id' : _this.data.id }});
139                   return;
140               }
141              
142               if (act.type == 'load') {
143                   _this.data = act.result.data;
144                   var meth = _this.data.comptype == 'OWNER' ? 'disable' : 'enable';
145                
146                       
147                   if (_this.form.findField('comptype')) {
148                       _this.form.findField('comptype')[meth]();
149                   }
150                    
151                  // _this.loaded();
152                   return;
153               }
154               
155               
156               if (act.type == 'submit') { // only submitted here if we are 
157                   _this.dialog.hide();
158                  
159                   if (_this.callback) {
160                       _this.callback.call(this, act.result.data);
161                   }
162                   return; 
163               }
164               // unmask?? 
165           },
166          actionfailed : function(f, act) {
167               _this.dialog.el.unmask();
168               // error msg???
169               Pman.standardActionFailed(f,act);
170                         
171           },
172          rendered : function (form)
173           {
174               _this.form = form;
175           }
176         },
177         xns : Roo.form,
178         '|xns' : 'Roo.form',
179         items  : [
180          {
181           xtype : 'Column',
182           width : 500,
183           xns : Roo.form,
184           '|xns' : 'Roo.form',
185           items  : [
186            {
187             xtype : 'TextField',
188             allowBlank : true,
189             fieldLabel : _this._strings['b33457e7e1cd5dbf1db34a0c60fcb75f'] /* Company ID (for filing Ref.) */,
190             name : 'code',
191             qtip : _this._strings['733640ec0c9367df1b4d85eb286ed9ae'] /* Enter code */,
192             width : 100,
193             xns : Roo.form,
194             '|xns' : 'Roo.form'
195            },
196            {
197             xtype : 'ComboBox',
198             alwaysQuery : true,
199             displayField : 'display_name',
200             emptyText : _this._strings['023a5dfa857c4aa0156e6685231a1dbd'] /* Select Type */,
201             fieldLabel : _this._strings['a1fa27779242b4902f7ae3bdd5c6d508'] /* Type */,
202             forceSelection : true,
203             hiddenName : 'comptype',
204             listWidth : 250,
205             loadingText : _this._strings['1243daf593fa297e07ab03bf06d925af'] /* Searching... */,
206             minChars : 2,
207             name : 'comptype_display_name',
208             pageSize : 20,
209             qtip : _this._strings['8535bcc0f05358a583bb432bbadf7e0d'] /* Select type */,
210             queryParam : 'query[name]',
211             selectOnFocus : true,
212             tpl : '<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> : {display_name}</div>',
213             triggerAction : 'all',
214             typeAhead : false,
215             valueField : 'name',
216             width : 200,
217             listeners : {
218              render : function (_self)
219               {
220                   _this.etypeCombo = _self;
221               }
222             },
223             xns : Roo.form,
224             '|xns' : 'Roo.form',
225             store : {
226              xtype : 'Store',
227              remoteSort : true,
228              sortInfo : { direction : 'ASC', field: 'id' },
229              listeners : {
230               beforeload : function (_self, o){
231                    o.params = o.params || {};
232                    // set more here
233                    //o.params['query[empty_etype]'] = 1;
234                    o.params.etype = 'COMPTYPE';
235                }
236              },
237              xns : Roo.data,
238              '|xns' : 'Roo.data',
239              proxy : {
240               xtype : 'HttpProxy',
241               method : 'GET',
242               url : baseURL + '/Roo/core_enum.php',
243               xns : Roo.data,
244               '|xns' : 'Roo.data'
245              },
246              reader : {
247               xtype : 'JsonReader',
248               fields : [{"name":"id","type":"int"},{"name":"name","type":"string"}],
249               id : 'id',
250               root : 'data',
251               totalProperty : 'total',
252               xns : Roo.data,
253               '|xns' : 'Roo.data'
254              }
255             }
256            },
257            {
258             xtype : 'TextField',
259             allowBlank : false,
260             fieldLabel : _this._strings['e7b47c58815acf1d3afa59a84b5db7fb'] /* Company Name */,
261             name : 'name',
262             qtip : _this._strings['4ef6052d74436756f08e95fd63949653'] /* Enter Company Name */,
263             width : 300,
264             xns : Roo.form,
265             '|xns' : 'Roo.form'
266            },
267            {
268             xtype : 'TextField',
269             allowBlank : true,
270             fieldLabel : _this._strings['bcc254b55c4a1babdf1dcb82c207506b'] /* Phone */,
271             name : 'tel',
272             qtip : _this._strings['bc3a4c40d007b8d610a16312970e5cb3'] /* Enter Phone Number */,
273             width : 300,
274             xns : Roo.form,
275             '|xns' : 'Roo.form'
276            },
277            {
278             xtype : 'TextField',
279             allowBlank : true,
280             fieldLabel : _this._strings['9810aa2b9f44401be4bf73188ef2b67d'] /* Fax */,
281             name : 'fax',
282             qtip : _this._strings['cf3a5d25d39613ad5bbc2f5eb0f9b675'] /* Enter Fax Number */,
283             width : 300,
284             xns : Roo.form,
285             '|xns' : 'Roo.form'
286            },
287            {
288             xtype : 'TextField',
289             allowBlank : true,
290             fieldLabel : _this._strings['ce8ae9da5b7cd6c3df2929543a9af92d'] /* Email */,
291             name : 'email',
292             qtip : _this._strings['9f86c00615b1a210935ac28ff8ebbb22'] /* Enter Email Address */,
293             width : 300,
294             xns : Roo.form,
295             '|xns' : 'Roo.form'
296            },
297            {
298             xtype : 'TextField',
299             allowBlank : true,
300             fieldLabel : _this._strings['02a3a357710cc2a5dfdfb74ed012fb59'] /* Url */,
301             name : 'url',
302             qtip : _this._strings['8c04eb09879a05470fae436ba76e3bb9'] /* Enter Url */,
303             width : 300,
304             xns : Roo.form,
305             '|xns' : 'Roo.form'
306            },
307            {
308             xtype : 'TextField',
309             allowBlank : true,
310             fieldLabel : _this._strings['dd7bf230fde8d4836917806aff6a6b27'] /* Address */,
311             name : 'address',
312             qtip : _this._strings['32c4e9483403d60115b21519178e5384'] /* Enter Address */,
313             width : 300,
314             xns : Roo.form,
315             '|xns' : 'Roo.form'
316            },
317            {
318             xtype : 'TextArea',
319             allowBlank : true,
320             fieldLabel : _this._strings['231bc72756b5e6de492aaaa1577f61b1'] /* Remarks */,
321             height : 120,
322             name : 'remarks',
323             qtip : _this._strings['c54b90756cfbeff9217293b567cb2eb0'] /* Enter remarks */,
324             width : 300,
325             xns : Roo.form,
326             '|xns' : 'Roo.form'
327            }
328           ]
329          },
330          {
331           xtype : 'Column',
332           labelAlign : 'top',
333           width : 200,
334           xns : Roo.form,
335           '|xns' : 'Roo.form',
336           items  : [
337            {
338             xtype : 'ColorField',
339             fieldLabel : _this._strings['35cb9e66ff801a819684ee0fbeabaeeb'] /* Background Colour */,
340             name : 'background_color',
341             xns : Roo.form,
342             '|xns' : 'Roo.form'
343            },
344            {
345             xtype : 'DisplayField',
346             fieldLabel : _this._strings['bc87ef2144ae15ef4f78211e73948051'] /* Logo Image */,
347             height : 170,
348             icon : 'rootURL + \'images/default/dd/drop-add.gif\'',
349             name : 'logo_id',
350             style : 'border: 1px solid #ccc;',
351             valueRenderer : function(v) {
352                 //var vp = v ? v : 'Companies:' + _this.data.id + ':-LOGO';
353                 if (!v) {
354                     return "No Image Available" + '<BR/>';
355                 }
356                 return String.format('<a target="_new" href="{1}"><img src="{0}" width="150"></a>', 
357                         baseURL + '/Images/Thumb/150x150/' + v + '/logo.jpg',
358                         baseURL + '/Images/'+v+'/logo.jpg'           // fixme - put escaped company name..
359                 );
360             },
361             width : 170,
362             xns : Roo.form,
363             '|xns' : 'Roo.form'
364            },
365            {
366             xtype : 'Button',
367             text : _this._strings['b9c49611cfda3259a2b837b39489e650'] /* Add Image */,
368             listeners : {
369              click : function (_self, e)
370               {
371                   var _t = _this.form.findField('logo_id');
372                                        
373                   Pman.Dialog.Image.show({
374                       onid :_this.data.id,
375                       ontable : 'Companies',
376                       imgtype : 'LOGO'
377                   }, function(data) {
378                       if  (data) {
379                           _t.setValue(data.id);
380                       }
381                       
382                   });
383               }
384             },
385             xns : Roo,
386             '|xns' : 'Roo'
387            }
388           ]
389          },
390          {
391           xtype : 'Hidden',
392           name : 'id',
393           xns : Roo.form,
394           '|xns' : 'Roo.form'
395          }
396         ]
397        }
398       ]
399      }
400     ]
401    });
402  }
403 };