3 "name": "Pman.Tab.MTrackTimeline",
4 "parent": "Pman.Tab.DocumentsTab",
6 "path": "/home/alan/gitlive/Pman.MTrack/Pman.Tab.MTrackTimeline.bjs",
10 "activate": "function (_self)\n{\n // navigation..\n // a) record the fact we go here.. (for history)\n \n // when page loads, we have to go to this page..\n \n // at other times, we just check \n // a) project was the same as before... - do not change.\n // b) \n _this.project = _this.project || 0;\n \n \n if (typeof(MTrackWeb) != 'undefined' && !MTrackWeb.Layout) {\n return;\n }\n \n if (typeof(Pman.Tab.DocumentsTab) == 'undefined') {\n return;\n }\n /*\n if (!_this.iscroll) { \n \n (function() {\n \n try {\n _this.iscroll = new Roo.ux.Iscroll(_this.tpanel.el.dom);\n } catch(e) { \n Roo.log(e);\n }\n }).defer(100); \n\n }\n _this.iscroll = true; \n \n */\n var chg_project = (_this.project != Pman.Tab.DocumentsTab.panel.getProjectId());\n \n _this.project = Pman.Tab.DocumentsTab.panel.getProjectId();\n \n if (typeof(MTrackWeb) == 'undefined') {\n return;\n }\n try { \n window.history.pushState( { url: '/Timeline' }, 'Timeline' , baseURL + '/Timeline' );\n } catch (e) {}\n \n MTrack.currentURL = '/Timeline';\n if (chg_project) {\n (function() {\n _this.grid.ds.load({});\n //_this.tpanel.view.store.load({});\n }).defer(100);\n }\n \n \n}"
16 "title": "Project Timeline",
17 "xtype": "NestedLayoutPanel",
22 "xtype": "BorderLayout",
28 "xtype": "LayoutRegion",
34 "xtype": "LayoutRegion",
39 "activate": "function (_self)\n{\n _this.tpanel = _self;\n}"
47 "xtype": "ContentPanel",
48 "|mload": "function(url) {\n\n // can you actually link to this page..\n // perhaps a specific day..\n\n this._url = url;\n // this._project = MTrack.projectCombo.getValue();\n // MTrack.ajaxLoad(url, this);\n _this.grid.ds.load({});\n \n}\n",
57 "text": "Select a date to refresh..",
71 "|url": "rootURL + '/Pman/MTrack/templates/timeline.html'",
76 "beforeload": "function (_self, o)\n{\n o = o || {};\n o.params = o.params || {};\n \n var sel = _this.grid.selModel.getSelected();\n o.params.from_date = sel.data.changeday.format(\"Y-m-d\");\n o.params.person_id = sel.data.person_id;\n // o.params.viewtype = 'summary'; \n o.params.timeline = 1;\n // project?\n o.params.project_id = sel.data.project_id;\n}"
81 "|sortInfo": "{ field : 'person_name', direction: 'ASC' }",
88 "|url": "baseURL + '/Roo/mtrack_change.php'",
95 "totalProperty": "total",
96 "xtype": "JsonReader",
97 "|fields": "[\n {\n 'name': 'person_id',\n 'type': 'int'\n },\n {\n 'name': 'person_name',\n 'type': 'string'\n },\n {\n 'name': 'changeday',\n 'type': 'date',\n 'dateFormat': 'Y-m-d'\n },\n {\n 'name': 'nchanges',\n 'type': 'int'\n },\n 'project_code',\n 'project_id',\n \n\n]",
108 "xtype": "NestedLayoutPanel",
113 "xtype": "BorderLayout",
118 "xtype": "LayoutRegion",
124 "xtype": "LayoutRegion",
129 "|activate": "function() {\n _this.gridpanel = this;\n\n}"
133 "fitContainer": true,
136 "tableName": "Events",
138 "xtype": "GridPanel",
143 "|render": "function() \n{\n _this.grid = this; \n //_this.dialog = Pman.Dialog.FILL_IN\n this.dataSource.load({});\n\n}"
146 "autoExpandColumn": "person_id_name",
153 "afterselectionchange": "function (_self)\n{\n // select the data..\n \n var r= _this.grid.sm.getSelected();\n \n \n _this.datePicker.setValue(r.data.changeday);\n _this.tpanel.view.store.load({});\n \n} "
156 "singleSelect": true,
157 "xtype": "RowSelectionModel",
162 "beforeload": "function (_self, o)\n{\n o = o || {};\n o.params = o.params || {};\n \n if (!_this.datePicker || !_this.datePicker.getValue) {\n return false;\n }\n o.params.from_date = _this.datePicker.activeDate.format(\"Y-m-01\");\n o.params.viewtype = 'summary'; \n o.params.timeline = 1;\n // project?\n o.params.project_id = Pman.Tab.DocumentsTab ? Pman.Tab.DocumentsTab.panel.getProjectId() : 0;\n}"
164 "*prop": "dataSource",
167 "|sortInfo": "{ field : 'person_name', direction: 'ASC' }",
173 "xtype": "HttpProxy",
174 "|url": "baseURL + '/Roo/mtrack_change.php'",
181 "totalProperty": "total",
182 "xtype": "JsonReader",
183 "|fields": "[\n {\n 'name': 'person_id',\n 'type': 'int'\n },\n {\n 'name': 'person_name',\n 'type': 'string'\n },\n {\n 'name': 'changeday',\n 'type': 'date',\n 'dateFormat': 'Y-m-d'\n },\n {\n 'name': 'nchanges',\n 'type': 'int'\n },\n 'project_code',\n 'project_id',\n \n\n]",
189 "*prop": "colModel[]",
190 "dataIndex": "changeday",
193 "xtype": "ColumnModel",
194 "|renderer": "function(v,x,r) { \n\n return String.format('{0}', v ? v.format('d') : '' );\n }",
198 "*prop": "colModel[]",
199 "dataIndex": "project_code",
202 "xtype": "ColumnModel",
203 "|renderer": "function(v,x,r) { \n \n Roo.log(r);\n return String.format( '{0}' ,v );\n }\n ",
207 "*prop": "colModel[]",
208 "dataIndex": "person_name",
211 "xtype": "ColumnModel",
212 "|renderer": "function(v,x,r) { \n \n return String.format( '{0}' , v);\n }\n ",
216 "*prop": "colModel[]",
218 "dataIndex": "nchanges",
221 "xtype": "ColumnModel",
222 "|renderer": "function(v,x,r) { \n return v * 1;\n }\n ",
231 "xtype": "ContentPanel",
236 "render": "function (_self)\n{\n _this.datePicker = _self;\n}",
237 "select": "function (_self, date)\n{\n if (!_this.tpanel) {\n return;\n }\n _this.tpanel.view.store.load({});\n}",
238 "monthchange": "function (_self, date)\n{\n if (_this.grid) {\n _this.grid.ds.load({ });\n }\n}"
240 "xtype": "DatePicker",