3 "name": "Pman.Dialog.CoreNotifyRecur",
6 "path": "/home/chris/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": "dtstart",
118 "xtype": "ColumnModel",
119 "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
124 "xtype": "GridEditor",
129 "xtype": "DateField",
137 "*prop": "colModel[]",
138 "dataIndex": "dtend",
141 "xtype": "ColumnModel",
142 "|renderer": "function(v) { return String.format('{0}', v ? v.format('d/M/Y') : ''); }",
147 "xtype": "GridEditor",
152 "xtype": "DateField",
160 "*prop": "colModel[]",
161 "dataIndex": "freq_day",
162 "header": "on day(s)",
164 "xtype": "ColumnModel",
165 "|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}",
170 "xtype": "GridEditor",
176 "displayField": "title",
178 "fieldLabel": "Country",
179 "hiddenName": "freq_day",
182 "name": "freq_day_name",
184 "triggerAction": "all",
185 "valueField": "code",
186 "xtype": "ComboCheck",
191 "xtype": "SimpleStore",
192 "|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})()",
193 "|fields": "['code', 'title']",
194 "|sortInfo": "{ field : 'title', direction: 'ASC' }",
204 "*prop": "colModel[]",
205 "dataIndex": "freq_hour",
206 "header": "at Hour(s)",
208 "xtype": "ColumnModel",
209 "|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}",
214 "xtype": "GridEditor",
220 "displayField": "title",
222 "fieldLabel": "Country",
223 "hiddenName": "freq_hour",
226 "name": "freq_hour_name",
228 "triggerAction": "all",
229 "valueField": "code",
230 "xtype": "ComboCheck",
235 "xtype": "SimpleStore",
236 "|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})()",
237 "|fields": "['code', 'title']",
238 "|sortInfo": "{ field : 'title', direction: 'ASC' }",
248 "*prop": "colModel[]",
250 "header": "Timezone",
252 "xtype": "ColumnModel",
253 "|renderer": "function(v) { return String.format('{0}', v); }",
258 "xtype": "GridEditor",
263 "allowBlank": "false",
264 "displayField": "tz",
266 "emptyText": "Select timezone",
267 "fieldLabel": "core_enum",
268 "forceSelection": true,
270 "loadingText": "Searching...",
274 "qtip": "Select timezone",
276 "selectOnFocus": true,
277 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{tz}</b> </div>",
278 "triggerAction": "all",
286 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n}\n"
291 "|sortInfo": "{ direction : 'ASC', field: 'tz' }",
297 "xtype": "HttpProxy",
298 "|url": "baseURL + '/Core/I18n/Timezone.php'\n",
305 "totalProperty": "total",
306 "xtype": "JsonReader",
307 "|fields": "[{\"name\":\"tz\",\"type\":\"string\"}]",
319 "*prop": "colModel[]",
320 "dataIndex": "last_event_id",
321 "header": "Last Sent",
323 "xtype": "ColumnModel",
324 "|renderer": "function(v) { return String.format('{0}', v ? v : 'never'); }",
333 "click": "function (_self, e)\n{\n _this.dialog.hide();\n}"
335 "*prop": "buttons[]",