]>
git.proxmox.com Git - pve-manager.git/blob - www/manager5/window/Edit.js
e150cf1d9f082a2db7c3c71af609f95bd579391f
1 // fixme: how can we avoid those lint errors?
2 /*jslint confusion: true */
3 Ext
.define('PVE.window.Edit', {
4 extend
: 'Ext.window.Window',
5 alias
: 'widget.pveWindowEdit',
9 // use this tio atimatically generate a title like
13 // set create to true if you want a Create button (instead
17 // set to true if you want an Add button (instead of Create)
20 // set to true if you want an Remove button (instead of Create)
30 var form
= me
.formPanel
.getForm();
31 return form
.isValid();
34 getValues: function(dirtyOnly
) {
39 var form
= me
.formPanel
.getForm();
41 form
.getFields().each(function(field
) {
42 if (!field
.up('inputpanel') && (!dirtyOnly
|| field
.isDirty())) {
43 PVE
.Utils
.assemble_field_data(values
, field
.getSubmitData());
47 Ext
.Array
.each(me
.query('inputpanel'), function(panel
) {
48 PVE
.Utils
.assemble_field_data(values
, panel
.getValues(dirtyOnly
));
54 setValues: function(values
) {
57 var form
= me
.formPanel
.getForm();
59 Ext
.iterate(values
, function(fieldId
, val
) {
60 var field
= form
.findField(fieldId
);
61 if (field
&& !field
.up('inputpanel')) {
63 if (form
.trackResetOnLoad
) {
64 field
.resetOriginalValue();
69 Ext
.Array
.each(me
.query('inputpanel'), function(panel
) {
70 panel
.setValues(values
);
77 var form
= me
.formPanel
.getForm();
79 var values
= me
.getValues();
80 Ext
.Object
.each(values
, function(name
, val
) {
81 if (values
.hasOwnProperty(name
)) {
82 if (Ext
.isArray(val
) && !val
.length
) {
89 values
.digest
= me
.digest
;
92 if (me
.backgroundDelay
) {
93 values
.background_delay
= me
.backgroundDelay
;
97 if (me
.method
=== 'DELETE') {
98 url
= url
+ "?" + Ext
.Object
.toQueryString(values
);
102 PVE
.Utils
.API2Request({
105 method
: me
.method
|| (me
.backgroundDelay
? 'POST' : 'PUT'),
107 failure: function(response
, options
) {
108 if (response
.result
&& response
.result
.errors
) {
109 form
.markInvalid(response
.result
.errors
);
111 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
);
113 success: function(response
, options
) {
115 if ((me
.backgroundDelay
|| me
.showProgress
) &&
116 response
.result
.data
) {
117 var upid
= response
.result
.data
;
118 var win
= Ext
.create('PVE.window.TaskProgress', {
127 load: function(options
) {
130 var form
= me
.formPanel
.getForm();
132 options
= options
|| {};
134 var newopts
= Ext
.apply({
138 var createWrapper = function(successFn
) {
142 success: function(response
, opts
) {
144 me
.digest
= response
.result
.data
.digest
;
146 successFn(response
, opts
);
148 me
.setValues(response
.result
.data
);
150 // hack: fix ExtJS bug
151 Ext
.Array
.each(me
.query('radiofield'), function(f
) {
152 f
.resetOriginalValue();
155 failure: function(response
, opts
) {
156 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
, function() {
163 createWrapper(options
.success
);
165 PVE
.Utils
.API2Request(newopts
);
168 initComponent : function() {
172 throw "no url specified";
175 var items
= Ext
.isArray(me
.items
) ? me
.items
: [ me
.items
];
177 me
.items
= undefined;
179 me
.formPanel
= Ext
.create('Ext.form.Panel', {
181 method
: me
.method
|| 'PUT',
182 trackResetOnLoad
: true,
188 fieldDefaults
: Ext
.apply({}, me
.fieldDefaults
, {
195 var form
= me
.formPanel
.getForm();
197 var submitBtn
= Ext
.create('Ext.Button', {
198 text
: me
.create
? (me
.isAdd
? gettext('Add') : ( me
.isRemove
? gettext('Remove') : gettext('Create'))) : gettext('OK'),
199 disabled
: !me
.create
,
200 handler: function() {
205 var resetBtn
= Ext
.create('Ext.Button', {
213 var set_button_status = function() {
214 var valid
= form
.isValid();
215 var dirty
= form
.isDirty();
216 submitBtn
.setDisabled(!valid
|| !(dirty
|| me
.create
));
217 resetBtn
.setDisabled(!dirty
);
220 form
.on('dirtychange', set_button_status
);
221 form
.on('validitychange', set_button_status
);
224 if (me
.fieldDefaults
&& me
.fieldDefaults
.labelWidth
) {
225 colwidth
+= me
.fieldDefaults
.labelWidth
- 100;
229 var twoColumn
= items
[0].column1
|| items
[0].column2
;
231 if (me
.subject
&& !me
.title
) {
232 me
.title
= PVE
.Utils
.dialog_title(me
.subject
, me
.create
, me
.isAdd
);
236 me
.buttons
= [ submitBtn
] ;
238 me
.buttons
= [ submitBtn
, resetBtn
];
243 width
: twoColumn
? colwidth
*2 : colwidth
,
245 items
: [ me
.formPanel
],
250 // always mark invalid fields
251 me
.on('afterlayout', function() {