Pman.Tab.AdminNotify.bjs
[Pman.Admin] / Pman.Tab.AdminNotify.bjs
1 {
2     "name" : "Pman.Tab.AdminNotify",
3     "parent" : "Pman.Tab.AdminWatchNotify",
4     "title" : "Pman.Tab.AdminNotify",
5     "path" : "/home/edward/gitlive/Pman.Admin/Pman.Tab.AdminNotify.bjs",
6     "permname" : "",
7     "modOrder" : "001",
8     "items" : [
9         {
10             "listeners" : {
11                 "|activate" : "function() {\n    _this.panel = this;\n    if (_this.grid) {\n        _this.grid.footer.onClick('first');\n    }\n    \n}"
12             },
13             "fitToframe" : true,
14             "background" : true,
15             "region" : "center",
16             "title" : "Current Notifications",
17             "xtype" : "GridPanel",
18             "fitContainer" : true,
19             "$ xns" : "Roo",
20             "tableName" : "core_notify",
21             "items" : [
22                 {
23                     "listeners" : {
24                         "|render" : "function() \n{\n    _this.grid = this; \n    //_this.dialog = Pman.Dialog.FILL_IN\n    if (_this.panel.active) {\n       this.footer.onClick('first');\n    }\n}"
25                     },
26                     "autoExpandColumn" : "person_id_name",
27                     "xtype" : "Grid",
28                     "loadMask" : true,
29                     "$ xns" : "Roo.grid",
30                     "* prop" : "grid",
31                     "items" : [
32                         {
33                             "listeners" : {
34                                 "beforeload" : "function (_self, options)\n{\n    options.params = options.params || {};\n    \n    options.params._evtype_align = 1;\n    \n    if (!_this.toggleBtn.pressed) {\n        options.params['event_id'] = 0;\n    }\n    if (!_this.personCombo) {\n        return false;\n    }\n    var p = _this.personCombo.getValue();\n    if (p*1) { \n        options.params.person_id = p;\n    }\n    \n    var from = _this.fromDateSel.getValue();\n    \n    if(from){\n        options.params.from = from.format('Y-m-d');\n    }\n    \n    var to = _this.toDateSel.getValue();\n    \n    if(to){\n        options.params.to = to.format('Y-m-d');\n    }\n    \n    var type = _this.typeCombo.getValue();\n    \n    if(type.length){\n        options.params.evtype = type;\n    }\n}"
35                             },
36                             "xtype" : "Store",
37                             "remoteSort" : true,
38                             "$ sortInfo" : "{ field : 'act_when', direction: 'DESC' }",
39                             "$ xns" : "Roo.data",
40                             "* prop" : "dataSource",
41                             "items" : [
42                                 {
43                                     "$ url" : "baseURL + '/Roo/core_notify.php'",
44                                     "method" : "GET",
45                                     "xtype" : "HttpProxy",
46                                     "$ xns" : "Roo.data",
47                                     "* prop" : "proxy"
48                                 },
49                                 {
50                                     "id" : "id",
51                                     "root" : "data",
52                                     "xtype" : "JsonReader",
53                                     "$ xns" : "Roo.data",
54                                     "$ fields" : "[\n    {\n        'name': 'id',\n        'type': 'int'\n    },\n    {\n        'name': 'act_when',\n        'type': 'date',\n        'dateFormat': 'Y-m-d'\n    },\n    {\n        'name': 'onid',\n        'type': 'int'\n    },\n    {\n        'name': 'ontable',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id',\n        'type': 'int'\n    },\n    {\n        'name': 'msgid',\n        'type': 'string'\n    },\n    {\n        'name': 'sent',\n        'type': 'date',\n        'dateFormat': 'Y-m-d'\n    },\n    {\n        'name': 'event_id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_office_id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_name',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_phone',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_fax',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_email',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_company_id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_role',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_active',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_remarks',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_passwd',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_owner_id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_lang',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_no_reset_sent',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_action_type',\n        'type': 'string'\n    },\n    {\n        'name': 'person_id_project_id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_deleted_by',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id_deleted_dt',\n        'type': 'date'\n    },\n    {\n        'name': 'event_id_id',\n        'type': 'int'\n    },\n    {\n        'name': 'event_id_person_name',\n        'type': 'string'\n    },\n    {\n        'name': 'event_id_event_when',\n        'type': 'date'\n    },\n    {\n        'name': 'event_id_action',\n        'type': 'string'\n    },\n    {\n        'name': 'event_id_ipaddr',\n        'type': 'string'\n    },\n    {\n        'name': 'event_id_on_id',\n        'type': 'int'\n    },\n    {\n        'name': 'event_id_on_table',\n        'type': 'string'\n    },\n    {\n        'name': 'event_id_person_id',\n        'type': 'int'\n    },\n    {\n        'name': 'event_id_remarks',\n        'type': 'string'\n    }\n]",
55                                     "* prop" : "reader",
56                                     "totalProperty" : "total"
57                                 }
58                             ]
59                         },
60                         {
61                             "pageSize" : 25,
62                             "xtype" : "PagingToolbar",
63                             "emptyMsg" : "No core_notify found",
64                             "$ xns" : "Roo",
65                             "displayInfo" : true,
66                             "displayMsg" : "Displaying core_notify{0} - {1} of {2}",
67                             "* prop" : "footer"
68                         },
69                         {
70                             "xtype" : "Toolbar",
71                             "$ xns" : "Roo",
72                             "* prop" : "toolbar",
73                             "items" : [
74                                 {
75                                     "listeners" : {
76                                         "render" : "function (_self)\n{\n   _this.personCombo = _self;\n}",
77                                         "select" : "function (combo, record, index)\n{\n   _this.grid.footer.onClick('first');\n}"
78                                     },
79                                     "listWidth" : 400,
80                                     "triggerAction" : "all",
81                                     "forceSelection" : true,
82                                     "selectOnFocus" : true,
83                                     "pageSize" : 20,
84                                     "displayField" : "person_id_name",
85                                     "emptyText" : "Select person",
86                                     "minChars" : 2,
87                                     "valueField" : "person_id",
88                                     "xtype" : "ComboBox",
89                                     "allowBlank" : true,
90                                     "editable" : true,
91                                     "width" : 200,
92                                     "$ xns" : "Roo.form",
93                                     "qtip" : "Select person",
94                                     "queryParam" : "query[person_id_name]",
95                                     "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{person_id_name}</b> {person_id_email}</div>",
96                                     "loadingText" : "Searching...",
97                                     "items" : [
98                                         {
99                                             "listeners" : {
100                                                 "|beforeload" : "function (_self, o){\n    o.params = o.params || {};\n    o.params._distinct='person_id';\n    o.params._columns='person_id,person_id_name,person_id_email';\n    o.params['!person_id_name'] = '';\n    \n    // set more here\n}\n"
101                                             },
102                                             "xtype" : "Store",
103                                             "remoteSort" : true,
104                                             "$ sortInfo" : "{ direction : 'ASC', field: 'person_id_name' }",
105                                             "$ xns" : "Roo.data",
106                                             "* prop" : "store",
107                                             "items" : [
108                                                 {
109                                                     "$ url" : "baseURL + '/Roo/core_notify.php'",
110                                                     "method" : "GET",
111                                                     "xtype" : "HttpProxy",
112                                                     "$ xns" : "Roo.data",
113                                                     "* prop" : "proxy"
114                                                 },
115                                                 {
116                                                     "id" : "id",
117                                                     "root" : "data",
118                                                     "xtype" : "JsonReader",
119                                                     "$ xns" : "Roo.data",
120                                                     "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"ontable\",\"type\":\"string\"}]",
121                                                     "* prop" : "reader",
122                                                     "totalProperty" : "total"
123                                                 }
124                                             ]
125                                         }
126                                     ]
127                                 },
128                                 {
129                                     "xtype" : "Separator",
130                                     "$ xns" : "Roo.Toolbar"
131                                 },
132                                 {
133                                     "listeners" : {
134                                         "render" : "function (_self)\n{\n   _this.typeCombo = _self;\n}",
135                                         "select" : "function (combo, record, index)\n{\n   _this.grid.footer.onClick('first');\n}"
136                                     },
137                                     "listWidth" : 400,
138                                     "triggerAction" : "all",
139                                     "forceSelection" : true,
140                                     "selectOnFocus" : true,
141                                     "pageSize" : 20,
142                                     "displayField" : "display_name",
143                                     "emptyText" : "Select notify type",
144                                     "minChars" : 2,
145                                     "valueField" : "name",
146                                     "xtype" : "ComboBox",
147                                     "allowBlank" : true,
148                                     "editable" : true,
149                                     "width" : 200,
150                                     "$ xns" : "Roo.form",
151                                     "qtip" : "Select type",
152                                     "queryParam" : "query[name]",
153                                     "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{display_name}</b></div>",
154                                     "loadingText" : "Searching...",
155                                     "items" : [
156                                         {
157                                             "listeners" : {
158                                                 "|beforeload" : "function (_self, o){\n    o.params = o.params || {};\n    o.params.etype = 'Core.NotifyType';\n    o.params.active = 1;\n}\n"
159                                             },
160                                             "xtype" : "Store",
161                                             "remoteSort" : true,
162                                             "$ sortInfo" : "{ direction : 'ASC', field: 'id' }",
163                                             "$ xns" : "Roo.data",
164                                             "* prop" : "store",
165                                             "items" : [
166                                                 {
167                                                     "$ url" : "baseURL + '/Roo/core_enum.php'",
168                                                     "xtype" : "HttpProxy",
169                                                     "method" : "GET",
170                                                     "$ xns" : "Roo.data",
171                                                     "* prop" : "proxy"
172                                                 },
173                                                 {
174                                                     "id" : "id",
175                                                     "root" : "data",
176                                                     "xtype" : "JsonReader",
177                                                     "$ xns" : "Roo.data",
178                                                     "$ fields" : "[{\"name\":\"name\",\"type\":\"string\"},{\"name\":\"display_name\",\"type\":\"string\"}]",
179                                                     "* prop" : "reader",
180                                                     "totalProperty" : "total"
181                                                 }
182                                             ]
183                                         }
184                                     ]
185                                 },
186                                 {
187                                     "xtype" : "Separator",
188                                     "$ xns" : "Roo.Toolbar"
189                                 },
190                                 {
191                                     "text" : "From",
192                                     "xtype" : "TextItem",
193                                     "$ xns" : "Roo.Toolbar"
194                                 },
195                                 {
196                                     "listeners" : {
197                                         "render" : "function (_self)\r\n{\r\n    _this.fromDateSel = _self;\r\n   //_self.setValue(  new Date() );\r\n}",
198                                         "select" : "function (combo, date)\n{\n    _this.grid.footer.onClick('first');\n}"
199                                     },
200                                     "format" : "d/M/Y",
201                                     "xtype" : "DateField",
202                                     "width" : 100,
203                                     "$ xns" : "Roo.form"
204                                 },
205                                 {
206                                     "xtype" : "Separator",
207                                     "$ xns" : "Roo.Toolbar"
208                                 },
209                                 {
210                                     "text" : "To",
211                                     "xtype" : "TextItem",
212                                     "$ xns" : "Roo.Toolbar"
213                                 },
214                                 {
215                                     "listeners" : {
216                                         "render" : "function (_self)\r\n{\r\n    _this.toDateSel = _self;\r\n   //_self.setValue(  new Date() );\r\n}",
217                                         "select" : "function (combo, date)\n{\n    _this.grid.footer.onClick('first');\n}"
218                                     },
219                                     "format" : "d/M/Y",
220                                     "xtype" : "DateField",
221                                     "width" : 100,
222                                     "$ xns" : "Roo.form"
223                                 },
224                                 {
225                                     "xtype" : "Fill",
226                                     "$ xns" : "Roo.Toolbar"
227                                 },
228                                 {
229                                     "listeners" : {
230                                         "|click" : "function()\n{\n    Pman.genericDelete(_this, 'core_notify'); \n}\n        "
231                                     },
232                                     "text" : "Delete",
233                                     "xtype" : "Button",
234                                     "cls" : "x-btn-text-icon",
235                                     "$ icon" : "rootURL + '/Pman/templates/images/trash.gif'",
236                                     "$ xns" : "Roo.Toolbar"
237                                 },
238                                 {
239                                     "listeners" : {
240                                         "toggle" : "function (_self, pressed)\n{\n    this.setText(pressed ? \"Hide Completed\" : \"Show Completed\");\n    _this.grid.footer.onClick('first');\n}",
241                                         "render" : "function (_self)\n{\n    _this.toggleBtn = _self;\n}"
242                                     },
243                                     "text" : "Show Completed",
244                                     "enableToggle" : true,
245                                     "xtype" : "Button",
246                                     "$ xns" : "Roo.Toolbar"
247                                 }
248                             ]
249                         },
250                         {
251                             "xtype" : "ColumnModel",
252                             "sortable" : true,
253                             "header" : "id#",
254                             "width" : 50,
255                             "$ renderer" : "function(v) { return String.format('{0}', v ); }",
256                             "$ xns" : "Roo.grid",
257                             "* prop" : "colModel[]",
258                             "dataIndex" : "id"
259                         },
260                         {
261                             "xtype" : "ColumnModel",
262                             "sortable" : true,
263                             "header" : "Method",
264                             "width" : 200,
265                             "$ renderer" : "function(v,x,r) \n{ \n    var vv = (typeof(r.data.evtype_align) != 'undefined' && r.data.evtype_align) ? r.data.evtype_align : v;\n    return String.format('<span qtip=\"{0}\">{1}</span>', v, vv ); \n}",
266                             "$ xns" : "Roo.grid",
267                             "* prop" : "colModel[]",
268                             "dataIndex" : "evtype"
269                         },
270                         {
271                             "xtype" : "ColumnModel",
272                             "sortable" : true,
273                             "header" : "Act when",
274                             "width" : 150,
275                             "$ renderer" : "function(v) { return String.format('{0}', v ? v.format('d/M/Y H:i:s') : ''); }",
276                             "$ xns" : "Roo.grid",
277                             "* prop" : "colModel[]",
278                             "dataIndex" : "act_when"
279                         },
280                         {
281                             "xtype" : "ColumnModel",
282                             "sortable" : true,
283                             "header" : "Sent",
284                             "width" : 150,
285                             "$ renderer" : "function(v,x,r) {\n    if (r.data.event_id *1 == 0) {\n        return '';\n    }\n     return String.format('{0}', v ? v.format('d/M/Y H:i:s') : '');\n  }",
286                             "$ xns" : "Roo.grid",
287                             "* prop" : "colModel[]",
288                             "dataIndex" : "sent"
289                         },
290                         {
291                             "xtype" : "ColumnModel",
292                             "header" : "Ontable",
293                             "width" : 150,
294                             "$ renderer" : "function(v,x,r) { return String.format('{0}:{1}', v,r.data.onid); }",
295                             "$ xns" : "Roo.grid",
296                             "* prop" : "colModel[]",
297                             "dataIndex" : "ontable"
298                         },
299                         {
300                             "xtype" : "ColumnModel",
301                             "header" : "Who to notify",
302                             "width" : 100,
303                             "$ renderer" : "function(v,x,r) {\n     return String.format('{0} <u>&lt;{1}&gt;</u>', v, r.data.person_id_email); \n }",
304                             "$ xns" : "Roo.grid",
305                             "* prop" : "colModel[]",
306                             "dataIndex" : "person_id_name"
307                         },
308                         {
309                             "xtype" : "ColumnModel",
310                             "header" : "Triggered by",
311                             "width" : 100,
312                             "$ renderer" : "function(v,x,r) {\n     return String.format(\n            '{0} : {1} {2}', \n            r.data.trigger_event_id_on_table, \n            r.data.trigger_event_id_on_id, \n            r.data.trigger_event_id_remarks\n        ); \n }",
313                             "$ xns" : "Roo.grid",
314                             "* prop" : "colModel[]",
315                             "dataIndex" : "trigger_event_id"
316                         },
317                         {
318                             "xtype" : "ColumnModel",
319                             "width" : 200,
320                             "header" : "Msgid",
321                             "$ renderer" : "function(v) { return String.format('{0}', v); }",
322                             "$ xns" : "Roo.grid",
323                             "* prop" : "colModel[]",
324                             "dataIndex" : "msgid"
325                         },
326                         {
327                             "xtype" : "ColumnModel",
328                             "header" : "Event",
329                             "width" : 300,
330                             "$ renderer" : "function(v) { return String.format('<span qtip=\"{0}\">{0}</span>', v); }",
331                             "$ xns" : "Roo.grid",
332                             "* prop" : "colModel[]",
333                             "dataIndex" : "event_id_remarks"
334                         }
335                     ]
336                 }
337             ]
338         }
339     ]
340 }