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>
|