3 "name": "Pman.Tab.MTrackTicket",
4 "parent": "Pman.Tab.DocumentsTab",
5 "title": "MTrackWeb.Ticket",
6 "path": "/home/alan/gitlive/Pman.MTrack/Pman.Tab.MTrackTicket.bjs",
10 "activate": "function (_self)\n{\n _this.panel = _self;\n (function () {\n if (_this.tpanel) {\n _this.panel.layout.getRegion('south').hide();\n //_this.panel.layout.getRegion('north').hide();\n }\n }).defer(100);\n try {\n if (!_this.url || !_this.project || (_this.project != MTrack.projectCombo.getValue())) {\n (function() { \n if (_this.tpanel) { \n // _this.tpanel.mload(\"/Report/1\"); \n }\n }).defer(300);\n }\n \n \n } catch(e) {Roo.log(\"activate fail\" + e.toString()); }\n}"
17 "xtype": "NestedLayoutPanel",
22 "xtype": "BorderLayout",
28 "xtype": "LayoutRegion",
37 "xtype": "LayoutRegion",
44 "xtype": "LayoutRegion",
49 "|activate": "function() {\n _this.gpanel = this;\n if (_this.grid) {\n _this.grid.ds.load({});\n }\n}"
55 "tableName": "mtrack_ticket",
56 "title": "mtrack_ticket",
62 "|render": "function() \n{\n _this.grid = this; \n _this.panel.grid = this; // works with doc manager...\n //_this.dialog = Pman.Dialog.FILL_IN\n if (_this.gpanel.active) {\n _this.grid.ds.load({});\n }\n}",
63 "afteredit": "function (e)\n{\n Roo.log(e);\n e.record.commit();\n}",
64 "celldblclick": "function (_self, rowIndex, columnIndex, e)\n{\n var c = _this.grid.colModel.getDataIndex(columnIndex);\n \n \n if (c.match(/_id$/) ) {\n return;\n }\n var rec = _this.grid.ds.getAt(rowIndex);\n Pman.Dialog.MTrackTicket.show({ id : rec.data.id } , function(res) {\n // update row, and re-render..\n \n });\n \n \n}"
67 "autoExpandColumn": "summary",
69 "ddGroup": "mtrack_ticket",
70 "enableDragDrop": true,
72 "xtype": "EditorGrid",
73 "|getProjectId": "function() {\n\n if (typeof(MTrack) != 'undefined') {\n return MTrack.projectCombo.getValue();\n }\n \n // project_id : _this.grid.getProjectId(), //MTrack.projectCombo ? MTrack.projectCombo.getValue() :2830 , // testing.\n // project_id_name : _this.grid.getProjectId(), //MTrack.projectCombo.el.dom.value,\n \n \n \n try {\n var pr = Pman.Tab.Projects; // shuld be documentsProjects\n if (!pr || !pr.grid) {\n return false;\n }\n } catch (e) {\n return false;\n }\n var sels = pr.grid.getSelectionModel().getSelections();\n var prids = [];\n if (sels.length) {\n Roo.each(sels,function(s) {\n prids.push(s.data.id);\n });\n // multi support later..\n return prids[0];\n }\n \n \n \n return 0;\n \n \n}\n",
74 "|getProjectName": "function() {\n // project_id : _this.grid.getProjectId(), //MTrack.projectCombo ? MTrack.projectCombo.getValue() :2830 , // testing.\n \n if (typeof(MTrack) != 'undefined') {\n \n return MTrack.projectCombo.el.dom.value;\n }\n \n \n \n try {\n var pr = Pman.Tab.Projects; // shuld be documentsProjects\n if (!pr || !pr.grid) {\n return false;\n }\n } catch (e) {\n return false;\n }\n var sels = pr.grid.getSelectionModel().getSelections();\n var prids = [];\n if (sels.length) {\n Roo.each(sels,function(s) {\n prids.push(s.data.name);\n });\n // multi support later..\n return prids[0];\n }\n \n \n \n return ''; \n}\n",
79 "cellselect": "function (_self, rowIndex, colIndex)\n{\n var rec = _this.grid.ds.getAt(rowIndex);\n \n // verify nothing has chagned.. \n \n // load the ticked, and render a view of it...\n new Pman.Request({\n url : baseURL + '/Roo/mtrack_ticket',\n method : 'GET',\n params : { \n _id : rec.data.id\n },\n success : function(res) {\n //Roo.log(res.data);\n // render it into a template..\n _this.tpanel.setContent(Pman.MTrack.template.ticket_view(res.data));\n _this.tpanel.el.scrollTo('top',0);\n \n //... ehh\n Pman.MTrack.loadAudit(rec.data.id, _this.tpanel.el.select('.mtrack-ticket-events',true).first());\n \n \n \n new Pman.Request({\n url : baseURL + '/Roo/Images',\n method : 'GET',\n params : { \n onid : rec.data.id,\n ontable : 'mtrack_ticket'\n },\n success : function(ares) {\n Roo.log(ares.data);\n var el = Roo.select('.ticket-status-attachments .attachments-list', true).first();\n // fill in the attachement area with data from this..\n el.dom.innerHTML = Pman.MTrack.template.ticket_attachments(ares) ;\n }\n });\n \n \n _this.form.reset();\n\n _this.form.setValues({\n id : rec.data.id,\n owner_id : rec.data.owner_id,\n owner_id_name : rec.data.owner_id_name,\n status : rec.data.status,\n status_name : \"No Change\"\n }); \n \n \n for(var k in res.data) {\n rec.set(k,res.data[k]);\n }\n \n }\n });\n \n \n \n}"
82 "xtype": "CellSelectionModel",
87 "beforeload": "function (_self, options)\n{\n options.params = options.params || {};\n options.params['query[search]'] = _this.searchBox.getValue();\n var sq = options.params['query[viewtype]'] = _this.status.getValue(); \n \n var ps = _this.personSel.getValue();\n ps = ps ? ps : 0;\n if (ps ) {\n options.params.developer_id = ps <0 ? 0 : ps;\n }\n\n \n \n \n var pc = false;\n try {\n var pc = _this.grid.colModel.getIndexByDataIndex('project_id_name');\n \n } catch(e) {} \n \n \n \n try { \n options.params.project_id = Pman.Tab.DocumentsTab.panel.getProjectId();\n } catch(e) {\n options.params.project_id = MTrack.projectCombo.getValue();\n }\n options.params.project_id = options.params.project_id || undefined;\n \n \n \n if ( ps < 1 && pc !== false) {\n _this.grid.colModel.setHidden(pc, true);\n \n }\n \n // project column\n if (pc!== false) {\n _this.grid.colModel.setHidden(pc, true);\n }\n if (pc !== false && !options.params.project_id) {\n\n _this.grid.colModel.setHidden(pc, false); \n\n }\n\n options.params.limit = 999;\n // columns...\n\n \n \n}",
88 "update": "function (_self, record, operation)\n{\n Roo.log('update: ' + JSON.stringify(operation));\n if (operation != 'commit') {\n return;\n }\n // send things that might change..\n new Pman.Request({\n url : baseURL + '/Roo/mtrack_ticket',\n method : 'POST',\n params : {\n id : record.data.id,\n milestone_id : record.data.milestone_id,\n priority_id : record.data.priority_id,\n severity_id : record.data.severity_id,\n classification_id : record.data.classification_id,\n estimated : record.data.estimated,\n developer_id : record.data.developer_id\n },\n success : function(res)\n {\n var r = res.data;\n //Roo.log(r);\n // do nothing?\n record.modified = record.modified || {};\n for (var k in r) {\n // update the \n if (!k.match(/_id$/) && !k.match(/_id_/)) {\n continue;\n }\n record.data[k] = r[k];\n record.modified[k] = r[k];\n }\n record.store.afterEdit(record);\n }\n // we should really have a failure - to reset to the old value.\n });\n \n \n \n}"
90 "*prop": "dataSource",
93 "|sortInfo": "{ field : 'summary', direction: 'ASC' }",
100 "|url": "baseURL + '/Roo/mtrack_ticket.php'",
105 "xtype": "JsonReader",
106 "totalProperty": "total",
110 "|fields": "[\n {\n 'name': 'id',\n 'type': 'int'\n },\n {\n 'name': 'project_id',\n 'type': 'int'\n },\n {\n 'name': 'summary',\n 'type': 'string'\n },\n {\n 'name': 'description',\n 'type': 'string'\n },\n {\n 'name': 'changelog',\n 'type': 'string'\n },\n {\n 'name': 'created',\n 'type': 'int'\n },\n {\n 'name': 'updated',\n 'type': 'int'\n },\n {\n 'name': 'owner_id',\n 'type': 'int'\n },\n {\n 'name': 'priority_id',\n 'type': 'int'\n },\n {\n 'name': 'severity_id',\n 'type': 'int'\n },\n {\n 'name': 'classification_id',\n 'type': 'int'\n },\n {\n 'name': 'resolution_id',\n 'type': 'int'\n },\n {\n 'name': 'cc',\n 'type': 'string'\n },\n {\n 'name': 'status',\n 'type': 'int'\n },\n {\n 'name': 'estimated',\n 'type': 'float'\n },\n {\n 'name': 'spent',\n 'type': 'float'\n },\n {\n 'name': 'x_fieldname',\n 'type': 'string'\n },\n {\n 'name': 'developer_id',\n 'type': 'int'\n },\n {\n 'name': 'milestone_id',\n 'type': 'int'\n },\n {\n 'name': 'updated_id',\n 'type': 'int'\n },\n {\n 'name': 'updated_person_id',\n 'type': 'int'\n },\n {\n 'name': 'updated_ontable',\n 'type': 'string'\n },\n {\n 'name': 'updated_onid',\n 'type': 'int'\n },\n {\n 'name': 'updated_changedate',\n 'type': 'date'\n },\n {\n 'name': 'updated_reason',\n 'type': 'string'\n },\n {\n 'name': 'created_id',\n 'type': 'int'\n },\n {\n 'name': 'created_person_id',\n 'type': 'int'\n },\n {\n 'name': 'created_ontable',\n 'type': 'string'\n },\n {\n 'name': 'created_onid',\n 'type': 'int'\n },\n {\n 'name': 'created_changedate',\n 'type': 'date'\n },\n {\n 'name': 'created_reason',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_id',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_office_id',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_name',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_phone',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_fax',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_email',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_company_id',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_role',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_active',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_remarks',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_passwd',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_owner_id',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_lang',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_no_reset_sent',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_action_type',\n 'type': 'string'\n },\n {\n 'name': 'owner_id_project_id',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_deleted_by',\n 'type': 'int'\n },\n {\n 'name': 'owner_id_deleted_dt',\n 'type': 'date'\n },\n {\n 'name': 'developer_id_id',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_office_id',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_name',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_phone',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_fax',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_email',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_company_id',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_role',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_active',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_remarks',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_passwd',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_owner_id',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_lang',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_no_reset_sent',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_action_type',\n 'type': 'string'\n },\n {\n 'name': 'developer_id_project_id',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_deleted_by',\n 'type': 'int'\n },\n {\n 'name': 'developer_id_deleted_dt',\n 'type': 'date'\n },\n {\n 'name': 'priority_id_id',\n 'type': 'int'\n },\n {\n 'name': 'priority_id_etype',\n 'type': 'string'\n },\n {\n 'name': 'priority_id_name',\n 'type': 'string'\n },\n {\n 'name': 'priority_id_active',\n 'type': 'int'\n },\n {\n 'name': 'priority_id_seqid',\n 'type': 'int'\n },\n {\n 'name': 'severity_id_id',\n 'type': 'int'\n },\n {\n 'name': 'severity_id_etype',\n 'type': 'string'\n },\n {\n 'name': 'severity_id_name',\n 'type': 'string'\n },\n {\n 'name': 'severity_id_active',\n 'type': 'int'\n },\n {\n 'name': 'severity_id_seqid',\n 'type': 'int'\n },\n {\n 'name': 'classification_id_id',\n 'type': 'int'\n },\n {\n 'name': 'classification_id_etype',\n 'type': 'string'\n },\n {\n 'name': 'classification_id_name',\n 'type': 'string'\n },\n {\n 'name': 'classification_id_active',\n 'type': 'int'\n },\n {\n 'name': 'classification_id_seqid',\n 'type': 'int'\n },\n {\n 'name': 'resolution_id_id',\n 'type': 'int'\n },\n {\n 'name': 'resolution_id_etype',\n 'type': 'string'\n },\n {\n 'name': 'resolution_id_name',\n 'type': 'string'\n },\n {\n 'name': 'resolution_id_active',\n 'type': 'int'\n },\n {\n 'name': 'resolution_id_seqid',\n 'type': 'int'\n },\n {\n 'name': 'status_id',\n 'type': 'int'\n },\n {\n 'name': 'status_etype',\n 'type': 'string'\n },\n {\n 'name': 'status_name',\n 'type': 'string'\n },\n {\n 'name': 'status_active',\n 'type': 'int'\n },\n {\n 'name': 'status_seqid',\n 'type': 'int'\n },\n {\n 'name': 'project_id_id',\n 'type': 'int'\n },\n {\n 'name': 'project_id_name',\n 'type': 'string'\n },\n {\n 'name': 'project_id_remarks',\n 'type': 'string'\n },\n {\n 'name': 'project_id_owner_id',\n 'type': 'int'\n },\n {\n 'name': 'project_id_code',\n 'type': 'string'\n },\n {\n 'name': 'project_id_active',\n 'type': 'int'\n },\n {\n 'name': 'project_id_type',\n 'type': 'string'\n },\n {\n 'name': 'project_id_client_id',\n 'type': 'int'\n },\n {\n 'name': 'project_id_team_id',\n 'type': 'int'\n },\n {\n 'name': 'project_id_file_location',\n 'type': 'string'\n },\n {\n 'name': 'project_id_open_date',\n 'type': 'date'\n },\n {\n 'name': 'project_id_open_by',\n 'type': 'int'\n },\n {\n 'name': 'project_id_close_date',\n 'type': 'date'\n },\n {\n 'name': 'project_id_countries',\n 'type': 'string'\n },\n {\n 'name': 'project_id_languages',\n 'type': 'string'\n },\n {\n 'name': 'project_id_agency_id',\n 'type': 'int'\n },\n {\n 'name': 'milestone_id_id',\n 'type': 'int'\n },\n {\n 'name': 'milestone_id_name',\n 'type': 'string'\n },\n {\n 'name': 'milestone_id_description',\n 'type': 'string'\n },\n {\n 'name': 'milestone_id_startdate',\n 'type': 'date'\n },\n {\n 'name': 'milestone_id_duedate',\n 'type': 'date'\n },\n {\n 'name': 'milestone_id_completed',\n 'type': 'date'\n },\n {\n 'name': 'milestone_id_deleted',\n 'type': 'int'\n },\n {\n 'name': 'milestone_id_created',\n 'type': 'int'\n },\n {\n 'name': 'milestone_id_updated',\n 'type': 'int'\n },\n {\n 'name': 'milestone_id_project_id',\n 'type': 'int'\n }\n]"
121 "click": "function (_self, e)\n{\n Pman.Dialog.MTrackTicket.show({\n project_id : Pman.Tab.DocumentsTab.panel.getProjectId(), //MTrack.projectCombo ? MTrack.projectCombo.getValue() :2830 , // testing.\n project_id_name : Pman.Tab.DocumentsTab.panel.getProjectName(), //MTrack.projectCombo.el.dom.value,\n owner_id : Pman.Login.authUser.id,\n owner_id_name : Pman.Login.authUser.name\n\n }, function() { \n _this.grid.ds.load({}); \n });\n \n}"
123 "text": "Add New Ticket",
125 "|xns": "Roo.Toolbar"
129 "click": "function (_self, e)\n{\n params = {};\n params.project_id = Pman.Tab.DocumentsTab.panel.getProjectId(); // testing.\n params.limit = 999;\n // columns...\n params['query[viewtype]'] = 'active'\n \n for (var k in _this.filterBtn) {\n if (_this.filterBtn[k].pressed) {\n params['query[viewtype]'] = k;\n }\n }\n var ii =0;\n Roo.each(_this.grid.colModel.config, function(c,i) {\n params['csvCols['+i+']'] = c.dataIndex;\n params['csvTitles['+i+']'] = c.header;\n try {\n if (typeof( c.editor.field.name) != 'undefined') {\n params['csvCols['+i+']'] = c.editor.field.name;\n }\n } catch(e) {}\n ii++;\n });\n \n params['csvCols['+ii+']'] = 'description';\n params['csvTitles['+ii+']'] = \"Details\";\n \n \n \n new Pman.Download({\n url: baseURL + '/Roo/mtrack_ticket',\n method: 'GET' ,\n params: params\n \n });\n \n \n}"
131 "text": "Download to Excel",
133 "|xns": "Roo.Toolbar"
136 "|xns": "Roo.Toolbar",
142 "|xns": "Roo.Toolbar"
146 "render": "function (_self)\n{\n_this.searchBox= _self;\n}",
147 "specialkey": "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
149 "xtype": "TextField",
154 "|select": "function (combo, record, index)\n{\n _this.grid.ds.load({});\n \n}",
155 "|render": "function (_self)\n{\n _this.personSel = _self;\n if (Pman.Login.authUser.id) {\n this.setFromData({\n developer_id : Pman.Login.authUser.id,\n developer_id_name : Pman.Login.authUser.name\n });\n \n }\n}"
158 "displayField": "developer_id_name",
160 "emptyText": "Select Person ",
161 "fieldLabel": "Person ",
162 "forceSelection": true,
163 "hiddenName": "developer_id",
165 "loadingText": "Searching...",
167 "name": "developer_id",
169 "qtip": "Select Person ",
170 "queryParam": "query[name]",
171 "selectOnFocus": true,
172 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{developer_id_name}</b></div>",
173 "triggerAction": "all",
175 "valueField": "developer_id",
182 "|beforeload": "function (_self, o)\n{\n o.params = o.params || {};\n o.params._distinct = 'developer_id';\n o.params._columns = 'developer_id,developer_id_name';\n}",
183 "load": "function (_self, records, options)\n{\n Roo.log(records);\n var ua = _this.personSel.store.reader.newRow({\n developer_id : -1,\n developer_id_name : '-- Un-assigned --'\n });\n this.insert(0,[ua]);\n// records.unshift(ua);\n}"
187 "|sortInfo": "{ field : 'developer_id_name' , dir : 'ASC' }",
193 "xtype": "HttpProxy",
194 "|url": "baseURL + '/Roo/Mtrack_ticket.php'",
201 "totalProperty": "total",
202 "xtype": "JsonReader",
203 "|fields": "[\n {\n 'name': 'developer_id',\n 'type': 'int'\n } ,\n {\n 'name': 'developer_id_name',\n 'type' : 'text'\n }\n \n \n]",
212 "render": "function (_self)\n{\n _this.status = _self;\n}",
213 "select": "function (combo, record, index)\n{\n Roo.log('select');\n _this.grid.ds.load({});\n}"
216 "displayField": "fname",
218 "fieldLabel": "Status",
219 "hiddenName": "cm_status",
222 "name": "cm_status_name",
223 "triggerAction": "all",
225 "valueField": "ftype",
232 "xtype": "SimpleStore",
233 "|data": "[ \n [ 'active', \"Active\"],\n [ 'me' , \"Assigned to me\"],\n [ 'me-all' , \"Assigned to me (All projects)\"], \n [ 'closed' , \"Closed\"],\n [ 'pending' , \"Pending Review\"],\n [ 'in-progress' , \"In Progress\"],\n [ 'all' , \"All States\"]\n \n]\n",
234 "|fields": "[ 'ftype', 'fname']",
241 "|click": "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
245 "|icon": "rootURL + '/Pman/templates/images/search.gif'",
246 "|xns": "Roo.Toolbar"
250 "|click": "function (_self, e)\n{\n _this.searchBox.setValue('');\n \n _this.grid.ds.load({});\n}"
254 "|icon": "rootURL + '/Pman/templates/images/edit-clear.gif'",
255 "|xns": "Roo.Toolbar"
260 "*prop": "colModel[]",
265 "xtype": "ColumnModel",
266 "|renderer": "function(v) { return String.format('#{0}', v); }",
270 "*prop": "colModel[]",
271 "dataIndex": "project_id_name",
275 "xtype": "ColumnModel",
276 "|renderer": "function(v) { return String.format('{0}', v); }",
280 "*prop": "colModel[]",
281 "dataIndex": "milestone_id",
282 "header": "Milestone",
285 "xtype": "ColumnModel",
286 "|renderer": "function(v, x,r ) { return String.format('{0}', r.data.milestone_id_name); }",
291 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
294 "xtype": "GridEditor",
299 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
304 "displayField": "name",
306 "emptyText": "Select mtrack_milestone",
307 "forceSelection": true,
308 "hiddenName": "milestone_id",
310 "loadingText": "Searching...",
312 "name": "milestone_id_name",
314 "qtip": "Select mtrack_milestone",
316 "selectOnFocus": true,
317 "tpl": "<div class=\"x-grid-cell-text\"><b>{name}</b> - {startdate:date(\"d/m/Y\")} - {duedate:date(\"d/m/Y\")} </div>",
318 "triggerAction": "all",
327 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n var rec = _this.grid.activeEditor.record;\n\n o.params.project_id = rec.data.project_id;\n //o.params._viewtype = 'ACTIVE';\n o.params._viewtype\n}\n"
332 "|sortInfo": "{ direction : 'ASC', field: 'duedate' }",
337 "xtype": "HttpProxy",
340 "|url": "baseURL + '/Roo/mtrack_milestone.php'"
344 "xtype": "JsonReader",
348 "totalProperty": "total",
349 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
360 "*prop": "colModel[]",
361 "dataIndex": "summary",
364 "xtype": "ColumnModel",
365 "|renderer": "function(v,x,r) { \n \n return String.format(\n r.data.status_name == 'closed' ?\n '{2}<s>[{1}]</s> {0}':\n '{2}[{1}] {0}',\n v,\n r.data.status_name == 'closed' ?\n r.data.resolution_id_name : \n r.data.status_name ,\n r.json.jira_ref ? (r.json.jira_ref+ ' ') : ''\n ); \n}\n",
369 "*prop": "colModel[]",
370 "dataIndex": "owner_id_name",
373 "xtype": "ColumnModel",
374 "|renderer": "function(v) { return String.format('{0}', v); }",
378 "*prop": "colModel[]",
379 "dataIndex": "developer_id",
380 "header": "Developer",
382 "xtype": "ColumnModel",
383 "|renderer": "function(v,x,r) { return String.format('{0}', r.data.developer_id_name); }",
388 "xtype": "GridEditor",
393 "select": "function (combo, record, index)\n{\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
398 "displayField": "name",
400 "emptyText": "Select Person",
401 "fieldLabel": "Action Required By",
402 "forceSelection": true,
403 "hiddenName": "developer_id",
405 "loadingText": "Searching...",
407 "name": "developer_id_name",
408 "qtip": "Select Person",
409 "queryParam": "query[name]",
410 "selectOnFocus": true,
411 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
412 "triggerAction": "all",
421 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n var rec = _this.grid.activeEditor.record;\n\n \n o.params['query[ticket_id]'] = rec.data.id;\n \n o.params['query[project_id]']= rec.data.project_id;\n o.params._anyrole = 1;\n o.params.limit = 99;\n}\n"
426 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
431 "xtype": "HttpProxy",
434 "|url": "baseURL + '/Roo/Person.php'"
438 "xtype": "JsonReader",
442 "totalProperty": "total",
443 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
454 "*prop": "colModel[]",
455 "dataIndex": "priority_id",
456 "header": "Priority",
459 "xtype": "ColumnModel",
460 "|renderer": "function(v,x,r) { \n x.css += \" \" + String.format('RdYlGn-q{0}-{1}', r.data.priority_id_seqid, r.data.priority_id_seqmax ); \n return String.format('{0}', r.data.priority_id_name); \n \n}\n",
465 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
468 "xtype": "GridEditor",
473 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
478 "displayField": "name",
480 "emptyText": "Select priority",
481 "forceSelection": true,
482 "hiddenName": "priority_id",
484 "loadingText": "Searching...",
486 "name": "priority_id_name",
488 "qtip": "Select priority",
490 "selectOnFocus": true,
491 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
492 "triggerAction": "all",
501 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='priority'\n // set more here\n \n}\n"
506 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
512 "xtype": "HttpProxy",
513 "|url": "baseURL + '/Roo/core_enum.php'",
518 "xtype": "JsonReader",
522 "totalProperty": "total",
523 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
534 "*prop": "colModel[]",
535 "dataIndex": "severity_id",
536 "header": "Severity",
539 "xtype": "ColumnModel",
540 "|renderer": "function(v,x,r) { \n x.css += \" \" + String.format('RdYlGn-q{0}-{1}', r.data.severity_id_seqid, r.data.severity_id_seqmax ); \n return String.format('{0}', r.data.severity_id_name); \n }",
545 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
548 "xtype": "GridEditor",
553 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
558 "displayField": "name",
560 "emptyText": "Select severity",
561 "forceSelection": true,
562 "hiddenName": "severity_id",
564 "loadingText": "Searching...",
566 "name": "severity_id_name",
568 "qtip": "Select severity",
570 "selectOnFocus": true,
571 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
572 "triggerAction": "all",
581 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='severity'\n // set more here\n \n}\n"
586 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
592 "xtype": "HttpProxy",
593 "|url": "baseURL + '/Roo/core_enum.php'",
598 "xtype": "JsonReader",
602 "totalProperty": "total",
603 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
614 "*prop": "colModel[]",
615 "dataIndex": "classification_id",
616 "header": "Classification",
619 "xtype": "ColumnModel",
620 "|renderer": "function(v,x,r) { \n x.css += \" \" + String.format('RdYlGn-q{0}-{1}', r.data.classification_id_seqid, r.data.classification_id_seqmax ); \n return String.format('{0}', r.data.classification_id_name); \n }",
625 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
628 "xtype": "GridEditor",
633 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
638 "displayField": "name",
640 "emptyText": "Select classification",
641 "forceSelection": true,
642 "hiddenName": "classification_id",
644 "loadingText": "Searching...",
646 "name": "classification_id_name",
648 "qtip": "Select classification",
650 "selectOnFocus": true,
651 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
652 "triggerAction": "all",
661 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='classification'\n // set more here\n \n}\n"
666 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
672 "xtype": "HttpProxy",
673 "|url": "baseURL + '/Roo/core_enum.php'",
678 "xtype": "JsonReader",
682 "totalProperty": "total",
683 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
694 "*prop": "colModel[]",
695 "dataIndex": "resolution_id",
696 "header": "Resolution",
699 "xtype": "ColumnModel",
700 "|renderer": "function(v) { return String.format('{0}', v); }",
704 "*prop": "colModel[]",
705 "dataIndex": "estimated",
708 "xtype": "ColumnModel",
709 "|renderer": "function(v,x,r) { \n return String.format('{0}/{1}', r.data.spent, v); \n}",
714 "xtype": "GridEditor",
719 "allowDecimals": true,
720 "decimalPrecision": 1,
721 "xtype": "NumberField",
729 "*prop": "colModel[]",
730 "dataIndex": "updated_changedate",
734 "xtype": "ColumnModel",
735 "|renderer": "function(v,x,r) { \n\n \n var str= Date.parseDate( r.data.updated ? r.json.updated_changedate : r.json.created_changedate, 'Y-m-d H:i:s');\n \n \n return String.format('{0}', str ? str.format('d/M/Y') : '?');\n }",
740 "over": "function (source, e, data)\n{\n\n Roo.log('over');\n// if drag point == drop point...\n var grid = _this.grid;\n var t = Roo.lib.Event.getTarget(e); \n var ri = grid.view.findRowIndex(t);\n var dp = this.getDropPoint(e,data);\n Roo.log(dp);\n //Roo.log(JSON.stringify({ dp: dp, ri: ri, src_ri: data.rowIndex}));\n if(ri == data.rowIndex ||\n (dp == 'above' && ri-1 == data.rowIndex) ||\n (dp == 'below' && ri+1 == data.rowIndex) \n ) {\n this.expandRow(false);\n \n this.valid = false;\n return;\n }\n this.expandRow(ri, dp);\n \n \n this.valid = 'ok-add'; \n}",
741 "drop": "function (source, e, data)\n{\n var grid = _this.grid;\n var t = Roo.lib.Event.getTarget(e); \n var t = Roo.lib.Event.getTarget(e); \n var ri = grid.view.findRowIndex(t);\n //Roo.log(e);\n //Roo.log(data);\n var dp = this.getDropPoint(e,data);\n // at this point should have above or below..\n var os = grid.selModel.getSelectedCell()\n grid.ds.remove(data.selections[0]);\n var new_row = ri + (dp == 'below' ? 1 : 0);\n grid.ds.insert(new_row , data.selections);\n grid.selModel.select(new_row , os[1])\n this.expandRow(false);\n \n \n var above_id = 0;\n var above_row = new_row-1;\n if (above_row > -1) {\n above_id = grid.ds.getAt(above_row).data.id;\n }\n new Pman.Request({\n method : 'POST',\n url : baseURL + '/Roo/Mtrack_ticket',\n params : { \n id : grid.ds.getAt(new_row).data.id,\n _reorder : above_id\n }\n \n });\n \n \n \n}"
743 "*prop": "dropTarget",
744 "ddGroup": "mtrack_ticket",
745 "xtype": "DropTarget",
746 "|expandRow": " function(ri,pos)\n{\n var dom = _this.grid.view.getRow(ri);\n //Roo.log(dom);\n //if (this.activeDom == dom) {\n // return;\n //}\n if (this.activeDom) {\n Roo.get(this.activeDom).removeClass('x-grid-dd-above');\n Roo.get(this.activeDom).removeClass('x-grid-dd-below');\n \n this.activeDom = false;\n }\n \n if (ri === false) {\n return;\n }\n Roo.get(dom).addClass('x-grid-dd-' + pos);\n \n this.activeDom = dom;\n\n\n}",
747 "|getDropPoint": "function(e, data)\n{\n //var tn = n.node;\n // data is from griddragzone\n \n var te = Roo.lib.Event.getTarget(e); \n \n // use grid??\n var ri = Roo.fly(te).findParent(\"td\", 6);\n \n \n var dragEl = ri;\n var t = Roo.lib.Dom.getY(dragEl),\n b = t + dragEl.offsetHeight;\n var y = Roo.lib.Event.getPageY(e);\n //var noAppend = tn.allowChildren === false || tn.isLeaf();\n \n // we may drop nodes anywhere, as long as allowChildren has not been set to false..\n \n \n var q = (b - t) / 2;\n \n \n if(y >= t && y < (t + q)){\n return \"above\";\n }\n if(y >= b-q && y <= b){\n return \"below\";\n }\n //Roo.log( JSON.stringify( {pos: y, dragtop : t, mid : q, drabgot: b }));\n \n \n return false;\n}",
756 "activate": "function (_self)\n{\n _this.tpanel = _self;\n}",
757 "resize": "function (_self, width, height)\n{\n // create and update the CSS style\n \n if (!_this.css) {\n _this.css = Roo.util.CSS;\n \n _this.css.createStyleSheet(\n \n \".ticket-view-main .ticket-left-col { }\\n\" +\n \".ticket-view-main .readonly-tkt-description { }\\n\" +\n \".ticket-view-main .mtrack-ticket-events {} \\n\"\n ,\n Roo.id()\n ); \n \n }\n var w = width - 400;\n Roo.log(\"new width: \" + Math.max(0,w));\n \n _this.css.updateRule(\n \".ticket-view-main .ticket-left-col\", \n \"width\", Math.max(0, w) + 'px'\n );\n _this.css.updateRule(\n \".ticket-view-main .readonly-tkt-description\",\n \"width\", Math.max(0, w-10) + 'px'\n );\n _this.css.updateRule(\n \".ticket-view-main .mtrack-ticket-events\",\n \"width\", Math.max(0, w-10) + 'px'\n );\n}"
761 "fitContainer": true,
765 "xtype": "ContentPanel",
766 "|mload": "function(url) {\n if (typeof(MTrack) == 'undefined') {\n return;\n }\n this._url = url;\n this._project = MTrack.projectCombo.getValue();\n if (!_this.tpanel) {\n return;\n }\n MTrack.ajaxLoad(url, this);\n MTrackWeb.pushState({\n url : url,\n title : \"Browse : \" + url,\n href : baseURL + url\n });\n \n}\n",
776 "click": "function (_self, e)\n{\n \n \n \n var rc = _this.grid.getSelectionModel().getSelectedCell()\n if (!rc) {\n Roo.MessageBox.alert(\"Error\", \"Select a ticket\");\n return;\n }\n \n \n function ok()\n {\n _this.panel.layout.getRegion('south').show();\n _this.panel.layout.getRegion('north').hide();\n _this.form.reset();\n var rec = _this.grid.ds.getAt(rc[0]);\n _this.form.setValues({\n id : rec.data.id,\n developer_id : rec.data.developer_id,\n developer_id_name : rec.data.developer_id_name\n });\n \n }\n \n if (_this.panel.layout.getRegion('south').isVisible() && _this.form.isDirty()) {\n Roo.MessageBox.confirm(\"Cancel\", \"Are you sure you want to cancel editing\", function(r) {\n if (r !='yes') {\n return;\n }\n ok(); \n \n });\n return;\n }\n \n ok();\n \n\n\n}"
778 "text": "Add Comment / Update",
780 "|xns": "Roo.Toolbar"
784 "click": "function (_self, e)\n{\n var rc = _this.grid.getSelectionModel().getSelectedCell()\n if (!rc) {\n Roo.MessageBox.alert(\"Error\", \"Select a ticket\");\n return;\n }\n var rec = _this.grid.ds.getAt(rc[0]);\n Pman.Dialog.MTrackTicket.show({ id : rec.data.id } , function(res) {\n // apply the data to the current row, and reload the display part..\n \n });\n \n \n \n}"
786 "text": "Edit original ticket",
788 "|xns": "Roo.Toolbar"
792 "click": "function (_self, e)\n{\n var rc = _this.grid.getSelectionModel().getSelectedCell()\n if (!rc) {\n Roo.MessageBox.alert(\"Error\", \"Select a ticket\");\n return;\n }\n var rec = _this.grid.ds.getAt(rc[0]);\n Pman.Dialog.Image.show( {\n onid : rec.data.id,\n ontable : 'mtrack_ticket'\n } ,\n function(res) {\n // update the body part..\n \n }\n );\n \n \n \n \n}"
794 "text": "Add Attachment / Patch",
796 "|xns": "Roo.Toolbar"
801 "|xns": "Roo.Toolbar"
809 "xtype": "ContentPanel",
819 "click": "function (_self, e)\n{\n if (!_this.form.findField('status_name').getValue()) {\n Roo.MessageBox.alert(\"Error\", \"Fill in the new status\");\n return;\n }\n \n \n _this.form.submit();\n}"
823 "|xns": "Roo.Toolbar"
826 "|xns": "Roo.Toolbar",
831 "click": "function (_self, e)\n{\n _this.form.reset();\n _this.panel.layout.getRegion('south').hide();\n _this.panel.layout.getRegion('north').show();\n _this.panel.layout.getRegion('north').expand();\n}"
835 "|xns": "Roo.Toolbar"
841 "|actioncomplete": "function(_self,action)\n{\n if (action.type == 'setdata') {\n //_this.dialog.el.mask(\"Loading\");\n //this.load({ method: 'GET', params: { '_id' : _this.data.id }});\n return;\n }\n if (action.type == 'load') {\n \n return;\n }\n if (action.type =='submit') {\n \n // refresh body..\n \n \n var sm = _this.grid.getSelectionModel();\n var cs = sm.getSelectedCell();\n sm.fireEvent('cellselect', sm, cs[0], cs[1] );\n \n // hide stuff.\n\n _this.panel.layout.getRegion('south').hide();\n _this.panel.layout.getRegion('north').show();\n _this.panel.layout.getRegion('north').expand();\n \n _this.form.reset();\n return;\n }\n}\n",
842 "|rendered": "function (form)\n{\n _this.form= form;\n}\n"
845 "style": "margin:10px;",
847 "|url": "baseURL + '/Roo/mtrack_ticket.php'",
862 "fieldLabel": "Your comment",
872 "labelAlign": "right",
881 "displayField": "name",
883 "emptyText": "Change Status",
884 "fieldLabel": "Status",
885 "forceSelection": true,
886 "hiddenName": "status",
888 "loadingText": "Searching...",
890 "name": "status_name",
891 "qtip": "Change Status",
892 "queryParam": "query[name]",
893 "selectOnFocus": true,
894 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>",
895 "triggerAction": "all",
904 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n o.params['query[ticket_change]'] = _this.form.findField('id').getValue();\n}\n",
905 "load": "function (_self, records, options)\n{\n var cs = _this.grid.getSelectionModel().getSelectedCell();\n var status = _this.grid.ds.getAt(cs[0]).data.status;\n \n Roo.each(records, function(r) {\n \n if (r.data.id == status) {\n r.set('name', \"No Change\");\n return;\n }\n \n // me... ??\n \n // \n if (r.data.etype == 'resolution') {\n r.set('name', \"Close as \" + r.data.name);\n return;\n }\n r.set('name', 'Change to ' + r.data.name);\n });\n}"
910 "|sortInfo": "{ direction : 'ASC', field: 'id' }",
916 "xtype": "HttpProxy",
917 "|url": "baseURL + '/Roo/core_enum.php'",
924 "totalProperty": "total",
925 "xtype": "JsonReader",
926 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
936 "displayField": "name",
938 "emptyText": "Select Person",
939 "fieldLabel": "Developer / Action Required By",
940 "forceSelection": true,
941 "hiddenName": "developer_id",
943 "loadingText": "Searching...",
945 "name": "developer_id_name",
946 "qtip": "Select Person",
947 "queryParam": "query[name]",
948 "selectOnFocus": true,
949 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
950 "triggerAction": "all",
959 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n o.params['query[ticket_id]'] =_this.grid.getSelected().data.id;\n \n o.params['query[project_id]']= _this.grid.getSelected().data.project_id;\n o.params._anyrole = 1;\n \n o.params.limit = 999;\n}\n"
964 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
969 "xtype": "HttpProxy",
972 "|url": "baseURL + '/Roo/Person.php'"
976 "xtype": "JsonReader",
980 "totalProperty": "total",
981 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"