add border radius
[Pman.Core] / Pman.Dialog.CoreEmail.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.CoreEmail = {
8
9  _strings : {
10   'e44b145bd8b49b06e0ad2ced1ad56466' :"Plain Text",
11   '2f26e35d61be90501e099089dc533638' :"Select Images",
12   'f2a6c498fb90ee345d997f888fce3b18' :"Delete",
13   'b357b524e740bc85b9790a0712d84a30' :"Email address",
14   '962b90039a542a29cedd51d87a9f28a1' :"Html Editor",
15   '72d6d7a1885885bb55a565fd1070581a' :"Import",
16   '28690be026c0bb9003aa58e45e5662ca' :"Enabled - will be sent out",
17   'ea30b40c3caf28acb29198d20d243e54' :"Images / Attachments >>",
18   '31fde7b05ac8952dacf4af8a704074ec' :"Preview",
19   'b337c8a67244afb6551ee1f8f9717676' :"Test Class <BR/> (for system reference only)",
20   '884df8e413319ff51a3f5f528606238a' :"Use template",
21   'e6b391a8d2c4d45902a23a8b6585703d' :"URL",
22   '6f16a5f8ff5d75ab84c018adacdfcbb7' :"Field",
23   'ec211f7c20af43e742bf2570c3cb84f9' :"Add",
24   '2393ad754ba179442d85e415d1d5167c' :"Displayorder",
25   'e9968623956c15023d54335ea3699855' :"Convert Html to Text",
26   '1243daf593fa297e07ab03bf06d925af' :"Searching...",
27   '5b8ef4e762c00a15a41cfc26dc3ef99c' :"Send me a test copy",
28   'c7892ebbb139886662c6f2fc8c450710' :"Subject",
29   'dc0de523c25be298ba751c63c694109e' :"Responsive Email (1)",
30   '396ecabf0cd1f9503e591418851ef406' :"Edit / Create Message",
31   'b9c49611cfda3259a2b837b39489e650' :"Add Image",
32   'ea4788705e6873b424c65e91c2846b19' :"Cancel",
33   '68b00d723d37122f64da8d9939f836f0' :"BCC Group",
34   'c4ca4238a0b923820dcc509a6f75849b' :"1",
35   'bd88a20b53a47f7b5704a83a15ff5506' :"Saved Version",
36   'b20a8b77b05d53b4e695738731400c85' :"Mailout Name",
37   '1bd18d39370b7f26c1c5e18067b74c6f' :"Html File",
38   '2c466a2c159463f1d9ef5a7b57b52827' :"Select BCC Group",
39   '5da618e8e4b89c66fe86e32cdafde142' :"From",
40   '31bb2f6e9b8fb11cbb7fb63c6025223f' :"Select Template",
41   'b78a3223503896721cca1303f776159b' :"Title",
42   '278c491bdd8a53618c149c4ac790da34' :"Template",
43   '1351017ac6423911223bc19a8cb7c653' :"Filename",
44   '308f2757bfc9ce92fb00ff93fdffd279' :"Images / Attachments",
45   'c9cc8cce247e49bae79f15173ce97354' :"Save",
46   '5feb9bf3c03b32635135006cbacb9542' :"Insert Field",
47   '4c2a8fe7eaf24721cc7a9f0175115bd4' :"Message",
48   'fff0d600f8a0b5e19e88bfb821dd1157' :"Images"
49  },
50  _named_strings : {
51   'active_boxLabel' : '28690be026c0bb9003aa58e45e5662ca' /* Enabled - will be sent out */ ,
52   'template_fieldLabel' : '278c491bdd8a53618c149c4ac790da34' /* Template */ ,
53   'name_fieldLabel' : 'b20a8b77b05d53b4e695738731400c85' /* Mailout Name */ ,
54   'bcc_group_id_name_qtip' : '2c466a2c159463f1d9ef5a7b57b52827' /* Select BCC Group */ ,
55   'bcc_group_id_name_emptyText' : '2c466a2c159463f1d9ef5a7b57b52827' /* Select BCC Group */ ,
56   'template_qtip' : '31bb2f6e9b8fb11cbb7fb63c6025223f' /* Select Template */ ,
57   'template_loadingText' : '1243daf593fa297e07ab03bf06d925af' /* Searching... */ ,
58   'from_email_fieldLabel' : 'b357b524e740bc85b9790a0712d84a30' /* Email address */ ,
59   'template_emptyText' : '31bb2f6e9b8fb11cbb7fb63c6025223f' /* Select Template */ ,
60   'active_value' : 'c4ca4238a0b923820dcc509a6f75849b' /* 1 */ ,
61   'from_name_fieldLabel' : '5da618e8e4b89c66fe86e32cdafde142' /* From */ ,
62   'bcc_group_id_name_loadingText' : '1243daf593fa297e07ab03bf06d925af' /* Searching... */ ,
63   'bcc_group_id_name_fieldLabel' : '68b00d723d37122f64da8d9939f836f0' /* BCC Group */ ,
64   'subject_fieldLabel' : 'c7892ebbb139886662c6f2fc8c450710' /* Subject */ ,
65   'test_class_fieldLabel' : 'b337c8a67244afb6551ee1f8f9717676' /* Test Class <BR/> (for system reference only) */ 
66  },
67
68  dialog : false,
69  callback:  false,
70
71  show : function(data, cb)
72  {
73   if (!this.dialog) {
74    this.create();
75   }
76
77   this.callback = cb;
78   this.data = data;
79   this.dialog.show.apply(this.dialog,  Array.prototype.slice.call(arguments).slice(2));
80   if (this.form) {
81    this.form.reset();
82    this.form.setValues(data);
83    this.form.fireEvent('actioncomplete', this.form,  { type: 'setdata', data: data });
84   }
85
86  },
87
88  create : function()
89  {
90    var _this = this;
91    this.dialog = Roo.factory({
92     xtype : 'LayoutDialog',
93     closable : true,
94     collapsible : false,
95     height : 500,
96     modal : true,
97     resizable : true,
98     title : _this._strings['396ecabf0cd1f9503e591418851ef406'] /* Edit / Create Message */,
99     width : 800,
100     listeners : {
101      show : function (_self)
102       {
103           
104           _self.layout.getRegion('center').showPanel(0);
105           var w = Roo.lib.Dom.getViewWidth();\r
106           var h = Roo.lib.Dom.getViewHeight();    \r    this.resizeTo(w-50, h-50);\r
107           this.center();\r    
108           var ew = Math.max(250, w-320);\r
109           var eh = Math.max(250, h-350) ;\r
110           var e = _this.dialog.layout.getRegion('east');
111           if (e.visible) {
112               e.hide();
113           }
114           
115           var el = _self.getEl();
116           var elw = el.dom.clientWidth;
117           
118           var bdtext = _this.form.findField('bodytext');
119           var ptext = _this.form.findField('plaintext');
120           if(bdtext.resizeEl){
121               bdtext.width = elw-100;
122               bdtext.resizeEl.resizeTo.defer(110, bdtext.resizeEl,[ bdtext.width, bdtext.height  ] );
123               ptext.setSize(bdtext.width , bdtext.height);
124           }
125           
126       }
127     },
128     xns : Roo,
129     '|xns' : 'Roo',
130     center : {
131      xtype : 'LayoutRegion',
132      tabPosition : 'top',
133      xns : Roo,
134      '|xns' : 'Roo'
135     },
136     east : {
137      xtype : 'LayoutRegion',
138      hidden : true,
139      split : true,
140      title : _this._strings['308f2757bfc9ce92fb00ff93fdffd279'] /* Images / Attachments */,
141      titlebar : true,
142      width : 500,
143      xns : Roo,
144      '|xns' : 'Roo'
145     },
146     buttons : [
147      {
148       xtype : 'Button',
149       text : _this._strings['31fde7b05ac8952dacf4af8a704074ec'] /* Preview */,
150       listeners : {
151        click : function (_self, e)
152         {
153             //_this.dialog.hide();
154             Roo.log(_this.data.module);
155             Pman.Dialog.CoreEmailPreview.show({ id : _this.form.findField('id').getValue(), module : _this.data.module });
156         },
157        render : function (_self)
158         {
159             _this.preview_btn = _self;
160         }
161       },
162       xns : Roo,
163       '|xns' : 'Roo'
164      },
165      {
166       xtype : 'Button',
167       text : _this._strings['5b8ef4e762c00a15a41cfc26dc3ef99c'] /* Send me a test copy */,
168       listeners : {
169        click : function (_self, e)
170         {
171             //_this.dialog.hide();
172         
173             var id = _this.form.findField('id').getValue();
174             
175             if(id*1 < 1){
176                 Roo.MessageBox.alert('Error', 'Please save the message frist!');
177                 return;
178             }
179            
180             new Pman.Request({
181                 url : baseURL + '/Core/MessagePreview',
182                 method : 'POST',
183                 mask: 'Sending',
184                 params : {
185                     _id : id,
186                     _table : _this.data.module
187                 }, 
188                 success : function(res) { 
189                     if(res.data == 'SUCCESS'){
190                         Roo.MessageBox.alert("Email Sent", 'The report was sent to your email (HTML format).');
191                     }
192                 }
193             });
194         },
195        render : function (_self)
196         {
197             _this.html_preview = _self;
198         }
199       },
200       xns : Roo,
201       '|xns' : 'Roo'
202      },
203      {
204       xtype : 'Button',
205       text : _this._strings['ea4788705e6873b424c65e91c2846b19'] /* Cancel */,
206       listeners : {
207        click : function (_self, e)
208         {
209             _this.dialog.hide();
210         }
211       },
212       xns : Roo,
213       '|xns' : 'Roo'
214      },
215      {
216       xtype : 'Button',
217       text : _this._strings['c9cc8cce247e49bae79f15173ce97354'] /* Save */,
218       listeners : {
219        click : function (_self, e)
220         {
221         
222             // do some checks?
223             _this.form.preValidate(function(res) {
224                 if (!res) {
225                     return; //failed.
226                 }
227                  _this.form.doAction("submit");
228             });
229         
230         }
231       },
232       xns : Roo,
233       '|xns' : 'Roo'
234      }
235     ],
236     items  : [
237      {
238       xtype : 'NestedLayoutPanel',
239       autoScroll : false,
240       fitContainer : true,
241       fitToFrame : true,
242       region : 'center',
243       xns : Roo,
244       '|xns' : 'Roo',
245       toolbar : {
246        xtype : 'Toolbar',
247        xns : Roo,
248        '|xns' : 'Roo',
249        items  : [
250         {
251          xtype : 'Button',
252          text : _this._strings['72d6d7a1885885bb55a565fd1070581a'] /* Import */,
253          xns : Roo.Toolbar,
254          '|xns' : 'Roo.Toolbar',
255          menu : {
256           xtype : 'Menu',
257           xns : Roo.menu,
258           '|xns' : 'Roo.menu',
259           items  : [
260            {
261             xtype : 'Item',
262             text : _this._strings['e6b391a8d2c4d45902a23a8b6585703d'] /* URL */,
263             listeners : {
264              click : function (_self, e)
265               {
266                   Pman.Dialog.CoreImportUrl.show({
267                       target : '/Core/ImportMailMessage.php'
268                   }, function(data) {
269                       if  (data) {
270                         //  Roo.log(data);
271                           _this.form.findField('bodytext').setValue(data);
272                       }
273                   });
274               }
275             },
276             xns : Roo.menu,
277             '|xns' : 'Roo.menu'
278            },
279            {
280             xtype : 'Item',
281             text : _this._strings['1bd18d39370b7f26c1c5e18067b74c6f'] /* Html File */,
282             listeners : {
283              click : function (_self, e)
284               {
285                   Pman.Dialog.Image.show({
286                       _url : baseURL + '/Core/ImportMailMessage.php'
287                   }, function(data) {
288                       if  (data) {
289                           _this.form.findField('bodytext').setValue(data);
290                       }
291                   });
292               }
293             },
294             xns : Roo.menu,
295             '|xns' : 'Roo.menu'
296            }
297           ]
298          }
299         },
300         {
301          xtype : 'Button',
302          text : _this._strings['884df8e413319ff51a3f5f528606238a'] /* Use template */,
303          xns : Roo.Toolbar,
304          '|xns' : 'Roo.Toolbar',
305          menu : {
306           xtype : 'Menu',
307           xns : Roo.menu,
308           '|xns' : 'Roo.menu',
309           items  : [
310            {
311             xtype : 'Item',
312             text : _this._strings['dc0de523c25be298ba751c63c694109e'] /* Responsive Email (1) */,
313             listeners : {
314              click : function (_self, e)
315               {
316               
317                   var l = document.location;
318                   new Pman.Request({
319               
320                       url : baseURL + '/Core/ImportMailMessage.php',
321               
322                       method: 'POST',
323                       mask : "Loading",
324                       params : {
325                             importUrl : l.protocol +'//' + l.host +   rootURL + '/Pman/Crm/mail_templates/responsive1.html'
326                      },
327                       success : function (res) {
328               
329                        _this.form.findField('bodytext').setValue(res.data);
330                       }
331                 
332                   });
333               }
334             },
335             xns : Roo.menu,
336             '|xns' : 'Roo.menu'
337            }
338           ]
339          }
340         },
341         {
342          xtype : 'ComboBox',
343          allowBlank : true,
344          alwaysQuery : true,
345          displayField : 'file',
346          editable : false,
347          emptyText : _this._strings['31bb2f6e9b8fb11cbb7fb63c6025223f'] /* Select Template */,
348          fieldLabel : _this._strings['278c491bdd8a53618c149c4ac790da34'] /* Template */,
349          forceSelection : true,
350          hiddenName : 'template',
351          listWidth : 400,
352          loadingText : _this._strings['1243daf593fa297e07ab03bf06d925af'] /* Searching... */,
353          minChars : 2,
354          name : 'template',
355          pageSize : 20,
356          qtip : _this._strings['31bb2f6e9b8fb11cbb7fb63c6025223f'] /* Select Template */,
357          selectOnFocus : true,
358          tpl : '<div class=\"x-grid-cell-text x-btn button\"><b>{file}</b> </div>',
359          triggerAction : 'all',
360          typeAhead : true,
361          valueField : 'file',
362          width : 200,
363          listeners : {
364           select : function (combo, record, index)
365            {
366               
367            /*
368                (function() { 
369                    combo.setValue('');
370                }).defer(100);
371            */    
372                if(!record){
373                    return;
374                }
375                _this.form.findField('bodytext').setValue(record.data.content);
376            
377            }
378          },
379          xns : Roo.form,
380          '|xns' : 'Roo.form',
381          store : {
382           xtype : 'Store',
383           remoteSort : true,
384           sortInfo : { direction : 'DESC', field: 'file' },
385           listeners : {
386            beforeload : function (_self, o){
387                 o.params = o.params || {};
388                 // set more here
389                
390             }
391           },
392           xns : Roo.data,
393           '|xns' : 'Roo.data',
394           proxy : {
395            xtype : 'HttpProxy',
396            method : 'GET',
397            url : baseURL + '/Core/MailTemplateList.php',
398            xns : Roo.data,
399            '|xns' : 'Roo.data'
400           },
401           reader : {
402            xtype : 'JsonReader',
403            fields : [{"name":"file","type":"string"},{"name":"content","type":"string"}],
404            id : 'name',
405            root : 'data',
406            totalProperty : 'total',
407            xns : Roo.data,
408            '|xns' : 'Roo.data'
409           }
410          }
411         },
412         {
413          xtype : 'Fill',
414          xns : Roo.Toolbar,
415          '|xns' : 'Roo.Toolbar'
416         },
417         {
418          xtype : 'Button',
419          text : _this._strings['ea30b40c3caf28acb29198d20d243e54'] /* Images / Attachments >> */,
420          listeners : {
421           click : function (_self, e)
422            {
423                var el = _this.dialog.layout.getRegion('east');
424                if (el.visible) {
425                    el.hide();
426                } else {
427                    el.show();
428                    el.showPanel(0);
429                }
430                
431            }
432          },
433          xns : Roo.Toolbar,
434          '|xns' : 'Roo.Toolbar'
435         }
436        ]
437       },
438       layout : {
439        xtype : 'BorderLayout',
440        xns : Roo,
441        '|xns' : 'Roo',
442        center : {
443         xtype : 'LayoutRegion',
444         autoScroll : true,
445         xns : Roo,
446         '|xns' : 'Roo'
447        },
448        items  : [
449         {
450          xtype : 'ContentPanel',
451          autoScroll : false,
452          background : false,
453          fitContainer : true,
454          fitToFrame : true,
455          region : 'center',
456          title : _this._strings['4c2a8fe7eaf24721cc7a9f0175115bd4'] /* Message */,
457          listeners : {
458           render : function (_self, width, height)
459            {
460                
461                  Roo.log("RESIZE, " + width + ',' + height);
462                
463                var ew = Math.max(250, width-50);
464                var eh = Math.max(250,height-50) ;
465                
466               
467            
468            },
469           resize : function (_self, width, height)\r
470            {\r
471               var ew = Math.max(250, width-50);\r
472                var eh = Math.max(250,height-50) ;
473                
474                if (!_this.form) {\r
475                    return;\r
476                }\r
477                var bdtext = _this.form.findField('bodytext');\r
478                var ptext = _this.form.findField('plaintext');\r
479                if(bdtext.resizeEl){\r
480                    bdtext.width = ew-50;\r
481                    bdtext.resizeEl.resizeTo.defer(110, bdtext.resizeEl,[ bdtext.width, bdtext.height  ] );\r
482                    ptext.setSize(bdtext.width , bdtext.height);\r
483                }\r\r
484            \r
485            }
486          },
487          xns : Roo,
488          '|xns' : 'Roo',
489          items  : [
490           {
491            xtype : 'Form',
492            labelAlign : 'right',
493            labelWidth : 120,
494            method : 'POST',
495            preValidate : function(done_callback) {
496                
497                Roo.MessageBox.progress("Uploading Images", "Uploading");
498                
499                if(!_this.form.findField('bodytext').editorcore.sourceEditMode){
500                    _this.form.findField('bodytext').syncValue();
501                }else{
502                    _this.form.findField('bodytext').pushValue();
503                }
504                
505                var html = _this.form.findField('bodytext').getValue();
506                
507                var s = Roo.get(_this.form.findField('bodytext').editorcore.doc.documentElement);
508                
509                var ontable = (_this.data.module) ? _this.data.module : 'crm_mailing_list_message';
510                
511                var nodes = [];
512                s.select('img[src]').each(function(i) {
513                    nodes.push(i.dom);
514                });
515                var total = nodes.length;
516                var mkimg = function() {
517                
518                    if (!nodes.length) {
519                          Roo.MessageBox.hide();
520                          _this.form.findField('bodytext').syncValue();
521                          done_callback(true);
522                       //    _this.form.doAction("submit");
523                          return;
524                    }
525                    var i = nodes.pop(); 
526                    
527                    var n = i.getAttribute('src').match(/(baseURL|server_baseurl)/);
528                    
529                    if(n){
530                        mkimg();
531                        return;
532                    }
533                    
534                    n = i.getAttribute('src').match(/^http(.*)/);
535                   
536                    if(!n ){
537                        mkimg();
538                        return;
539                    }
540                    
541                    new Pman.Request({
542                        url : baseURL + '/Roo/Images.php',
543                        method : 'POST',
544                        params : {
545                            onid : _this.form.findField('id').getValue(),
546                            ontable : ontable ,
547                            _remote_upload : i.src
548                        },
549                        success : function(res){
550                            if(res.success == true){      
551                                i.setAttribute('src', res.data);
552                                Roo.MessageBox.updateProgress( (total - nodes.length) / total , "Done " + (total - nodes.length) + '/' + total);
553                            }
554                            mkimg();
555                        }
556                    });
557                   
558                }
559                
560                if (!_this.form.findField('bodytext').getValue().match(/unsubscribe/i)) {
561                    Roo.MessageBox.confirm("Missing unusubscribe",
562                        "There is no unsubscribe link on the email  are you sure you want to save it",
563                        function(res) {
564                            if (res == 'no') {
565                                return;
566                            }
567                            mkimg();
568                        }
569                    );
570            
571                    return;
572                }
573                
574                mkimg();
575            },
576            style : 'margin:10px',
577            url : baseURL + '/Roo/crm_mailing_list_message.php',
578            listeners : {
579             actioncomplete : function(_self,action)
580              {
581                 
582                  if (action.type == 'setdata') {
583                  
584                      setInterval(_this.form.findField('bodytext').autosave, 5000);
585                      
586                      _this.data.module = _this.data.module || 'crm_mailing_list_message';
587                      
588                      _this.form.url = baseURL + '/Roo/' + _this.data.module;
589                      
590                      _this.html_preview.hide();
591                      _this.preview_btn.hide();
592                          
593                      if(_this.data.id*1 > 0){
594                          _this.dialog.el.mask("Loading");
595                          this.load({ method: 'GET', params: { '_id' : _this.data.id }});
596                          _this.html_preview.show();
597                          _this.preview_btn.show();
598                          
599                      } else {
600                          _this.form.setValues({
601                              'from_name' : Pman.Login.authUser.name,
602                              'from_email' : Pman.Login.authUser.email
603                          });
604                      }
605                     return;
606                  }
607                  if (action.type == 'load') {
608                      _this.dialog.el.unmask();
609                      
610                      _this.form.findField('bodytext').originalValue = _this.form.findField('bodytext').getValue();
611                      
612                      return;
613                  }
614                  if (action.type =='submit') {
615                  
616                      _this.dialog.el.unmask();
617                      _this.dialog.hide();
618                  
619                       if (_this.callback) {
620                          _this.callback.call(_this, action.result.data);
621                       }
622                       _this.form.reset();
623                       return;
624                  }
625              },
626             rendered : function (form)
627              {
628                  _this.form= form;
629              }
630            },
631            xns : Roo.form,
632            '|xns' : 'Roo.form',
633            items  : [
634             {
635              xtype : 'Row',
636              xns : Roo.form,
637              '|xns' : 'Roo.form',
638              items  : [
639               {
640                xtype : 'TextField',
641                allowBlank : false,
642                fieldLabel : _this._strings['b20a8b77b05d53b4e695738731400c85'] /* Mailout Name */,
643                name : 'name',
644                width : 400,
645                xns : Roo.form,
646                '|xns' : 'Roo.form'
647               },
648               {
649                xtype : 'Column',
650                hideLabels : true,
651                xns : Roo.form,
652                '|xns' : 'Roo.form',
653                items  : [
654                 {
655                  xtype : 'Checkbox',
656                  boxLabel : _this._strings['28690be026c0bb9003aa58e45e5662ca'] /* Enabled - will be sent out */,
657                  checked : true,
658                  name : 'active',
659                  value : 1,
660                  valueOff : 0,
661                  listeners : {
662                   check : function (_self, checked)
663                    {
664                        var boxLabel = 'Enabled - will be sent out';
665                        
666                        if(!checked){
667                            boxLabel = 'Disabled - will NOT be sent out';
668                        }
669                        
670                        this.setBoxLabel(boxLabel);
671                    }
672                  },
673                  xns : Roo.form,
674                  '|xns' : 'Roo.form'
675                 }
676                ]
677               }
678              ]
679             },
680             {
681              xtype : 'Row',
682              xns : Roo.form,
683              '|xns' : 'Roo.form',
684              items  : [
685               {
686                xtype : 'TextField',
687                allowBlank : false,
688                fieldLabel : _this._strings['5da618e8e4b89c66fe86e32cdafde142'] /* From */,
689                name : 'from_name',
690                width : 300,
691                xns : Roo.form,
692                '|xns' : 'Roo.form'
693               },
694               {
695                xtype : 'TextField',
696                allowBlank : false,
697                fieldLabel : _this._strings['b357b524e740bc85b9790a0712d84a30'] /* Email address */,
698                name : 'from_email',
699                width : 300,
700                xns : Roo.form,
701                '|xns' : 'Roo.form'
702               },
703               {
704                xtype : 'ComboBox',
705                allowBlank : true,
706                alwaysQuery : true,
707                displayField : 'name',
708                editable : false,
709                emptyText : _this._strings['2c466a2c159463f1d9ef5a7b57b52827'] /* Select BCC Group */,
710                fieldLabel : _this._strings['68b00d723d37122f64da8d9939f836f0'] /* BCC Group */,
711                forceSelection : true,
712                hiddenName : 'bcc_group_id',
713                loadingText : _this._strings['1243daf593fa297e07ab03bf06d925af'] /* Searching... */,
714                minChars : 2,
715                name : 'bcc_group_id_name',
716                pageSize : 25,
717                qtip : _this._strings['2c466a2c159463f1d9ef5a7b57b52827'] /* Select BCC Group */,
718                selectOnFocus : true,
719                tpl : '<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>',
720                triggerAction : 'all',
721                typeAhead : true,
722                valueField : 'id',
723                width : 300,
724                xns : Roo.form,
725                '|xns' : 'Roo.form',
726                store : {
727                 xtype : 'Store',
728                 remoteSort : true,
729                 sortInfo : { direction : 'ASC', field: 'name' },
730                 listeners : {
731                  beforeload : function (_self, o){
732                       o.params = o.params || {};
733                       
734                       o.params._direct_return = 1;
735                   }
736                 },
737                 xns : Roo.data,
738                 '|xns' : 'Roo.data',
739                 proxy : {
740                  xtype : 'HttpProxy',
741                  method : 'GET',
742                  url : baseURL + '/Roo/Core_group',
743                  xns : Roo.data,
744                  '|xns' : 'Roo.data'
745                 },
746                 reader : {
747                  xtype : 'JsonReader',
748                  fields : [{"name":"name","type":"string"},{"name":"id","type":"int"}],
749                  id : 'name',
750                  root : 'data',
751                  totalProperty : 'total',
752                  xns : Roo.data,
753                  '|xns' : 'Roo.data'
754                 }
755                }
756               }
757              ]
758             },
759             {
760              xtype : 'TextField',
761              allowBlank : false,
762              fieldLabel : _this._strings['c7892ebbb139886662c6f2fc8c450710'] /* Subject */,
763              name : 'subject',
764              width : 600,
765              xns : Roo.form,
766              '|xns' : 'Roo.form'
767             },
768             {
769              xtype : 'Row',
770              hideLabels : true,
771              xns : Roo.form,
772              '|xns' : 'Roo.form',
773              items  : [
774               {
775                xtype : 'FieldSet',
776                hideLabels : true,
777                legend : _this._strings['962b90039a542a29cedd51d87a9f28a1'] /* Html Editor */,
778                style : 'text-align:center;',
779                xns : Roo.form,
780                '|xns' : 'Roo.form',
781                items  : [
782                 {
783                  xtype : 'HtmlEditor',
784                  allowComments : true,
785                  autosave : function() {
786                      
787                      var body = _this.form.findField('bodytext');
788                      
789                      if(!body.wrap.isVisible(true) || body.getValue() == '' || !body.isDirty()){
790                          Roo.log('body not dirty');
791                          return;
792                      }
793                      
794                      Roo.log('body dirty, auto save!');
795                      
796                      body.fireEvent('autosave', body);
797                     
798                  },
799                  clearUp : false,
800                  cwhite : [ 
801                      'background',
802                      'background-color',
803                      'border',
804                      'border-radius',
805                      'border-bottom',
806                      'border-collapse',
807                      'box-shadow',
808                      'clear',
809                      'color',
810                      'cursor',
811                      'display',
812                      'float' ,
813                      'font-family',
814                      'font-size',
815                      'font-weight',
816                      'height',
817                      'left',
818                      'line-height',
819                      'list-style',
820                      'margin',
821                      'margin-bottom',
822                      'margin-left',
823                      'margin-right',
824                      'margin-top',
825                      'max-width',
826                      'min-height',
827                      '-ms-interpolation-mode',
828                      'mso-table-rspace',
829                      '-ms-text-size-adjust',
830                      'outline',
831                      'overflow',
832                      'padding',
833                      'padding-bottom',
834                      'padding-left',
835                      'padding-right',
836                      'padding-top',
837                      'position',
838                      'right',
839                      'text-align',
840                      'text-decoration',
841                      'top',
842                      'vertical-align',
843                      '-webkit-text-size-adjust',
844                      'width',
845                      'width',
846                      'z-index'
847                   ],
848                  height : 250,
849                  name : 'bodytext',
850                  resizable : 's',
851                  listeners : {
852                   autosave : function (_self)
853                    {
854                        Roo.log('autosave');
855                        
856                        var id = _this.form.findField('id').getValue() * 1;
857                        
858                        /*
859                        if(!_self.editorcore.sourceEditMode){
860                            _self.syncValue();
861                        }else{
862                            _self.pushValue();
863                        }
864                        */
865                        
866                        new Pman.Request({
867                            url : baseURL + '/Roo/Events.php',
868                            method :'POST',
869                            params : {
870                                id : 0,
871                                action : 'AUTOSAVE',
872                                on_id : (id > 0) ? id : 0,
873                                on_table : 'crm_mailing_list_message',
874                                remarks : 'BODY',
875                                source: _self.getValue()
876                            },
877                            success : function() {
878                                _self.originalValue = _self.getValue();
879                                
880                            },
881                            failure : function() 
882                            {
883                                Roo.log('body autosave failed?!');
884                            }
885                        });
886                        
887                    },
888                   savedpreview : function (_self)
889                    {
890                        var id = _this.form.findField('id').getValue() * 1;
891                        
892                        var successFn = function(res){
893                            return res.data.POST.source;
894                        };
895                        
896                        var params = {
897                            action : 'AUTOSAVE',
898                            remarks : 'BODY',
899                            on_id : (id < 1) ? 0 : id,
900                            on_table : 'crm_mailing_list_message',
901                            successFn : successFn
902                        };
903                        
904                        
905                        Pman.Dialog.CoreAutoSavePreview.show(params, function(res){
906                            _self.setValue(res);
907                            _self.originalValue = res;
908                        });
909                    }
910                  },
911                  xns : Roo.form,
912                  '|xns' : 'Roo.form',
913                  toolbars : [
914                   {
915                    xtype : 'ToolbarContext',
916                    xns : Roo.form.HtmlEditor,
917                    '|xns' : 'Roo.form.HtmlEditor'
918                   },
919                   {
920                    xtype : 'ToolbarStandard',
921                    xns : Roo.form.HtmlEditor,
922                    '|xns' : 'Roo.form.HtmlEditor',
923                    btns : [
924                     {
925                      xtype : 'ComboBox',
926                      alwaysQuery : true,
927                      displayField : 'name',
928                      editable : false,
929                      emptyText : _this._strings['b9c49611cfda3259a2b837b39489e650'] /* Add Image */,
930                      fieldLabel : _this._strings['fff0d600f8a0b5e19e88bfb821dd1157'] /* Images */,
931                      forceSelection : true,
932                      listWidth : 400,
933                      loadingText : _this._strings['1243daf593fa297e07ab03bf06d925af'] /* Searching... */,
934                      minChars : 2,
935                      pageSize : 20,
936                      qtip : _this._strings['2f26e35d61be90501e099089dc533638'] /* Select Images */,
937                      selectOnFocus : true,
938                      tpl : '<div class=\"x-grid-cell-text x-btn button\"><img src=\"{public_baseURL}/Core/Images/Thumb/150x150/{id}.jpg\" height=\"150\" width=\"150\"><b>{filename}</b> </div>',
939                      triggerAction : 'all',
940                      typeAhead : true,
941                      valueField : 'id',
942                      width : 100,
943                      listeners : {
944                       beforequery : function (combo, query, forceAll, cancel, e)
945                        {
946                            var id = _this.form.findField('id').getValue() * 1;    
947                            if (!id) {
948                                Roo.MessageBox.alert("Error", "Save message first");
949                                return false;
950                            }
951                        },
952                       render : function (_self)
953                        {
954                            _this.extendimgselect = _self;
955                        },
956                       select : function (combo, record, index)
957                        {
958                            Roo.log(record);
959                            (function() { 
960                                combo.setValue('');
961                            }).defer(100);
962                            var editor = _this.form.findField('bodytext').editorcore;
963                            
964                            var curnode = editor.getSelectedNode();
965                            if (curnode && curnode.tagName == 'IMG') {
966                                curnode.src= String.format('{0}/Images/{1}/{2}#image-{1}',
967                                        baseURL,  record.data.id, record.data.filename
968                                    );
969                                    // note -forces an update... hopefully...
970                                editor.owner.fireEvent('editorevent', editor, false);
971                            } else {
972                            
973                                editor.insertAtCursor(
974                                    String.format('<img src="{0}/Images/{1}/{2}#image-{1}">',
975                                    baseURL,  record.data.id, record.data.filename
976                                    )
977                                );
978                        
979                            }
980                            
981                         }
982                      },
983                      xns : Roo.form,
984                      '|xns' : 'Roo.form',
985                      store : {
986                       xtype : 'Store',
987                       remoteSort : true,
988                       sortInfo : { direction : 'ASC', field: 'id' },
989                       listeners : {
990                        beforeload : function (_self, o){
991                             o.params = o.params || {};
992                         
993                             var id = _this.form.findField('id').getValue() * 1;    
994                             if (!id) {
995                                 Roo.MessageBox.alert("Error", "Save email template first");
996                                 return false;
997                             }
998                             o.params.onid = id;
999                             o.params.ontable = (_this.data.module) ? _this.data.module : 'crm_mailing_list_message';
1000                             
1001                            // o.params.imgtype = 'PressRelease';
1002                             //o.params['query[imagesize]'] = '150x150';
1003                             // set more here
1004                         }
1005                       },
1006                       xns : Roo.data,
1007                       '|xns' : 'Roo.data',
1008                       proxy : {
1009                        xtype : 'HttpProxy',
1010                        method : 'GET',
1011                        url : baseURL + '/Roo/Images.php',
1012                        xns : Roo.data,
1013                        '|xns' : 'Roo.data'
1014                       },
1015                       reader : {
1016                        xtype : 'JsonReader',
1017                        fields : [{"name":"id","type":"int"},{"name":"filename","type":"string"},{"name":"url_thumb","type":"string"}],
1018                        id : 'id',
1019                        root : 'data',
1020                        totalProperty : 'total',
1021                        xns : Roo.data,
1022                        '|xns' : 'Roo.data'
1023                       }
1024                      }
1025                     },
1026                     {
1027                      xtype : 'ComboBox',
1028                      alwaysQuery : true,
1029                      displayField : 'name',
1030                      editable : false,
1031                      emptyText : _this._strings['5feb9bf3c03b32635135006cbacb9542'] /* Insert Field */,
1032                      fieldLabel : _this._strings['6f16a5f8ff5d75ab84c018adacdfcbb7'] /* Field */,
1033                      forceSelection : true,
1034                      listWidth : 400,
1035                      loadingText : _this._strings['1243daf593fa297e07ab03bf06d925af'] /* Searching... */,
1036                      minChars : 2,
1037                      pageSize : 20,
1038                      qtip : _this._strings['5feb9bf3c03b32635135006cbacb9542'] /* Insert Field */,
1039                      selectOnFocus : true,
1040                      tpl : '<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>',
1041                      triggerAction : 'all',
1042                      typeAhead : true,
1043                      valueField : 'type',
1044                      width : 100,
1045                      listeners : {
1046                       render : function (_self)
1047                        {
1048                            _this.unsubscribeselect = _self;
1049                        },
1050                       select : function (combo, record, index)
1051                        {
1052                            Roo.log(record);
1053                            (function() { 
1054                                combo.setValue('');
1055                            }).defer(100);
1056                            var editor = _this.form.findField('bodytext').editorcore;
1057                            
1058                            if(record.data.name == 'Unsubscribe'){
1059                                editor.insertAtCursor(
1060                                    String.format('<a href="{0}">{1}</a>',
1061                                        record.data.type,  record.data.name
1062                                    )
1063                                );
1064                                return;     
1065                            }
1066                            
1067                            editor.insertAtCursor(
1068                                String.format('{0}',
1069                                    record.data.type
1070                                )
1071                            );
1072                            
1073                         }
1074                      },
1075                      xns : Roo.form,
1076                      '|xns' : 'Roo.form',
1077                      store : {
1078                       xtype : 'SimpleStore',
1079                       data : [ 
1080                           [ '{person.firstname}', "First Name"],
1081                           [ '{person.lastname}' , "Last Name"],
1082                           [ '{person.name}', "Full Name"],
1083                           [ '#unsubscribe', "Unsubscribe"]
1084                       ],
1085                       fields : [  'type', 'name'],
1086                       xns : Roo.data,
1087                       '|xns' : 'Roo.data'
1088                      }
1089                     },
1090                     {
1091                      xtype : 'Separator',
1092                      xns : Roo.Toolbar,
1093                      '|xns' : 'Roo.Toolbar'
1094                     },
1095                     {
1096                      xtype : 'Button',
1097                      cls : 'x-init-enable',
1098                      text : _this._strings['bd88a20b53a47f7b5704a83a15ff5506'] /* Saved Version */,
1099                      listeners : {
1100                       click : function (_self, e)
1101                        {
1102                            this.scope.owner.fireEvent('savedpreview', this.scope.owner);
1103                            
1104                        }
1105                      },
1106                      xns : Roo.Toolbar,
1107                      '|xns' : 'Roo.Toolbar'
1108                     }
1109                    ]
1110                   }
1111                  ]
1112                 }
1113                ]
1114               }
1115              ]
1116             },
1117             {
1118              xtype : 'Row',
1119              hideLabels : true,
1120              xns : Roo.form,
1121              '|xns' : 'Roo.form',
1122              items  : [
1123               {
1124                xtype : 'Button',
1125                text : _this._strings['e9968623956c15023d54335ea3699855'] /* Convert Html to Text */,
1126                listeners : {
1127                 click : function (_self, e)
1128                  {
1129                      var h = _this.form.findField('bodytext').getValue();
1130                      var p = _this.form.findField('plaintext');
1131                      
1132                      new Pman.Request({\r
1133                          url : baseURL + '/Core/ImportMailMessage.php',\r
1134                          method : 'POST',\r
1135                          params : {
1136                            bodytext : h,\r
1137                            _convertToPlain : true,
1138                            _check_unsubscribe : true\r
1139                          }, \r
1140                          success : function(res) {\r
1141                              if(res.success == true){
1142                                 p.setValue(res.data);
1143                              }\r
1144                          }\r
1145                      });
1146                      
1147                  }
1148                },
1149                xns : Roo,
1150                '|xns' : 'Roo'
1151               }
1152              ]
1153             },
1154             {
1155              xtype : 'Row',
1156              hideLabels : true,
1157              xns : Roo.form,
1158              '|xns' : 'Roo.form',
1159              items  : [
1160               {
1161                xtype : 'FieldSet',
1162                hideLabels : true,
1163                legend : _this._strings['e44b145bd8b49b06e0ad2ced1ad56466'] /* Plain Text */,
1164                style : 'text-align:center;',
1165                xns : Roo.form,
1166                '|xns' : 'Roo.form',
1167                items  : [
1168                 {
1169                  xtype : 'TextArea',
1170                  height : 50,
1171                  name : 'plaintext',
1172                  xns : Roo.form,
1173                  '|xns' : 'Roo.form'
1174                 }
1175                ]
1176               }
1177              ]
1178             },
1179             {
1180              xtype : 'Row',
1181              xns : Roo.form,
1182              '|xns' : 'Roo.form',
1183              items  : [
1184               {
1185                xtype : 'TextField',
1186                allowBlank : true,
1187                fieldLabel : _this._strings['b337c8a67244afb6551ee1f8f9717676'] /* Test Class <BR/> (for system reference only) */,
1188                name : 'test_class',
1189                readOnly : true,
1190                width : 300,
1191                xns : Roo.form,
1192                '|xns' : 'Roo.form'
1193               }
1194              ]
1195             },
1196             {
1197              xtype : 'Hidden',
1198              name : 'id',
1199              xns : Roo.form,
1200              '|xns' : 'Roo.form'
1201             }
1202            ]
1203           }
1204          ]
1205         }
1206        ]
1207       }
1208      },
1209      {
1210       xtype : 'GridPanel',
1211       autoScroll : false,
1212       background : false,
1213       fitContainer : true,
1214       fitToframe : true,
1215       region : 'east',
1216       tableName : 'Images',
1217       title : _this._strings['308f2757bfc9ce92fb00ff93fdffd279'] /* Images / Attachments */,
1218       listeners : {
1219        activate : function() {
1220             _this.ipanel = this;
1221             if (_this.igrid) {
1222                _this.igrid.ds.load({});
1223             }
1224         }
1225       },
1226       xns : Roo,
1227       '|xns' : 'Roo',
1228       grid : {
1229        xtype : 'Grid',
1230        autoExpandColumn : 'filename',
1231        loadMask : true,
1232        listeners : {
1233         render : function() 
1234          {
1235              _this.igrid = this; 
1236              //_this.dialog = Pman.Dialog.FILL_IN
1237              if (_this.ipanel.active) {
1238             //    _this.igrid.ds.load({});
1239              }
1240          }
1241        },
1242        xns : Roo.grid,
1243        '|xns' : 'Roo.grid',
1244        toolbar : {
1245         xtype : 'Toolbar',
1246         xns : Roo,
1247         '|xns' : 'Roo',
1248         items  : [
1249          {
1250           xtype : 'Button',
1251           cls : 'x-btn-text-icon',
1252           icon : Roo.rootURL + 'images/default/dd/drop-add.gif',
1253           text : _this._strings['ec211f7c20af43e742bf2570c3cb84f9'] /* Add */,
1254           listeners : {
1255            click : function()
1256             {
1257                 var id = _this.form.findField('id').getValue();
1258                 
1259                 if(id*1 < 1){
1260                     Roo.MessageBox.alert('Error', 'Please save the email template first');
1261                     return;
1262                 }
1263                 
1264                 var ontable = (_this.data.module) ? _this.data.module : 'crm_mailing_list_message';
1265                 
1266                 Pman.Dialog.Image.show( { id : 0, onid: id, ontable: ontable }, function() {
1267                     _this.igrid.getDataSource().load({});
1268                 });
1269             }
1270           },
1271           xns : Roo.Toolbar,
1272           '|xns' : 'Roo.Toolbar'
1273          },
1274          {
1275           xtype : 'Button',
1276           cls : 'x-btn-text-icon',
1277           icon : rootURL + '/Pman/templates/images/trash.gif',
1278           text : _this._strings['f2a6c498fb90ee345d997f888fce3b18'] /* Delete */,
1279           listeners : {
1280            click : function()
1281             {
1282                 var s = _this.igrid.getSelectionModel().getSelected();
1283                 if (!s || isNaN(s.id *1)) {
1284                     Roo.MessageBox.alert("Error", "Select a image"); 
1285                     return;
1286                 }
1287                 Roo.MessageBox.confirm("Confirm", "Are sure you want to delete this image?", function (v){
1288                     if (v != 'yes') {
1289                         return;
1290                     }
1291                     
1292                     new Pman.Request({
1293                         url : baseURL + '/Roo/Images.php',
1294                         method: 'POST',
1295                         params : {
1296                             _delete : s.id
1297                         },
1298                         success : function()
1299                         {
1300                             Roo.log('Got Success!!');
1301                            _this.igrid.ds.load({});
1302                         }
1303                     });
1304                 });
1305             }
1306           },
1307           xns : Roo.Toolbar,
1308           '|xns' : 'Roo.Toolbar'
1309          }
1310         ]
1311        },
1312        dataSource : {
1313         xtype : 'Store',
1314         remoteSort : true,
1315         sortInfo : { field : 'filename', direction: 'ASC' },
1316         listeners : {
1317          beforeload : function (_self, options)
1318           {
1319               options.params = options.params || {};
1320               if (typeof(_this.data) == 'undefined') {
1321                   return false;
1322               }
1323               if(_this.data.id * 1 >= 0)
1324               {
1325                   options.params.onid = _this.data.id;
1326           
1327                   options.params.ontable = (_this.data.module) ? _this.data.module : 'crm_mailing_list_message';
1328               }
1329           }
1330         },
1331         xns : Roo.data,
1332         '|xns' : 'Roo.data',
1333         proxy : {
1334          xtype : 'HttpProxy',
1335          method : 'GET',
1336          url : baseURL + '/Roo/Images.php',
1337          xns : Roo.data,
1338          '|xns' : 'Roo.data'
1339         },
1340         reader : {
1341          xtype : 'JsonReader',
1342          fields : [
1343              {
1344                  'name': 'id',
1345                  'type': 'int'
1346              },
1347              {
1348                  'name': 'filename',
1349                  'type': 'string'
1350              },
1351              {
1352                  'name': 'ontable',
1353                  'type': 'string'
1354              },
1355              {
1356                  'name': 'onid',
1357                  'type': 'int'
1358              },
1359              {
1360                  'name': 'mimetype',
1361                  'type': 'string'
1362              },
1363              {
1364                  'name': 'width',
1365                  'type': 'int'
1366              },
1367              {
1368                  'name': 'height',
1369                  'type': 'int'
1370              },
1371              {
1372                  'name': 'filesize',
1373                  'type': 'int'
1374              },
1375              {
1376                  'name': 'displayorder',
1377                  'type': 'int'
1378              },
1379              {
1380                  'name': 'language',
1381                  'type': 'string'
1382              },
1383              {
1384                  'name': 'parent_image_id',
1385                  'type': 'int'
1386              },
1387              {
1388                  'name': 'created',
1389                  'type': 'date',
1390                  'dateFormat': 'Y-m-d'
1391              },
1392              {
1393                  'name': 'imgtype',
1394                  'type': 'string'
1395              },
1396              {
1397                  'name': 'linkurl',
1398                  'type': 'string'
1399              },
1400              {
1401                  'name': 'descript',
1402                  'type': 'string'
1403              },
1404              {
1405                  'name': 'title',
1406                  'type': 'string'
1407              },
1408              {
1409                  'name': 'parent_image_id_id',
1410                  'type': 'int'
1411              },
1412              {
1413                  'name': 'parent_image_id_filename',
1414                  'type': 'string'
1415              },
1416              {
1417                  'name': 'parent_image_id_ontable',
1418                  'type': 'string'
1419              },
1420              {
1421                  'name': 'parent_image_id_onid',
1422                  'type': 'int'
1423              },
1424              {
1425                  'name': 'parent_image_id_mimetype',
1426                  'type': 'string'
1427              },
1428              {
1429                  'name': 'parent_image_id_width',
1430                  'type': 'int'
1431              },
1432              {
1433                  'name': 'parent_image_id_height',
1434                  'type': 'int'
1435              },
1436              {
1437                  'name': 'parent_image_id_filesize',
1438                  'type': 'int'
1439              },
1440              {
1441                  'name': 'parent_image_id_displayorder',
1442                  'type': 'int'
1443              },
1444              {
1445                  'name': 'parent_image_id_language',
1446                  'type': 'string'
1447              },
1448              {
1449                  'name': 'parent_image_id_parent_image_id',
1450                  'type': 'int'
1451              },
1452              {
1453                  'name': 'parent_image_id_created',
1454                  'type': 'date'
1455              },
1456              {
1457                  'name': 'parent_image_id_imgtype',
1458                  'type': 'string'
1459              },
1460              {
1461                  'name': 'parent_image_id_linkurl',
1462                  'type': 'string'
1463              },
1464              {
1465                  'name': 'parent_image_id_descript',
1466                  'type': 'string'
1467              },
1468              {
1469                  'name': 'parent_image_id_title',
1470                  'type': 'string'
1471              }
1472          ],
1473          id : 'id',
1474          root : 'data',
1475          totalProperty : 'total',
1476          xns : Roo.data,
1477          '|xns' : 'Roo.data'
1478         }
1479        },
1480        colModel : [
1481         {
1482          xtype : 'ColumnModel',
1483          dataIndex : 'filename',
1484          header : _this._strings['1351017ac6423911223bc19a8cb7c653'] /* Filename */,
1485          renderer : function(v,x,r)
1486          {
1487              var width = r.data.width;
1488              var height = r.data.height;
1489              
1490              if(width > 50){
1491                  height = Math.round(height * 50 / width);
1492                  width = 50;
1493              }
1494              
1495             return '<img src="' + baseURL + '/Images/' + r.data.id + '/' + r.data.filename + '" width="' + width + '" height="' + height + '" />';
1496          },
1497          width : 300,
1498          xns : Roo.grid,
1499          '|xns' : 'Roo.grid'
1500         },
1501         {
1502          xtype : 'ColumnModel',
1503          dataIndex : 'displayorder',
1504          header : _this._strings['2393ad754ba179442d85e415d1d5167c'] /* Displayorder */,
1505          renderer : function(v) { return String.format('{0}', v); },
1506          width : 75,
1507          xns : Roo.grid,
1508          '|xns' : 'Roo.grid'
1509         },
1510         {
1511          xtype : 'ColumnModel',
1512          dataIndex : 'title',
1513          header : _this._strings['b78a3223503896721cca1303f776159b'] /* Title */,
1514          renderer : function(v) { return String.format('{0}', v); },
1515          width : 75,
1516          xns : Roo.grid,
1517          '|xns' : 'Roo.grid'
1518         }
1519        ]
1520       }
1521      }
1522     ]
1523    });
1524  }
1525 };