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/alan/gitlive/Pman.Admin/Pman.Tab.AdminNotify.bjs",
6  "permname" : "",
7  "modOrder" : "001",
8  "strings" : {
9   "136fac3c5c5881e0a7d0039e57decd68" : "Select notify type",
10   "bf1cb7e2a337a5e2ebf614009cbce9cc" : "Current Notifications",
11   "8535bcc0f05358a583bb432bbadf7e0d" : "Select type",
12   "e12167aa0a7698e6ebc92b4ce3909b53" : "To",
13   "478192f02d448c49bc6b7d76818d8483" : "Ontable",
14   "dca4dd744d00b6fe1362ef7825ffdee5" : "No core_notify found",
15   "dc873ea4b71ca217b0d8d1fdd45854ac" : "id#",
16   "0f6d01b16d57911731aa44b94dbfefcc" : "Act when",
17   "7f8c0283f16925caed8e632086b81b9c" : "Sent",
18   "c956c97343a45cca5d492e70c56daa8e" : "Select person",
19   "12832b4def6eb0b6105b3d11e16066ea" : "Msgid",
20   "1243daf593fa297e07ab03bf06d925af" : "Searching...",
21   "24463f10155b8af973300f86302c4fde" : "Who to notify",
22   "b22e7ea679daf5146f08f477419dd8bd" : "Triggered by",
23   "5da618e8e4b89c66fe86e32cdafde142" : "From",
24   "e4b478c05a833569833f9cc63b6c4354" : "Displaying core_notify{0} - {1} of {2}",
25   "4c3880bb027f159e801041b1021e88e8" : "Method",
26   "a4ecfc70574394990cf17bd83df499f7" : "Event",
27   "f2a6c498fb90ee345d997f888fce3b18" : "Delete",
28   "f821027bade4aa6b7a4191cd1676cf41" : "Show Completed"
29  },
30  "items" : [
31   {
32    "xtype" : "NestedLayoutPanel",
33    "$ xns" : "Roo",
34    "items" : [
35     {
36      "xtype" : "BorderLayout",
37      "$ xns" : "Roo",
38      "* prop" : "layout",
39      "items" : [
40       {
41        "xtype" : "LayoutRegion",
42        "$ xns" : "Roo",
43        "* prop" : "center"
44       },
45       {
46        "xtype" : "LayoutRegion",
47        "$ xns" : "Roo",
48        "* prop" : "south"
49       },
50       {
51        "listeners" : {
52         "|activate" : "function() {\n    _this.panel = this;\n    if (_this.grid) {\n        _this.grid.footer.onClick('first');\n    }\n    \n}"
53        },
54        "bool background" : true,
55        "fitToframe" : true,
56        "region" : "center",
57        "title" : "Current Notifications",
58        "xtype" : "GridPanel",
59        "fitContainer" : true,
60        "$ xns" : "Roo",
61        "tableName" : "core_notify",
62        "items" : [
63         {
64          "listeners" : {
65           "|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}"
66          },
67          "autoExpandColumn" : "person_id_name",
68          "xtype" : "Grid",
69          "loadMask" : true,
70          "$ xns" : "Roo.grid",
71          "* prop" : "grid",
72          "items" : [
73           {
74            "listeners" : {
75             "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}"
76            },
77            "xtype" : "Store",
78            "remoteSort" : true,
79            "$ sortInfo" : "{ field : 'act_when', direction: 'DESC' }",
80            "$ xns" : "Roo.data",
81            "* prop" : "dataSource",
82            "items" : [
83             {
84              "$ url" : "baseURL + '/Roo/core_notify.php'",
85              "method" : "GET",
86              "xtype" : "HttpProxy",
87              "$ xns" : "Roo.data",
88              "* prop" : "proxy"
89             },
90             {
91              "id" : "id",
92              "root" : "data",
93              "xtype" : "JsonReader",
94              "$ xns" : "Roo.data",
95              "$ 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]",
96              "* prop" : "reader",
97              "totalProperty" : "total"
98             }
99            ]
100           },
101           {
102            "pageSize" : 25,
103            "xtype" : "PagingToolbar",
104            "emptyMsg" : "No core_notify found",
105            "$ xns" : "Roo",
106            "displayInfo" : true,
107            "displayMsg" : "Displaying core_notify{0} - {1} of {2}",
108            "* prop" : "footer"
109           },
110           {
111            "xtype" : "Toolbar",
112            "$ xns" : "Roo",
113            "* prop" : "toolbar",
114            "items" : [
115             {
116              "listeners" : {
117               "render" : "function (_self)\n{\n   _this.personCombo = _self;\n}",
118               "select" : "function (combo, record, index)\n{\n   _this.grid.footer.onClick('first');\n}"
119              },
120              "listWidth" : 400,
121              "triggerAction" : "all",
122              "forceSelection" : true,
123              "selectOnFocus" : true,
124              "pageSize" : 20,
125              "displayField" : "person_id_name",
126              "emptyText" : "Select person",
127              "minChars" : 2,
128              "valueField" : "person_id",
129              "xtype" : "ComboBox",
130              "allowBlank" : true,
131              "editable" : true,
132              "width" : 200,
133              "$ xns" : "Roo.form",
134              "qtip" : "Select person",
135              "queryParam" : "query[person_id_name]",
136              "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{person_id_name}</b> {person_id_email}</div>",
137              "loadingText" : "Searching...",
138              "items" : [
139               {
140                "listeners" : {
141                 "|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"
142                },
143                "xtype" : "Store",
144                "remoteSort" : true,
145                "$ sortInfo" : "{ direction : 'ASC', field: 'person_id_name' }",
146                "$ xns" : "Roo.data",
147                "* prop" : "store",
148                "items" : [
149                 {
150                  "$ url" : "baseURL + '/Roo/core_notify.php'",
151                  "method" : "GET",
152                  "xtype" : "HttpProxy",
153                  "$ xns" : "Roo.data",
154                  "* prop" : "proxy"
155                 },
156                 {
157                  "id" : "id",
158                  "root" : "data",
159                  "xtype" : "JsonReader",
160                  "$ xns" : "Roo.data",
161                  "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"ontable\",\"type\":\"string\"}]",
162                  "* prop" : "reader",
163                  "totalProperty" : "total"
164                 }
165                ]
166               }
167              ]
168             },
169             {
170              "xtype" : "Separator",
171              "$ xns" : "Roo.Toolbar"
172             },
173             {
174              "listeners" : {
175               "render" : "function (_self)\n{\n   _this.typeCombo = _self;\n}",
176               "select" : "function (combo, record, index)\n{\n   _this.grid.footer.onClick('first');\n}"
177              },
178              "listWidth" : 400,
179              "triggerAction" : "all",
180              "forceSelection" : true,
181              "selectOnFocus" : true,
182              "pageSize" : 20,
183              "displayField" : "display_name",
184              "emptyText" : "Select notify type",
185              "minChars" : 2,
186              "valueField" : "name",
187              "xtype" : "ComboBox",
188              "allowBlank" : true,
189              "editable" : true,
190              "width" : 200,
191              "$ xns" : "Roo.form",
192              "qtip" : "Select type",
193              "queryParam" : "query[name]",
194              "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{display_name}</b></div>",
195              "loadingText" : "Searching...",
196              "items" : [
197               {
198                "listeners" : {
199                 "|beforeload" : "function (_self, o){\n    o.params = o.params || {};\n    o.params.etype = 'Core.NotifyType';\n    o.params.active = 1;\n}\n"
200                },
201                "xtype" : "Store",
202                "remoteSort" : true,
203                "$ sortInfo" : "{ direction : 'ASC', field: 'id' }",
204                "$ xns" : "Roo.data",
205                "* prop" : "store",
206                "items" : [
207                 {
208                  "$ url" : "baseURL + '/Roo/core_enum.php'",
209                  "xtype" : "HttpProxy",
210                  "method" : "GET",
211                  "$ xns" : "Roo.data",
212                  "* prop" : "proxy"
213                 },
214                 {
215                  "id" : "id",
216                  "root" : "data",
217                  "xtype" : "JsonReader",
218                  "$ xns" : "Roo.data",
219                  "$ fields" : "[{\"name\":\"name\",\"type\":\"string\"},{\"name\":\"display_name\",\"type\":\"string\"}]",
220                  "* prop" : "reader",
221                  "totalProperty" : "total"
222                 }
223                ]
224               }
225              ]
226             },
227             {
228              "xtype" : "Separator",
229              "$ xns" : "Roo.Toolbar"
230             },
231             {
232              "text" : "From",
233              "xtype" : "TextItem",
234              "$ xns" : "Roo.Toolbar"
235             },
236             {
237              "listeners" : {
238               "render" : "function (_self)\r\n{\r\n    _this.fromDateSel = _self;\r\n   //_self.setValue(  new Date() );\r\n}",
239               "select" : "function (combo, date)\n{\n    _this.grid.footer.onClick('first');\n}"
240              },
241              "format" : "d/M/Y",
242              "xtype" : "DateField",
243              "width" : 100,
244              "$ xns" : "Roo.form"
245             },
246             {
247              "xtype" : "Separator",
248              "$ xns" : "Roo.Toolbar"
249             },
250             {
251              "text" : "To",
252              "xtype" : "TextItem",
253              "$ xns" : "Roo.Toolbar"
254             },
255             {
256              "listeners" : {
257               "render" : "function (_self)\r\n{\r\n    _this.toDateSel = _self;\r\n   //_self.setValue(  new Date() );\r\n}",
258               "select" : "function (combo, date)\n{\n    _this.grid.footer.onClick('first');\n}"
259              },
260              "format" : "d/M/Y",
261              "xtype" : "DateField",
262              "width" : 100,
263              "$ xns" : "Roo.form"
264             },
265             {
266              "xtype" : "Fill",
267              "$ xns" : "Roo.Toolbar"
268             },
269             {
270              "listeners" : {
271               "|click" : "function()\n{\n    Pman.genericDelete(_this, 'core_notify'); \n}\n        "
272              },
273              "text" : "Delete",
274              "xtype" : "Button",
275              "cls" : "x-btn-text-icon",
276              "$ icon" : "rootURL + '/Pman/templates/images/trash.gif'",
277              "$ xns" : "Roo.Toolbar"
278             },
279             {
280              "listeners" : {
281               "toggle" : "function (_self, pressed)\n{\n    this.setText(pressed ? \"Hide Completed\" : \"Show Completed\");\n    _this.grid.footer.onClick('first');\n}",
282               "render" : "function (_self)\n{\n    _this.toggleBtn = _self;\n}"
283              },
284              "text" : "Show Completed",
285              "enableToggle" : true,
286              "xtype" : "Button",
287              "$ xns" : "Roo.Toolbar"
288             }
289            ]
290           },
291           {
292            "xtype" : "ColumnModel",
293            "sortable" : true,
294            "header" : "id#",
295            "width" : 50,
296            "$ renderer" : "function(v) { return String.format('{0}', v ); }",
297            "$ xns" : "Roo.grid",
298            "* prop" : "colModel[]",
299            "dataIndex" : "id"
300           },
301           {
302            "xtype" : "ColumnModel",
303            "sortable" : true,
304            "header" : "Method",
305            "width" : 100,
306            "$ 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}",
307            "$ xns" : "Roo.grid",
308            "* prop" : "colModel[]",
309            "dataIndex" : "evtype"
310           },
311           {
312            "xtype" : "ColumnModel",
313            "sortable" : true,
314            "header" : "Act when",
315            "width" : 150,
316            "$ renderer" : "function(v) { return String.format('{0}', v ? v.format('d/M/Y H:i:s') : ''); }",
317            "$ xns" : "Roo.grid",
318            "* prop" : "colModel[]",
319            "dataIndex" : "act_when"
320           },
321           {
322            "xtype" : "ColumnModel",
323            "sortable" : true,
324            "header" : "Sent",
325            "width" : 150,
326            "$ 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  }",
327            "$ xns" : "Roo.grid",
328            "* prop" : "colModel[]",
329            "dataIndex" : "sent"
330           },
331           {
332            "xtype" : "ColumnModel",
333            "header" : "Ontable",
334            "width" : 150,
335            "$ renderer" : "function(v,x,r) { return String.format('{0}:{1}', v,r.data.onid); }",
336            "$ xns" : "Roo.grid",
337            "* prop" : "colModel[]",
338            "dataIndex" : "ontable"
339           },
340           {
341            "xtype" : "ColumnModel",
342            "header" : "Who to notify",
343            "width" : 100,
344            "$ renderer" : "function(v,x,r) {\n\n    var pt = r.data.person_table.toLowerCase() ;\n    var pt = pt.length ? pt : 'person';\n     var ecol = pt + '_id_email' ;\n     var ncol = pt + '_id_name' ;\n     return String.format('{0} <u>&lt;{1}&gt;</u>', r.data[ncol], r.data[ecol]); \n }",
345            "$ xns" : "Roo.grid",
346            "* prop" : "colModel[]",
347            "dataIndex" : "person_id_name"
348           },
349           {
350            "xtype" : "ColumnModel",
351            "header" : "Triggered by",
352            "width" : 100,
353            "$ 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 }",
354            "$ xns" : "Roo.grid",
355            "* prop" : "colModel[]",
356            "dataIndex" : "trigger_event_id"
357           },
358           {
359            "xtype" : "ColumnModel",
360            "width" : 200,
361            "header" : "Msgid",
362            "$ renderer" : "function(v) { return String.format('{0}', v); }",
363            "$ xns" : "Roo.grid",
364            "* prop" : "colModel[]",
365            "dataIndex" : "msgid"
366           },
367           {
368            "xtype" : "ColumnModel",
369            "header" : "Event",
370            "width" : 300,
371            "$ renderer" : "function(v) { return String.format('<span qtip=\"{0}\">{0}</span>', v); }",
372            "$ xns" : "Roo.grid",
373            "* prop" : "colModel[]",
374            "dataIndex" : "event_id_remarks"
375           }
376          ]
377         }
378        ]
379       }
380      ]
381     }
382    ]
383   }
384  ]
385 }