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 return false;\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}",
80 "afterselectionchange": "function (_self, rowIndex, colIndex)\n{\n \n var sels = _this.grid.selModel.getSelections();\n \n if (!sels || sels.length > 1) {\n \n return;\n }\n \n var rec = sels[0];\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}"
83 "xtype": "RowSelectionModel",
88 "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}",
89 "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}"
91 "*prop": "dataSource",
94 "|sortInfo": "{ field : 'summary', direction: 'ASC' }",
101 "|url": "baseURL + '/Roo/mtrack_ticket.php'",
106 "xtype": "JsonReader",
107 "totalProperty": "total",
111 "|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]"
122 "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}"
124 "text": "Add New Ticket",
126 "|xns": "Roo.Toolbar"
130 "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}"
132 "text": "Download to Excel",
134 "|xns": "Roo.Toolbar"
138 "click": "function (_self, e)\n{\n var sels = _this.grid.selModel.getSelections()\n\n var pid = 0;\n var ids = [];\n Roo.each(sels, function(s) {\n ids.push(s.data.id);\n if (pid && s.data.project_id != pid) {\n pid = -1;\n return false;\n }\n pid = s.data.project_id ;\n \n });\n if (pid < 1) {\n Roo.MessageBox.alert(\"Error\", \"selected tickets must be of the same project\");\n return;\n }\n \n // permission based?\n \n Pman.Dialog.MTrackBulkChange.show({\n project_id : sels[0].data.project_id,\n project_id_name : sels[0].data.project_id_name,\n ids : ids.join(',')\n }, function(res) {\n Roo.log(res);\n var tks = {};\n \n Roo.each(res.data, function(d) {\n tks[d.id*1] = d;\n });\n \n Roo.each(sels, function(sel) {\n var record = _this.grid.ds.getById(sel.data.id);\n record.modified = record.modified || {};\n \n for (var k in tks[record.data.id*1]) {\n // update the \n if (!k.match(/_id$/) && !k.match(/_id_/)) {\n continue;\n }\n record.data[k] = tks[record.data.id*1][k];\n record.modified[k] = tks[record.data.id*1][k];\n }\n record.store.afterEdit(record);\n });\n \n });\n\n \n \n}"
140 "text": "Bulk Change",
142 "|xns": "Roo.Toolbar"
145 "|xns": "Roo.Toolbar",
151 "|xns": "Roo.Toolbar"
155 "render": "function (_self)\n{\n_this.searchBox= _self;\n}",
156 "specialkey": "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
158 "xtype": "TextField",
163 "|select": "function (combo, record, index)\n{\n _this.grid.ds.load({});\n \n}",
164 "|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}"
167 "displayField": "developer_id_name",
169 "emptyText": "Select Person ",
170 "fieldLabel": "Person ",
171 "forceSelection": true,
172 "hiddenName": "developer_id",
174 "loadingText": "Searching...",
176 "name": "developer_id",
178 "qtip": "Select Person ",
179 "queryParam": "query[name]",
180 "selectOnFocus": true,
181 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{developer_id_name}</b></div>",
182 "triggerAction": "all",
184 "valueField": "developer_id",
191 "|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}",
192 "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}"
196 "|sortInfo": "{ field : 'developer_id_name' , dir : 'ASC' }",
202 "xtype": "HttpProxy",
203 "|url": "baseURL + '/Roo/Mtrack_ticket.php'",
210 "totalProperty": "total",
211 "xtype": "JsonReader",
212 "|fields": "[\n {\n 'name': 'developer_id',\n 'type': 'int'\n } ,\n {\n 'name': 'developer_id_name',\n 'type' : 'text'\n }\n \n \n]",
221 "render": "function (_self)\n{\n _this.status = _self;\n}",
222 "select": "function (combo, record, index)\n{\n Roo.log('select');\n _this.grid.ds.load({});\n}"
225 "displayField": "fname",
227 "fieldLabel": "Status",
228 "hiddenName": "cm_status",
231 "name": "cm_status_name",
232 "triggerAction": "all",
234 "valueField": "ftype",
241 "xtype": "SimpleStore",
242 "|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",
243 "|fields": "[ 'ftype', 'fname']",
250 "|click": "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
254 "|icon": "rootURL + '/Pman/templates/images/search.gif'",
255 "|xns": "Roo.Toolbar"
259 "|click": "function (_self, e)\n{\n _this.searchBox.setValue('');\n \n _this.grid.ds.load({});\n}"
263 "|icon": "rootURL + '/Pman/templates/images/edit-clear.gif'",
264 "|xns": "Roo.Toolbar"
269 "*prop": "colModel[]",
274 "xtype": "ColumnModel",
275 "|renderer": "function(v) { return String.format('#{0}', v); }",
279 "*prop": "colModel[]",
280 "dataIndex": "project_id_name",
284 "xtype": "ColumnModel",
285 "|renderer": "function(v) { return String.format('{0}', v); }",
289 "*prop": "colModel[]",
290 "dataIndex": "milestone_id",
291 "header": "Milestone",
294 "xtype": "ColumnModel",
295 "|renderer": "function(v, x,r ) { return String.format('{0}', r.data.milestone_id_name); }",
300 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
303 "xtype": "GridEditor",
308 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
313 "displayField": "name",
315 "emptyText": "Select mtrack_milestone",
316 "forceSelection": true,
317 "hiddenName": "milestone_id",
319 "loadingText": "Searching...",
321 "name": "milestone_id_name",
323 "qtip": "Select mtrack_milestone",
325 "selectOnFocus": true,
326 "tpl": "<div class=\"x-grid-cell-text\"><b>{name}</b> - {startdate:date(\"d/m/Y\")} - {duedate:date(\"d/m/Y\")} </div>",
327 "triggerAction": "all",
336 "|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"
341 "|sortInfo": "{ direction : 'ASC', field: 'duedate' }",
346 "xtype": "HttpProxy",
349 "|url": "baseURL + '/Roo/mtrack_milestone.php'"
353 "xtype": "JsonReader",
357 "totalProperty": "total",
358 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
369 "*prop": "colModel[]",
370 "dataIndex": "status_name",
374 "xtype": "ColumnModel",
378 "*prop": "colModel[]",
379 "dataIndex": "resolution_id_name",
380 "header": "Resolved",
383 "xtype": "ColumnModel",
387 "*prop": "colModel[]",
388 "dataIndex": "summary",
391 "xtype": "ColumnModel",
392 "|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",
396 "*prop": "colModel[]",
397 "dataIndex": "owner_id_name",
400 "xtype": "ColumnModel",
401 "|renderer": "function(v) { return String.format('{0}', v); }",
405 "*prop": "colModel[]",
406 "dataIndex": "developer_id",
407 "header": "Developer",
409 "xtype": "ColumnModel",
410 "|renderer": "function(v,x,r) { return String.format('{0}', r.data.developer_id_name); }",
415 "xtype": "GridEditor",
420 "select": "function (combo, record, index)\n{\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
425 "displayField": "name",
427 "emptyText": "Select Person",
428 "fieldLabel": "Action Required By",
429 "forceSelection": true,
430 "hiddenName": "developer_id",
432 "loadingText": "Searching...",
434 "name": "developer_id_name",
435 "qtip": "Select Person",
436 "queryParam": "query[name]",
437 "selectOnFocus": true,
438 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
439 "triggerAction": "all",
448 "|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"
453 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
458 "xtype": "HttpProxy",
461 "|url": "baseURL + '/Roo/Person.php'"
465 "xtype": "JsonReader",
469 "totalProperty": "total",
470 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
481 "*prop": "colModel[]",
482 "dataIndex": "priority_id",
483 "header": "Priority",
486 "xtype": "ColumnModel",
487 "|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",
492 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
495 "xtype": "GridEditor",
500 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
505 "displayField": "name",
507 "emptyText": "Select priority",
508 "forceSelection": true,
509 "hiddenName": "priority_id",
511 "loadingText": "Searching...",
513 "name": "priority_id_name",
515 "qtip": "Select priority",
517 "selectOnFocus": true,
518 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
519 "triggerAction": "all",
528 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='priority'\n // set more here\n \n}\n"
533 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
539 "xtype": "HttpProxy",
540 "|url": "baseURL + '/Roo/core_enum.php'",
545 "xtype": "JsonReader",
549 "totalProperty": "total",
550 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
561 "*prop": "colModel[]",
562 "dataIndex": "severity_id",
563 "header": "Severity",
566 "xtype": "ColumnModel",
567 "|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 }",
572 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
575 "xtype": "GridEditor",
580 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
585 "displayField": "name",
587 "emptyText": "Select severity",
588 "forceSelection": true,
589 "hiddenName": "severity_id",
591 "loadingText": "Searching...",
593 "name": "severity_id_name",
595 "qtip": "Select severity",
597 "selectOnFocus": true,
598 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
599 "triggerAction": "all",
608 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='severity'\n // set more here\n \n}\n"
613 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
619 "xtype": "HttpProxy",
620 "|url": "baseURL + '/Roo/core_enum.php'",
625 "xtype": "JsonReader",
629 "totalProperty": "total",
630 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
641 "*prop": "colModel[]",
642 "dataIndex": "classification_id",
643 "header": "Classification",
646 "xtype": "ColumnModel",
647 "|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 }",
652 "complete": "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
655 "xtype": "GridEditor",
660 "select": "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
665 "displayField": "name",
667 "emptyText": "Select classification",
668 "forceSelection": true,
669 "hiddenName": "classification_id",
671 "loadingText": "Searching...",
673 "name": "classification_id_name",
675 "qtip": "Select classification",
677 "selectOnFocus": true,
678 "tpl": "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
679 "triggerAction": "all",
688 "|beforeload": "function (_self, o){\n o.params = o.params || {};\n o.params.etype='classification'\n // set more here\n \n}\n"
693 "|sortInfo": "{ direction : 'ASC', field: 'seqid' }",
699 "xtype": "HttpProxy",
700 "|url": "baseURL + '/Roo/core_enum.php'",
705 "xtype": "JsonReader",
709 "totalProperty": "total",
710 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"
721 "*prop": "colModel[]",
722 "dataIndex": "estimated",
725 "xtype": "ColumnModel",
726 "|renderer": "function(v,x,r) { \n return String.format('{0}/{1}', r.data.spent, v); \n}",
731 "xtype": "GridEditor",
736 "allowDecimals": true,
737 "decimalPrecision": 1,
738 "xtype": "NumberField",
746 "*prop": "colModel[]",
747 "dataIndex": "spent",
751 "xtype": "ColumnModel",
752 "|renderer": "function(v,x,r) { \n return String.format('{0}',v); \n}",
756 "*prop": "colModel[]",
757 "dataIndex": "updated_changedate",
761 "xtype": "ColumnModel",
762 "|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 }",
767 "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}",
768 "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}"
770 "*prop": "dropTarget",
771 "ddGroup": "mtrack_ticket",
772 "xtype": "DropTarget",
773 "|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}",
774 "|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}",
783 "activate": "function (_self)\n{\n _this.tpanel = _self;\n}",
784 "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}"
788 "fitContainer": true,
792 "xtype": "ContentPanel",
793 "|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",
803 "click": "function (_self, e)\n{\n \n \n \n var sels = _this.grid.getSelectionModel().getSelections()\n if (!sels || sels.length > 1) {\n Roo.MessageBox.alert(\"Error\", \"Select a ticket\");\n return;\n }\n var rec = sels[0];\n \n function ok()\n {\n _this.panel.layout.getRegion('south').show();\n _this.panel.layout.getRegion('north').hide();\n _this.form.reset();\n \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}"
805 "text": "Add Comment / Update",
807 "|xns": "Roo.Toolbar"
811 "click": "function (_self, e)\n{\n var sels = _this.grid.getSelectionModel().getSelections()\n if (!sels || sels.length > 1) {\n Roo.MessageBox.alert(\"Error\", \"Select a ticket\");\n return;\n }\n var rec = sels[0];\n \n \n \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}"
813 "text": "Edit original ticket",
815 "|xns": "Roo.Toolbar"
819 "click": "function (_self, e)\n{\n var sels = _this.grid.getSelectionModel().getSelections()\n if (!sels || sels.length > 1) {\n Roo.MessageBox.alert(\"Error\", \"Select a ticket\");\n return;\n }\n var rec = sels[0];\n \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}"
821 "text": "Add Attachment / Patch",
823 "|xns": "Roo.Toolbar"
828 "|xns": "Roo.Toolbar"
836 "xtype": "ContentPanel",
846 "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}"
850 "|xns": "Roo.Toolbar"
853 "|xns": "Roo.Toolbar",
858 "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}"
862 "|xns": "Roo.Toolbar"
868 "|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",
869 "|rendered": "function (form)\n{\n _this.form= form;\n}\n"
872 "style": "margin:10px;",
874 "|url": "baseURL + '/Roo/mtrack_ticket.php'",
889 "fieldLabel": "Your comment",
899 "labelAlign": "right",
908 "displayField": "name",
910 "emptyText": "Change Status",
911 "fieldLabel": "Status",
912 "forceSelection": true,
913 "hiddenName": "status",
915 "loadingText": "Searching...",
917 "name": "status_name",
918 "qtip": "Change Status",
919 "queryParam": "query[name]",
920 "selectOnFocus": true,
921 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>",
922 "triggerAction": "all",
931 "|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",
932 "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}"
937 "|sortInfo": "{ direction : 'ASC', field: 'id' }",
943 "xtype": "HttpProxy",
944 "|url": "baseURL + '/Roo/core_enum.php'",
951 "totalProperty": "total",
952 "xtype": "JsonReader",
953 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
963 "displayField": "name",
965 "emptyText": "Select Person",
966 "fieldLabel": "Developer / Action Required By",
967 "forceSelection": true,
968 "hiddenName": "developer_id",
970 "loadingText": "Searching...",
972 "name": "developer_id_name",
973 "qtip": "Select Person",
974 "queryParam": "query[name]",
975 "selectOnFocus": true,
976 "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
977 "triggerAction": "all",
986 "|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"
991 "|sortInfo": "{ direction : 'ASC', field: 'name' }",
996 "xtype": "HttpProxy",
999 "|url": "baseURL + '/Roo/Person.php'"
1003 "xtype": "JsonReader",
1007 "totalProperty": "total",
1008 "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]"