]>
git.proxmox.com Git - proxmox-backup.git/blob - www/config/SyncView.js
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_optional_timestamp: function(value
) {
118 if (!value
) return '-';
119 return Proxmox
.Utils
.render_timestamp(value
);
122 reload: function() { this.getView().getStore().rstore
.load(); },
124 init: function(view
) {
125 Proxmox
.Utils
.monStoreErrors(view
, view
.getStore().rstore
);
131 itemdblclick
: 'editSyncJob',
137 autoDestroyRstore
: true,
141 storeid
: 'pbs-sync-jobs-status',
142 model
: 'pbs-sync-jobs-status',
150 xtype
: 'proxmoxButton',
151 text
: gettext('Add'),
152 handler
: 'addSyncJob',
156 xtype
: 'proxmoxButton',
157 text
: gettext('Edit'),
158 handler
: 'editSyncJob',
162 xtype
: 'proxmoxStdRemoveButton',
163 baseurl
: '/config/sync/',
168 xtype
: 'proxmoxButton',
169 text
: gettext('Log'),
170 handler
: 'openTaskLog',
171 enableFn
: (rec
) => !!rec
.data
['last-run-upid'],
175 xtype
: 'proxmoxButton',
176 text
: gettext('Run now'),
177 handler
: 'runSyncJob',
188 header
: gettext('Sync Job'),
191 renderer
: Ext
.String
.htmlEncode
,
195 header
: gettext('Remote'),
201 header
: gettext('Remote Store'),
204 dataIndex
: 'remote-store',
207 header
: gettext('Local Store'),
213 header
: gettext('Schedule'),
215 dataIndex
: 'schedule',
218 header
: gettext('Status'),
219 dataIndex
: 'last-run-state',
221 renderer
: 'render_sync_status',
224 header
: gettext('Last Sync'),
227 renderer
: 'render_optional_timestamp',
228 dataIndex
: 'last-run-endtime',
231 text
: gettext('Duration'),
232 dataIndex
: 'duration',
234 renderer
: Proxmox
.Utils
.render_duration
,
237 header
: gettext('Next Run'),
240 renderer
: 'render_optional_timestamp',
241 dataIndex
: 'next-run',
244 header
: gettext('Comment'),
247 renderer
: Ext
.String
.htmlEncode
,
248 dataIndex
: 'comment',