2 "name" : "Pman.Tab.XtuplePeriods",
3 "parent" : "Pman.Tab.XtupleAccountsTab",
5 "path" : "/home/edward/gitlive/web.xtuple/Pman/Xtuple/Pman.Tab.XtuplePeriods.bjs",
14 "xtype" : "NestedLayoutPanel",
15 "fitContainer" : true,
19 "xtype" : "BorderLayout",
25 "xtype" : "LayoutRegion",
26 "tabPosition" : "top",
32 "title" : "Year Periods",
33 "xtype" : "LayoutRegion",
34 "tabPosition" : "top",
43 "|activate" : "function() {\n _this.wpanel = this;\n if (_this.wgrid) {\n _this.wgrid.ds.load({});\n }\n}"
48 "title" : "Year Periods",
49 "xtype" : "GridPanel",
50 "fitContainer" : true,
52 "tableName" : "yearperiod",
56 "cellclick" : "function (_self, rowIndex, columnIndex, e)\n{\n\n var di = this.colModel.getDataIndex(columnIndex);\n\n if (di != 'yearperiod_closed') {\n return;\n }\n\n var rec = this.ds.getAt(rowIndex);\n\n\n var open = function(){\n new Pman.Request({\n url : baseURL + '/Roo/Yearperiod.php',\n timeout: 600000,\n mask : 'Processing',\n method : 'POST',\n params : {\n yearperiod_id : rec.data.yearperiod_id,\n _open : 1\n \n }, \n success : function() {\n _this.wgrid.ds.load({});\n }\n }); \n };\n \n var close = function(){\n new Pman.Request({\n url : baseURL + '/Roo/Yearperiod.php',\n timeout: 600000,\n mask : 'Processing',\n method : 'POST',\n params : {\n yearperiod_id : rec.data.yearperiod_id,\n _close : 1\n \n }, \n success : function() {\n _this.wgrid.ds.load({});\n }\n }); \n };\n \n if(rec.data.yearperiod_id * 1 < 1){\n Roo.MessageBox.alert('Error', 'Please select a period?');\n return;\n }\n\n //Roo.log(rec.data);\n if(rec.data.yearperiod_closed *1){\n Roo.MessageBox.confirm(\"Confirm\", \"Are you sure want to open this year period?\" , function(r) {\n if (r !='yes') {\n return;\n }\n open();\n \n });\n return;\n }\n \n \n\n \n Roo.MessageBox.confirm(\"Confirm\", \"Are you sure want to close this year period?\" , function(r) {\n if (r !='yes') {\n return;\n }\n close();\n \n })\n \n \n \n \n}",
57 "|render" : "function() \n{\n _this.wgrid = this; \n //_this.dialog = Pman.Dialog.FILL_IN\n if (_this.wpanel.active) {\n this.ds.load({});\n }\n}",
58 "rowclick" : "function (_self, rowIndex, e)\n{\n _this.grid.ds.load({});\n}"
60 "autoExpandColumn" : "yearperiod_start",
67 "xtype" : "RowSelectionModel",
68 "singleSelect" : true,
75 "$ sortInfo" : "{ field : 'yearperiod_start', direction: 'ASC' }",
77 "* prop" : "dataSource",
80 "$ url" : "baseURL + '/Roo/Yearperiod.php'",
81 "xtype" : "HttpProxy",
89 "xtype" : "JsonReader",
90 "$ fields" : "[\n {\n 'name': 'yearperiod_id',\n 'type': 'int'\n },\n {\n 'name': 'yearperiod_name',\n 'type': 'string'\n }\n]",
93 "totalProperty" : "total"
98 "xtype" : "ColumnModel",
101 "$ renderer" : "function(v,x,r) \n{ \n v = r.data.yearperiod_start.getFullYear() + '-' + r.data.yearperiod_end.getFullYear();\n \n return String.format('{0}', v ? v : ''); \n}",
102 "$ xns" : "Roo.grid",
103 "* prop" : "colModel[]",
104 "dataIndex" : "yearperiod_name"
107 "xtype" : "ColumnModel",
111 "$ renderer" : "function(v) { return String.format('{0}', v ? v.format('Y-m-d') : ''); }",
112 "$ xns" : "Roo.grid",
113 "* prop" : "colModel[]",
114 "dataIndex" : "yearperiod_start"
117 "xtype" : "ColumnModel",
121 "$ renderer" : "function(v) { return String.format('{0}', v ? v.format('Y-m-d') : ''); }",
122 "$ xns" : "Roo.grid",
123 "* prop" : "colModel[]",
124 "dataIndex" : "yearperiod_end"
127 "xtype" : "ColumnModel",
131 "$ renderer" : "function(v) { \n var state = v ? '-checked' : '';\n\n return '<img class=\"x-grid-check-icon' + state + '\" src=\"' + Roo.BLANK_IMAGE_URL + '\"/>';\n \n }",
132 "$ xns" : "Roo.grid",
133 "* prop" : "colModel[]",
134 "dataIndex" : "yearperiod_closed"
142 "|activate" : "function() {\n _this.panel = this;\n}"
148 "xtype" : "GridPanel",
149 "fitContainer" : true,
151 "tableName" : "period",
155 "beforeedit" : "function (e)\n{\n if(e.field != 'period_name'){\n return false;\n }\n}",
156 "|render" : "function() \n{\n _this.grid = this; \n}",
157 "cellclick" : "function (_self, rowIndex, columnIndex, e)\n{\n\n var di = this.colModel.getDataIndex(columnIndex);\n\n if (di != 'period_closed' && di != 'period_freeze') {\n return;\n }\n\n var rec = _this.grid.ds.getAt(rowIndex);\n \n if(rec.data.period_id * 1 < 1){\n Roo.MessageBox.alert('Error', 'Error occur on getting the period id');\n return;\n }\n \n var action = rec.data[di] ? 'thaw' : 'freeze';\n \n if(di == 'period_closed'){\n action = rec.data[di] ? 'open' : 'close';\n }\n \n new Pman.Request({\n url : baseURL + '/Roo/Period.php',\n timeout: 600000,\n mask : 'Processing',\n method : 'POST',\n params : {\n period_id : rec.data.period_id,\n _action : action\n \n }, \n success : function() {\n _this.grid.ds.load({});\n }\n }); \n \n}",
158 "afteredit" : "function (e)\n{\n if(e.field != 'period_name' || e.originalValue == e.value){\n return;\n }\n \n if(e.record.data.period_id * 1 < 1){\n Roo.MessageBox.alert('Error', 'Error occur on getting the period id');\n return;\n }\n \n new Pman.Request({\n url : baseURL + '/Roo/Period.php',\n method : 'POST',\n params : {\n period_id : e.record.data.period_id,\n period_name : e.record.data.period_name\n \n }, \n success : function() {\n _this.grid.ds.load({});\n }\n });\n}"
160 "autoExpandColumn" : "period_name",
161 "xtype" : "EditorGrid",
164 "$ xns" : "Roo.grid",
170 "* prop" : "toolbar",
174 "render" : "function (_self)\n{\n _this.status = _self;\n}",
175 "select" : "function (combo, record, index)\n{\n _this.grid.ds.load({});\n}"
178 "triggerAction" : "all",
179 "fieldLabel" : "Status",
180 "displayField" : "fname",
181 "hiddenName" : "status",
183 "valueField" : "ftype",
184 "xtype" : "ComboBox",
185 "allowBlank" : false,
188 "$ xns" : "Roo.form",
193 "xtype" : "SimpleStore",
194 "$ data" : "[ \n [ 'O', \"Open\"],\n [ 'C' , \"Closed\"],\n [ 'A', \"All\"] \n]\n",
195 "$ fields" : "[ 'ftype', 'fname']",
196 "$ xns" : "Roo.data",
203 "$ xns" : "Roo.Toolbar"
207 "|click" : "function()\n{\n var addPeriod = function(){\n new Pman.Request({\n url : baseURL + '/Roo/Period.php',\n timeout: 600000,\n mask : 'Processing',\n method : 'POST',\n params : {\n _addExtraYear : 1\n }, \n success : function() {\n _this.wgrid.ds.load({});\n }\n });\n }\n \n Roo.MessageBox.confirm(\"Confirm\", \"Are you sure want to add extra year\" , function(r) {\n if (r !='yes') {\n return;\n }\n addPeriod();\n })\n \n}\n"
209 "text" : "Add Extra Year",
211 "cls" : "x-btn-text-icon",
212 "$ icon" : "Roo.rootURL + 'images/default/dd/drop-add.gif'",
213 "$ xns" : "Roo.Toolbar"
216 "xtype" : "Separator",
217 "$ xns" : "Roo.Toolbar"
221 "|click" : "function()\n{\n var list = []; \n \n \n \n _this.grid.ds.each(function (r) {\n if (r.data.period_closed) {\n return;\n }\n \n if(r.data.transactions > 0 ){\n return false;\n }\n list.push(r.data);\n\n });\n \n if (!list.length) {\n Roo.MessageBox.alert(\"Notice\", \"Nothing to close\");\n return;\n }\n \n var tl = list.length;\n \n var closeNext = function(){\n \n if (!list.length) {\n Roo.MessageBox.hide();\n _this.grid.ds.load({});\n return;\n }\n \n var item = list.shift();\n \n Roo.MessageBox.updateProgress(\n (tl-list.length) / tl,\n \"Closing \" + item.period_name\n \n );\n \n new Pman.Request({\n url : baseURL + '/Roo/Period.php',\n timeout: 900000,\n //mask : 'Processing',\n method : 'POST',\n params : {\n period_id : item.period_id,\n _action: 'close' ,\n _second_action : 'freeze'\n }, \n success : function() {\n closeNext();\n// _this.grid.ds.load({});\n }\n });\n };\n \n \n \n \n Roo.MessageBox.confirm(\"Confirm\", \"Are you sure want to close the period where there are no transactions?\" , function(r) {\n if (r !='yes') {\n return;\n }\n Roo.MessageBox.progress( \"Closing periods\", \"Closing periods\");\n closeNext();\n \n })\n \n \n \n \n \n}\n"
223 "text" : "Close all empty months",
225 "cls" : "x-btn-text-icon",
226 "$ icon" : "Roo.rootURL + 'images/default/tree/leaf.gif'",
227 "$ xns" : "Roo.Toolbar"
233 "beforeload" : "function (_self, options)\n{\n options.params = options.params || {};\n \n var s = _this.wgrid.getSelectionModel().getSelected();\n \n if(!s || !s.data.yearperiod_id * 1 > 0){\n Roo.MessageBox.alert('Error','Please select a year period');\n this.removeAll();\n return false;\n }\n \n options.params._status = _this.status.getValue();\n options.params.period_yearperiod_id = s.data.yearperiod_id;\n options.params._with_transactions = 1;\n \n\n}"
237 "$ sortInfo" : "{ field : 'period_start', direction: 'ASC' }",
238 "$ xns" : "Roo.data",
239 "* prop" : "dataSource",
242 "$ url" : "baseURL + '/Roo/Period.php'",
243 "xtype" : "HttpProxy",
245 "$ xns" : "Roo.data",
251 "xtype" : "JsonReader",
252 "$ fields" : "[\n {\n 'name': 'period_id',\n 'type': 'int'\n },\n {\n 'name': 'period_name',\n 'type': 'string'\n }\n]",
253 "$ xns" : "Roo.data",
255 "totalProperty" : "total"
260 "xtype" : "ColumnModel",
263 "$ renderer" : "function(v) \n{ \n return String.format('{0}', v ? v : ''); \n}",
264 "$ xns" : "Roo.grid",
265 "* prop" : "colModel[]",
266 "dataIndex" : "period_name",
269 "xtype" : "GridEditor",
270 "$ xns" : "Roo.grid",
274 "xtype" : "TextField",
275 "allowBlank" : false,
276 "$ xns" : "Roo.form",
284 "xtype" : "ColumnModel",
287 "$ renderer" : "function(v) { return String.format('{0}', v ? v.format('Y-m-d') : ''); }",
288 "$ xns" : "Roo.grid",
289 "* prop" : "colModel[]",
290 "dataIndex" : "period_start"
293 "xtype" : "ColumnModel",
296 "$ renderer" : "function(v) { return String.format('{0}', v ? v.format('Y-m-d') : ''); }",
297 "$ xns" : "Roo.grid",
298 "* prop" : "colModel[]",
299 "dataIndex" : "period_end"
302 "xtype" : "ColumnModel",
305 "$ renderer" : "function(v) { \n var state = v ? '-checked' : '';\n\n return '<img class=\"x-grid-check-icon' + state + '\" src=\"' + Roo.BLANK_IMAGE_URL + '\"/>';\n \n }",
306 "$ xns" : "Roo.grid",
307 "* prop" : "colModel[]",
308 "dataIndex" : "period_closed"
311 "xtype" : "ColumnModel",
314 "$ renderer" : "function(v) { \n var state = v ? '-checked' : '';\n\n return '<img class=\"x-grid-check-icon' + state + '\" src=\"' + Roo.BLANK_IMAGE_URL + '\"/>';\n \n }",
315 "$ xns" : "Roo.grid",
316 "* prop" : "colModel[]",
317 "dataIndex" : "period_freeze"
321 "xtype" : "ColumnModel",
322 "header" : "Transactions",
324 "$ renderer" : "function(v) \n{ \n return String.format('{0}', v ? v : ''); \n}",
325 "$ xns" : "Roo.grid",
326 "* prop" : "colModel[]",
327 "dataIndex" : "transactions"