Pman.Tab.BAdminEmailTemplates.bjs
[Pman.BAdmin] / Pman.Tab.BAdminEmailTemplates.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.Tab');
6
7 Pman.Tab.BAdminEmailTemplates = new Roo.XComponent({
8
9  _strings : {
10   'cdb6b6bab1fd18b9dbfe3fb84a5d34ae' :"<i class=\"fa fa-search\"></i>",
11   'cae905999a2ad1dfb8f4eae0e8cda73b' :"From Name<br/>Email",
12   '98d2ee61ddce0c7666297d81639914f1' :"To / BCC Group",
13   '73ea6b4441cdced246d236b22c8f991c' :"HTML File",
14   '694e249c3a9503141fa5ce3fb71d5477' :"<i class=\"fa fa-edit\"></i> Edit",
15   'cffbd822c38679e2fbf11cc182c945e5' :"search for email template",
16   '9e11143e29a031212f2cdefcf61f39e9' :"View Message",
17   'f49559cda3fb906fbd7736f8b8a0e37d' :"Email Template",
18   '27a7146e1e1890e289bc7fad72876831' :"<i class=\"fa fa-plus\"></i> Create a template",
19   'cd6df251f262cc64514b25f04aecf3c8' :"<i class=\"fa fa-clipboard\"></i> Copy",
20   'ed807858fcb68abdd180481f1fcba5c5' :"<i class=\"fa fa-trash\"></i> Delete",
21   '03c2e7e41ffc181a4e84080b4710e81e' :"New",
22   '4d3d769b812b6faa6b76e1a8abaece2d' :"Active",
23   'b5a7adde1af5c87d7fd797b6245c2a39' :"Description",
24   'e6b391a8d2c4d45902a23a8b6585703d' :"URL"
25  },
26
27   part     :  ["BAdmin", "EmailTemplates" ],
28   order    : '004-Pman.Tab.BAdminEmailTemplates',
29   region   : 'center',
30   parent   : 'Pman.Tab.BAdmin',
31   name     : "Pman.Tab.BAdminEmailTemplates",
32   disabled : false, 
33   permname : '', 
34   _tree : function(_data)
35   {
36    var _this = this;
37    var MODULE = this;
38    return {
39    xtype : 'Nest',
40    background : true,
41    title : _this._strings['f49559cda3fb906fbd7736f8b8a0e37d'] /* Email Template */,
42    xns : Roo.bootstrap.panel,
43    '|xns' : 'Roo.bootstrap.panel',
44    layout : {
45     xtype : 'Border',
46     xns : Roo.bootstrap.layout,
47     '|xns' : 'Roo.bootstrap.layout',
48     center : {
49      xtype : 'Region',
50      hideTabs : true,
51      tabPosition : 'top',
52      xns : Roo.bootstrap.layout,
53      '|xns' : 'Roo.bootstrap.layout'
54     },
55     south : {
56      xtype : 'Region',
57      autoScroll : true,
58      height : 200,
59      hideTabs : true,
60      split : true,
61      tabPosition : 'top',
62      titlebar : true,
63      xns : Roo.bootstrap.layout,
64      '|xns' : 'Roo.bootstrap.layout'
65     },
66     items  : [
67      {
68       xtype : 'Grid',
69       background : false,
70       closable : false,
71       fitContainer : true,
72       fitToFrame : true,
73       region : 'center',
74       listeners : {
75        activate : function (_self)
76         {
77             _this.edit_btn.hide();
78             _this.copy_btn.hide();
79             _this.delete_btn.hide();
80             
81             if (_this.table) {
82                 _this.table.footer.onClick('first');
83             }
84             
85         },
86        render : function (_self)
87         {
88             _this.grid = this;
89         }
90       },
91       xns : Roo.bootstrap.panel,
92       '|xns' : 'Roo.bootstrap.panel',
93       toolbar : {
94        xtype : 'NavSimplebar',
95        xns : Roo.bootstrap,
96        '|xns' : 'Roo.bootstrap',
97        items  : [
98         {
99          xtype : 'NavGroup',
100          xns : Roo.bootstrap,
101          '|xns' : 'Roo.bootstrap',
102          items  : [
103           {
104            xtype : 'NavItem',
105            xns : Roo.bootstrap,
106            '|xns' : 'Roo.bootstrap',
107            items  : [
108             {
109              xtype : 'Element',
110              xns : Roo.bootstrap,
111              '|xns' : 'Roo.bootstrap',
112              items  : [
113               {
114                xtype : 'Row',
115                cls : 'roo-toolbar',
116                xns : Roo.bootstrap,
117                '|xns' : 'Roo.bootstrap',
118                items  : [
119                 {
120                  xtype : 'Column',
121                  md : 4,
122                  xns : Roo.bootstrap,
123                  '|xns' : 'Roo.bootstrap',
124                  items  : [
125                   {
126                    xtype : 'Input',
127                    placeholder : _this._strings['cffbd822c38679e2fbf11cc182c945e5'] /* search for email template */,
128                    listeners : {
129                     render : function (_self)
130                      {
131                          _this.searchBox = this;
132                      },
133                     specialkey : function (_self, e)
134                      {    
135                           if(e.keyCode == e.ENTER) {
136                              if (_this.table) {
137                                  _this.table.footer.onClick('first'); 
138                              }
139                          
140                          }
141                          
142                      }
143                    },
144                    xns : Roo.bootstrap,
145                    '|xns' : 'Roo.bootstrap',
146                    after : {
147                     xtype : 'Button',
148                     html : _this._strings['cdb6b6bab1fd18b9dbfe3fb84a5d34ae'] /* <i class="fa fa-search"></i> */,
149                     listeners : {
150                      click : function (_self, e)
151                       {
152                           _this.table.footer.onClick('first');
153                       }
154                     },
155                     xns : Roo.bootstrap,
156                     '|xns' : 'Roo.bootstrap'
157                    }
158                   }
159                  ]
160                 },
161                 {
162                  xtype : 'Column',
163                  md : 8,
164                  style : 'text-align: right;',
165                  xns : Roo.bootstrap,
166                  '|xns' : 'Roo.bootstrap',
167                  items  : [
168                   {
169                    xtype : 'Button',
170                    cls : 'roo-toolbar-button',
171                    html : _this._strings['27a7146e1e1890e289bc7fad72876831'] /* <i class="fa fa-plus"></i> Create a template */,
172                    xns : Roo.bootstrap,
173                    '|xns' : 'Roo.bootstrap',
174                    menu : {
175                     xtype : 'Menu',
176                     xns : Roo.bootstrap,
177                     '|xns' : 'Roo.bootstrap',
178                     items  : [
179                      {
180                       xtype : 'MenuItem',
181                       fa : 'file-o',
182                       html : _this._strings['03c2e7e41ffc181a4e84080b4710e81e'] /* New */,
183                       listeners : {
184                        click : function (_self, e)
185                         {
186                             if (!_this.dialog) {
187                                 return;
188                             }
189                             
190                             _this.dialog.show( { id : 0, module : 'core_email' } , function() {
191                                 _this.table.footer.onClick('first');
192                            });
193                         }
194                       },
195                       xns : Roo.bootstrap,
196                       '|xns' : 'Roo.bootstrap'
197                      },
198                      {
199                       xtype : 'MenuItem',
200                       fa : 'link',
201                       html : _this._strings['e6b391a8d2c4d45902a23a8b6585703d'] /* URL */,
202                       listeners : {
203                        click : function (_self, e)
204                         {
205                             Pman.Dialog.BAdminImportUrl.show(
206                                 {
207                                     target : '/Core/ImportMailMessage.php'
208                                 },
209                             
210                                 function(data) {
211                                     if (data) {
212                                         Pman.Dialog.BAdminEmail.dialog.show();
213                                         Pman.Dialog.BAdminEmail.form.findField('bodytext').setValue(data);
214                                     }
215                                 }
216                             );
217                         }
218                       },
219                       xns : Roo.bootstrap,
220                       '|xns' : 'Roo.bootstrap'
221                      },
222                      {
223                       xtype : 'MenuItem',
224                       fa : 'code',
225                       html : _this._strings['73ea6b4441cdced246d236b22c8f991c'] /* HTML File */,
226                       listeners : {
227                        click : function (_self, e)
228                         {
229                             Pman.Dialog.BAdminImage.show(
230                                 {
231                                     _url : '/Core/ImportMailMessage.php'
232                                 },
233                             
234                                 function(data) {
235                                     if (data) {
236                                         Pman.Dialog.BAdminEmail.dialog.show();
237                                         Pman.Dialog.BAdminEmail.form.findField('bodytext').setValue(data);
238                                     }
239                                 }
240                             );
241                         }
242                       },
243                       xns : Roo.bootstrap,
244                       '|xns' : 'Roo.bootstrap'
245                      }
246                     ]
247                    }
248                   },
249                   {
250                    xtype : 'Button',
251                    cls : 'roo-toolbar-button',
252                    html : _this._strings['694e249c3a9503141fa5ce3fb71d5477'] /* <i class="fa fa-edit"></i> Edit */,
253                    listeners : {
254                     click : function (_self, e)
255                      {
256                          var sel = _this.grid.grid.selModel.getSelected();
257                          
258                          if (!sel || sel.data.id * 1 < 1) {
259                              Roo.MessageBox.alert("Error", "Select a message to edit");
260                              return;
261                          }
262                          
263                          Pman.Dialog.BAdminEmail.show( {id : sel.data.id, module : 'core_email'} , function() {
264                              _this.table.footer.onClick('first');
265                          }); 
266                      },
267                     render : function (_self)
268                      {
269                          _this.edit_btn = this;
270                          
271                          this.hide();
272                      }
273                    },
274                    xns : Roo.bootstrap,
275                    '|xns' : 'Roo.bootstrap'
276                   },
277                   {
278                    xtype : 'Button',
279                    cls : 'roo-toolbar-button',
280                    html : _this._strings['cd6df251f262cc64514b25f04aecf3c8'] /* <i class="fa fa-clipboard"></i> Copy */,
281                    listeners : {
282                     click : function (_self, e)
283                      {
284                          var sel = _this.grid.grid.selModel.getSelected();
285                          if (!sel) {
286                              Roo.MessageBox.alert("Error", "Select a message to copy");
287                              return;
288                          }
289                          new Pman.Request({
290                              url : baseURL + '/Roo/Core_email',
291                              method : 'POST',
292                              params : {
293                                  id : sel.data.id,
294                                  _make_copy : 1
295                              },
296                              success : function() {
297                                  _this.table.footer.onClick('refresh');
298                              }
299                          });
300                      },
301                     render : function (_self)
302                      {
303                          _this.copy_btn = this;
304                          
305                          this.hide();
306                      }
307                    },
308                    xns : Roo.bootstrap,
309                    '|xns' : 'Roo.bootstrap'
310                   },
311                   {
312                    xtype : 'Button',
313                    cls : 'roo-toolbar-button',
314                    html : _this._strings['ed807858fcb68abdd180481f1fcba5c5'] /* <i class="fa fa-trash"></i> Delete */,
315                    weight : 'primary',
316                    listeners : {
317                     click : function (_self, e)
318                      {
319                          Pman.genericDelete(_this.grid, 'core_email');
320                      },
321                     render : function (_self)
322                      {
323                          _this.delete_btn = this;
324                          
325                          this.hide();
326                      }
327                    },
328                    xns : Roo.bootstrap,
329                    '|xns' : 'Roo.bootstrap'
330                   }
331                  ]
332                 }
333                ]
334               }
335              ]
336             }
337            ]
338           }
339          ]
340         }
341        ]
342       },
343       grid : {
344        xtype : 'Table',
345        cellSelection : true,
346        hover : true,
347        loadMask : true,
348        responsive : true,
349        rowSelection : true,
350        listeners : {
351         cellclick : function (_self, el, rowIndex, columnIndex, e)
352          {
353              var di = this.colModel.getDataIndex(columnIndex);
354              
355               if(di != 'active'){
356                   return;
357               }
358               
359               var r = this.store.getAt(rowIndex);
360               
361              if(r.data.active * 1  < 1){
362                  
363                  return;
364              }
365              
366              
367               
368          },
369         render : function (_self)
370          {
371              
372              _this.table = this;
373              
374              _this.dialog = Pman.Dialog.BAdminEmail;
375          },
376         rowdblclick : function (_self, el, rowIndex, e)
377          {
378              if (!_this.dialog) {
379                  return;
380              }
381              
382              //var data = this.getDataSource().getAt(rowIndex).data;
383              var data = _this.table.store.getAt(rowIndex).data;
384              
385              _this.dialog.show( {id : data.id, module : 'core_email'} , function() {
386                  
387                  _this.table.footer.onClick('first');
388              }); 
389          }
390        },
391        xns : Roo.bootstrap,
392        '|xns' : 'Roo.bootstrap',
393        footer : {
394         xtype : 'PagingToolbar',
395         displayInfo : true,
396         pageSize : 25,
397         xns : Roo.bootstrap,
398         '|xns' : 'Roo.bootstrap'
399        },
400        store : {
401         xtype : 'Store',
402         remoteSort : true,
403         sortInfo : {field:'description',direction:'ASC'},
404         listeners : {
405          beforeload : function (_self, options)
406           {
407               if (!Pman.buildCompleted) {
408                   return false;
409               }
410               
411               options.params = options.params || {};
412               
413               var s = _this.searchBox.getValue();
414               
415               if(s.length){
416                   options.params['search[nameortitle]'] = s;
417               }
418           
419           },
420          load : function (_self, records, options)
421           {
422               _this.edit_btn.hide();
423               _this.copy_btn.hide();
424               _this.delete_btn.hide();
425           }
426         },
427         xns : Roo.data,
428         '|xns' : 'Roo.data',
429         proxy : {
430          xtype : 'HttpProxy',
431          method : 'GET',
432          url : baseURL+'/Roo/Core_email.php',
433          xns : Roo.data,
434          '|xns' : 'Roo.data'
435         },
436         reader : {
437          xtype : 'JsonReader',
438          fields : [
439              {
440                  "name":"name",
441                  "type":"string"
442              },
443              {
444                  "name":"subject",
445                  "type":"string"
446              },
447              {
448                  "name":"description",
449                  "type":"string"
450              }
451          ],
452          id : 'id',
453          root : 'data',
454          totalProperty : 'total',
455          xns : Roo.data,
456          '|xns' : 'Roo.data'
457         }
458        },
459        sm : {
460         xtype : 'RowSelectionModel',
461         singleSelect : true,
462         listeners : {
463          afterselectionchange : function (_self)
464           {
465               _this.edit_btn.hide();
466               _this.copy_btn.hide();
467               _this.delete_btn.hide();
468               
469               if (!this.getSelected()) {
470                   _this.viewPanel.setContent("Nothing Selected");
471                   return;
472               }
473               
474               if(this.getSelected().data) {
475                   _this.viewPanel.setContent(this.getSelected().data.bodytext);
476               }
477               
478               _this.edit_btn.show();
479               _this.copy_btn.show();
480               _this.delete_btn.show();
481               
482           }
483         },
484         xns : Roo.bootstrap.Table,
485         '|xns' : 'Roo.bootstrap.Table'
486        },
487        cm : [
488         {
489          xtype : 'ColumnModel',
490          align : 'center',
491          cursor : 'pointer',
492          dataIndex : 'active',
493          header : _this._strings['4d3d769b812b6faa6b76e1a8abaece2d'] /* Active */,
494          renderer : function(v) {  
495          
496              var state = v > 0 ?  'check-' : '';
497              var cls = v > 0 ? 'text-primary' : '';
498              
499              return '<i class=\"far fa-'+ state + 'square-o ' + cls + '\" aria-hidden=\"true\"></i>';
500                          
501           },
502          sortable : true,
503          xs : 1,
504          xns : Roo.grid,
505          '|xns' : 'Roo.grid'
506         },
507         {
508          xtype : 'ColumnModel',
509          cursor : 'pointer',
510          dataIndex : 'description',
511          header : _this._strings['b5a7adde1af5c87d7fd797b6245c2a39'] /* Description */,
512          renderer : function(v,x,r) 
513          { 
514              vv = (v.length) ? v : r.data.name;
515              
516              if(r.data.active * 1 < 1){
517                  return '<small style="color: #999;">' + vv + '</small>';
518              }
519              
520              return '<b>' + vv + '</b>';
521          },
522          sortable : true,
523          xs : 4,
524          xns : Roo.grid,
525          '|xns' : 'Roo.grid'
526         },
527         {
528          xtype : 'ColumnModel',
529          cursor : 'pointer',
530          dataIndex : 'from_email',
531          header : _this._strings['cae905999a2ad1dfb8f4eae0e8cda73b'] /* From Name<br/>Email */,
532          renderer : function(v,x,r)
533          {
534              if(r.data.active * 1 < 1){
535                  return '';
536              }
537              
538              return String.format('<small>{0}</small>', r.data.from_name );
539              
540          },
541          xs : 2,
542          xns : Roo.grid,
543          '|xns' : 'Roo.grid'
544         },
545         {
546          xtype : 'ColumnModel',
547          cursor : 'pointer',
548          dataIndex : 'to_group_name',
549          header : _this._strings['98d2ee61ddce0c7666297d81639914f1'] /* To / BCC Group */,
550          renderer : function(v,x,r)
551          { 
552              if(r.data.active * 1 < 1){
553                  return '';
554              }
555              
556              var nid = r.data.to_group_id * 1 ;
557              var n = nid > 0 ? r.data.group_member_count * 1 : 0;
558              var grp_str = String.format('<small>To: {0} ' + 
559                      '<span class="badge' + (n > 0 ?  '' : ' badge-danger') + '">{1}</span></small><br>',
560                      r.data.to_group_id_name,
561                      nid < 1 ? 'Not set' : n
562                  );
563             
564              if (nid < 0) { // no To needed..
565                  grp_str = '';
566              }
567              nid = r.data.bcc_group_id * 1;
568              n = nid > 0 ? r.data.bcc_group_member_count * 1 : 0;
569          
570              var bcc_str = String.format('<small>BCC: {0} <span class="badge' + (n > 0 ?  '' : ' badge-danger') + '">{1}</span></small>',
571                      r.data.bcc_group_id_name,
572                      nid < 1 ? 'Not set' : n
573                  );
574                  
575              if (nid < 0) { // no To needed..
576                  bcc_str = '';
577              }  
578              
579              return grp_str + bcc_str;
580          },
581          xs : 5,
582          xns : Roo.grid,
583          '|xns' : 'Roo.grid'
584         }
585        ]
586       }
587      },
588      {
589       xtype : 'Content',
590       fitToFrame : true,
591       region : 'south',
592       title : _this._strings['9e11143e29a031212f2cdefcf61f39e9'] /* View Message */,
593       listeners : {
594        render : function (_self)
595         {
596             _this.viewPanel = this;
597         }
598       },
599       xns : Roo.bootstrap.panel,
600       '|xns' : 'Roo.bootstrap.panel'
601      }
602     ]
603    }
604   };  }
605 });