3 "name": "Pman.Tab.MTrackTicket",
4 "parent": "Pman.Tab.DocumentsTab",
5 "title": "MTrackWeb.Ticket",
6 "path": "/home/chris/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 \n if (Pman.building) { return false; }\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 params['csvCols['+ii+']'] = 'jira_ref';\n params['csvTitles['+ii+']'] = \"Jira ID\";\n ii++;\n \n Roo.each(_this.grid.colModel.config, function(c,i) {\n params['csvCols['+ii+']'] = c.dataIndex;\n params['csvTitles['+ii+']'] = c.header;\n try {\n if (typeof( c.editor.field.name) != 'undefined') {\n params['csvCols['+ii+']'] = 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 \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": "status_name",
365 "xtype": "ColumnModel",
369 "*prop": "colModel[]",
370 "dataIndex": "resolution_id_name",
371 "header": "Resolved",
374 "xtype": "ColumnModel",
378 "*prop": "colModel[]",
379 "dataIndex": "summary",
382 "xtype": "ColumnModel",
383 "|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",
387 "*prop": "colModel[]",
388 "dataIndex": "owner_id_name",
391 "xtype": "ColumnModel",
392 "|renderer": "function(v) { return String.format('{0}', v); }",
396 "*prop": "colModel[]",
397 "dataIndex": "developer_id",
398 "header": "Developer",
400 "xtype": "ColumnModel",
401 "|renderer": "function(v,x,r) { return String.format('{0}', r.data.developer_id_name); }",
406 "xtype": "GridEditor",
411 "select": "function (combo, record, index)\n{\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
416 "displayField": "name",
418 "emptyText": "Select Person",
419 "fieldLabel": "Action Required By",
420 "forceSelection": true,
421 "hiddenName": "developer_id",
423 "loadingText": "Searching...",
425 "name": "developer_id_name",
426 "qtip": "Select Person",
427 "queryParam": "query[name]",
428 "selectOnFocus": true,
429 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
430 "triggerAction": "all",
439 "|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"
444 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
449 "xtype": "HttpProxy",
452 "|url": "baseURL + '/Roo/Person.php'"
456 "xtype": "JsonReader",
460 "totalProperty": "total",
461 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
472 "*prop": "colModel[]",
473 "dataIndex": "priority_id",
474 "header": "Priority",
477 "xtype": "ColumnModel",
478 "|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",
483 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
486 "xtype": "GridEditor",
491 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
496 "displayField": "name",
498 "emptyText": "Select priority",
499 "forceSelection": true,
500 "hiddenName": "priority_id",
502 "loadingText": "Searching...",
504 "name": "priority_id_name",
506 "qtip": "Select priority",
508 "selectOnFocus": true,
509 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
510 "triggerAction": "all",
519 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='priority'\n // set more here\n \n}\n"
524 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
530 "xtype": "HttpProxy",
531 "|url": "baseURL + '/Roo/core_enum.php'",
536 "xtype": "JsonReader",
540 "totalProperty": "total",
541 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
552 "*prop": "colModel[]",
553 "dataIndex": "severity_id",
554 "header": "Severity",
557 "xtype": "ColumnModel",
558 "|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 }",
563 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
566 "xtype": "GridEditor",
571 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
576 "displayField": "name",
578 "emptyText": "Select severity",
579 "forceSelection": true,
580 "hiddenName": "severity_id",
582 "loadingText": "Searching...",
584 "name": "severity_id_name",
586 "qtip": "Select severity",
588 "selectOnFocus": true,
589 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
590 "triggerAction": "all",
599 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='severity'\n // set more here\n \n}\n"
604 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
610 "xtype": "HttpProxy",
611 "|url": "baseURL + '/Roo/core_enum.php'",
616 "xtype": "JsonReader",
620 "totalProperty": "total",
621 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
632 "*prop": "colModel[]",
633 "dataIndex": "classification_id",
634 "header": "Classification",
637 "xtype": "ColumnModel",
638 "|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 }",
643 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
646 "xtype": "GridEditor",
651 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
656 "displayField": "name",
658 "emptyText": "Select classification",
659 "forceSelection": true,
660 "hiddenName": "classification_id",
662 "loadingText": "Searching...",
664 "name": "classification_id_name",
666 "qtip": "Select classification",
668 "selectOnFocus": true,
669 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
670 "triggerAction": "all",
679 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='classification'\n // set more here\n \n}\n"
684 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
690 "xtype": "HttpProxy",
691 "|url": "baseURL + '/Roo/core_enum.php'",
696 "xtype": "JsonReader",
700 "totalProperty": "total",
701 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
712 "*prop": "colModel[]",
713 "dataIndex": "estimated",
716 "xtype": "ColumnModel",
717 "|renderer": "function(v,x,r) { \n return String.format('{0}/{1}', r.data.spent, v); \n}",
722 "xtype": "GridEditor",
727 "allowDecimals": true,
728 "decimalPrecision": 1,
729 "xtype": "NumberField",
737 "*prop": "colModel[]",
738 "dataIndex": "spent",
742 "xtype": "ColumnModel",
743 "|renderer": "function(v,x,r) { \n return String.format('{0}',v); \n}",
747 "*prop": "colModel[]",
748 "dataIndex": "updated_changedate",
752 "xtype": "ColumnModel",
753 "|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 }",
758 "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}",
759 "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}"
761 "*prop": "dropTarget",
762 "ddGroup": "mtrack_ticket",
763 "xtype": "DropTarget",
764 "|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}",
765 "|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}",
774 "activate": "function (_self)\n{\n _this.tpanel = _self;\n}",
775 "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}"
779 "fitContainer": true,
783 "xtype": "ContentPanel",
784 "|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",
794 "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}"
796 "text": "Add Comment / Update",
798 "|xns": "Roo.Toolbar"
802 "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}"
804 "text": "Edit original ticket",
806 "|xns": "Roo.Toolbar"
810 "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}"
812 "text": "Add Attachment / Patch",
814 "|xns": "Roo.Toolbar"
819 "|xns": "Roo.Toolbar"
827 "xtype": "ContentPanel",
837 "click": "function (_self, e)\n{\n if (!_this.form.findField('status').getValue()) {\n Roo.MessageBox.alert(\"Error\", \"Fill in the new status\");\n return;\n }\n \n \n _this.form.submit();\n}"
841 "|xns": "Roo.Toolbar"
844 "|xns": "Roo.Toolbar",
849 "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}"
853 "|xns": "Roo.Toolbar"
859 "|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",
860 "|rendered": "function (form)\n{\n _this.form= form;\n}\n"
863 "style": "margin:10px;",
865 "|url": "baseURL + '/Roo/mtrack_ticket.php'",
880 "fieldLabel": "Your comment",
890 "labelAlign": "right",
899 "displayField": "name",
901 "emptyText": "Change Status",
902 "fieldLabel": "Status",
903 "forceSelection": true,
904 "hiddenName": "status",
906 "loadingText": "Searching...",
908 "name": "status_name",
909 "qtip": "Change Status",
910 "queryParam": "query[name]",
911 "selectOnFocus": true,
912 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>",
913 "triggerAction": "all",
922 "|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",
923 "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}"
928 "|sortInfo": "{ direction : 'ASC', field: 'id' }",
934 "xtype": "HttpProxy",
935 "|url": "baseURL + '/Roo/core_enum.php'",
942 "totalProperty": "total",
943 "xtype": "JsonReader",
944 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
954 "displayField": "name",
956 "emptyText": "Select Person",
957 "fieldLabel": "Developer / Action Required By",
958 "forceSelection": true,
959 "hiddenName": "developer_id",
961 "loadingText": "Searching...",
963 "name": "developer_id_name",
964 "qtip": "Select Person",
965 "queryParam": "query[name]",
966 "selectOnFocus": true,
967 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
968 "triggerAction": "all",
977 "|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"
982 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
987 "xtype": "HttpProxy",
990 "|url": "baseURL + '/Roo/Person.php'"
994 "xtype": "JsonReader",
998 "totalProperty": "total",
999 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"