/** * Provides a container for arranging a group of related Buttons in a tabular manner. * * @example * Ext.create('Ext.panel.Panel', { * title: 'Panel with ButtonGroup', * width: 300, * height:200, * renderTo: document.body, * bodyPadding: 10, * html: 'HTML Panel Content', * tbar: [{ * xtype: 'buttongroup', * columns: 3, * title: 'Clipboard', * items: [{ * text: 'Paste', * scale: 'large', * rowspan: 3, * iconCls: 'add', * iconAlign: 'top', * cls: 'btn-as-arrow' * },{ * xtype:'splitbutton', * text: 'Menu Button', * scale: 'large', * rowspan: 3, * iconCls: 'add', * iconAlign: 'top', * arrowAlign:'bottom', * menu: [{ text: 'Menu Item 1' }] * },{ * xtype:'splitbutton', text: 'Cut', iconCls: 'add16', menu: [{text: 'Cut Menu Item'}] * },{ * text: 'Copy', iconCls: 'add16' * },{ * text: 'Format', iconCls: 'add16' * }] * }] * }); * */Ext.define('Ext.container.ButtonGroup', { extend: 'Ext.panel.Panel', alias: 'widget.buttongroup', alternateClassName: 'Ext.ButtonGroup', requires: [ 'Ext.layout.container.Table' ], /** * @cfg {Number} columns * The `columns` configuration property passed to the {@link #layout configured layout manager}. * See {@link Ext.layout.container.Table#columns}. */ /** * @cfg baseCls * @inheritdoc */ baseCls: Ext.baseCSSPrefix + 'btn-group', /** * @cfg layout * @inheritdoc */ layout: { type: 'table' }, /** * @cfg defaultType * @inheritdoc */ defaultType: 'button', /** * @cfg frame * @inheritdoc */ frame: true, /** * @cfg {String} defaultButtonUI * A default {@link Ext.Component#ui ui} to use for {@link Ext.button.Button Button} items */ /** * @cfg frameHeader * @inheritdoc */ frameHeader: false, /** * @cfg {String} titleAlign * The alignment of the title text within the available space between the icon and the tools. */ titleAlign: 'center', noTitleCls: 'notitle', bodyAriaRole: 'toolbar', /** * @property focusableContainerEl * @inheritdoc */ focusableContainerEl: 'body', /** * @cfg focusableContainer * @inheritdoc */ focusableContainer: true, initComponent: function() { // Copy the component's columns config to the layout if specified var me = this, cols = me.columns; if (cols) { me.layout = Ext.apply({columns: cols}, me.layout); } if (!me.title) { me.addClsWithUI(me.noTitleCls); } me.callParent(); }, /** * @private */ onBeforeAdd: function(component) { if (component.isButton) { if (this.defaultButtonUI && component.ui === 'default' && !component.hasOwnProperty('ui')) { component.ui = this.defaultButtonUI; } else { component.ui = component.ui + '-toolbar'; } } this.callParent(arguments); }, beforeRender: function() { var me = this, ariaAttr; me.callParent(); // If header is off we need to set aria-label if (me.afterHeaderInit && !me.header && me.title) { ariaAttr = me.bodyAriaRenderAttributes || (me.bodyAriaRenderAttributes = {}); ariaAttr['aria-label'] = me.title; } }, updateHeader: function(force) { var me = this, bodyEl = me.body, header, ariaAttr; me.callParent([force]); header = me.header; if (header) { if (bodyEl) { bodyEl.dom.setAttribute('aria-labelledby', header.id + '-title-textEl'); bodyEl.dom.removeAttribute('aria-label'); } else { ariaAttr = me.bodyAriaRenderAttributes || (me.bodyAriaRenderAttributes = {}); ariaAttr['aria-labelledby'] = header.id + '-title-textEl'; delete ariaAttr['aria-label']; } } else if (me.title) { if (bodyEl) { bodyEl.dom.setAttribute('aria-label', me.title); bodyEl.dom.removeAttribute('aria-labelledby'); } else { ariaAttr = me.bodyAriaRenderAttributes || (me.bodyAriaRenderAttributes = {}); ariaAttr['aria-label'] = me.title; delete ariaAttr['aria-labelledby']; } } }, privates: { applyDefaults: function (c) { if (!Ext.isString(c)) { c = this.callParent(arguments); } return c; } } /** * @cfg {Array} tools * @private */ /** * @cfg {Boolean} collapsible * @private */ /** * @cfg {Boolean} collapseMode * @private */ /** * @cfg {Boolean} animCollapse * @private */ /** * @cfg {Boolean} closable * @private */});