]>
git.proxmox.com Git - proxmox-widget-toolkit.git/blob - window/Edit.js
e258e49271bf1c1d5a171bb620adc56abdb5ea6b
1 // fixme: how can we avoid those lint errors?
2 /*jslint confusion: true */
3 Ext
.define('Proxmox.window.Edit', {
4 extend
: 'Ext.window.Window',
5 alias
: 'widget.proxmoxWindowEdit',
7 // autoLoad trigger a load() after component creation
12 // use this tio atimatically generate a title like
16 // set isCreate to true if you want a Create button (instead
20 // set to true if you want an Add button (instead of Create)
23 // set to true if you want an Remove button (instead of Create)
27 submitText
: undefined,
31 // needed for finding the reference to submitbutton
32 // because we do not have a controller
33 referenceHolder
: true,
34 defaultButton
: 'submitbutton',
36 // finds the first form field
37 defaultFocus
: 'field[disabled=false][hidden=false]',
41 showTaskViewer
: false,
43 // gets called if we have a progress bar or taskview and it detected that
44 // the task finished. function(success)
45 taskDone
: Ext
.emptyFn
,
47 // gets called when the api call is finished, right at the beginning
48 // function(success, response, options)
49 apiCallDone
: Ext
.emptyFn
,
51 // assign a reference from docs, to add a help button docked to the
52 // bottom of the window. If undefined we magically fall back to the
53 // onlineHelp of our first item, if set.
54 onlineHelp
: undefined,
59 let form
= me
.formPanel
.getForm();
60 return form
.isValid();
63 getValues: function(dirtyOnly
) {
68 let form
= me
.formPanel
.getForm();
70 form
.getFields().each(function(field
) {
71 if (!field
.up('inputpanel') && (!dirtyOnly
|| field
.isDirty())) {
72 Proxmox
.Utils
.assemble_field_data(values
, field
.getSubmitData());
76 Ext
.Array
.each(me
.query('inputpanel'), function(panel
) {
77 Proxmox
.Utils
.assemble_field_data(values
, panel
.getValues(dirtyOnly
));
83 setValues: function(values
) {
86 let form
= me
.formPanel
.getForm();
87 let formfields
= form
.getFields();
89 Ext
.iterate(values
, function(id
, val
) {
90 let fields
= formfields
.filterBy((f
) =>
91 (f
.id
=== id
|| f
.name
=== id
|| f
.dataIndex
=== id
) && !f
.up('inputpanel'),
93 fields
.each((field
) => {
95 if (form
.trackResetOnLoad
) {
96 field
.resetOriginalValue();
101 Ext
.Array
.each(me
.query('inputpanel'), function(panel
) {
102 panel
.setValues(values
);
106 setSubmitText: function(text
) {
107 this.lookup('submitbutton').setText(text
);
113 let form
= me
.formPanel
.getForm();
115 let values
= me
.getValues();
116 Ext
.Object
.each(values
, function(name
, val
) {
117 if (Object
.prototype.hasOwnProperty
.call(values
, name
)) {
118 if (Ext
.isArray(val
) && !val
.length
) {
125 values
.digest
= me
.digest
;
128 if (me
.backgroundDelay
) {
129 values
.background_delay
= me
.backgroundDelay
;
133 if (me
.method
=== 'DELETE') {
134 url
= url
+ "?" + Ext
.Object
.toQueryString(values
);
138 Proxmox
.Utils
.API2Request({
141 method
: me
.method
|| (me
.backgroundDelay
? 'POST' : 'PUT'),
143 failure: function(response
, options
) {
144 me
.apiCallDone(false, response
, options
);
146 if (response
.result
&& response
.result
.errors
) {
147 form
.markInvalid(response
.result
.errors
);
149 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
);
151 success: function(response
, options
) {
153 (me
.backgroundDelay
|| me
.showProgress
|| me
.showTaskViewer
) &&
154 response
.result
.data
;
156 me
.apiCallDone(true, response
, options
);
158 if (hasProgressBar
) {
159 // stay around so we can trigger our close events
160 // when background action is completed
163 let upid
= response
.result
.data
;
164 let viewerClass
= me
.showTaskViewer
? 'Viewer' : 'Progress';
165 Ext
.create('Proxmox.window.Task' + viewerClass
, {
168 taskDone
: me
.taskDone
,
170 destroy: function() {
182 load: function(options
) {
185 let form
= me
.formPanel
.getForm();
187 options
= options
|| {};
189 let newopts
= Ext
.apply({
193 let createWrapper = function(successFn
) {
197 success: function(response
, opts
) {
199 me
.digest
= response
.result
.digest
|| response
.result
.data
.digest
;
201 successFn(response
, opts
);
203 me
.setValues(response
.result
.data
);
205 // hack: fix ExtJS bug
206 Ext
.Array
.each(me
.query('radiofield'), function(f
) {
207 f
.resetOriginalValue();
210 failure: function(response
, opts
) {
211 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
, function() {
218 createWrapper(options
.success
);
220 Proxmox
.Utils
.API2Request(newopts
);
223 initComponent: function() {
227 throw "no url specified";
230 if (me
.create
) {throw "deprecated parameter, use isCreate";}
232 let items
= Ext
.isArray(me
.items
) ? me
.items
: [me
.items
];
234 me
.items
= undefined;
236 me
.formPanel
= Ext
.create('Ext.form.Panel', {
238 method
: me
.method
|| 'PUT',
239 trackResetOnLoad
: true,
240 bodyPadding
: me
.bodyPadding
!== undefined ? me
.bodyPadding
: 10,
242 defaults
: Ext
.apply({}, me
.defaults
, {
245 fieldDefaults
: Ext
.apply({}, me
.fieldDefaults
, {
252 let inputPanel
= me
.formPanel
.down('inputpanel');
254 let form
= me
.formPanel
.getForm();
259 submitText
= me
.submitText
;
260 } else if (me
.isAdd
) {
261 submitText
= gettext('Add');
262 } else if (me
.isRemove
) {
263 submitText
= gettext('Remove');
265 submitText
= gettext('Create');
268 submitText
= me
.submitText
|| gettext('OK');
271 let submitBtn
= Ext
.create('Ext.Button', {
272 reference
: 'submitbutton',
274 disabled
: !me
.isCreate
,
275 handler: function() {
280 let resetBtn
= Ext
.create('Ext.Button', {
283 handler: function() {
288 let set_button_status = function() {
289 let valid
= form
.isValid();
290 let dirty
= form
.isDirty();
291 submitBtn
.setDisabled(!valid
|| !(dirty
|| me
.isCreate
));
292 resetBtn
.setDisabled(!dirty
);
294 if (inputPanel
&& inputPanel
.hasAdvanced
) {
295 // we want to show the advanced options
296 // as soon as some of it is not valid
297 let advancedItems
= me
.down('#advancedContainer').query('field');
298 let allAdvancedValid
= true;
299 advancedItems
.forEach(function(field
) {
300 if (!field
.isValid()) {
301 allAdvancedValid
= false;
305 if (!allAdvancedValid
) {
306 inputPanel
.setAdvancedVisible(true);
307 me
.down('#advancedcb').setValue(true);
312 form
.on('dirtychange', set_button_status
);
313 form
.on('validitychange', set_button_status
);
316 if (me
.fieldDefaults
&& me
.fieldDefaults
.labelWidth
) {
317 colwidth
+= me
.fieldDefaults
.labelWidth
- 100;
320 let twoColumn
= inputPanel
&& (inputPanel
.column1
|| inputPanel
.column2
);
322 if (me
.subject
&& !me
.title
) {
323 me
.title
= Proxmox
.Utils
.dialog_title(me
.subject
, me
.isCreate
, me
.isAdd
);
327 me
.buttons
= [submitBtn
];
329 me
.buttons
= [submitBtn
, resetBtn
];
332 if (inputPanel
&& inputPanel
.hasAdvanced
) {
333 let sp
= Ext
.state
.Manager
.getProvider();
334 let advchecked
= sp
.get('proxmox-advanced-cb');
335 inputPanel
.setAdvancedVisible(advchecked
);
338 xtype
: 'proxmoxcheckbox',
339 itemId
: 'advancedcb',
340 boxLabelAlign
: 'before',
341 boxLabel
: gettext('Advanced'),
342 stateId
: 'proxmox-advanced-cb',
345 change: function(cb
, val
) {
346 inputPanel
.setAdvancedVisible(val
);
347 sp
.set('proxmox-advanced-cb', val
);
354 let onlineHelp
= me
.onlineHelp
;
355 if (!onlineHelp
&& inputPanel
&& inputPanel
.onlineHelp
) {
356 onlineHelp
= inputPanel
.onlineHelp
;
360 let helpButton
= Ext
.create('Proxmox.button.Help');
361 me
.buttons
.unshift(helpButton
, '->');
362 Ext
.GlobalEvents
.fireEvent('proxmoxShowHelp', onlineHelp
);
367 width
: twoColumn
? colwidth
*2 : colwidth
,
369 items
: [me
.formPanel
],
374 // always mark invalid fields
375 me
.on('afterlayout', function() {
376 // on touch devices, the isValid function
377 // triggers a layout, which triggers an isValid
379 // to prevent this we disable the layouting here
380 // and enable it afterwards
381 me
.suspendLayout
= true;
383 me
.suspendLayout
= false;