]> git.proxmox.com Git - pmg-gui.git/blame - js/SpamQuarantine.js
SpamQuarantine: add context menu
[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
d9c3552a
DM
51 controller: {
52
2d1f7824 53 xclass: 'Ext.app.ViewController',
d9c3552a 54
2d1f7824 55 updatePreview: function(raw, rec) {
d9c3552a
DM
56 var preview = this.lookupReference('preview');
57
58 if (!rec || !rec.data || !rec.data.id) {
59 preview.update('');
2d1f7824 60 preview.setDisabled(true);
c96a22cb
DC
61 return;
62 }
63
c96a22cb 64 var url = '/api2/htmlmail/quarantine/content?id=' + rec.data.id + ((raw)?'&raw=1':'');
2d1f7824 65 preview.setDisabled(false);
d42f85b8
DC
66 this.lookupReference('raw').setDisabled(false);
67 this.lookupReference('spam').setDisabled(false);
c96a22cb
DC
68 preview.update("<iframe frameborder=0 width=100% height=100% sandbox='allow-same-origin' src='" + url +"'></iframe>");
69 },
70
d42f85b8
DC
71 multiSelect: function() {
72 var preview = this.lookupReference('preview');
73 var raw = this.lookupReference('raw');
74 var spam = this.lookupReference('spam');
75 var spaminfo = this.lookupReference('spaminfo');
76
77 preview.setDisabled(false);
78 preview.update('<h3>' + gettext('Multiple E-Mails selected') + '</h3>');
79 raw.setDisabled(true);
80 spam.setDisabled(true);
81 spam.setPressed(false);
82 spaminfo.setVisible(false);
83 },
84
2d1f7824 85 toggleRaw: function(button) {
c96a22cb 86 var me = this;
b76ce2c5
DC
87 var list = this.lookupReference('list');
88 var rec = list.selModel.getSelection()[0];
2d1f7824 89 me.raw = !me.raw;
b76ce2c5 90 me.updatePreview(me.raw, rec);
c96a22cb
DC
91 },
92
2d1f7824 93 btnHandler: function(button, e) {
7f0619ff
DC
94 var me = this;
95 var action = button.reference;
2d1f7824
DC
96 var list = this.lookupReference('list');
97 var selected = list.getSelection();
7f0619ff
DC
98 me.doAction(action, selected);
99 },
100
101 doAction: function(action, selected) {
2d1f7824 102 if (!selected.length) {
d9c3552a
DM
103 return;
104 }
105
7f0619ff 106 var list = this.lookupReference('list');
c96a22cb 107
d42f85b8
DC
108 if (selected.length > 1) {
109 var idlist = [];
110 selected.forEach(function(item) {
111 idlist.push(item.data.id);
112 });
113 Ext.Msg.confirm(
114 gettext('Confirm'),
115 Ext.String.format(
116 gettext("Action '{0}' for '{1}' items"),
117 action, selected.length
118 ),
119 function(button) {
120 if (button !== 'yes') {
121 return;
122 }
123
124 PMG.Utils.doQuarantineAction(action, idlist.join(';'), function() {
125 list.getController().load();
126 });
127 }
128 );
129 return;
130 }
131
aac17b9b 132 PMG.Utils.doQuarantineAction(action, selected[0].data.id, function() {
2d1f7824
DC
133 list.getController().load();
134 });
c96a22cb
DC
135 },
136
2d1f7824
DC
137 onSelectMail: function() {
138 var me = this;
139 var list = this.lookupReference('list');
d42f85b8
DC
140 var selection = list.selModel.getSelection();
141 if (selection.length > 1) {
142 me.multiSelect();
143 return;
144 }
2d1f7824
DC
145 var rec = list.selModel.getSelection()[0];
146
147 me.updatePreview(me.raw || false, rec);
148 me.lookupReference('spaminfo').setID(rec);
d9c3552a 149 },
c96a22cb 150
2d1f7824
DC
151 toggleSpamInfo: function(btn) {
152 var grid = this.lookupReference('spaminfo');
153 grid.setVisible(!grid.isVisible());
8e89b895
DC
154 },
155
c627f092
DC
156 openContextMenu: function(table, record, tr, index, event) {
157 event.stopEvent();
158 var me = this;
159 var list = me.lookup('list');
160 var menu = Ext.create('PMG.menu.SpamContextMenu', {
161 callback: function(action) {
162 me.doAction(action, list.getSelection());
163 }
164 });
165
166 menu.showAt(event.getXY());
167 },
168
207471c0
DC
169 init: function(view) {
170 this.lookup('list').cselect = view.cselect;
171 },
172
c96a22cb 173 control: {
c96a22cb 174 'button[reference=raw]': {
2d1f7824 175 click: 'toggleRaw'
c96a22cb 176 },
2d1f7824
DC
177 'button[reference=spam]': {
178 click: 'toggleSpamInfo'
c96a22cb 179 },
2d1f7824 180 'pmgQuarantineList': {
c627f092
DC
181 selectionChange: 'onSelectMail',
182 rowcontextmenu: 'openContextMenu'
749af060 183 }
c96a22cb 184 }
d9c3552a
DM
185 },
186
0277bfeb
DM
187 items: [
188 {
56b4528f 189 title: gettext('Spam Quarantine'),
2d1f7824
DC
190 xtype: 'pmgQuarantineList',
191 emailSelection: true,
192 reference: 'list',
d9c3552a 193 region: 'west',
c96a22cb 194 width: 500,
d9c3552a 195 split: true,
c96a22cb 196 collapsible: false,
2d1f7824
DC
197 store: {
198 model: 'pmg-spam-list',
199 groupField: 'day',
200 groupDir: 'DESC',
201 sorters: [{
202 property: 'time',
203 direction: 'DESC'
204 }]
205 },
206
207 columns: [
208 {
209 header: gettext('Sender/Subject'),
210 dataIndex: 'subject',
211 renderer: PMG.Utils.sender_renderer,
212 flex: 1
213 },
214 {
215 header: gettext('Score'),
216 dataIndex: 'spamlevel',
217 align: 'right',
218 width: 70
219 },
220 {
221 header: gettext('Size') + ' (KB)',
222 renderer: function(v) { return Ext.Number.toFixed(v/1024, 0); },
223 dataIndex: 'bytes',
224 align: 'right',
225 width: 90
226 },
227 {
228 header: gettext('Date'),
229 dataIndex: 'day',
230 hidden: true
231 },
232 {
233 xtype: 'datecolumn',
234 header: gettext('Time'),
235 dataIndex: 'time',
236 format: 'H:i:s'
237 }
238 ]
0277bfeb
DM
239 },
240 {
c96a22cb 241 title: gettext('Selected Mail'),
ea07c9aa 242 border: false,
d9c3552a 243 region: 'center',
c96a22cb
DC
244 split: true,
245 reference: 'preview',
246 disabled: true,
2d1f7824
DC
247 dockedItems: [
248 {
249 xtype: 'toolbar',
250 dock: 'top',
251 items: [
252 {
253 xtype: 'button',
254 reference: 'raw',
255 text: gettext('Toggle Raw'),
256 enableToggle: true,
257 iconCls: 'fa fa-file-code-o'
258 },
259 {
260 xtype: 'button',
261 reference: 'spam',
262 text: gettext('Toggle Spam Info'),
263 enableToggle: true,
264 iconCls: 'fa fa-bullhorn'
265 },
266 '->',
267 {
268 reference: 'whitelist',
269 text: gettext('Whitelist'),
270 iconCls: 'fa fa-check',
271 handler: 'btnHandler'
272 },
273 {
274 reference: 'blacklist',
275 text: gettext('Blacklist'),
276 iconCls: 'fa fa-times',
277 handler: 'btnHandler'
278 },
279 {
280 reference: 'deliver',
281 text: gettext('Deliver'),
282 iconCls: 'fa fa-paper-plane-o',
283 handler: 'btnHandler'
284 },
285 {
286 reference: 'delete',
287 text: gettext('Delete'),
288 iconCls: 'fa fa-trash-o',
289 handler: 'btnHandler'
290 }
291 ]
292 },
293 {
294 xtype: 'pmgSpamInfoGrid',
f34abaca 295 border: false,
2d1f7824
DC
296 reference: 'spaminfo'
297 }
298 ]
0277bfeb
DM
299 }
300 ]
301});