3 "name": "Pman.Dialog.CoreNotifyRecur",
6 "path": "/home/alan/gitlive/Pman.Core/Pman.Dialog.CoreNotifyRecur.bjs",
10 "show": "function (_self)\n{\n _this.grid.ds.load({});\n}"
15 "title": "Modify Recurrent Notifications",
17 "xtype": "LayoutDialog",
24 "xtype": "LayoutRegion",
29 "|activate": "function() {\n _this.panel = this;\n if (_this.grid) {\n// _this.grid.footer.onClick('first');\n }\n}"
35 "tableName": "core_notify_recur",
36 "title": "core_notify_recur",
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}"
47 "autoExpandColumn": "freq_day",
50 "xtype": "EditorGrid",
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}"
58 "*prop": "dataSource",
61 "|sortInfo": "{ field : 'freq', direction: 'ASC' }",
68 "|url": "baseURL + '/Roo/core_notify_recur.php'",
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]",
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"
91 "cls": "x-btn-text-icon",
94 "|icon": "Roo.rootURL + 'images/default/dd/drop-add.gif'",
98 "|xns": "Roo.Toolbar",
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 "
105 "cls": "x-btn-text-icon",
108 "|icon": "rootURL + '/Pman/templates/images/trash.gif'",
109 "|xns": "Roo.Toolbar"
114 "*prop": "colModel[]",
115 "dataIndex": "method_id_display_name",
118 "xtype": "ColumnModel",
119 "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
124 "xtype": "GridEditor",
130 "*prop": "colModel[]",
131 "dataIndex": "dtstart",
134 "xtype": "ColumnModel",
135 "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
140 "xtype": "GridEditor",
145 "xtype": "DateField",
153 "*prop": "colModel[]",
154 "dataIndex": "dtend",
157 "xtype": "ColumnModel",
158 "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
163 "xtype": "GridEditor",
168 "xtype": "DateField",
176 "*prop": "colModel[]",
177 "dataIndex": "freq_day",
178 "header": "on day(s)",
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}",
186 "xtype": "GridEditor",
192 "displayField": "title",
194 "fieldLabel": "Country",
195 "hiddenName": "freq_day",
198 "name": "freq_day_name",
200 "triggerAction": "all",
201 "valueField": "code",
202 "xtype": "ComboCheck",
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' }",
220 "*prop": "colModel[]",
221 "dataIndex": "freq_hour",
222 "header": "at Hour(s)",
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}",
230 "xtype": "GridEditor",
236 "displayField": "title",
238 "fieldLabel": "Country",
239 "hiddenName": "freq_hour",
242 "name": "freq_hour_name",
244 "triggerAction": "all",
245 "valueField": "code",
246 "xtype": "ComboCheck",
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' }",
264 "*prop": "colModel[]",
266 "header": "Timezone",
268 "xtype": "ColumnModel",
269 "|renderer": "function(v) { return String.format('{0}', v); }",
274 "xtype": "GridEditor",
279 "allowBlank": "false",
280 "displayField": "tz",
282 "emptyText": "Select timezone",
283 "fieldLabel": "core_enum",
284 "forceSelection": true,
286 "loadingText": "Searching...",
290 "qtip": "Select timezone",
292 "selectOnFocus": true,
293 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{tz}</b> </div>",
294 "triggerAction": "all",
302 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n}\n"
307 "|sortInfo": "{ direction : 'ASC', field: 'tz' }",
313 "xtype": "HttpProxy",
314 "|url": "baseURL + '/Core/I18n/Timezone.php'\n",
321 "totalProperty": "total",
322 "xtype": "JsonReader",
323 "|fields": "[{\"name\":\"tz\",\"type\":\"string\"}]",
335 "*prop": "colModel[]",
336 "dataIndex": "last_event_id",
337 "header": "Last Sent",
339 "xtype": "ColumnModel",
340 "|renderer": "function(v) { return String.format('{0}', v ? v : 'never'); }",
349 "click": "function (_self, e)\n{\n _this.dialog.hide();\n}"
351 "*prop": "buttons[]",