]> git.proxmox.com Git - pmg-gui.git/blame - js/SpamQuarantine.js
quarantine: display how many mails are selected
[pmg-gui.git] / js / SpamQuarantine.js
CommitLineData
2c1d504e 1/*global Proxmox*/
ea07c9aa
DC
2/*jslint confusion: true*/
3/*format is a string and a function*/
d9c3552a
DM
4Ext.define('pmg-spam-archive', {
5 extend: 'Ext.data.Model',
6 fields: [
7 { type: 'number', name: 'spamavg' },
8 { type: 'integer', name: 'count' },
9 { type: 'date', dateFormat: 'timestamp', name: 'day' }
10 ],
11 proxy: {
12 type: 'proxmox',
13 url: "/api2/json/quarantine/spam"
14 },
15 idProperty: 'day'
16});
17
d9c3552a
DM
18Ext.define('pmg-spam-list', {
19 extend: 'Ext.data.Model',
20 fields: [ 'id', 'envelope_sender', 'from', 'sender', 'receiver', 'subject',
af5aba0c 21 { type: 'number', name: 'spamlevel' },
d9c3552a 22 { type: 'integer', name: 'bytes' },
c96a22cb
DC
23 { type: 'date', dateFormat: 'timestamp', name: 'time' },
24 {
25 type: 'string',
26 name: 'day',
27 convert: function(v, rec) {
28 return Ext.Date.format(rec.get('time'), 'Y-m-d');
29 }, depends: ['time']
30 }
d9c3552a
DM
31 ],
32 proxy: {
33 type: 'proxmox',
749af060 34 url: "/api2/json/quarantine/spam"
d9c3552a
DM
35 },
36 idProperty: 'id'
37});
38
0277bfeb 39Ext.define('PMG.SpamQuarantine', {
d9c3552a 40 extend: 'Ext.container.Container',
0277bfeb
DM
41 xtype: 'pmgSpamQuarantine',
42
0277bfeb 43 border: false,
ea07c9aa 44 layout: { type: 'border' },
d9c3552a 45
0277bfeb
DM
46 defaults: { border: false },
47
207471c0
DC
48 // from mail link
49 cselect: undefined,
50
41a290e3
TL
51 viewModel: {
52 parent: null,
53 data: {
54 mailid: '',
55 },
56 formulas: {
57 downloadMailURL: get => '/api2/json/quarantine/download?mailid=' + encodeURIComponent(get('mailid')),
58 },
59 },
d9c3552a
DM
60 controller: {
61
2d1f7824 62 xclass: 'Ext.app.ViewController',
d9c3552a 63
2d1f7824 64 updatePreview: function(raw, rec) {
d9c3552a
DM
65 var preview = this.lookupReference('preview');
66
67 if (!rec || !rec.data || !rec.data.id) {
68 preview.update('');
2d1f7824 69 preview.setDisabled(true);
c96a22cb
DC
70 return;
71 }
72
c96a22cb 73 var url = '/api2/htmlmail/quarantine/content?id=' + rec.data.id + ((raw)?'&raw=1':'');
2d1f7824 74 preview.setDisabled(false);
d42f85b8
DC
75 this.lookupReference('raw').setDisabled(false);
76 this.lookupReference('spam').setDisabled(false);
7ad0de10 77 this.lookupReference('download').setDisabled(false);
c96a22cb
DC
78 preview.update("<iframe frameborder=0 width=100% height=100% sandbox='allow-same-origin' src='" + url +"'></iframe>");
79 },
80
b9a5e707 81 multiSelect: function(selection) {
d42f85b8
DC
82 var preview = this.lookupReference('preview');
83 var raw = this.lookupReference('raw');
84 var spam = this.lookupReference('spam');
85 var spaminfo = this.lookupReference('spaminfo');
ac6c1fb8 86 var mailinfo = this.lookupReference('mailinfo');
7ad0de10 87 var download = this.lookupReference('download');
d42f85b8
DC
88
89 preview.setDisabled(false);
b9a5e707 90 preview.update(`<h3 style="padding-left:5px;">${gettext('Multiple E-Mails selected')} (${selection.length})</h3>`);
d42f85b8
DC
91 raw.setDisabled(true);
92 spam.setDisabled(true);
93 spam.setPressed(false);
94 spaminfo.setVisible(false);
ac6c1fb8 95 mailinfo.setVisible(false);
7ad0de10 96 download.setDisabled(true);
d42f85b8
DC
97 },
98
2d1f7824 99 toggleRaw: function(button) {
c96a22cb 100 var me = this;
4935e8fb 101 var list = me.lookupReference('list');
b76ce2c5 102 var rec = list.selModel.getSelection()[0];
4935e8fb 103 me.lookupReference('mailinfo').setVisible(me.raw);
2d1f7824 104 me.raw = !me.raw;
b76ce2c5 105 me.updatePreview(me.raw, rec);
c96a22cb
DC
106 },
107
2d1f7824 108 btnHandler: function(button, e) {
7f0619ff
DC
109 var me = this;
110 var action = button.reference;
2d1f7824
DC
111 var list = this.lookupReference('list');
112 var selected = list.getSelection();
7f0619ff
DC
113 me.doAction(action, selected);
114 },
115
116 doAction: function(action, selected) {
2d1f7824 117 if (!selected.length) {
d9c3552a
DM
118 return;
119 }
120
7f0619ff 121 var list = this.lookupReference('list');
c96a22cb 122
d42f85b8
DC
123 if (selected.length > 1) {
124 var idlist = [];
125 selected.forEach(function(item) {
126 idlist.push(item.data.id);
127 });
128 Ext.Msg.confirm(
129 gettext('Confirm'),
130 Ext.String.format(
131 gettext("Action '{0}' for '{1}' items"),
132 action, selected.length
133 ),
134 function(button) {
135 if (button !== 'yes') {
136 return;
137 }
138
139 PMG.Utils.doQuarantineAction(action, idlist.join(';'), function() {
140 list.getController().load();
141 });
142 }
143 );
144 return;
145 }
146
aac17b9b 147 PMG.Utils.doQuarantineAction(action, selected[0].data.id, function() {
2d1f7824
DC
148 list.getController().load();
149 });
c96a22cb
DC
150 },
151
2d1f7824
DC
152 onSelectMail: function() {
153 var me = this;
154 var list = this.lookupReference('list');
d42f85b8
DC
155 var selection = list.selModel.getSelection();
156 if (selection.length > 1) {
b9a5e707 157 me.multiSelect(selection);
d42f85b8
DC
158 return;
159 }
2d1f7824 160
38771d94
DC
161 var rec = selection[0] || {};
162
163 me.getViewModel().set('mailid', rec.data ? rec.data.id : '');
2d1f7824
DC
164 me.updatePreview(me.raw || false, rec);
165 me.lookupReference('spaminfo').setID(rec);
72d8403c 166 me.lookupReference('mailinfo').setVisible(!!rec.data && !me.raw);
ac6c1fb8 167 me.lookupReference('mailinfo').update(rec.data);
d9c3552a 168 },
c96a22cb 169
2d1f7824
DC
170 toggleSpamInfo: function(btn) {
171 var grid = this.lookupReference('spaminfo');
172 grid.setVisible(!grid.isVisible());
8e89b895
DC
173 },
174
c627f092
DC
175 openContextMenu: function(table, record, tr, index, event) {
176 event.stopEvent();
177 var me = this;
178 var list = me.lookup('list');
179 var menu = Ext.create('PMG.menu.SpamContextMenu', {
180 callback: function(action) {
181 me.doAction(action, list.getSelection());
182 }
183 });
184
185 menu.showAt(event.getXY());
186 },
187
0b9c0528
DC
188 keyPress: function (table, record, item, index, event) {
189 var me = this;
190 var list = me.lookup('list');
191 var key = event.getKey();
192 var action = '';
193 switch(key) {
194 case event.DELETE:
195 case 127:
196 action = 'delete';
197 break;
198 case Ext.event.Event.D:
199 case Ext.event.Event.D + 32:
200 action = 'deliver';
201 break;
202 case Ext.event.Event.W:
203 case Ext.event.Event.W + 32:
204 action = 'whitelist';
205 break;
206 case Ext.event.Event.B:
207 case Ext.event.Event.B + 32:
208 action = 'blacklist';
209 break;
210 }
211
212 if (action !== '') {
213 me.doAction(action, list.getSelection());
214 }
215 },
216
207471c0
DC
217 init: function(view) {
218 this.lookup('list').cselect = view.cselect;
219 },
220
c96a22cb 221 control: {
c96a22cb 222 'button[reference=raw]': {
2d1f7824 223 click: 'toggleRaw'
c96a22cb 224 },
2d1f7824
DC
225 'button[reference=spam]': {
226 click: 'toggleSpamInfo'
c96a22cb 227 },
2d1f7824 228 'pmgQuarantineList': {
c627f092 229 selectionChange: 'onSelectMail',
0b9c0528 230 itemkeypress: 'keyPress',
c627f092 231 rowcontextmenu: 'openContextMenu'
749af060 232 }
c96a22cb 233 }
d9c3552a
DM
234 },
235
0277bfeb
DM
236 items: [
237 {
56b4528f 238 title: gettext('Spam Quarantine'),
2d1f7824 239 xtype: 'pmgQuarantineList',
62651172 240 selModel: 'checkboxmodel',
2d1f7824
DC
241 emailSelection: true,
242 reference: 'list',
d9c3552a 243 region: 'west',
c96a22cb 244 width: 500,
d9c3552a 245 split: true,
c96a22cb 246 collapsible: false,
2d1f7824
DC
247 store: {
248 model: 'pmg-spam-list',
249 groupField: 'day',
250 groupDir: 'DESC',
251 sorters: [{
252 property: 'time',
253 direction: 'DESC'
254 }]
255 },
256
257 columns: [
258 {
259 header: gettext('Sender/Subject'),
260 dataIndex: 'subject',
261 renderer: PMG.Utils.sender_renderer,
262 flex: 1
263 },
264 {
265 header: gettext('Score'),
266 dataIndex: 'spamlevel',
267 align: 'right',
268 width: 70
269 },
270 {
271 header: gettext('Size') + ' (KB)',
272 renderer: function(v) { return Ext.Number.toFixed(v/1024, 0); },
273 dataIndex: 'bytes',
274 align: 'right',
275 width: 90
276 },
277 {
278 header: gettext('Date'),
279 dataIndex: 'day',
280 hidden: true
281 },
282 {
283 xtype: 'datecolumn',
284 header: gettext('Time'),
285 dataIndex: 'time',
286 format: 'H:i:s'
287 }
288 ]
0277bfeb
DM
289 },
290 {
c96a22cb 291 title: gettext('Selected Mail'),
ea07c9aa 292 border: false,
d9c3552a 293 region: 'center',
c96a22cb
DC
294 split: true,
295 reference: 'preview',
296 disabled: true,
2d1f7824
DC
297 dockedItems: [
298 {
299 xtype: 'toolbar',
300 dock: 'top',
301 items: [
302 {
303 xtype: 'button',
304 reference: 'raw',
305 text: gettext('Toggle Raw'),
306 enableToggle: true,
307 iconCls: 'fa fa-file-code-o'
308 },
309 {
310 xtype: 'button',
311 reference: 'spam',
312 text: gettext('Toggle Spam Info'),
313 enableToggle: true,
314 iconCls: 'fa fa-bullhorn'
315 },
316 '->',
7ad0de10
DC
317 {
318 xtype: 'button',
319 reference: 'download',
320 text: gettext('Download'),
07a9b445
TL
321 setDownload: function(id) {
322 this.el.dom.download = id + ".eml";
323 },
324 bind: {
325 href: '{downloadMailURL}',
326 download: '{mailid}',
327 },
7ad0de10
DC
328 iconCls: 'fa fa-download'
329 },
330 '-',
2d1f7824
DC
331 {
332 reference: 'whitelist',
333 text: gettext('Whitelist'),
334 iconCls: 'fa fa-check',
335 handler: 'btnHandler'
336 },
337 {
338 reference: 'blacklist',
339 text: gettext('Blacklist'),
340 iconCls: 'fa fa-times',
341 handler: 'btnHandler'
342 },
343 {
344 reference: 'deliver',
345 text: gettext('Deliver'),
346 iconCls: 'fa fa-paper-plane-o',
347 handler: 'btnHandler'
348 },
349 {
350 reference: 'delete',
351 text: gettext('Delete'),
352 iconCls: 'fa fa-trash-o',
353 handler: 'btnHandler'
354 }
355 ]
356 },
357 {
358 xtype: 'pmgSpamInfoGrid',
f34abaca 359 border: false,
2d1f7824 360 reference: 'spaminfo'
ac6c1fb8
DC
361 },
362 {
363 xtype: 'pmgMailInfo',
364 hidden: true,
365 reference: 'mailinfo',
366 },
2d1f7824 367 ]
0277bfeb
DM
368 }
369 ]
370});