]>
git.proxmox.com Git - proxmox-backup.git/blob - www/config/SyncView.js
634977c4a6a8a1f83302bcd7a708b74e2177ed90
1 Ext
.define('pbs-sync-jobs-status', {
2 extend
: 'Ext.data.Model',
4 'id', 'remote', 'remote-store', 'store', 'schedule',
5 'next-run', 'last-run-upid', 'last-run-state', 'last-run-endtime',
8 calculate: function(data
) {
9 let endtime
= data
['last-run-endtime'];
10 if (!endtime
) return undefined;
11 let task
= Proxmox
.Utils
.parse_task_upid(data
['last-run-upid']);
12 return endtime
- task
.starttime
;
19 url
: '/api2/json/admin/sync',
23 Ext
.define('PBS.config.SyncJobView', {
24 extend
: 'Ext.grid.GridPanel',
25 alias
: 'widget.pbsSyncJobView',
28 stateId
: 'grid-sync-jobs',
30 title
: gettext('Sync Jobs'),
33 xclass
: 'Ext.app.ViewController',
35 addSyncJob: function() {
37 Ext
.create('PBS.window.SyncJobEdit', {
46 editSyncJob: function() {
48 let view
= me
.getView();
49 let selection
= view
.getSelection();
50 if (selection
.length
< 1) return;
52 Ext
.create('PBS.window.SyncJobEdit', {
53 id
: selection
[0].data
.id
,
62 openTaskLog: function() {
64 let view
= me
.getView();
65 let selection
= view
.getSelection();
66 if (selection
.length
< 1) return;
68 let upid
= selection
[0].data
['last-run-upid'];
71 Ext
.create('Proxmox.window.TaskViewer', {
76 runSyncJob: function() {
78 let view
= me
.getView();
79 let selection
= view
.getSelection();
80 if (selection
.length
< 1) return;
82 let id
= selection
[0].data
.id
;
83 Proxmox
.Utils
.API2Request({
85 url
: `/admin/sync/${id}/run`,
86 success: function(response
, opt
) {
87 Ext
.create('Proxmox.window.TaskViewer', {
88 upid
: response
.result
.data
,
89 taskDone: function(success
) {
94 failure: function(response
, opt
) {
95 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
);
100 render_sync_status: function(value
, metadata
, record
) {
101 if (!record
.data
['last-run-upid']) {
105 if (!record
.data
['last-run-endtime']) {
106 metadata
.tdCls
= 'x-grid-row-loading';
110 if (value
=== 'OK') {
111 return `<i class="fa fa-check good"></i> ${gettext("OK")}`;
114 return `<i class="fa fa-times critical"></i> ${gettext("Error")}:${value}`;
117 render_next_run: function(value
, metadat
, record
) {
118 if (!value
) return '-';
120 let now
= new Date();
121 let next
= new Date(value
*1000);
124 return gettext('pending');
126 return Proxmox
.Utils
.render_timestamp(value
);
129 render_optional_timestamp: function(value
, metadata
, record
) {
130 if (!value
) return '-';
131 return Proxmox
.Utils
.render_timestamp(value
);
134 reload: function() { this.getView().getStore().rstore
.load(); },
136 init: function(view
) {
137 Proxmox
.Utils
.monStoreErrors(view
, view
.getStore().rstore
);
143 itemdblclick
: 'editSyncJob',
149 autoDestroyRstore
: true,
153 storeid
: 'pbs-sync-jobs-status',
154 model
: 'pbs-sync-jobs-status',
162 xtype
: 'proxmoxButton',
163 text
: gettext('Add'),
164 handler
: 'addSyncJob',
168 xtype
: 'proxmoxButton',
169 text
: gettext('Edit'),
170 handler
: 'editSyncJob',
174 xtype
: 'proxmoxStdRemoveButton',
175 baseurl
: '/config/sync/',
180 xtype
: 'proxmoxButton',
181 text
: gettext('Log'),
182 handler
: 'openTaskLog',
183 enableFn
: (rec
) => !!rec
.data
['last-run-upid'],
187 xtype
: 'proxmoxButton',
188 text
: gettext('Run now'),
189 handler
: 'runSyncJob',
200 header
: gettext('Sync Job'),
203 renderer
: Ext
.String
.htmlEncode
,
207 header
: gettext('Remote'),
213 header
: gettext('Remote Store'),
216 dataIndex
: 'remote-store',
219 header
: gettext('Local Store'),
225 header
: gettext('Schedule'),
227 dataIndex
: 'schedule',
230 header
: gettext('Status'),
231 dataIndex
: 'last-run-state',
233 renderer
: 'render_sync_status',
236 header
: gettext('Last Sync'),
239 renderer
: 'render_optional_timestamp',
240 dataIndex
: 'last-run-endtime',
243 text
: gettext('Duration'),
244 dataIndex
: 'duration',
246 renderer
: Proxmox
.Utils
.render_duration
,
249 header
: gettext('Next Run'),
252 renderer
: 'render_next_run',
253 dataIndex
: 'next-run',
256 header
: gettext('Comment'),
259 renderer
: Ext
.String
.htmlEncode
,
260 dataIndex
: 'comment',