]>
Commit | Line | Data |
---|---|---|
644f752b DC |
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 | ||
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 | }); |