X-Git-Url: http://git.ithinksw.org/extjs.git/blobdiff_plain/530ef4b6c5b943cfa68b779d11cf7de29aa878bf..7a654f8d43fdb43d78b63d90528bed6e86b608cc:/src/widgets/form/CompositeField.js diff --git a/src/widgets/form/CompositeField.js b/src/widgets/form/CompositeField.js deleted file mode 100644 index cac9d8a2..00000000 --- a/src/widgets/form/CompositeField.js +++ /dev/null @@ -1,420 +0,0 @@ -/*! - * Ext JS Library 3.2.1 - * Copyright(c) 2006-2010 Ext JS, Inc. - * licensing@extjs.com - * http://www.extjs.com/license - */ -/** - * @class Ext.form.CompositeField - * @extends Ext.form.Field - * Composite field allowing a number of form Fields to be rendered on the same row. The fields are rendered - * using an hbox layout internally, so all of the normal HBox layout config items are available. Example usage: - *
-{ - xtype: 'compositefield', - labelWidth: 120 - items: [ - { - xtype : 'textfield', - fieldLabel: 'Title', - width : 20 - }, - { - xtype : 'textfield', - fieldLabel: 'First', - flex : 1 - }, - { - xtype : 'textfield', - fieldLabel: 'Last', - flex : 1 - } - ] -} - *- * In the example above the composite's fieldLabel will be set to 'Title, First, Last' as it groups the fieldLabels - * of each of its children. This can be overridden by setting a fieldLabel on the compositefield itself: - *
-{ - xtype: 'compositefield', - fieldLabel: 'Custom label', - items: [...] -} - *- * Any Ext.form.* component can be placed inside a composite field. - */ -Ext.form.CompositeField = Ext.extend(Ext.form.Field, { - - /** - * @property defaultMargins - * @type String - * The margins to apply by default to each field in the composite - */ - defaultMargins: '0 5 0 0', - - /** - * @property skipLastItemMargin - * @type Boolean - * If true, the defaultMargins are not applied to the last item in the composite field set (defaults to true) - */ - skipLastItemMargin: true, - - /** - * @property isComposite - * @type Boolean - * Signifies that this is a Composite field - */ - isComposite: true, - - /** - * @property combineErrors - * @type Boolean - * True to combine errors from the individual fields into a single error message at the CompositeField level (defaults to true) - */ - combineErrors: true, - - //inherit docs - //Builds the composite field label - initComponent: function() { - var labels = [], - items = this.items, - item; - - for (var i=0, j = items.length; i < j; i++) { - item = items[i]; - - labels.push(item.fieldLabel); - - //apply any defaults - Ext.apply(item, this.defaults); - - //apply default margins to each item except the last - if (!(i == j - 1 && this.skipLastItemMargin)) { - Ext.applyIf(item, {margins: this.defaultMargins}); - } - } - - this.fieldLabel = this.fieldLabel || this.buildLabel(labels); - - /** - * @property fieldErrors - * @type Ext.util.MixedCollection - * MixedCollection of current errors on the Composite's subfields. This is used internally to track when - * to show and hide error messages at the Composite level. Listeners are attached to the MixedCollection's - * add, remove and replace events to update the error icon in the UI as errors are added or removed. - */ - this.fieldErrors = new Ext.util.MixedCollection(true, function(item) { - return item.field; - }); - - this.fieldErrors.on({ - scope : this, - add : this.updateInvalidMark, - remove : this.updateInvalidMark, - replace: this.updateInvalidMark - }); - - Ext.form.CompositeField.superclass.initComponent.apply(this, arguments); - }, - - /** - * @private - * Creates an internal container using hbox and renders the fields to it - */ - onRender: function(ct, position) { - if (!this.el) { - /** - * @property innerCt - * @type Ext.Container - * A container configured with hbox layout which is responsible for laying out the subfields - */ - var innerCt = this.innerCt = new Ext.Container({ - layout : 'hbox', - renderTo: ct, - items : this.items, - cls : 'x-form-composite', - defaultMargins: '0 3 0 0' - }); - - this.el = innerCt.getEl(); - - var fields = innerCt.findBy(function(c) { - return c.isFormField; - }, this); - - /** - * @property items - * @type Ext.util.MixedCollection - * Internal collection of all of the subfields in this Composite - */ - this.items = new Ext.util.MixedCollection(); - this.items.addAll(fields); - - //if we're combining subfield errors into a single message, override the markInvalid and clearInvalid - //methods of each subfield and show them at the Composite level instead - if (this.combineErrors) { - this.eachItem(function(field) { - Ext.apply(field, { - markInvalid : this.onFieldMarkInvalid.createDelegate(this, [field], 0), - clearInvalid: this.onFieldClearInvalid.createDelegate(this, [field], 0) - }); - }); - } - - //set the label 'for' to the first item - var l = this.el.parent().parent().child('label', true); - if (l) { - l.setAttribute('for', this.items.items[0].id); - } - } - - Ext.form.CompositeField.superclass.onRender.apply(this, arguments); - }, - - /** - * Called if combineErrors is true and a subfield's markInvalid method is called. - * By default this just adds the subfield's error to the internal fieldErrors MixedCollection - * @param {Ext.form.Field} field The field that was marked invalid - * @param {String} message The error message - */ - onFieldMarkInvalid: function(field, message) { - var name = field.getName(), - error = {field: name, error: message}; - - this.fieldErrors.replace(name, error); - - field.el.addClass(field.invalidClass); - }, - - /** - * Called if combineErrors is true and a subfield's clearInvalid method is called. - * By default this just updates the internal fieldErrors MixedCollection. - * @param {Ext.form.Field} field The field that was marked invalid - */ - onFieldClearInvalid: function(field) { - this.fieldErrors.removeKey(field.getName()); - - field.el.removeClass(field.invalidClass); - }, - - /** - * @private - * Called after a subfield is marked valid or invalid, this checks to see if any of the subfields are - * currently invalid. If any subfields are invalid it builds a combined error message marks the composite - * invalid, otherwise clearInvalid is called - */ - updateInvalidMark: function() { - var ieStrict = Ext.isIE6 && Ext.isStrict; - - if (this.fieldErrors.length == 0) { - this.clearInvalid(); - - //IE6 in strict mode has a layout bug when using 'under' as the error message target. This fixes it - if (ieStrict) { - this.clearInvalid.defer(50, this); - } - } else { - var message = this.buildCombinedErrorMessage(this.fieldErrors.items); - - this.sortErrors(); - this.markInvalid(message); - - //IE6 in strict mode has a layout bug when using 'under' as the error message target. This fixes it - if (ieStrict) { - this.markInvalid(message); - } - } - }, - - /** - * Performs validation checks on each subfield and returns false if any of them fail validation. - * @return {Boolean} False if any subfield failed validation - */ - validateValue: function() { - var valid = true; - - this.eachItem(function(field) { - if (!field.isValid()) valid = false; - }); - - return valid; - }, - - /** - * Takes an object containing error messages for contained fields, returning a combined error - * string (defaults to just placing each item on a new line). This can be overridden to provide - * custom combined error message handling. - * @param {Array} errors Array of errors in format: [{field: 'title', error: 'some error'}] - * @return {String} The combined error message - */ - buildCombinedErrorMessage: function(errors) { - var combined = [], - error; - - for (var i = 0, j = errors.length; i < j; i++) { - error = errors[i]; - - combined.push(String.format("{0}: {1}", error.field, error.error)); - } - - return combined.join("