]> git.proxmox.com Git - pmg-gui.git/blob - js/VirusQuarantine.js
ConfigPanel.js - remove debug code
[pmg-gui.git] / js / VirusQuarantine.js
1 /*global Proxmox*/
2 /*jslint confusion: true*/
3 /*format is a string and a function*/
4 Ext.define('pmg-virus-list', {
5 extend: 'Ext.data.Model',
6 fields: [ 'id', 'envelope_sender', 'from', 'sender', 'receiver', 'subject',
7 { type: 'integer', name: 'bytes' },
8 { type: 'string', name: 'virusname' },
9 { type: 'date', dateFormat: 'timestamp', name: 'time' },
10 {
11 type: 'string',
12 name: 'day',
13 convert: function(v, rec) {
14 return Ext.Date.format(rec.get('time'), 'Y-m-d');
15 }, depends: ['time']
16 }
17 ],
18 proxy: {
19 type: 'proxmox',
20 url: "/api2/json/quarantine/virus"
21 },
22 idProperty: 'id'
23 });
24
25 Ext.define('PMG.VirusQuarantine', {
26 extend: 'Ext.container.Container',
27 xtype: 'pmgVirusQuarantine',
28
29 border: false,
30 layout: { type: 'border' },
31
32 defaults: { border: false },
33
34 controller: {
35
36 xclass: 'Ext.app.ViewController',
37
38 updatePreview: function(raw, rec) {
39 var list = this.lookupReference('list');
40 var rec = list.selModel.getSelection()[0];
41 var preview = this.lookupReference('preview');
42
43 if (!rec || !rec.data || !rec.data.id) {
44 preview.update('');
45 preview.setDisabled(true);
46 return;
47 }
48
49 var url = '/api2/htmlmail/quarantine/content?id=' + rec.data.id + ((raw)?'&raw=1':'');
50 preview.setDisabled(false);
51 preview.update("<iframe frameborder=0 width=100% height=100% sandbox='allow-same-origin' src='" + url +"'></iframe>");
52 },
53
54 toggleRaw: function(button) {
55 var me = this;
56 me.raw = !me.raw;
57 me.updatePreview(me.raw);
58 },
59
60 btnHandler: function(button, e) {
61 var list = this.lookupReference('list');
62 var selected = list.getSelection();
63 if (!selected.length) {
64 return;
65 }
66
67 var action = button.reference;
68
69 PMG.Utils.doQuarantineAction(action, selected[0].data.id, function() {
70 list.getController().load();
71 });
72 },
73
74 onSelectMail: function() {
75 var me = this;
76 var list = this.lookupReference('list');
77 var rec = list.selModel.getSelection()[0];
78
79 me.updatePreview(me.raw || false, rec);
80 },
81
82 control: {
83 'button[reference=raw]': {
84 click: 'toggleRaw'
85 },
86 'pmgQuarantineList': {
87 selectionChange: 'onSelectMail'
88 }
89 }
90
91 },
92
93 items: [
94 {
95 title: gettext('Virus Quarantine'),
96 xtype: 'pmgQuarantineList',
97 emptyText: gettext('No data in database.'),
98 emailSelection: false,
99 reference: 'list',
100 region: 'west',
101 width: 500,
102 split: true,
103 collapsible: false,
104 store: {
105 model: 'pmg-virus-list',
106 groupField: 'day',
107 groupDir: 'DESC',
108 sorters: [{
109 property: 'time',
110 direction: 'DESC'
111 }]
112 },
113
114 columns: [
115 {
116 header: gettext('Sender/Subject'),
117 dataIndex: 'subject',
118 renderer: PMG.Utils.sender_renderer,
119 flex: 1
120 },
121 {
122 header: gettext('Virus'),
123 dataIndex: 'virusname',
124 align: 'right',
125 width: 70
126 },
127 {
128 header: gettext('Size') + ' (KB)',
129 renderer: function(v) { return Ext.Number.toFixed(v/1024, 0); },
130 dataIndex: 'bytes',
131 align: 'right',
132 width: 90
133 },
134 {
135 header: gettext('Date'),
136 dataIndex: 'day',
137 hidden: true
138 },
139 {
140 xtype: 'datecolumn',
141 header: gettext('Time'),
142 dataIndex: 'time',
143 format: 'H:m:s'
144 }
145 ]
146 },
147 {
148 title: gettext('Selected Mail'),
149 border: false,
150 region: 'center',
151 split: true,
152 reference: 'preview',
153 disabled: true,
154 dockedItems: [
155 {
156 xtype: 'toolbar',
157 dock: 'top',
158 items: [
159 {
160 xtype: 'button',
161 reference: 'raw',
162 text: gettext('Toggle Raw'),
163 enableToggle: true,
164 iconCls: 'fa fa-file-code-o'
165 },
166 '->',
167 {
168 reference: 'deliver',
169 text: gettext('Deliver'),
170 iconCls: 'fa fa-paper-plane-o',
171 handler: 'btnHandler'
172 },
173 {
174 reference: 'delete',
175 text: gettext('Delete'),
176 iconCls: 'fa fa-trash-o',
177 handler: 'btnHandler'
178 }
179 ]
180 }
181 ]
182 }
183 ]
184 });