2 "name" : "Pman.Tab.MTrackTicket",
3 "parent" : "Pman.Tab.DocumentsTab",
4 "title" : "MTrackWeb.Ticket",
5 "path" : "/home/alan/gitlive/Pman.MTrack/Pman.Tab.MTrackTicket.bjs",
9 "340c2ee497b85d5954b01c64de7f44f6" : "Select Person",
10 "b9dd47d69178dbf735bfcd2733fd4ea6" : "Add Comment / Update",
11 "290612199861c31d1036b185b4e69b75" : "Summary",
12 "8a223eb0008a86f053b2a7eac0fa6eac" : "Select priority",
13 "04720e14ddfde3154a120fdd0ae73d19" : "Action Required By",
14 "ef6703d6c606526cece4a9eda9d49045" : "Your comment",
15 "c76a5e84e4bdee527e274ea30c680d79" : "active",
16 "502996d9790340c5fd7b86a5b93b1c9f" : "Priority",
17 "40bed7cf9b3d4bb3a3d7a7e3eb18c5eb" : "Person ",
18 "5c9335b28e6277ddbe0137f04e5e58a7" : "Classification",
19 "7e5ddb4ca31c30e778f4d9c57b9577b1" : "Change Status",
20 "1fd968087e03faeb2e87df1e9849d983" : "Spent",
21 "1243daf593fa297e07ab03bf06d925af" : "Searching...",
22 "b6f4a2ec6356bbd56d49f2096bf9d3d3" : "Owner",
23 "672caf27f5363dc833bda5099775e891" : "Developer",
24 "6a7e73161603d87b26a8eac49dab0a9c" : "Hours",
25 "ff0a3b7f3daef040faf89a88fdac01b7" : "Updated",
26 "b1550c2a1a5eb0d078d92eef8a0ef883" : "ID#",
27 "9e727fdd3aec8274f46685441900280d" : "Project",
28 "ec53a8c4f07baed5d8825072c89799be" : "Status",
29 "ea4788705e6873b424c65e91c2846b19" : "Cancel",
30 "a3edc4e7beafdcd450f339ec414b7508" : "Developer / Action Required By",
31 "c1c694bd849d91d0eb34bfef8c2d8894" : "Tickets",
32 "a5ffb2a210f259195a75e5abca8db4a2" : "Select mtrack_milestone",
33 "3efbc55730fd4af147b96183d8afbd3b" : "mtrack_ticket",
34 "a3a1edf91a3157dad9417dedb4af500d" : "Add New Ticket",
35 "df25de42c84837baf5fa15049a8bc764" : "View:",
36 "423570be9f14a39fe88384797ee376fd" : "Select severity",
37 "5bf7a37a56bdea44d9b2b69201e91fbd" : "Edit original ticket",
38 "d10e7195b9d5009f7b8e6bb25a099e84" : "Add Attachment / Patch",
39 "e9c626b8a8b62de7562dfbf51a576ae5" : "Milestone",
40 "b26917587d98330d93f87808fc9d7267" : "Subscribe",
41 "f691f042a559b1c1a4f89826c6f75760" : "Resolved",
42 "007cc9547ae8884ad597cd92ba505422" : "Severity",
43 "c9cc8cce247e49bae79f15173ce97354" : "Save",
44 "01bd6a16732dfa2b760dc8566c58afae" : "Download to Excel",
45 "887950755a62e33c26209bdcbdc1d3d3" : "Bulk Change",
46 "7025046a3448dfea367705b884148992" : "Select classification"
51 "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}"
57 "xtype" : "NestedLayoutPanel",
58 "fitContainer" : true,
62 "xtype" : "BorderLayout",
67 "xtype" : "LayoutRegion",
68 "tabPosition" : "top",
74 "xtype" : "LayoutRegion",
75 "tabPosition" : "top",
82 "xtype" : "LayoutRegion",
90 "|activate" : "function() {\n _this.gpanel = this;\n if (_this.grid) {\n _this.grid.ds.load({});\n }\n}"
95 "title" : "mtrack_ticket",
96 "xtype" : "GridPanel",
97 "fitContainer" : true,
99 "tableName" : "mtrack_ticket",
103 "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}",
104 "|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}",
105 "afteredit" : "function (e)\n{\n Roo.log(e);\n e.record.commit();\n}"
107 "autoExpandColumn" : "summary",
108 "xtype" : "EditorGrid",
109 "ddGroup" : "mtrack_ticket",
111 "$ 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",
113 "$ xns" : "Roo.grid",
115 "enableDragDrop" : true,
116 "$ 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",
120 "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}",
121 "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}"
123 "xtype" : "RowSelectionModel",
124 "$ xns" : "Roo.grid",
129 "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 \n if (k.match(/_id$/) || k.match(/_id_/) || k.match(/^status_/)) {\n \n record.data[k] = r[k];\n record.modified[k] = r[k];\n }\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}",
130 "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}"
134 "$ sortInfo" : "{ field : 'summary', direction: 'ASC' }",
135 "$ xns" : "Roo.data",
136 "* prop" : "dataSource",
139 "$ url" : "baseURL + '/Roo/mtrack_ticket.php'",
141 "xtype" : "HttpProxy",
142 "$ xns" : "Roo.data",
148 "xtype" : "JsonReader",
149 "$ xns" : "Roo.data",
150 "$ 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]",
152 "totalProperty" : "total"
159 "* prop" : "toolbar",
163 "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}"
165 "text" : "Add New Ticket",
167 "$ xns" : "Roo.Toolbar"
171 "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}"
173 "text" : "Download to Excel",
175 "$ xns" : "Roo.Toolbar"
179 "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 Roo.log(tks[record.data.id*1]);\n \n for (var k in tks[record.data.id*1]) {\n // update the \n \n \n if (k.match(/_id$/) || k.match(/_id_/) || k.match(/^status_/)) {\n\n\n Roo.log(\"SET \" + k + \"=\" + tks[record.data.id*1][k]);\n record.data[k] = tks[record.data.id*1][k];\n record.modified[k] = tks[record.data.id*1][k];\n }\n }\n record.store.afterEdit(record);\n });\n \n });\n\n \n \n}"
181 "text" : "Bulk Change",
183 "$ xns" : "Roo.Toolbar"
187 "$ xns" : "Roo.Toolbar"
191 "xtype" : "TextItem",
192 "$ xns" : "Roo.Toolbar"
196 "specialkey" : "function (_self, e)\n{\n _this.grid.ds.load({});\n}",
197 "render" : "function (_self)\n{\n_this.searchBox= _self;\n}"
199 "xtype" : "TextField",
204 "|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}",
205 "|select" : "function (combo, record, index)\n{\n _this.grid.ds.load({});\n \n}"
208 "triggerAction" : "all",
209 "fieldLabel" : "Person ",
210 "forceSelection" : true,
211 "selectOnFocus" : true,
213 "displayField" : "developer_id_name",
214 "emptyText" : "Select Person ",
215 "hiddenName" : "developer_id",
217 "valueField" : "developer_id",
218 "xtype" : "ComboBox",
223 "$ xns" : "Roo.form",
224 "name" : "developer_id",
225 "qtip" : "Select Person ",
226 "queryParam" : "query[name]",
227 "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{developer_id_name}</b></div>",
228 "loadingText" : "Searching...",
232 "|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}",
233 "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}"
236 "$ sortInfo" : "{ field : 'developer_id_name' , dir : 'ASC' }",
237 "$ xns" : "Roo.data",
241 "$ url" : "baseURL + '/Roo/Mtrack_ticket.php'",
242 "xtype" : "HttpProxy",
244 "$ xns" : "Roo.data",
250 "xtype" : "JsonReader",
251 "$ fields" : "[\n {\n 'name': 'developer_id',\n 'type': 'int'\n } ,\n {\n 'name': 'developer_id_name',\n 'type' : 'text'\n }\n \n \n]",
252 "$ xns" : "Roo.data",
254 "totalProperty" : "total"
262 "render" : "function (_self)\n{\n _this.status = _self;\n}",
263 "select" : "function (combo, record, index)\n{\n Roo.log('select');\n _this.grid.ds.load({});\n}"
266 "triggerAction" : "all",
267 "fieldLabel" : "Status",
268 "displayField" : "fname",
269 "hiddenName" : "cm_status",
271 "valueField" : "ftype",
272 "xtype" : "ComboBox",
273 "allowBlank" : false,
276 "$ xns" : "Roo.form",
278 "name" : "cm_status_name",
281 "xtype" : "SimpleStore",
282 "$ data" : "[ \n [ 'active', \"Active\"],\n [ 'me' , \"Assigned to me\"],\n [ 'me-all' , \"Assigned to me (All projects)\"], \n [ 'closed' , \"Closed\"],\n [ 'on-hold' , \"On Hold\"],\n [ 'pending' , \"Pending Review / Resolved\"],\n [ 'in-progress' , \"In Progress\"],\n [ 'all' , \"All States\"]\n \n]\n",
283 "$ fields" : "[ 'ftype', 'fname']",
284 "$ xns" : "Roo.data",
291 "|click" : "function (_self, e)\n{\n _this.grid.ds.load({});\n}"
294 "cls" : "x-btn-icon",
295 "$ icon" : "rootURL + '/Pman/templates/images/search.gif'",
296 "$ xns" : "Roo.Toolbar"
300 "|click" : "function (_self, e)\n{\n _this.searchBox.setValue('');\n \n _this.grid.ds.load({});\n}"
303 "cls" : "x-btn-icon",
304 "$ icon" : "rootURL + '/Pman/templates/images/edit-clear.gif'",
305 "$ xns" : "Roo.Toolbar"
310 "xtype" : "ColumnModel",
314 "$ renderer" : "function(v) { return String.format('#{0}', v); }",
315 "$ xns" : "Roo.grid",
316 "* prop" : "colModel[]",
321 "xtype" : "ColumnModel",
322 "header" : "Project",
324 "$ renderer" : "function(v) { return String.format('{0}', v); }",
325 "$ xns" : "Roo.grid",
326 "* prop" : "colModel[]",
327 "dataIndex" : "project_id_name"
330 "xtype" : "ColumnModel",
332 "header" : "Milestone",
334 "$ renderer" : "function(v, x,r ) { return String.format('{0}', r.data.milestone_id_name); }",
335 "$ xns" : "Roo.grid",
336 "* prop" : "colModel[]",
337 "dataIndex" : "milestone_id",
341 "complete" : "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
343 "xtype" : "GridEditor",
344 "$ xns" : "Roo.grid",
349 "select" : "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
351 "alwaysQuery" : true,
353 "triggerAction" : "all",
354 "forceSelection" : true,
355 "selectOnFocus" : true,
357 "displayField" : "name",
358 "emptyText" : "Select mtrack_milestone",
359 "hiddenName" : "milestone_id",
362 "xtype" : "ComboBox",
363 "allowBlank" : false,
367 "$ xns" : "Roo.form",
369 "name" : "milestone_id_name",
370 "qtip" : "Select mtrack_milestone",
372 "tpl" : "<div class=\"x-grid-cell-text\"><b>{name}</b> - {startdate:date(\"d/m/Y\")} - {duedate:date(\"d/m/Y\")} </div>",
373 "loadingText" : "Searching...",
377 "|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"
381 "$ sortInfo" : "{ direction : 'ASC', field: 'duedate' }",
382 "$ xns" : "Roo.data",
386 "$ url" : "baseURL + '/Roo/mtrack_milestone.php'",
388 "xtype" : "HttpProxy",
389 "$ xns" : "Roo.data",
395 "xtype" : "JsonReader",
396 "$ xns" : "Roo.data",
397 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
399 "totalProperty" : "total"
411 "xtype" : "ColumnModel",
414 "$ xns" : "Roo.grid",
415 "* prop" : "colModel[]",
416 "dataIndex" : "status_name"
420 "xtype" : "ColumnModel",
421 "header" : "Resolved",
423 "$ xns" : "Roo.grid",
424 "* prop" : "colModel[]",
425 "dataIndex" : "resolution_id_name"
428 "xtype" : "ColumnModel",
429 "header" : "Summary",
431 "$ 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",
432 "$ xns" : "Roo.grid",
433 "* prop" : "colModel[]",
434 "dataIndex" : "summary"
437 "xtype" : "ColumnModel",
440 "$ renderer" : "function(v) { return String.format('{0}', v); }",
441 "$ xns" : "Roo.grid",
442 "* prop" : "colModel[]",
443 "dataIndex" : "owner_id_name"
446 "xtype" : "ColumnModel",
447 "header" : "Developer",
449 "$ renderer" : "function(v,x,r) { return String.format('{0}', r.data.developer_id_name); }",
450 "$ xns" : "Roo.grid",
451 "* prop" : "colModel[]",
452 "dataIndex" : "developer_id",
455 "xtype" : "GridEditor",
456 "$ xns" : "Roo.grid",
461 "select" : "function (combo, record, index)\n{\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
463 "alwaysQuery" : true,
465 "triggerAction" : "all",
466 "fieldLabel" : "Action Required By",
467 "forceSelection" : true,
468 "selectOnFocus" : true,
469 "displayField" : "name",
470 "emptyText" : "Select Person",
471 "hiddenName" : "developer_id",
474 "xtype" : "ComboBox",
479 "$ xns" : "Roo.form",
481 "name" : "developer_id_name",
482 "qtip" : "Select Person",
483 "queryParam" : "query[name]",
484 "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
485 "loadingText" : "Searching...",
489 "|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"
493 "$ sortInfo" : "{ direction : 'ASC', field: 'name' }",
494 "$ xns" : "Roo.data",
498 "$ url" : "baseURL + '/Roo/Person.php'",
500 "xtype" : "HttpProxy",
501 "$ xns" : "Roo.data",
507 "xtype" : "JsonReader",
508 "$ xns" : "Roo.data",
509 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
511 "totalProperty" : "total"
522 "xtype" : "ColumnModel",
524 "header" : "Priority",
526 "$ renderer" : "function(v,x,r) { \n x.css += \" \" + String.format('RdYlGn-q{0}-{1}', r.data.priority_id_seqid % 10, r.data.priority_id_seqmax % 10 ); \n return String.format('{0}', r.data.priority_id_name); \n}\n",
527 "$ xns" : "Roo.grid",
528 "* prop" : "colModel[]",
529 "dataIndex" : "priority_id",
533 "complete" : "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
535 "xtype" : "GridEditor",
536 "$ xns" : "Roo.grid",
541 "select" : "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
543 "alwaysQuery" : true,
545 "triggerAction" : "all",
546 "forceSelection" : true,
547 "selectOnFocus" : true,
549 "displayField" : "name",
550 "emptyText" : "Select priority",
551 "hiddenName" : "priority_id",
554 "xtype" : "ComboBox",
555 "allowBlank" : false,
559 "$ xns" : "Roo.form",
561 "name" : "priority_id_name",
562 "qtip" : "Select priority",
564 "tpl" : "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
565 "loadingText" : "Searching...",
569 "|beforeload" : "function (_self, o){\n o.params = o.params || {};\n o.params.etype='priority'\n // set more here\n \n}\n"
573 "$ sortInfo" : "{ direction : 'ASC', field: 'seqid' }",
574 "$ xns" : "Roo.data",
578 "$ url" : "baseURL + '/Roo/core_enum.php'",
579 "xtype" : "HttpProxy",
581 "$ xns" : "Roo.data",
587 "xtype" : "JsonReader",
588 "$ xns" : "Roo.data",
589 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
591 "totalProperty" : "total"
602 "xtype" : "ColumnModel",
604 "header" : "Severity",
606 "$ 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 }",
607 "$ xns" : "Roo.grid",
608 "* prop" : "colModel[]",
609 "dataIndex" : "severity_id",
613 "complete" : "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
615 "xtype" : "GridEditor",
616 "$ xns" : "Roo.grid",
621 "select" : "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
623 "alwaysQuery" : true,
625 "triggerAction" : "all",
626 "forceSelection" : true,
627 "selectOnFocus" : true,
629 "displayField" : "name",
630 "emptyText" : "Select severity",
631 "hiddenName" : "severity_id",
634 "xtype" : "ComboBox",
635 "allowBlank" : false,
639 "$ xns" : "Roo.form",
641 "name" : "severity_id_name",
642 "qtip" : "Select severity",
644 "tpl" : "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
645 "loadingText" : "Searching...",
649 "|beforeload" : "function (_self, o){\n o.params = o.params || {};\n o.params.etype='severity'\n // set more here\n \n}\n"
653 "$ sortInfo" : "{ direction : 'ASC', field: 'seqid' }",
654 "$ xns" : "Roo.data",
658 "$ url" : "baseURL + '/Roo/core_enum.php'",
659 "xtype" : "HttpProxy",
661 "$ xns" : "Roo.data",
667 "xtype" : "JsonReader",
668 "$ xns" : "Roo.data",
669 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
671 "totalProperty" : "total"
682 "xtype" : "ColumnModel",
684 "header" : "Classification",
686 "$ 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 }",
687 "$ xns" : "Roo.grid",
688 "* prop" : "colModel[]",
689 "dataIndex" : "classification_id",
693 "complete" : "function (_self, value, startValue)\n{\n Roo.log('complete');\n}"
695 "xtype" : "GridEditor",
696 "$ xns" : "Roo.grid",
701 "select" : "function (combo, record, index)\n{\n Roo.log('selected');\n \n (function() { \n _this.grid.stopEditing();\n }).defer(100);\n}"
703 "alwaysQuery" : true,
705 "triggerAction" : "all",
706 "forceSelection" : true,
707 "selectOnFocus" : true,
709 "displayField" : "name",
710 "emptyText" : "Select classification",
711 "hiddenName" : "classification_id",
714 "xtype" : "ComboBox",
715 "allowBlank" : false,
719 "$ xns" : "Roo.form",
721 "name" : "classification_id_name",
722 "qtip" : "Select classification",
724 "tpl" : "<div class=\"x-grid-cell-text RdYlGn-q{seqid}-{seqmax}\"><b>{name}</b> </div>",
725 "loadingText" : "Searching...",
729 "|beforeload" : "function (_self, o){\n o.params = o.params || {};\n o.params.etype='classification'\n // set more here\n \n}\n"
733 "$ sortInfo" : "{ direction : 'ASC', field: 'seqid' }",
734 "$ xns" : "Roo.data",
738 "$ url" : "baseURL + '/Roo/core_enum.php'",
739 "xtype" : "HttpProxy",
741 "$ xns" : "Roo.data",
747 "xtype" : "JsonReader",
748 "$ xns" : "Roo.data",
749 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
751 "totalProperty" : "total"
762 "xtype" : "ColumnModel",
765 "$ renderer" : "function(v,x,r) { \n return String.format('{0}/{1}', r.data.spent, v); \n}",
766 "$ xns" : "Roo.grid",
767 "* prop" : "colModel[]",
768 "dataIndex" : "estimated",
771 "xtype" : "GridEditor",
772 "$ xns" : "Roo.grid",
776 "xtype" : "NumberField",
777 "allowDecimals" : true,
778 "decimalPrecision" : 1,
779 "$ xns" : "Roo.form",
788 "xtype" : "ColumnModel",
791 "$ renderer" : "function(v,x,r) { \n return String.format('{0}',v); \n}",
792 "$ xns" : "Roo.grid",
793 "* prop" : "colModel[]",
794 "dataIndex" : "spent"
797 "xtype" : "ColumnModel",
799 "header" : "Updated",
801 "$ 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 }",
802 "$ xns" : "Roo.grid",
803 "* prop" : "colModel[]",
804 "dataIndex" : "updated_changedate"
808 "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}",
809 "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}"
811 "xtype" : "DropTarget",
812 "ddGroup" : "mtrack_ticket",
814 "$ 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}",
815 "* prop" : "dropTarget",
816 "$ 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}"
824 "activate" : "function (_self)\n{\n _this.tpanel = _self;\n}",
825 "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}"
828 "background" : false,
832 "xtype" : "ContentPanel",
833 "fitContainer" : true,
835 "$ 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",
840 "* prop" : "toolbar",
844 "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}"
846 "text" : "Add Comment / Update",
848 "$ xns" : "Roo.Toolbar"
852 "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}"
854 "text" : "Edit original ticket",
856 "$ xns" : "Roo.Toolbar"
860 "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}"
862 "text" : "Add Attachment / Patch",
864 "$ xns" : "Roo.Toolbar"
867 "text" : "Subscribe",
869 "$ xns" : "Roo.Toolbar"
877 "xtype" : "ContentPanel",
883 "* prop" : "toolbar",
887 "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}"
891 "$ xns" : "Roo.Toolbar"
895 "$ xns" : "Roo.Toolbar"
899 "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}"
903 "$ xns" : "Roo.Toolbar"
909 "|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\n sm.fireEvent('afterselectionchange', sm)\n\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",
910 "|rendered" : "function (form)\n{\n _this.form= form;\n}\n"
912 "$ url" : "baseURL + '/Roo/mtrack_ticket.php'",
915 "style" : "margin:10px;",
916 "$ xns" : "Roo.form",
920 "$ xns" : "Roo.form",
924 "labelAlign" : "top",
927 "$ xns" : "Roo.form",
930 "fieldLabel" : "Your comment",
931 "xtype" : "TextArea",
933 "$ xns" : "Roo.form",
940 "labelAlign" : "right",
944 "$ xns" : "Roo.form",
947 "alwaysQuery" : true,
949 "triggerAction" : "all",
950 "fieldLabel" : "Status",
951 "forceSelection" : true,
952 "selectOnFocus" : true,
953 "displayField" : "name",
954 "emptyText" : "Change Status",
955 "hiddenName" : "status",
958 "xtype" : "ComboBox",
963 "$ xns" : "Roo.form",
964 "name" : "status_name",
965 "qtip" : "Change Status",
966 "queryParam" : "query[name]",
967 "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>",
968 "loadingText" : "Searching...",
972 "|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",
973 "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}"
977 "$ sortInfo" : "{ direction : 'ASC', field: 'id' }",
978 "$ xns" : "Roo.data",
982 "$ url" : "baseURL + '/Roo/Mtrack_ticket.php'",
983 "xtype" : "HttpProxy",
985 "$ xns" : "Roo.data",
991 "xtype" : "JsonReader",
992 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
993 "$ xns" : "Roo.data",
995 "totalProperty" : "total"
1002 "alwaysQuery" : true,
1004 "triggerAction" : "all",
1005 "fieldLabel" : "Developer / Action Required By",
1006 "forceSelection" : true,
1007 "selectOnFocus" : true,
1008 "displayField" : "name",
1009 "emptyText" : "Select Person",
1010 "hiddenName" : "developer_id",
1012 "valueField" : "id",
1013 "xtype" : "ComboBox",
1014 "allowBlank" : true,
1018 "$ xns" : "Roo.form",
1019 "name" : "developer_id_name",
1020 "qtip" : "Select Person",
1021 "queryParam" : "query[name]",
1022 "tpl" : "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> <{email}></div>",
1023 "loadingText" : "Searching...",
1027 "|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"
1030 "remoteSort" : true,
1031 "$ sortInfo" : "{ direction : 'ASC', field: 'name' }",
1032 "$ xns" : "Roo.data",
1036 "$ url" : "baseURL + '/Roo/Person.php'",
1038 "xtype" : "HttpProxy",
1039 "$ xns" : "Roo.data",
1045 "xtype" : "JsonReader",
1046 "$ xns" : "Roo.data",
1047 "$ fields" : "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"name\",\"type\":\"string\"}]",
1048 "* prop" : "reader",
1049 "totalProperty" : "total"
1061 "$ xns" : "Roo.form",