Pman.Dialog.CoreNotifyRecur.bjs
[Pman.Core] / Pman.Dialog.CoreNotifyRecur.bjs
1 {
2     "id": "roo-file-100",
3     "name": "Pman.Dialog.CoreNotifyRecur",
4     "parent": "",
5     "title": "",
6     "path": "/home/alan/gitlive/Pman.Core/Pman.Dialog.CoreNotifyRecur.bjs",
7     "items": [
8         {
9             "listeners": {
10                 "show": "function (_self)\n{\n    _this.grid.ds.load({});\n}"
11             },
12             "height": 550,
13             "modal": true,
14             "resizable": false,
15             "title": "Modify Recurrent Notifications",
16             "width": 800,
17             "xtype": "LayoutDialog",
18             "|xns": "Roo",
19             "items": [
20                 {
21                     "*prop": "center",
22                     "autoScroll": true,
23                     "loadOnce": true,
24                     "xtype": "LayoutRegion",
25                     "|xns": "Roo"
26                 },
27                 {
28                     "listeners": {
29                         "|activate": "function() {\n _this.panel = this;\n    if (_this.grid) {\n//        _this.grid.footer.onClick('first');\n    }\n}"
30                     },
31                     "background": false,
32                     "fitContainer": true,
33                     "fitToFrame": true,
34                     "region": "center",
35                     "tableName": "core_notify_recur",
36                     "title": "core_notify_recur",
37                     "xtype": "GridPanel",
38                     "|xns": "Roo",
39                     "items": [
40                         {
41                             "listeners": {
42                                 "|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}",
43                                 "|rowdblclick": "function (_self, rowIndex, e)\n{\n    if (!_this.dialog) return;\n    _this.dialog.show( this.getDataSource().getAt(rowIndex).data, function() {\n        _this.grid.footer.onClick('first');\n    }); \n}\n",
44                                 "afteredit": "function (e)\n{\n   e.record.commit();\n}"
45                             },
46                             "*prop": "grid",
47                             "autoExpandColumn": "freq_day",
48                             "clicksToEdit": 1,
49                             "loadMask": true,
50                             "xtype": "EditorGrid",
51                             "|xns": "Roo.grid",
52                             "items": [
53                                 {
54                                     "listeners": {
55                                         "update": "function (_self, record, operation)\n{\n    //Roo.log(operation);\n    if (operation != 'commit') {\n        return;\n    }\n    var p = Roo.apply({}, record.data);\n    p.dtstart = record.data.dtstart.format('Y-m-d');\n    p.dtend = record.data.dtend.format('Y-m-d');    \n    \n    \n    new Pman.Request({\n        url : baseURL + '/Roo/Core_notify_recur',\n        method :'POST',\n        params : p,\n        success : function(data)\n        {\n            //Roo.log(data);\n            record.set('id', data.data.id);\n        },\n        failure : function() {\n            Roo.MessageBox.alert(\"Error\", \"There was a problem saving\");\n        }\n    });\n       \n    \n    \n}",
56                                         "beforeload": "function (_self, o)\n{\n    if (!_this.data) {\n        return false;\n    }\n    o.params =  Roo.apply(o.params || {}, {\n        person_id : _this.data.person_id,\n        onid : _this.data.onid,\n        ontable : _this.data.ontable,\n        method : _this.data.method\n    });\n        \n}"
57                                     },
58                                     "*prop": "dataSource",
59                                     "remoteSort": true,
60                                     "xtype": "Store",
61                                     "|sortInfo": "{ field : 'freq', direction: 'ASC' }",
62                                     "|xns": "Roo.data",
63                                     "items": [
64                                         {
65                                             "*prop": "proxy",
66                                             "xtype": "HttpProxy",
67                                             "method": "GET",
68                                             "|url": "baseURL + '/Roo/core_notify_recur.php'",
69                                             "|xns": "Roo.data"
70                                         },
71                                         {
72                                             "*prop": "reader",
73                                             "id": "id",
74                                             "root": "data",
75                                             "totalProperty": "total",
76                                             "xtype": "JsonReader",
77                                             "|fields": "[\n    {\n        'name': 'id',\n        'type': 'int'\n    },\n    {\n        'name': 'person_id',\n        'type': 'int'\n    },\n    {\n        'name': 'dtstart',\n        'type': 'date',\n        'dateFormat': 'Y-m-d'\n    },\n    {\n        'name': 'dtend',\n        'type': 'date',\n        'dateFormat': 'Y-m-d'\n    },\n    {\n        'name': 'tz',\n        'type': 'float'\n    },\n    {\n        'name': 'last_applied_dt',\n        'type': 'date',\n        'dateFormat': 'Y-m-d'\n    },\n    {\n        'name': 'freq',\n        'type': 'string'\n    },\n    {\n        'name': 'freq_day',\n        'type': 'string'\n    },\n    {\n        'name': 'freq_hour',\n        'type': 'string'\n    },\n    {\n        'name': 'last_event_id',\n        'type': 'int'\n    },\n    {\n        'name': 'method',\n        'type': 'string'\n    }\n]",
78                                             "|xns": "Roo.data"
79                                         }
80                                     ]
81                                 },
82                                 {
83                                     "*prop": "toolbar",
84                                     "xtype": "Toolbar",
85                                     "|xns": "Roo",
86                                     "items": [
87                                         {
88                                             "listeners": {
89                                                 "|click": "function()\n{\n    var grid = _this.grid;\n    var r = grid.getDataSource().reader.newRow({\n    // defaults..\n        person_id : _this.data.person_id,\n        dtstart : new Date(),\n        dtend : Date.parseDate('2050-01-01', 'Y-m-d'),\n        tz : 'Asia/Hong_Kong',\n        onid : _this.data.onid,\n        ontable : _this.data.ontable,\n        method : _this.data.method,\n        last_event_id : 0,\n        freq_day_name : '',\n        freq_hour_name : '',\n        freq_name : ''\n        \n    \n    });\n    grid.stopEditing();\n    grid.getDataSource().insert(0, r); \n    grid.startEditing(0, 2); \n    \n\n}\n"
90                                             },
91                                             "cls": "x-btn-text-icon",
92                                             "text": "Add",
93                                             "xtype": "Button",
94                                             "|icon": "Roo.rootURL + 'images/default/dd/drop-add.gif'",
95                                             "|xns": "Roo.Toolbar"
96                                         },
97                                         {
98                                             "|xns": "Roo.Toolbar",
99                                             "xtype": "Fill"
100                                         },
101                                         {
102                                             "listeners": {
103                                                 "|click": "function()\n{\n     _this.grid.stopEditing();\n     var s = _this.grid.selModel.getSelectedCell();\n     if (!s) {\n        Roo.MessageBox.alert(\"Error\", \"Select row\");\n        return;\n    }\n    \n    new Pman.Request({\n        url : baseURL + '/Roo/core_notify_recur',\n        method : 'POST',\n        params : {\n            _delete : _this.grid.ds.getAt(s[0]).data.id\n        }, \n        success : function() {\n            _this.grid.ds.load({});\n        },\n        failure : function() {\n            Roo.MessageBox.alert(\"Error\", \"Deleting failed - try reloading\");\n        }\n   });\n    \n}\n        "
104                                             },
105                                             "cls": "x-btn-text-icon",
106                                             "text": "Delete",
107                                             "xtype": "Button",
108                                             "|icon": "rootURL + '/Pman/templates/images/trash.gif'",
109                                             "|xns": "Roo.Toolbar"
110                                         }
111                                     ]
112                                 },
113                                 {
114                                     "*prop": "colModel[]",
115                                     "dataIndex": "method_id_display_name",
116                                     "header": "From",
117                                     "width": 75,
118                                     "xtype": "ColumnModel",
119                                     "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
120                                     "|xns": "Roo.grid",
121                                     "items": [
122                                         {
123                                             "|xns": "Roo.grid",
124                                             "xtype": "GridEditor",
125                                             "*prop": "editor"
126                                         }
127                                     ]
128                                 },
129                                 {
130                                     "*prop": "colModel[]",
131                                     "dataIndex": "dtstart",
132                                     "header": "From",
133                                     "width": 75,
134                                     "xtype": "ColumnModel",
135                                     "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
136                                     "|xns": "Roo.grid",
137                                     "items": [
138                                         {
139                                             "|xns": "Roo.grid",
140                                             "xtype": "GridEditor",
141                                             "*prop": "editor",
142                                             "items": [
143                                                 {
144                                                     "|xns": "Roo.form",
145                                                     "xtype": "DateField",
146                                                     "*prop": "field"
147                                                 }
148                                             ]
149                                         }
150                                     ]
151                                 },
152                                 {
153                                     "*prop": "colModel[]",
154                                     "dataIndex": "dtend",
155                                     "header": "Until",
156                                     "width": 75,
157                                     "xtype": "ColumnModel",
158                                     "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
159                                     "|xns": "Roo.grid",
160                                     "items": [
161                                         {
162                                             "|xns": "Roo.grid",
163                                             "xtype": "GridEditor",
164                                             "*prop": "editor",
165                                             "items": [
166                                                 {
167                                                     "|xns": "Roo.form",
168                                                     "xtype": "DateField",
169                                                     "*prop": "field"
170                                                 }
171                                             ]
172                                         }
173                                     ]
174                                 },
175                                 {
176                                     "*prop": "colModel[]",
177                                     "dataIndex": "freq_day",
178                                     "header": "on day(s)",
179                                     "width": 100,
180                                     "xtype": "ColumnModel",
181                                     "|renderer": "function(v,x,r) { \n    \n    if (v.length) {\n     \n        var cm = _this.grid.colModel;\n       \n        var ci = cm.getColumnByDataIndex(this.name);\n       \n         var tv = [];\n        var vals = Roo.decode(v);\n        Roo.each(vals, function(k) {\n            var r = this.findRecord(this.valueField, k);\n            if(r){\n                tv.push(r.data[this.displayField]);\n            }else if(this.valueNotFoundText !== undefined){\n                tv.push( this.valueNotFoundText );\n            }\n        },ci.editor.field);\n\n        r.data[this.name + '_name'] = tv.join(', ');\n        return String.format('{0}',tv.join(', '));\n\n        \n    \n    }\n    r.data[this.name + '_name'] = '';\n    return String.format('{0}', r.data.freq_day_name || v); \n    \n}",
182                                     "|xns": "Roo.grid",
183                                     "items": [
184                                         {
185                                             "|xns": "Roo.grid",
186                                             "xtype": "GridEditor",
187                                             "*prop": "editor",
188                                             "items": [
189                                                 {
190                                                     "*prop": "field",
191                                                     "allowBlank": false,
192                                                     "displayField": "title",
193                                                     "editable": false,
194                                                     "fieldLabel": "Country",
195                                                     "hiddenName": "freq_day",
196                                                     "listWidth": 300,
197                                                     "mode": "local",
198                                                     "name": "freq_day_name",
199                                                     "pageSize": 40,
200                                                     "triggerAction": "all",
201                                                     "valueField": "code",
202                                                     "xtype": "ComboCheck",
203                                                     "|xns": "Roo.form",
204                                                     "items": [
205                                                         {
206                                                             "*prop": "store",
207                                                             "xtype": "SimpleStore",
208                                                             "|data": "(function() { \n    var ret = [];\n    Roo.each(Date.dayNames, function(d) {\n        ret.push([ d.substring(0,3).toUpperCase(), d ]);\n    });\n    return ret;\n})()",
209                                                             "|fields": "['code', 'title']",
210                                                             "|sortInfo": "{ field : 'title', direction: 'ASC' }",
211                                                             "|xns": "Roo.data"
212                                                         }
213                                                     ]
214                                                 }
215                                             ]
216                                         }
217                                     ]
218                                 },
219                                 {
220                                     "*prop": "colModel[]",
221                                     "dataIndex": "freq_hour",
222                                     "header": "at Hour(s)",
223                                     "width": 250,
224                                     "xtype": "ColumnModel",
225                                     "|renderer": "function(v,x,r) { \n    \n \n    if (v.length) {\n     \n        var cm = _this.grid.colModel;\n       \n        var ci = cm.getColumnByDataIndex(this.name);\n       \n         var tv = [];\n        var vals = Roo.decode(v);\n        Roo.each(vals, function(k) {\n            var r = this.findRecord(this.valueField, k);\n            if(r){\n                tv.push(r.data[this.displayField]);\n            }else if(this.valueNotFoundText !== undefined){\n                tv.push( this.valueNotFoundText );\n            }\n        },ci.editor.field);\n\n         r.data[this.name + '_name'] = tv.join(', ');\n        return String.format('{0}',tv.join(', '));\n\n        \n    \n    }\n        r.data[this.name + '_name'] = '';\n    return String.format('{0}', r.data.freq_hour_name || v); \n    \n}",
226                                     "|xns": "Roo.grid",
227                                     "items": [
228                                         {
229                                             "|xns": "Roo.grid",
230                                             "xtype": "GridEditor",
231                                             "*prop": "editor",
232                                             "items": [
233                                                 {
234                                                     "*prop": "field",
235                                                     "allowBlank": false,
236                                                     "displayField": "title",
237                                                     "editable": false,
238                                                     "fieldLabel": "Country",
239                                                     "hiddenName": "freq_hour",
240                                                     "listWidth": 300,
241                                                     "mode": "local",
242                                                     "name": "freq_hour_name",
243                                                     "pageSize": 40,
244                                                     "triggerAction": "all",
245                                                     "valueField": "code",
246                                                     "xtype": "ComboCheck",
247                                                     "|xns": "Roo.form",
248                                                     "items": [
249                                                         {
250                                                             "*prop": "store",
251                                                             "xtype": "SimpleStore",
252                                                             "|data": "(function() { \n    var ret = [];\n    for (var i = 5; i < 25; i++) {\n        var h = i < 10 ? ('0' + i) : i;\n        var mer = i < 12 || i > 23 ? 'am' : 'pm';\n        var dh = i < 13 ? i : i-12;\n        \n        ret.push([ h+':00', dh+':00' + mer ]);\n        ret.push([ h+':30', dh+':30' + mer ]);        \n    }\n    return ret;\n})()",
253                                                             "|fields": "['code', 'title']",
254                                                             "|sortInfo": "{ field : 'title', direction: 'ASC' }",
255                                                             "|xns": "Roo.data"
256                                                         }
257                                                     ]
258                                                 }
259                                             ]
260                                         }
261                                     ]
262                                 },
263                                 {
264                                     "*prop": "colModel[]",
265                                     "dataIndex": "tz",
266                                     "header": "Timezone",
267                                     "width": 100,
268                                     "xtype": "ColumnModel",
269                                     "|renderer": "function(v) { return String.format('{0}', v); }",
270                                     "|xns": "Roo.grid",
271                                     "items": [
272                                         {
273                                             "|xns": "Roo.grid",
274                                             "xtype": "GridEditor",
275                                             "*prop": "editor",
276                                             "items": [
277                                                 {
278                                                     "*prop": "field",
279                                                     "allowBlank": "false",
280                                                     "displayField": "tz",
281                                                     "editable": true,
282                                                     "emptyText": "Select timezone",
283                                                     "fieldLabel": "core_enum",
284                                                     "forceSelection": true,
285                                                     "listWidth": 400,
286                                                     "loadingText": "Searching...",
287                                                     "minChars": 2,
288                                                     "name": "tz",
289                                                     "pageSize": 999,
290                                                     "qtip": "Select timezone",
291                                                     "queryParam": "q",
292                                                     "selectOnFocus": true,
293                                                     "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{tz}</b> </div>",
294                                                     "triggerAction": "all",
295                                                     "typeAhead": true,
296                                                     "width": 300,
297                                                     "xtype": "ComboBox",
298                                                     "|xns": "Roo.form",
299                                                     "items": [
300                                                         {
301                                                             "listeners": {
302                                                                 "|beforeload": "function (_self, o){\n    o.params = o.params || {};\n    // set more here\n}\n"
303                                                             },
304                                                             "*prop": "store",
305                                                             "remoteSort": true,
306                                                             "xtype": "Store",
307                                                             "|sortInfo": "{ direction : 'ASC', field: 'tz' }",
308                                                             "|xns": "Roo.data",
309                                                             "items": [
310                                                                 {
311                                                                     "*prop": "proxy",
312                                                                     "method": "GET",
313                                                                     "xtype": "HttpProxy",
314                                                                     "|url": "baseURL + '/Core/I18n/Timezone.php'\n",
315                                                                     "|xns": "Roo.data"
316                                                                 },
317                                                                 {
318                                                                     "*prop": "reader",
319                                                                     "id": "id",
320                                                                     "root": "data",
321                                                                     "totalProperty": "total",
322                                                                     "xtype": "JsonReader",
323                                                                     "|fields": "[{\"name\":\"tz\",\"type\":\"string\"}]",
324                                                                     "|xns": "Roo.data"
325                                                                 }
326                                                             ]
327                                                         }
328                                                     ]
329                                                 }
330                                             ]
331                                         }
332                                     ]
333                                 },
334                                 {
335                                     "*prop": "colModel[]",
336                                     "dataIndex": "last_event_id",
337                                     "header": "Last Sent",
338                                     "width": 75,
339                                     "xtype": "ColumnModel",
340                                     "|renderer": "function(v) { return String.format('{0}', v ? v : 'never'); }",
341                                     "|xns": "Roo.grid"
342                                 }
343                             ]
344                         }
345                     ]
346                 },
347                 {
348                     "listeners": {
349                         "click": "function (_self, e)\n{\n    _this.dialog.hide();\n}"
350                     },
351                     "*prop": "buttons[]",
352                     "text": "Done",
353                     "xtype": "Button",
354                     "|xns": "Roo"
355                 }
356             ]
357         }
358     ],
359     "permname": "",
360     "modOrder": "001"
361 }