]> git.proxmox.com Git - pve-manager.git/blob - www/manager6/qemu/HDMove.js
ui: adapt task-history icon, use same as in PBS
[pve-manager.git] / www / manager6 / qemu / HDMove.js
1 Ext.define('PVE.window.HDMove', {
2 extend: 'Ext.window.Window',
3
4 resizable: false,
5
6
7 move_disk: function(disk, storage, format, delete_disk) {
8 var me = this;
9 var qemu = me.type === 'qemu';
10 var params = {};
11 params.storage = storage;
12 params[qemu ? 'disk':'volume'] = disk;
13
14 if (format && qemu) {
15 params.format = format;
16 }
17
18 if (delete_disk) {
19 params.delete = 1;
20 }
21
22 var url = '/nodes/' + me.nodename + '/' + me.type + '/' + me.vmid + '/';
23 url += qemu ? 'move_disk' : 'move_volume';
24
25 Proxmox.Utils.API2Request({
26 params: params,
27 url: url,
28 waitMsgTarget: me,
29 method: 'POST',
30 failure: function(response, opts) {
31 Ext.Msg.alert('Error', response.htmlStatus);
32 },
33 success: function(response, options) {
34 var upid = response.result.data;
35 var win = Ext.create('Proxmox.window.TaskViewer', {
36 upid: upid,
37 });
38 win.show();
39 win.on('destroy', function() { me.close(); });
40 },
41 });
42 },
43
44 initComponent: function() {
45 var me = this;
46
47 if (!me.nodename) {
48 throw "no node name specified";
49 }
50
51 if (!me.vmid) {
52 throw "no VM ID specified";
53 }
54
55 if (!me.type) {
56 me.type = 'qemu';
57 }
58
59 var qemu = me.type === 'qemu';
60
61 var items = [
62 {
63 xtype: 'displayfield',
64 name: qemu ? 'disk' : 'volume',
65 value: me.disk,
66 fieldLabel: qemu ? gettext('Disk') : gettext('Mount Point'),
67 vtype: 'StorageId',
68 allowBlank: false,
69 },
70 ];
71
72 items.push({
73 xtype: 'pveDiskStorageSelector',
74 storageLabel: gettext('Target Storage'),
75 nodename: me.nodename,
76 storageContent: qemu ? 'images' : 'rootdir',
77 hideSize: true,
78 });
79
80 items.push({
81 xtype: 'proxmoxcheckbox',
82 fieldLabel: gettext('Delete source'),
83 name: 'deleteDisk',
84 uncheckedValue: 0,
85 checked: false,
86 });
87
88 me.formPanel = Ext.create('Ext.form.Panel', {
89 bodyPadding: 10,
90 border: false,
91 fieldDefaults: {
92 labelWidth: 100,
93 anchor: '100%',
94 },
95 items: items,
96 });
97
98 var form = me.formPanel.getForm();
99
100 var submitBtn;
101
102 me.title = qemu ? gettext("Move disk") : gettext('Move Volume');
103 submitBtn = Ext.create('Ext.Button', {
104 text: me.title,
105 handler: function() {
106 if (form.isValid()) {
107 var values = form.getValues();
108 me.move_disk(me.disk, values.hdstorage, values.diskformat,
109 values.deleteDisk);
110 }
111 },
112 });
113
114 Ext.apply(me, {
115 modal: true,
116 width: 350,
117 border: false,
118 layout: 'fit',
119 buttons: [submitBtn],
120 items: [me.formPanel],
121 });
122
123
124 me.callParent();
125
126 me.mon(me.formPanel, 'validitychange', function(fp, isValid) {
127 submitBtn.setDisabled(!isValid);
128 });
129
130 me.formPanel.isValid();
131 },
132 });