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": "RowSelectionModel",
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 var pc = false;\n var ps = false;\n try {\n pc = _this.grid.colModel.getIndexByDataIndex('project_id_name');\n \n } catch(e) {} \n \n\n if (!options.params['query[search]'].length || isNaN(options.params['query[search]'])) {\n \n \n 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 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 \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 \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"
137 "click": "function (_self, e)\n{\n var sels = this.grid.getSelections()\n\n //Pman.Dialog.MTrackBulkChange.show();\n\n \n \n}"
139 "text": "Bulk Change",
141 "|xns": "Roo.Toolbar"
144 "|xns": "Roo.Toolbar",
150 "|xns": "Roo.Toolbar"
154 "render": "function (_self)\n{\n_this.searchBox= _self;\n}",
155 "specialkey": "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
157 "xtype": "TextField",
162 "|select": "function (combo, record, index)\n{\n _this.grid.ds.load({});\n \n}",
163 "|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}"
166 "displayField": "developer_id_name",
168 "emptyText": "Select Person ",
169 "fieldLabel": "Person ",
170 "forceSelection": true,
171 "hiddenName": "developer_id",
173 "loadingText": "Searching...",
175 "name": "developer_id",
177 "qtip": "Select Person ",
178 "queryParam": "query[name]",
179 "selectOnFocus": true,
180 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{developer_id_name}</b></div>",
181 "triggerAction": "all",
183 "valueField": "developer_id",
190 "|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}",
191 "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}"
195 "|sortInfo": "{ field : 'developer_id_name' , dir : 'ASC' }",
201 "xtype": "HttpProxy",
202 "|url": "baseURL + '/Roo/Mtrack_ticket.php'",
209 "totalProperty": "total",
210 "xtype": "JsonReader",
211 "|fields": "[\n {\n 'name': 'developer_id',\n 'type': 'int'\n } ,\n {\n 'name': 'developer_id_name',\n 'type' : 'text'\n }\n \n \n]",
220 "render": "function (_self)\n{\n _this.status = _self;\n}",
221 "select": "function (combo, record, index)\n{\n Roo.log('select');\n _this.grid.ds.load({});\n}"
224 "displayField": "fname",
226 "fieldLabel": "Status",
227 "hiddenName": "cm_status",
230 "name": "cm_status_name",
231 "triggerAction": "all",
233 "valueField": "ftype",
240 "xtype": "SimpleStore",
241 "|data": "[ \n [ 'active', \"Active\"],\n [ 'me' , \"Assigned to me\"],\n [ 'me-all' , \"Assigned to me (All projects)\"], \n [ 'closed' , \"Closed\"],\n [ 'pending' , \"Pending Review / Resolved\"],\n [ 'in-progress' , \"In Progress\"],\n [ 'all' , \"All States\"]\n \n]\n",
242 "|fields": "[ 'ftype', 'fname']",
249 "|click": "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
253 "|icon": "rootURL + '/Pman/templates/images/search.gif'",
254 "|xns": "Roo.Toolbar"
258 "|click": "function (_self, e)\n{\n _this.searchBox.setValue('');\n \n _this.grid.ds.load({});\n}"
262 "|icon": "rootURL + '/Pman/templates/images/edit-clear.gif'",
263 "|xns": "Roo.Toolbar"
268 "*prop": "colModel[]",
273 "xtype": "ColumnModel",
274 "|renderer": "function(v) { return String.format('#{0}', v); }",
278 "*prop": "colModel[]",
279 "dataIndex": "project_id_name",
283 "xtype": "ColumnModel",
284 "|renderer": "function(v) { return String.format('{0}', v); }",
288 "*prop": "colModel[]",
289 "dataIndex": "milestone_id",
290 "header": "Milestone",
293 "xtype": "ColumnModel",
294 "|renderer": "function(v, x,r ) { return String.format('{0}', r.data.milestone_id_name); }",
299 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
302 "xtype": "GridEditor",
307 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
312 "displayField": "name",
314 "emptyText": "Select mtrack_milestone",
315 "forceSelection": true,
316 "hiddenName": "milestone_id",
318 "loadingText": "Searching...",
320 "name": "milestone_id_name",
322 "qtip": "Select mtrack_milestone",
324 "selectOnFocus": true,
325 "tpl": "<div class=\"x-grid-cell-text\"><b>{name}</b> - {startdate:date(\"d/m/Y\")} - {duedate:date(\"d/m/Y\")} </div>",
326 "triggerAction": "all",
335 "|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"
340 "|sortInfo": "{ direction : 'ASC', field: 'duedate' }",
345 "xtype": "HttpProxy",
348 "|url": "baseURL + '/Roo/mtrack_milestone.php'"
352 "xtype": "JsonReader",
356 "totalProperty": "total",
357 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
368 "*prop": "colModel[]",
369 "dataIndex": "status_name",
373 "xtype": "ColumnModel",
377 "*prop": "colModel[]",
378 "dataIndex": "resolution_id_name",
379 "header": "Resolved",
382 "xtype": "ColumnModel",
386 "*prop": "colModel[]",
387 "dataIndex": "summary",
390 "xtype": "ColumnModel",
391 "|renderer": "function(v,x,r) { \n \n var col = '#000'; // closed?\n switch (r.data.status_name) {\n case 'resolved':\n col = '#0cc'; break; // blue\n case 'open':\n case 'reopened': \n case 'new': \n col = '#c00'; break; // redish\n case 'closed': \n col = '#999'; break; // grey\n }\n \n return String.format(\n r.data.status_name == 'closed' ?\n '{2}</span><s style=\"color:{3}\">[{1}]</s> {0}':\n '{2}<span style=\"color:{3}\">[{1}]</span> {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 col\n ); \n}\n",
395 "*prop": "colModel[]",
396 "dataIndex": "owner_id_name",
399 "xtype": "ColumnModel",
400 "|renderer": "function(v) { return String.format('{0}', v); }",
404 "*prop": "colModel[]",
405 "dataIndex": "developer_id",
406 "header": "Developer",
408 "xtype": "ColumnModel",
409 "|renderer": "function(v,x,r) { return String.format('{0}', r.data.developer_id_name); }",
414 "xtype": "GridEditor",
419 "select": "function (combo, record, index)\n{\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
424 "displayField": "name",
426 "emptyText": "Select Person",
427 "fieldLabel": "Action Required By",
428 "forceSelection": true,
429 "hiddenName": "developer_id",
431 "loadingText": "Searching...",
433 "name": "developer_id_name",
434 "qtip": "Select Person",
435 "queryParam": "query[name]",
436 "selectOnFocus": true,
437 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
438 "triggerAction": "all",
447 "|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"
452 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
457 "xtype": "HttpProxy",
460 "|url": "baseURL + '/Roo/Person.php'"
464 "xtype": "JsonReader",
468 "totalProperty": "total",
469 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
480 "*prop": "colModel[]",
481 "dataIndex": "priority_id",
482 "header": "Priority",
485 "xtype": "ColumnModel",
486 "|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",
491 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
494 "xtype": "GridEditor",
499 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
504 "displayField": "name",
506 "emptyText": "Select priority",
507 "forceSelection": true,
508 "hiddenName": "priority_id",
510 "loadingText": "Searching...",
512 "name": "priority_id_name",
514 "qtip": "Select priority",
516 "selectOnFocus": true,
517 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
518 "triggerAction": "all",
527 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='priority'\n // set more here\n \n}\n"
532 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
538 "xtype": "HttpProxy",
539 "|url": "baseURL + '/Roo/core_enum.php'",
544 "xtype": "JsonReader",
548 "totalProperty": "total",
549 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
560 "*prop": "colModel[]",
561 "dataIndex": "severity_id",
562 "header": "Severity",
565 "xtype": "ColumnModel",
566 "|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 }",
571 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
574 "xtype": "GridEditor",
579 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
584 "displayField": "name",
586 "emptyText": "Select severity",
587 "forceSelection": true,
588 "hiddenName": "severity_id",
590 "loadingText": "Searching...",
592 "name": "severity_id_name",
594 "qtip": "Select severity",
596 "selectOnFocus": true,
597 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
598 "triggerAction": "all",
607 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='severity'\n // set more here\n \n}\n"
612 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
618 "xtype": "HttpProxy",
619 "|url": "baseURL + '/Roo/core_enum.php'",
624 "xtype": "JsonReader",
628 "totalProperty": "total",
629 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
640 "*prop": "colModel[]",
641 "dataIndex": "classification_id",
642 "header": "Classification",
645 "xtype": "ColumnModel",
646 "|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 }",
651 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
654 "xtype": "GridEditor",
659 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
664 "displayField": "name",
666 "emptyText": "Select classification",
667 "forceSelection": true,
668 "hiddenName": "classification_id",
670 "loadingText": "Searching...",
672 "name": "classification_id_name",
674 "qtip": "Select classification",
676 "selectOnFocus": true,
677 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
678 "triggerAction": "all",
687 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='classification'\n // set more here\n \n}\n"
692 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
698 "xtype": "HttpProxy",
699 "|url": "baseURL + '/Roo/core_enum.php'",
704 "xtype": "JsonReader",
708 "totalProperty": "total",
709 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
720 "*prop": "colModel[]",
721 "dataIndex": "estimated",
724 "xtype": "ColumnModel",
725 "|renderer": "function(v,x,r) { \n return String.format('{0}/{1}', r.data.spent, v); \n}",
730 "xtype": "GridEditor",
735 "allowDecimals": true,
736 "decimalPrecision": 1,
737 "xtype": "NumberField",
745 "*prop": "colModel[]",
746 "dataIndex": "spent",
750 "xtype": "ColumnModel",
751 "|renderer": "function(v,x,r) { \n return String.format('{0}',v); \n}",
755 "*prop": "colModel[]",
756 "dataIndex": "updated_changedate",
760 "xtype": "ColumnModel",
761 "|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 }",
766 "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}",
767 "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}"
769 "*prop": "dropTarget",
770 "ddGroup": "mtrack_ticket",
771 "xtype": "DropTarget",
772 "|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}",
773 "|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}",
782 "activate": "function (_self)\n{\n _this.tpanel = _self;\n}",
783 "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}"
787 "fitContainer": true,
791 "xtype": "ContentPanel",
792 "|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",
802 "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}"
804 "text": "Add Comment / Update",
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.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}"
812 "text": "Edit original ticket",
814 "|xns": "Roo.Toolbar"
818 "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}"
820 "text": "Add Attachment / Patch",
822 "|xns": "Roo.Toolbar"
827 "|xns": "Roo.Toolbar"
835 "xtype": "ContentPanel",
845 "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}"
849 "|xns": "Roo.Toolbar"
852 "|xns": "Roo.Toolbar",
857 "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}"
861 "|xns": "Roo.Toolbar"
867 "|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",
868 "|rendered": "function (form)\n{\n _this.form= form;\n}\n"
871 "style": "margin:10px;",
873 "|url": "baseURL + '/Roo/mtrack_ticket.php'",
888 "fieldLabel": "Your comment",
898 "labelAlign": "right",
907 "displayField": "name",
909 "emptyText": "Change Status",
910 "fieldLabel": "Status",
911 "forceSelection": true,
912 "hiddenName": "status",
914 "loadingText": "Searching...",
916 "name": "status_name",
917 "qtip": "Change Status",
918 "queryParam": "query[name]",
919 "selectOnFocus": true,
920 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>",
921 "triggerAction": "all",
930 "|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",
931 "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}"
936 "|sortInfo": "{ direction : 'ASC', field: 'id' }",
942 "xtype": "HttpProxy",
943 "|url": "baseURL + '/Roo/core_enum.php'",
950 "totalProperty": "total",
951 "xtype": "JsonReader",
952 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
962 "displayField": "name",
964 "emptyText": "Select Person",
965 "fieldLabel": "Developer / Action Required By",
966 "forceSelection": true,
967 "hiddenName": "developer_id",
969 "loadingText": "Searching...",
971 "name": "developer_id_name",
972 "qtip": "Select Person",
973 "queryParam": "query[name]",
974 "selectOnFocus": true,
975 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
976 "triggerAction": "all",
985 "|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"
990 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
995 "xtype": "HttpProxy",
998 "|url": "baseURL + '/Roo/Person.php'"
1002 "xtype": "JsonReader",
1006 "totalProperty": "total",
1007 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"