| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906 | 
							- <!DOCTYPE html>
 
- <html>
 
- <head>
 
-   <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 
-   <title>The source code</title>
 
-   <link href="../resources/prettify/prettify.css" type="text/css" rel="stylesheet" />
 
-   <script type="text/javascript" src="../resources/prettify/prettify.js"></script>
 
-   <style type="text/css">
 
-     .highlight { display: block; background-color: #ddd; }
 
-   </style>
 
-   <script type="text/javascript">
 
-     function highlight() {
 
-       document.getElementById(location.hash.replace(/#/, "")).className = "highlight";
 
-     }
 
-   </script>
 
- </head>
 
- <body onload="prettyPrint(); highlight();">
 
-   <pre class="prettyprint lang-js"><span id='Ext-grid-column-Column'>/**
 
- </span> * This class specifies the definition for a column inside a {@link Ext.grid.Panel}. It encompasses
 
-  * both the grid header configuration as well as displaying data within the grid itself. If the
 
-  * {@link #columns} configuration is specified, this column will become a column group and can
 
-  * contain other columns inside. In general, this class will not be created directly, rather
 
-  * an array of column configurations will be passed to the grid:
 
-  *
 
-  *     @example
 
-  *     Ext.create('Ext.data.Store', {
 
-  *         storeId:'employeeStore',
 
-  *         fields:['firstname', 'lastname', 'seniority', 'dep', 'hired'],
 
-  *         data:[
 
-  *             {firstname:"Michael", lastname:"Scott", seniority:7, dep:"Management", hired:"01/10/2004"},
 
-  *             {firstname:"Dwight", lastname:"Schrute", seniority:2, dep:"Sales", hired:"04/01/2004"},
 
-  *             {firstname:"Jim", lastname:"Halpert", seniority:3, dep:"Sales", hired:"02/22/2006"},
 
-  *             {firstname:"Kevin", lastname:"Malone", seniority:4, dep:"Accounting", hired:"06/10/2007"},
 
-  *             {firstname:"Angela", lastname:"Martin", seniority:5, dep:"Accounting", hired:"10/21/2008"}
 
-  *         ]
 
-  *     });
 
-  *
 
-  *     Ext.create('Ext.grid.Panel', {
 
-  *         title: 'Column Demo',
 
-  *         store: Ext.data.StoreManager.lookup('employeeStore'),
 
-  *         columns: [
 
-  *             {text: 'First Name',  dataIndex:'firstname'},
 
-  *             {text: 'Last Name',  dataIndex:'lastname'},
 
-  *             {text: 'Hired Month',  dataIndex:'hired', xtype:'datecolumn', format:'M'},
 
-  *             {text: 'Department (Yrs)', xtype:'templatecolumn', tpl:'{dep} ({seniority})'}
 
-  *         ],
 
-  *         width: 400,
 
-  *         forceFit: true,
 
-  *         renderTo: Ext.getBody()
 
-  *     });
 
-  *
 
-  * # Convenience Subclasses
 
-  *
 
-  * There are several column subclasses that provide default rendering for various data types
 
-  *
 
-  *  - {@link Ext.grid.column.Action}: Renders icons that can respond to click events inline
 
-  *  - {@link Ext.grid.column.Boolean}: Renders for boolean values
 
-  *  - {@link Ext.grid.column.Date}: Renders for date values
 
-  *  - {@link Ext.grid.column.Number}: Renders for numeric values
 
-  *  - {@link Ext.grid.column.Template}: Renders a value using an {@link Ext.XTemplate} using the record data
 
-  *
 
-  * # Setting Sizes
 
-  *
 
-  * The columns are laid out by a {@link Ext.layout.container.HBox} layout, so a column can either
 
-  * be given an explicit width value or a flex configuration. If no width is specified the grid will
 
-  * automatically the size the column to 100px. For column groups, the size is calculated by measuring
 
-  * the width of the child columns, so a width option should not be specified in that case.
 
-  *
 
-  * # Header Options
 
-  *
 
-  *  - {@link #text}: Sets the header text for the column
 
-  *  - {@link #sortable}: Specifies whether the column can be sorted by clicking the header or using the column menu
 
-  *  - {@link #hideable}: Specifies whether the column can be hidden using the column menu
 
-  *  - {@link #menuDisabled}: Disables the column header menu
 
-  *  - {@link #cfg-draggable}: Specifies whether the column header can be reordered by dragging
 
-  *  - {@link #groupable}: Specifies whether the grid can be grouped by the column dataIndex. See also {@link Ext.grid.feature.Grouping}
 
-  *
 
-  * # Data Options
 
-  *
 
-  *  - {@link #dataIndex}: The dataIndex is the field in the underlying {@link Ext.data.Store} to use as the value for the column.
 
-  *  - {@link #renderer}: Allows the underlying store value to be transformed before being displayed in the grid
 
-  */
 
- Ext.define('Ext.grid.column.Column', {
 
-     extend: 'Ext.grid.header.Container',
 
-     alias: 'widget.gridcolumn',
 
-     requires: ['Ext.util.KeyNav', 'Ext.grid.ColumnComponentLayout', 'Ext.grid.ColumnLayout'],
 
-     alternateClassName: 'Ext.grid.Column',
 
-     baseCls: Ext.baseCSSPrefix + 'column-header ' + Ext.baseCSSPrefix + 'unselectable',
 
-     // Not the standard, automatically applied overCls because we must filter out overs of child headers.
 
-     hoverCls: Ext.baseCSSPrefix + 'column-header-over',
 
-     handleWidth: 5,
 
-     sortState: null,
 
-     possibleSortStates: ['ASC', 'DESC'],
 
-     childEls: [
 
-         'titleEl', 'triggerEl', 'textEl'
 
-     ],
 
-     renderTpl:
 
-         '<div id="{id}-titleEl" {tipMarkup}class="' + Ext.baseCSSPrefix + 'column-header-inner">' +
 
-             '<span id="{id}-textEl" class="' + Ext.baseCSSPrefix + 'column-header-text">' +
 
-                 '{text}' +
 
-             '</span>' +
 
-             '<tpl if="!menuDisabled">'+
 
-                 '<div id="{id}-triggerEl" class="' + Ext.baseCSSPrefix + 'column-header-trigger"></div>'+
 
-             '</tpl>' +
 
-         '</div>' +
 
-         '{%this.renderContainer(out,values)%}',
 
- <span id='Ext-grid-column-Column-cfg-columns'>    /**
 
- </span>     * @cfg {Object[]} columns
 
-      * An optional array of sub-column definitions. This column becomes a group, and houses the columns defined in the
 
-      * `columns` config.
 
-      *
 
-      * Group columns may not be sortable. But they may be hideable and moveable. And you may move headers into and out
 
-      * of a group. Note that if all sub columns are dragged out of a group, the group is destroyed.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-stateId'>    /**
 
- </span>     * @override
 
-      * @cfg {String} stateId
 
-      * An identifier which identifies this column uniquely within the owning grid's {@link #stateful state}.
 
-      * 
 
-      * This does not have to be *globally* unique. A column's state is not saved standalone. It is encapsulated within
 
-      * the owning grid's state.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-dataIndex'>    /**
 
- </span>     * @cfg {String} dataIndex
 
-      * The name of the field in the grid's {@link Ext.data.Store}'s {@link Ext.data.Model} definition from
 
-      * which to draw the column's value. **Required.**
 
-      */
 
-     dataIndex: null,
 
- <span id='Ext-grid-column-Column-cfg-text'>    /**
 
- </span>     * @cfg {String} text
 
-      * The header text to be used as innerHTML (html tags are accepted) to display in the Grid.
 
-      * **Note**: to have a clickable header with no text displayed you can use the default of `&#160;` aka `&nbsp;`.
 
-      */
 
-     text: '&#160;',
 
- <span id='Ext-grid-column-Column-cfg-header'>    /**
 
- </span>     * @cfg {String} header
 
-      * The header text.
 
-      * @deprecated 4.0 Use {@link #text} instead.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-menuText'>    /**
 
- </span>     * @cfg {String} menuText
 
-      * The text to render in the column visibility selection menu for this column.  If not
 
-      * specified, will default to the text value.
 
-      */
 
-     menuText: null,
 
- <span id='Ext-grid-column-Column-cfg-emptyCellText'>    /**
 
- </span>     * @cfg {String} [emptyCellText=undefined]
 
-      * The text to diplay in empty cells (cells with a value of `undefined`, `null`, or `''`).
 
-      *
 
-      * Defaults to `&#160;` aka `&nbsp;`.
 
-      */
 
-     emptyCellText: '&#160;',
 
- <span id='Ext-grid-column-Column-cfg-sortable'>    /**
 
- </span>     * @cfg {Boolean} sortable
 
-      * False to disable sorting of this column. Whether local/remote sorting is used is specified in
 
-      * `{@link Ext.data.Store#remoteSort}`.
 
-      */
 
-     sortable: true,
 
- <span id='Ext-grid-column-Column-cfg-groupable'>    /**
 
- </span>     * @cfg {Boolean} groupable
 
-      * If the grid uses a {@link Ext.grid.feature.Grouping}, this option may be used to disable the header menu
 
-      * item to group by the column selected. By default, the header menu group option is enabled. Set to false to
 
-      * disable (but still show) the group option in the header menu for the column.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-fixed'>    /**
 
- </span>     * @cfg {Boolean} fixed
 
-      * True to prevent the column from being resizable.
 
-      * @deprecated 4.0 Use {@link #resizable} instead.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-locked'>    /**
 
- </span>     * @cfg {Boolean} [locked=false]
 
-      * True to lock this column in place.  Implicitly enables locking on the grid.
 
-      * See also {@link Ext.grid.Panel#enableLocking}.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-resizable'>    /**
 
- </span>     * @cfg {Boolean} resizable
 
-      * False to prevent the column from being resizable.
 
-      */
 
-     resizable: true,
 
- <span id='Ext-grid-column-Column-cfg-hideable'>    /**
 
- </span>     * @cfg {Boolean} hideable
 
-      * False to prevent the user from hiding this column.
 
-      */
 
-     hideable: true,
 
- <span id='Ext-grid-column-Column-cfg-menuDisabled'>    /**
 
- </span>     * @cfg {Boolean} menuDisabled
 
-      * True to disable the column header menu containing sort/hide options.
 
-      */
 
-     menuDisabled: false,
 
- <span id='Ext-grid-column-Column-cfg-renderer'>    /**
 
- </span>     * @cfg {Function/String} renderer
 
-      * A renderer is an 'interceptor' method which can be used to transform data (value, appearance, etc.)
 
-      * before it is rendered. Example:
 
-      *
 
-      *     {
 
-      *         renderer: function(value){
 
-      *             if (value === 1) {
 
-      *                 return '1 person';
 
-      *             }
 
-      *             return value + ' people';
 
-      *         }
 
-      *     }
 
-      *
 
-      * Additionally a string naming an {@link Ext.util.Format} method can be passed:
 
-      *
 
-      *     {
 
-      *         renderer: 'uppercase'
 
-      *     }
 
-      *
 
-      * @cfg {Object} renderer.value The data value for the current cell
 
-      * @cfg {Object} renderer.metaData A collection of metadata about the current cell; can be used or modified
 
-      * by the renderer. Recognized properties are: tdCls, tdAttr, and style.
 
-      * @cfg {Ext.data.Model} renderer.record The record for the current row
 
-      * @cfg {Number} renderer.rowIndex The index of the current row
 
-      * @cfg {Number} renderer.colIndex The index of the current column
 
-      * @cfg {Ext.data.Store} renderer.store The data store
 
-      * @cfg {Ext.view.View} renderer.view The current view
 
-      * @cfg {String} renderer.return The HTML string to be rendered.
 
-      */
 
-     renderer: false,
 
- <span id='Ext-grid-column-Column-cfg-scope'>    /**
 
- </span>     * @cfg {Object} scope
 
-      * The scope to use when calling the {@link #renderer} function.
 
-      */
 
-     
 
- <span id='Ext-grid-column-Column-method-defaultRenderer'>    /**
 
- </span>     * @method defaultRenderer
 
-      * When defined this will take precedence over the {@link Ext.grid.column.Column#renderer renderer} config.
 
-      * This is meant to be defined in subclasses that wish to supply their own renderer.
 
-      * @protected
 
-      * @template
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-editRenderer'>    /**
 
- </span>     * @cfg {Function} editRenderer
 
-      * A renderer to be used in conjunction with {@link Ext.grid.plugin.RowEditing RowEditing}. This renderer is used to
 
-      * display a custom value for non-editable fields.
 
-      */
 
-     editRenderer: false,
 
- <span id='Ext-grid-column-Column-cfg-align'>    /**
 
- </span>     * @cfg {String} align
 
-      * Sets the alignment of the header and rendered columns.
 
-      * Possible values are: `'left'`, `'center'`, and `'right'`.
 
-      */
 
-     align: 'left',
 
- <span id='Ext-grid-column-Column-cfg-draggable'>    /**
 
- </span>     * @cfg {Boolean} draggable
 
-      * False to disable drag-drop reordering of this column.
 
-      */
 
-     draggable: true,
 
-     
 
- <span id='Ext-grid-column-Column-cfg-tooltip'>    /**
 
- </span>     * @cfg {String} tooltip
 
-      * A tooltip to display for this column header
 
-      */
 
-     
 
- <span id='Ext-grid-column-Column-cfg-tooltipType'>    /**
 
- </span>     * @cfg {String} [tooltipType="qtip"]
 
-      * The type of {@link #tooltip} to use. Either 'qtip' for QuickTips or 'title' for title attribute.
 
-      */
 
-     tooltipType: 'qtip',
 
-     // Header does not use the typical ComponentDraggable class and therefore we
 
-     // override this with an emptyFn. It is controlled at the HeaderDragZone.
 
-     initDraggable: Ext.emptyFn,
 
- <span id='Ext-grid-column-Column-cfg-tdCls'>    /**
 
- </span>     * @cfg {String} tdCls
 
-      * A CSS class names to apply to the table cells for this column.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-editor'>    /**
 
- </span>     * @cfg {Object/String} editor
 
-      * An optional xtype or config object for a {@link Ext.form.field.Field Field} to use for editing.
 
-      * Only applicable if the grid is using an {@link Ext.grid.plugin.Editing Editing} plugin.
 
-      */
 
- <span id='Ext-grid-column-Column-cfg-field'>    /**
 
- </span>     * @cfg {Object/String} field
 
-      * Alias for {@link #editor}.
 
-      * @deprecated 4.0.5 Use {@link #editor} instead.
 
-      */
 
- <span id='Ext-grid-column-Column-property-triggerEl'>    /**
 
- </span>     * @property {Ext.Element} triggerEl
 
-      * Element that acts as button for column header dropdown menu.
 
-      */
 
- <span id='Ext-grid-column-Column-property-textEl'>    /**
 
- </span>     * @property {Ext.Element} textEl
 
-      * Element that contains the text in column header.
 
-      */
 
- <span id='Ext-grid-column-Column-property-isHeader'>    /**
 
- </span>     * @property {Boolean} isHeader
 
-      * Set in this class to identify, at runtime, instances which are not instances of the
 
-      * HeaderContainer base class, but are in fact, the subclass: Header.
 
-      */
 
-     isHeader: true,
 
-     componentLayout: 'columncomponent',
 
-     
 
-     // We need to override the default component resizable behaviour here
 
-     initResizable: Ext.emptyFn,
 
-     initComponent: function() {
 
-         var me = this,
 
-             renderer;
 
-         if (Ext.isDefined(me.header)) {
 
-             me.text = me.header;
 
-             delete me.header;
 
-         }
 
-         if (!me.triStateSort) {
 
-             me.possibleSortStates.length = 2;
 
-         }
 
-         // A group header; It contains items which are themselves Headers
 
-         if (Ext.isDefined(me.columns)) {
 
-             me.isGroupHeader = true;
 
-             //<debug>
 
-             if (me.dataIndex) {
 
-                 Ext.Error.raise('Ext.grid.column.Column: Group header may not accept a dataIndex');
 
-             }
 
-             if ((me.width && me.width !== Ext.grid.header.Container.prototype.defaultWidth) || me.flex) {
 
-                 Ext.Error.raise('Ext.grid.column.Column: Group header does not support setting explicit widths or flexs. The group header width is calculated by the sum of its children.');
 
-             }
 
-             //</debug>
 
-             // The headers become child items
 
-             me.items = me.columns;
 
-             delete me.columns;
 
-             delete me.flex;
 
-             delete me.width;
 
-             me.cls = (me.cls||'') + ' ' + Ext.baseCSSPrefix + 'group-header';
 
-             me.sortable = false;
 
-             me.resizable = false;
 
-             me.align = 'center';
 
-         } else {
 
-             // If we are not a group header, then this is not to be used as a container, and must not have a container layout executed, and it must
 
-             // acquire layout height from DOM content, not from child items.
 
-             me.isContainer = false;
 
-             // Flexed Headers need to have a minWidth defined so that they can never be squeezed out of existence by the
 
-             // HeaderContainer's specialized Box layout, the ColumnLayout. The ColumnLayout's overridden calculateChildboxes
 
-             // method extends the available layout space to accommodate the "desiredWidth" of all the columns.
 
-             if (me.flex) {
 
-                 me.minWidth = me.minWidth || Ext.grid.plugin.HeaderResizer.prototype.minColWidth;
 
-             }
 
-         }
 
-         me.addCls(Ext.baseCSSPrefix + 'column-header-align-' + me.align);
 
-         
 
-         renderer = me.renderer;
 
-         if (renderer) {
 
-             // When specifying a renderer as a string, it always resolves
 
-             // to Ext.util.Format
 
-             if (typeof renderer == 'string') {
 
-                 me.renderer = Ext.util.Format[renderer];
 
-             }
 
-             me.hasCustomRenderer = true;
 
-         } else if (me.defaultRenderer) {
 
-             me.scope = me;
 
-             me.renderer = me.defaultRenderer;
 
-         }
 
-         // Initialize as a HeaderContainer
 
-         me.callParent(arguments);
 
-         me.on({
 
-             element:  'el',
 
-             click:    me.onElClick,
 
-             dblclick: me.onElDblClick,
 
-             scope:    me
 
-         });
 
-         me.on({
 
-             element:    'titleEl',
 
-             mouseenter: me.onTitleMouseOver,
 
-             mouseleave: me.onTitleMouseOut,
 
-             scope:      me
 
-         });
 
-     },
 
-     onAdd: function(childHeader) {
 
-         childHeader.isSubHeader = true;
 
-         childHeader.addCls(Ext.baseCSSPrefix + 'group-sub-header');
 
-         this.callParent(arguments);
 
-     },
 
-     onRemove: function(childHeader) {
 
-         childHeader.isSubHeader = false;
 
-         childHeader.removeCls(Ext.baseCSSPrefix + 'group-sub-header');
 
-         this.callParent(arguments);
 
-     },
 
-     initRenderData: function() {
 
-         var me = this,
 
-             tipMarkup = '',
 
-             tip = me.tooltip,
 
-             attr = me.tooltipType == 'qtip' ? 'data-qtip' : 'title';
 
-             
 
-         if (!Ext.isEmpty(tip)) {
 
-             tipMarkup = attr + '="' + tip + '" ';
 
-         }
 
-             
 
-         return Ext.applyIf(me.callParent(arguments), {
 
-             text: me.text,
 
-             menuDisabled: me.menuDisabled,
 
-             tipMarkup: tipMarkup
 
-         });
 
-     },
 
-     applyColumnState: function (state) {
 
-         var me = this,
 
-             defined = Ext.isDefined;
 
-             
 
-         // apply any columns
 
-         me.applyColumnsState(state.columns);
 
-         // Only state properties which were saved should be restored.
 
-         // (Only user-changed properties were saved by getState)
 
-         if (defined(state.hidden)) {
 
-             me.hidden = state.hidden;
 
-         }
 
-         if (defined(state.locked)) {
 
-             me.locked = state.locked;
 
-         }
 
-         if (defined(state.sortable)) {
 
-             me.sortable = state.sortable;
 
-         }
 
-         if (defined(state.width)) {
 
-             delete me.flex;
 
-             me.width = state.width;
 
-         } else if (defined(state.flex)) {
 
-             delete me.width;
 
-             me.flex = state.flex;
 
-         }
 
-     },
 
-     getColumnState: function () {
 
-         var me = this,
 
-             items = me.items.items,
 
-             // Check for the existence of items, since column.Action won't have them
 
-             iLen = items ? items.length : 0,
 
-             i,
 
-             columns = [],
 
-             state = {
 
-                 id: me.getStateId()
 
-             };
 
-         me.savePropsToState(['hidden', 'sortable', 'locked', 'flex', 'width'], state);
 
-         
 
-         if (me.isGroupHeader) {
 
-             for (i = 0; i < iLen; i++) {
 
-                 columns.push(items[i].getColumnState());
 
-             }
 
-             if (columns.length) {
 
-                 state.columns = columns;
 
-             }
 
-         } else if (me.isSubHeader && me.ownerCt.hidden) {
 
-             // don't set hidden on the children so they can auto height
 
-             delete me.hidden;
 
-         }
 
-         if ('width' in state) {
 
-             delete state.flex; // width wins
 
-         }
 
-         return state;
 
-     },
 
-     getStateId: function () {
 
-         return this.stateId || this.headerId;
 
-     },
 
- <span id='Ext-grid-column-Column-method-setText'>    /**
 
- </span>     * Sets the header text for this Column.
 
-      * @param {String} text The header to display on this Column.
 
-      */
 
-     setText: function(text) {
 
-         this.text = text;
 
-         if (this.rendered) {
 
-             this.textEl.update(text);
 
-         }
 
-     },
 
-     // Find the topmost HeaderContainer: An ancestor which is NOT a Header.
 
-     // Group Headers are themselves HeaderContainers
 
-     getOwnerHeaderCt: function() {
 
-         return this.up(':not([isHeader])');
 
-     },
 
- <span id='Ext-grid-column-Column-method-getIndex'>    /**
 
- </span>     * Returns the index of this column only if this column is a base level Column. If it
 
-      * is a group column, it returns `false`.
 
-      * @return {Number}
 
-      */
 
-     getIndex: function() {
 
-         return this.isGroupColumn ? false : this.getOwnerHeaderCt().getHeaderIndex(this);
 
-     },
 
-     
 
- <span id='Ext-grid-column-Column-method-getVisibleIndex'>    /**
 
- </span>     * Returns the index of this column in the list of *visible* columns only if this column is a base level Column. If it
 
-      * is a group column, it returns `false`.
 
-      * @return {Number}
 
-      */
 
-     getVisibleIndex: function() {
 
-         return this.isGroupColumn ? false : Ext.Array.indexOf(this.getOwnerHeaderCt().getVisibleGridColumns(), this);
 
-     },
 
-     beforeRender: function() {
 
-         var me = this,
 
-             grid = me.up('tablepanel');
 
-         me.callParent();
 
-         // Disable the menu if there's nothing to show in the menu, ie:
 
-         // Column cannot be sorted, grouped or locked, and there are no grid columns which may be hidden
 
-         if (grid && (!me.sortable || grid.sortableColumns === false) && !me.groupable &&
 
-                      !me.lockable && (grid.enableColumnHide === false ||
 
-                      !me.getOwnerHeaderCt().getHideableColumns().length)) {
 
-             me.menuDisabled = true;
 
-         }
 
-     },
 
-     afterRender: function() {
 
-         var me = this,
 
-             el = me.el;
 
-         me.callParent(arguments);
 
-         if (me.overCls) {
 
-             el.addClsOnOver(me.overCls);
 
-         }
 
-         // BrowserBug: Ie8 Strict Mode, this will break the focus for this browser,
 
-         // must be fixed when focus management will be implemented.
 
-         if (!Ext.isIE8 || !Ext.isStrict) {
 
-             me.mon(me.getFocusEl(), {
 
-                 focus: me.onTitleMouseOver,
 
-                 blur: me.onTitleMouseOut,
 
-                 scope: me
 
-             });
 
-         }
 
-         me.keyNav = new Ext.util.KeyNav(el, {
 
-             enter: me.onEnterKey,
 
-             down: me.onDownKey,
 
-             scope: me
 
-         });
 
-     },
 
-     // private
 
-     // Inform the header container about the resize
 
-     afterComponentLayout: function(width, height, oldWidth, oldHeight) {
 
-         var me = this,
 
-             ownerHeaderCt = me.getOwnerHeaderCt();
 
-         me.callParent(arguments);
 
-         if (ownerHeaderCt && (oldWidth != null || me.flex) && width !== oldWidth) {
 
-             ownerHeaderCt.onHeaderResize(me, width, true);
 
-         }
 
-     },
 
-     // private
 
-     // After the container has laid out and stretched, it calls this to correctly pad the inner to center the text vertically
 
-     // Total available header height must be passed to enable padding for inner elements to be calculated.
 
-     setPadding: function(headerHeight) {
 
-         var me = this,
 
-             lineHeight = parseInt(me.textEl.getStyle('line-height'), 10),
 
-             textHeight = me.textEl.dom.offsetHeight,
 
-             titleEl = me.titleEl,
 
-             availableHeight = headerHeight - me.el.getBorderWidth('tb'),
 
-             titleElHeight;
 
-         // Top title containing element must stretch to match height of sibling group headers
 
-         if (!me.isGroupHeader) {
 
-             if (titleEl.getHeight() < availableHeight) {
 
-                 titleEl.setHeight(availableHeight);
 
-                 // the column el's parent element (the 'innerCt') may have an incorrect height
 
-                 // at this point because it may have been shrink wrapped prior to the titleEl's
 
-                 // height being set, so we need to sync it up here
 
-                 me.ownerCt.layout.innerCt.setHeight(headerHeight);
 
-             }
 
-         }
 
-         titleElHeight = titleEl.getViewSize().height;
 
-         // Vertically center the header text in potentially vertically stretched header
 
-         if (textHeight) {
 
-             if(lineHeight) {
 
-                 textHeight = Math.ceil(textHeight / lineHeight) * lineHeight;
 
-             }
 
-             titleEl.setStyle({
 
-                 paddingTop: Math.floor(Math.max(((titleElHeight - textHeight) / 2), 0)) + 'px'
 
-             });
 
-         }
 
-         // Only IE needs this
 
-         if (Ext.isIE && me.triggerEl) {
 
-             me.triggerEl.setHeight(titleElHeight);
 
-         }
 
-     },
 
-     onDestroy: function() {
 
-         var me = this;
 
-         // force destroy on the textEl, IE reports a leak
 
-         Ext.destroy(me.textEl, me.keyNav, me.field);
 
-         delete me.keyNav;
 
-         me.callParent(arguments);
 
-     },
 
-     onTitleMouseOver: function() {
 
-         this.titleEl.addCls(this.hoverCls);
 
-     },
 
-     onTitleMouseOut: function() {
 
-         this.titleEl.removeCls(this.hoverCls);
 
-     },
 
-     onDownKey: function(e) {
 
-         if (this.triggerEl) {
 
-             this.onElClick(e, this.triggerEl.dom || this.el.dom);
 
-         }
 
-     },
 
-     onEnterKey: function(e) {
 
-         this.onElClick(e, this.el.dom);
 
-     },
 
- <span id='Ext-grid-column-Column-method-onElDblClick'>    /**
 
- </span>     * @private
 
-      * Double click
 
-      * @param e
 
-      * @param t
 
-      */
 
-     onElDblClick: function(e, t) {
 
-         var me = this,
 
-             ownerCt = me.ownerCt;
 
-         if (ownerCt && Ext.Array.indexOf(ownerCt.items, me) !== 0 && me.isOnLeftEdge(e) ) {
 
-             ownerCt.expandToFit(me.previousSibling('gridcolumn'));
 
-         }
 
-     },
 
-     onElClick: function(e, t) {
 
-         // The grid's docked HeaderContainer.
 
-         var me = this,
 
-             ownerHeaderCt = me.getOwnerHeaderCt();
 
-         if (ownerHeaderCt && !ownerHeaderCt.ddLock) {
 
-             // Firefox doesn't check the current target in a within check.
 
-             // Therefore we check the target directly and then within (ancestors)
 
-             if (me.triggerEl && (e.target === me.triggerEl.dom || t === me.triggerEl.dom || e.within(me.triggerEl))) {
 
-                 ownerHeaderCt.onHeaderTriggerClick(me, e, t);
 
-             // if its not on the left hand edge, sort
 
-             } else if (e.getKey() || (!me.isOnLeftEdge(e) && !me.isOnRightEdge(e))) {
 
-                 me.toggleSortState();
 
-                 ownerHeaderCt.onHeaderClick(me, e, t);
 
-             }
 
-         }
 
-     },
 
- <span id='Ext-grid-column-Column-method-processEvent'>    /**
 
- </span>     * @private
 
-      * Process UI events from the view. The owning TablePanel calls this method, relaying events from the TableView
 
-      * @param {String} type Event type, eg 'click'
 
-      * @param {Ext.view.Table} view TableView Component
 
-      * @param {HTMLElement} cell Cell HtmlElement the event took place within
 
-      * @param {Number} recordIndex Index of the associated Store Model (-1 if none)
 
-      * @param {Number} cellIndex Cell index within the row
 
-      * @param {Ext.EventObject} e Original event
 
-      */
 
-     processEvent: function(type, view, cell, recordIndex, cellIndex, e) {
 
-         return this.fireEvent.apply(this, arguments);
 
-     },
 
-     toggleSortState: function() {
 
-         var me = this,
 
-             idx,
 
-             nextIdx;
 
-         if (me.sortable) {
 
-             idx = Ext.Array.indexOf(me.possibleSortStates, me.sortState);
 
-             nextIdx = (idx + 1) % me.possibleSortStates.length;
 
-             me.setSortState(me.possibleSortStates[nextIdx]);
 
-         }
 
-     },
 
-     doSort: function(state) {
 
-         var ds = this.up('tablepanel').store;
 
-         ds.sort({
 
-             property: this.getSortParam(),
 
-             direction: state
 
-         });
 
-     },
 
- <span id='Ext-grid-column-Column-method-getSortParam'>    /**
 
- </span>     * Returns the parameter to sort upon when sorting this header. By default this returns the dataIndex and will not
 
-      * need to be overriden in most cases.
 
-      * @return {String}
 
-      */
 
-     getSortParam: function() {
 
-         return this.dataIndex;
 
-     },
 
-     //setSortState: function(state, updateUI) {
 
-     //setSortState: function(state, doSort) {
 
-     setSortState: function(state, skipClear, initial) {
 
-         var me = this,
 
-             colSortClsPrefix = Ext.baseCSSPrefix + 'column-header-sort-',
 
-             ascCls = colSortClsPrefix + 'ASC',
 
-             descCls = colSortClsPrefix + 'DESC',
 
-             nullCls = colSortClsPrefix + 'null',
 
-             ownerHeaderCt = me.getOwnerHeaderCt(),
 
-             oldSortState = me.sortState;
 
-         if (oldSortState !== state && me.getSortParam()) {
 
-             me.addCls(colSortClsPrefix + state);
 
-             // don't trigger a sort on the first time, we just want to update the UI
 
-             if (state && !initial) {
 
-                 me.doSort(state);
 
-             }
 
-             switch (state) {
 
-                 case 'DESC':
 
-                     me.removeCls([ascCls, nullCls]);
 
-                     break;
 
-                 case 'ASC':
 
-                     me.removeCls([descCls, nullCls]);
 
-                     break;
 
-                 case null:
 
-                     me.removeCls([ascCls, descCls]);
 
-                     break;
 
-             }
 
-             if (ownerHeaderCt && !me.triStateSort && !skipClear) {
 
-                 ownerHeaderCt.clearOtherSortStates(me);
 
-             }
 
-             me.sortState = state;
 
-             // we only want to fire the event if we have a null state when using triStateSort
 
-             if (me.triStateSort || state != null) {
 
-                 ownerHeaderCt.fireEvent('sortchange', ownerHeaderCt, me, state);
 
-             }
 
-         }
 
-     },
 
-     hide: function(fromOwner) {
 
-         var me = this,
 
-             ownerHeaderCt = me.getOwnerHeaderCt(),
 
-             owner = me.ownerCt,
 
-             ownerIsGroup = owner.isGroupHeader,
 
-             item, items, len, i;
 
-         // owner is a group, hide call didn't come from the owner
 
-         if (ownerIsGroup && !fromOwner) {
 
-             items = owner.query('>:not([hidden])');
 
-             // only have one item that isn't hidden, this is it.
 
-             if (items.length === 1 && items[0] == me) {
 
-                 me.ownerCt.hide();
 
-                 return;
 
-             }
 
-         }
 
-         Ext.suspendLayouts();
 
-         if (me.isGroupHeader) {
 
-             items = me.items.items;
 
-             for (i = 0, len = items.length; i < len; i++) {
 
-                 item = items[i];
 
-                 if (!item.hidden) {
 
-                     item.hide(true);
 
-                 }
 
-             }
 
-         }
 
-         me.callParent();
 
-         // Notify owning HeaderContainer
 
-         ownerHeaderCt.onHeaderHide(me);
 
-         Ext.resumeLayouts(true);
 
-     },
 
-     show: function(fromOwner, fromChild) {
 
-         var me = this,
 
-             ownerCt = me.ownerCt,
 
-             items,
 
-             len, i,
 
-             item;
 
-         Ext.suspendLayouts();
 
-         // If a sub header, ensure that the group header is visible
 
-         if (me.isSubHeader && ownerCt.hidden) {
 
-             ownerCt.show(false, true);
 
-         }
 
-         me.callParent(arguments);
 
-         // If we've just shown a group with all its sub headers hidden, then show all its sub headers
 
-         if (me.isGroupHeader && fromChild !== true && !me.query(':not([hidden])').length) {
 
-             items = me.query('>*');
 
-             for (i = 0, len = items.length; i < len; i++) {
 
-                 item = items[i];
 
-                 if (item.hidden) {
 
-                     item.show(true);
 
-                 }
 
-             }
 
-         }
 
-         Ext.resumeLayouts(true);
 
-         // Notify owning HeaderContainer AFTER layout has been flushed so that header and headerCt widths are all correct
 
-         ownerCt = me.getOwnerHeaderCt();
 
-         if (ownerCt) {
 
-             ownerCt.onHeaderShow(me);
 
-         }
 
-     },
 
-     getDesiredWidth: function() {
 
-         var me = this;
 
-         if (me.rendered && me.componentLayout && me.componentLayout.lastComponentSize) {
 
-             // headers always have either a width or a flex
 
-             // because HeaderContainer sets a defaults width
 
-             // therefore we can ignore the natural width
 
-             // we use the componentLayout's tracked width so that
 
-             // we can calculate the desired width when rendered
 
-             // but not visible because its being obscured by a layout
 
-             return me.componentLayout.lastComponentSize.width;
 
-         // Flexed but yet to be rendered this could be the case
 
-         // where a HeaderContainer and Headers are simply used as data
 
-         // structures and not rendered.
 
-         }
 
-         else if (me.flex) {
 
-             // this is going to be wrong, the defaultWidth
 
-             return me.width;
 
-         }
 
-         else {
 
-             return me.width;
 
-         }
 
-     },
 
-     getCellSelector: function() {
 
-         return '.' + Ext.baseCSSPrefix + 'grid-cell-' + this.getItemId();
 
-     },
 
-     getCellInnerSelector: function() {
 
-         return this.getCellSelector() + ' .' + Ext.baseCSSPrefix + 'grid-cell-inner';
 
-     },
 
-     isOnLeftEdge: function(e) {
 
-         return (e.getXY()[0] - this.el.getLeft() <= this.handleWidth);
 
-     },
 
-     isOnRightEdge: function(e) {
 
-         return (this.el.getRight() - e.getXY()[0] <= this.handleWidth);
 
-     }
 
-     // intentionally omit getEditor and setEditor definitions bc we applyIf into columns
 
-     // when the editing plugin is injected
 
- <span id='Ext-grid-column-Column-method-getEditor'>    /**
 
- </span>     * @method getEditor
 
-      * Retrieves the editing field for editing associated with this header. Returns false if there is no field
 
-      * associated with the Header the method will return false. If the field has not been instantiated it will be
 
-      * created. Note: These methods only has an implementation if a Editing plugin has been enabled on the grid.
 
-      * @param {Object} record The {@link Ext.data.Model Model} instance being edited.
 
-      * @param {Object} defaultField An object representing a default field to be created
 
-      * @return {Ext.form.field.Field} field
 
-      */
 
- <span id='Ext-grid-column-Column-method-setEditor'>    /**
 
- </span>     * @method setEditor
 
-      * Sets the form field to be used for editing. Note: This method only has an implementation if an Editing plugin has
 
-      * been enabled on the grid.
 
-      * @param {Object} field An object representing a field to be created. If no xtype is specified a 'textfield' is
 
-      * assumed.
 
-      */
 
- });
 
- </pre>
 
- </body>
 
- </html>
 
 
  |