]>
git.proxmox.com Git - proxmox-widget-toolkit.git/blob - window/Edit.js
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 create 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)
28 // needed for finding the reference to submitbutton
29 // because we do not have a controller
30 referenceHolder
: true,
31 defaultButton
: 'submitbutton',
33 // finds the first form field
34 defaultFocus
: 'field',
41 var form
= me
.formPanel
.getForm();
42 return form
.isValid();
45 getValues: function(dirtyOnly
) {
50 var form
= me
.formPanel
.getForm();
52 form
.getFields().each(function(field
) {
53 if (!field
.up('inputpanel') && (!dirtyOnly
|| field
.isDirty())) {
54 Proxmox
.Utils
.assemble_field_data(values
, field
.getSubmitData());
58 Ext
.Array
.each(me
.query('inputpanel'), function(panel
) {
59 Proxmox
.Utils
.assemble_field_data(values
, panel
.getValues(dirtyOnly
));
65 setValues: function(values
) {
68 var form
= me
.formPanel
.getForm();
70 Ext
.iterate(values
, function(fieldId
, val
) {
71 var field
= form
.findField(fieldId
);
72 if (field
&& !field
.up('inputpanel')) {
74 if (form
.trackResetOnLoad
) {
75 field
.resetOriginalValue();
80 Ext
.Array
.each(me
.query('inputpanel'), function(panel
) {
81 panel
.setValues(values
);
88 var form
= me
.formPanel
.getForm();
90 var values
= me
.getValues();
91 Ext
.Object
.each(values
, function(name
, val
) {
92 if (values
.hasOwnProperty(name
)) {
93 if (Ext
.isArray(val
) && !val
.length
) {
100 values
.digest
= me
.digest
;
103 if (me
.backgroundDelay
) {
104 values
.background_delay
= me
.backgroundDelay
;
108 if (me
.method
=== 'DELETE') {
109 url
= url
+ "?" + Ext
.Object
.toQueryString(values
);
113 Proxmox
.Utils
.API2Request({
116 method
: me
.method
|| (me
.backgroundDelay
? 'POST' : 'PUT'),
118 failure: function(response
, options
) {
119 if (response
.result
&& response
.result
.errors
) {
120 form
.markInvalid(response
.result
.errors
);
122 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
);
124 success: function(response
, options
) {
125 var hasProgressBar
= (me
.backgroundDelay
|| me
.showProgress
) &&
126 response
.result
.data
? true : false;
128 if (hasProgressBar
) {
129 // stay around so we can trigger our close events
130 // when background action is completed
133 var upid
= response
.result
.data
;
134 var win
= Ext
.create('PVE.window.TaskProgress', {
137 destroy: function () {
150 load: function(options
) {
153 var form
= me
.formPanel
.getForm();
155 options
= options
|| {};
157 var newopts
= Ext
.apply({
161 var createWrapper = function(successFn
) {
165 success: function(response
, opts
) {
167 me
.digest
= response
.result
.data
.digest
;
169 successFn(response
, opts
);
171 me
.setValues(response
.result
.data
);
173 // hack: fix ExtJS bug
174 Ext
.Array
.each(me
.query('radiofield'), function(f
) {
175 f
.resetOriginalValue();
178 failure: function(response
, opts
) {
179 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
, function() {
186 createWrapper(options
.success
);
188 Proxmox
.Utils
.API2Request(newopts
);
191 initComponent : function() {
195 throw "no url specified";
198 var items
= Ext
.isArray(me
.items
) ? me
.items
: [ me
.items
];
200 me
.items
= undefined;
202 me
.formPanel
= Ext
.create('Ext.form.Panel', {
204 method
: me
.method
|| 'PUT',
205 trackResetOnLoad
: true,
211 fieldDefaults
: Ext
.apply({}, me
.fieldDefaults
, {
218 var inputPanel
= me
.formPanel
.down('inputpanel');
220 var form
= me
.formPanel
.getForm();
225 submitText
= gettext('Add');
226 } else if (me
.isRemove
) {
227 submitText
= gettext('Remove');
229 submitText
= gettext('Create');
232 submitText
= gettext('OK');
235 var submitBtn
= Ext
.create('Ext.Button', {
236 reference
: 'submitbutton',
238 disabled
: !me
.create
,
239 handler: function() {
244 var resetBtn
= Ext
.create('Ext.Button', {
252 var set_button_status = function() {
253 var valid
= form
.isValid();
254 var dirty
= form
.isDirty();
255 submitBtn
.setDisabled(!valid
|| !(dirty
|| me
.create
));
256 resetBtn
.setDisabled(!dirty
);
259 form
.on('dirtychange', set_button_status
);
260 form
.on('validitychange', set_button_status
);
263 if (me
.fieldDefaults
&& me
.fieldDefaults
.labelWidth
) {
264 colwidth
+= me
.fieldDefaults
.labelWidth
- 100;
267 var twoColumn
= inputPanel
&&
268 (inputPanel
.column1
|| inputPanel
.column2
);
270 if (me
.subject
&& !me
.title
) {
271 me
.title
= Proxmox
.Utils
.dialog_title(me
.subject
, me
.create
, me
.isAdd
);
275 me
.buttons
= [ submitBtn
] ;
277 me
.buttons
= [ submitBtn
, resetBtn
];
280 if (inputPanel
&& inputPanel
.onlineHelp
) {
281 var helpButton
= Ext
.create('PVE.button.Help');
282 me
.buttons
.unshift(helpButton
, '->');
283 Ext
.GlobalEvents
.fireEvent('pveShowHelp', items
[0].onlineHelp
);
288 width
: twoColumn
? colwidth
*2 : colwidth
,
290 items
: [ me
.formPanel
]
295 // always mark invalid fields
296 me
.on('afterlayout', function() {
297 // on touch devices, the isValid function
298 // triggers a layout, which triggers an isValid
300 // to prevent this we disable the layouting here
301 // and enable it afterwards
302 me
.suspendLayout
= true;
304 me
.suspendLayout
= false;