]> git.proxmox.com Git - pmg-gui.git/blame - js/VirusQuarantine.js
implement multiselection of spamquarantine mails
[pmg-gui.git] / js / VirusQuarantine.js
CommitLineData
644f752b
DC
1/*global Proxmox*/
2/*jslint confusion: true*/
3/*format is a string and a function*/
4Ext.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
25Ext.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
b76ce2c5 38 updatePreview: function(raw) {
644f752b
DC
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
aac17b9b 69 PMG.Utils.doQuarantineAction(action, selected[0].data.id, function() {
644f752b
DC
70 list.getController().load();
71 });
72 },
73
74 onSelectMail: function() {
75 var me = this;
b76ce2c5 76 me.updatePreview(me.raw || false);
644f752b
DC
77 },
78
79 control: {
80 'button[reference=raw]': {
81 click: 'toggleRaw'
82 },
83 'pmgQuarantineList': {
84 selectionChange: 'onSelectMail'
85 }
86 }
87
88 },
89
90 items: [
91 {
56b4528f 92 title: gettext('Virus Quarantine'),
644f752b 93 xtype: 'pmgQuarantineList',
d42f85b8 94 selModel: 'rowmodel',
64fb657f 95 emptyText: gettext('No data in database'),
644f752b
DC
96 emailSelection: false,
97 reference: 'list',
98 region: 'west',
99 width: 500,
100 split: true,
101 collapsible: false,
102 store: {
103 model: 'pmg-virus-list',
104 groupField: 'day',
105 groupDir: 'DESC',
106 sorters: [{
107 property: 'time',
108 direction: 'DESC'
109 }]
110 },
111
112 columns: [
113 {
114 header: gettext('Sender/Subject'),
115 dataIndex: 'subject',
116 renderer: PMG.Utils.sender_renderer,
117 flex: 1
118 },
119 {
120 header: gettext('Virus'),
121 dataIndex: 'virusname',
122 align: 'right',
123 width: 70
124 },
125 {
126 header: gettext('Size') + ' (KB)',
127 renderer: function(v) { return Ext.Number.toFixed(v/1024, 0); },
128 dataIndex: 'bytes',
129 align: 'right',
130 width: 90
131 },
132 {
133 header: gettext('Date'),
134 dataIndex: 'day',
135 hidden: true
136 },
137 {
138 xtype: 'datecolumn',
139 header: gettext('Time'),
140 dataIndex: 'time',
141 format: 'H:m:s'
142 }
143 ]
144 },
145 {
146 title: gettext('Selected Mail'),
147 border: false,
148 region: 'center',
149 split: true,
150 reference: 'preview',
151 disabled: true,
152 dockedItems: [
153 {
154 xtype: 'toolbar',
155 dock: 'top',
156 items: [
157 {
158 xtype: 'button',
159 reference: 'raw',
160 text: gettext('Toggle Raw'),
161 enableToggle: true,
162 iconCls: 'fa fa-file-code-o'
163 },
164 '->',
165 {
166 reference: 'deliver',
167 text: gettext('Deliver'),
168 iconCls: 'fa fa-paper-plane-o',
169 handler: 'btnHandler'
170 },
171 {
172 reference: 'delete',
173 text: gettext('Delete'),
174 iconCls: 'fa fa-trash-o',
175 handler: 'btnHandler'
176 }
177 ]
178 }
179 ]
180 }
181 ]
182});