]> git.proxmox.com Git - pmg-gui.git/blame - js/VirusQuarantine.js
quarantine action: use shadow for toast "window"
[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;
4935e8fb 56 me.lookup('mailinfo').setVisible(me.raw);
644f752b
DC
57 me.raw = !me.raw;
58 me.updatePreview(me.raw);
59 },
60
61 btnHandler: function(button, e) {
62 var list = this.lookupReference('list');
63 var selected = list.getSelection();
64 if (!selected.length) {
65 return;
66 }
67
68 var action = button.reference;
69
aac17b9b 70 PMG.Utils.doQuarantineAction(action, selected[0].data.id, function() {
644f752b
DC
71 list.getController().load();
72 });
73 },
74
75 onSelectMail: function() {
76 var me = this;
b76ce2c5 77 me.updatePreview(me.raw || false);
ac6c1fb8
DC
78 let mailinfo = me.lookup('mailinfo');
79 let list = me.lookup('list');
80 let selection = list.getSelection();
81 if (selection.length < 1) {
82 mailinfo.setVisible(false);
83 return;
84 }
72d8403c 85 mailinfo.setVisible(!me.raw);
ac6c1fb8 86 mailinfo.update(selection[0].data);
644f752b
DC
87 },
88
89 control: {
90 'button[reference=raw]': {
91 click: 'toggleRaw'
92 },
93 'pmgQuarantineList': {
94 selectionChange: 'onSelectMail'
95 }
96 }
97
98 },
99
100 items: [
101 {
56b4528f 102 title: gettext('Virus Quarantine'),
644f752b 103 xtype: 'pmgQuarantineList',
64fb657f 104 emptyText: gettext('No data in database'),
644f752b
DC
105 emailSelection: false,
106 reference: 'list',
107 region: 'west',
108 width: 500,
109 split: true,
110 collapsible: false,
111 store: {
112 model: 'pmg-virus-list',
113 groupField: 'day',
114 groupDir: 'DESC',
115 sorters: [{
116 property: 'time',
117 direction: 'DESC'
118 }]
119 },
120
121 columns: [
122 {
123 header: gettext('Sender/Subject'),
124 dataIndex: 'subject',
125 renderer: PMG.Utils.sender_renderer,
126 flex: 1
127 },
128 {
129 header: gettext('Virus'),
130 dataIndex: 'virusname',
131 align: 'right',
132 width: 70
133 },
134 {
135 header: gettext('Size') + ' (KB)',
136 renderer: function(v) { return Ext.Number.toFixed(v/1024, 0); },
137 dataIndex: 'bytes',
138 align: 'right',
139 width: 90
140 },
141 {
142 header: gettext('Date'),
143 dataIndex: 'day',
144 hidden: true
145 },
146 {
147 xtype: 'datecolumn',
148 header: gettext('Time'),
149 dataIndex: 'time',
150 format: 'H:m:s'
151 }
152 ]
153 },
154 {
155 title: gettext('Selected Mail'),
156 border: false,
157 region: 'center',
158 split: true,
159 reference: 'preview',
160 disabled: true,
161 dockedItems: [
162 {
163 xtype: 'toolbar',
164 dock: 'top',
165 items: [
166 {
167 xtype: 'button',
168 reference: 'raw',
169 text: gettext('Toggle Raw'),
170 enableToggle: true,
171 iconCls: 'fa fa-file-code-o'
172 },
173 '->',
174 {
175 reference: 'deliver',
176 text: gettext('Deliver'),
177 iconCls: 'fa fa-paper-plane-o',
178 handler: 'btnHandler'
179 },
180 {
181 reference: 'delete',
182 text: gettext('Delete'),
183 iconCls: 'fa fa-trash-o',
184 handler: 'btnHandler'
185 }
186 ]
ac6c1fb8
DC
187 },
188 {
189 xtype: 'pmgMailInfo',
190 hidden: true,
191 reference: 'mailinfo',
192 },
644f752b
DC
193 ]
194 }
195 ]
196});