all files / items/ ribbon-groupbutton.js

99.29% Statements 280/282
90.69% Branches 185/204
95.45% Functions 21/22
99.29% Lines 279/281
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468   687× 687× 687×   8338×   353×   51× 51× 51× 51×       51× 51× 143× 141×       141× 141×             141× 141×   141× 137× 137×       141× 141× 114×     27×   141× 78× 16×     62× 36× 36×     78×   141×         141×     51×     24×     17×                                         37× 37× 37× 37× 37× 37× 111× 111× 42×       37× 29×   37×     37×   37×     36× 24×   24× 72× 25× 25×       24× 24× 24× 18× 18× 18×           12×   12× 12×           12× 12× 36×     12×                     12×   36× 29×   36× 36×   36× 25× 25×       21× 21× 21× 21× 21× 21× 19× 19×     19× 19× 57× 57× 13×   44×           19×     19×             19×   19× 26×   19×     19×           34× 27× 27× 25×                     18× 18× 18× 18× 18×   18×   18× 18×                                           10× 10× 10× 10× 10× 11×                 10× 10×               10×     76× 76× 25× 25× 25× 25× 25×     48× 48× 48× 144× 12×     132×   144× 144× 144×                  
define(["require", "exports", "@syncfusion/ej2-base", "../base/constant", "@syncfusion/ej2-buttons", "../base/interface", "@syncfusion/ej2-splitbuttons", "../base/utils", "@syncfusion/ej2-popups"], function (require, exports, ej2_base_1, constants, ej2_buttons_1, interface_1, ej2_splitbuttons_1, utils_1, ej2_popups_1) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var RibbonGroupButton = (function () {
        function RibbonGroupButton(parent) {
            this.grpBtnIndex = 0;
            this.parent = parent;
            this.isSelected = false;
        }
        RibbonGroupButton.prototype.getModuleName = function () {
            return 'ribbonGroupButton';
        };
        RibbonGroupButton.prototype.destroy = function () {
            this.parent = null;
        };
        RibbonGroupButton.prototype.createGroupButton = function (item, itemElement) {
            var _this = this;
            var groupBtnSettings = item.groupButtonSettings;
            this.count = 0;
            var btnContainerEle = this.parent.createElement('div', {
                id: item.id + constants.RIBBON_GROUP_BUTTON_ID,
                className: 'e-btn-group'
            });
            itemElement.appendChild(btnContainerEle);
            for (var i = 0; i < groupBtnSettings.items.length; i++) {
                if ((groupBtnSettings.items[parseInt(i.toString(), 10)].iconCss)) {
                    var groupButtonEle = this.parent.createElement('button', {
                        id: item.id + constants.RIBBON_GROUP_BUTTON_ID + i,
                        className: constants.RIBBON_GROUP_BUTTON
                    });
                    btnContainerEle.appendChild(groupButtonEle);
                    new ej2_buttons_1.Button({
                        iconCss: groupBtnSettings.items[parseInt(i.toString(), 10)].iconCss,
                        disabled: item.disabled,
                        enableRtl: this.parent.enableRtl,
                        content: item.activeSize === interface_1.RibbonItemSize.Small ? '' : groupBtnSettings.items[parseInt(i.toString(), 10)].content,
                        iconPosition: item.activeSize === interface_1.RibbonItemSize.Large ? 'Top' : 'Left'
                    }, groupButtonEle);
                    Eif (groupBtnSettings.items[parseInt(i.toString(), 10)].htmlAttributes) {
                        utils_1.setCustomAttributes(groupButtonEle, groupBtnSettings.items[parseInt(i.toString(), 10)].htmlAttributes);
                    }
                    if (groupBtnSettings.items[parseInt(i.toString(), 10)].content) {
                        groupButtonEle.classList.add(constants.RIBBON_GROUP_BUTTON_CONTENT);
                        groupButtonEle.setAttribute('aria-label', groupBtnSettings.items[parseInt(i.toString(), 10)].content);
                    }
                    else {
                        groupButtonEle.setAttribute('aria-label', 'groupbuttonitem');
                    }
                    var buttonEle = itemElement.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + i);
                    if (groupBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Single) {
                        btnContainerEle.classList.add(constants.RIBBON_SINGLE_BUTTON_SELECTION);
                    }
                    else {
                        btnContainerEle.classList.add(constants.RIBBON_MULTIPLE_BUTTON_SELECTION);
                    }
                    if (groupBtnSettings.items[parseInt(i.toString(), 10)].selected) {
                        if (groupBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Multiple) {
                            buttonEle.classList.add('e-active');
                        }
                        else {
                            if (this.count < 1) {
                                buttonEle.classList.add('e-active');
                                this.count++;
                            }
                        }
                        this.grpBtnIndex = i;
                    }
                    if (groupBtnSettings.items[parseInt(i.toString(), 10)].ribbonTooltipSettings &&
                        utils_1.isTooltipPresent(groupBtnSettings.items[parseInt(i.toString(), 10)].ribbonTooltipSettings)) {
                        groupButtonEle.classList.add(constants.RIBBON_TOOLTIP_TARGET);
                        this.parent.tooltipData.push({
                            id: groupButtonEle.id, data: groupBtnSettings.items[parseInt(i.toString(), 10)].ribbonTooltipSettings
                        });
                    }
                    ej2_base_1.EventHandler.add(buttonEle, 'click', this.groupButtonClicked.bind(this, i, item, groupBtnSettings), this);
                }
            }
            if (this.parent.activeLayout === 'Simplified') {
                var dropdownIcon = void 0;
                var activeEleCount = 0;
                var count = 0;
                var buttonEle = this.parent.createElement('button', {
                    id: item.id
                });
                itemElement.appendChild(buttonEle);
                for (var i = 0; i < groupBtnSettings.items.length; i++) {
                    if (item.groupButtonSettings.items[parseInt(i.toString(), 10)].selected &&
                        !this.isSelected && groupBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Single) {
                        dropdownIcon = item.groupButtonSettings.items[parseInt(i.toString(), 10)].iconCss;
                        this.isSelected = true;
                    }
                    else if (item.groupButtonSettings.items[parseInt(i.toString(), 10)].selected &&
                        groupBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Multiple) {
                        activeEleCount++;
                        if (activeEleCount === 1) {
                            dropdownIcon = item.groupButtonSettings.items[parseInt(i.toString(), 10)].iconCss;
                        }
                        else {
                            dropdownIcon = null;
                        }
                    }
                }
                while (count < item.groupButtonSettings.items.length && !this.isSelected && !dropdownIcon) {
                    Eif (item.groupButtonSettings.items[parseInt(count.toString(), 10)].iconCss) {
                        dropdownIcon = item.groupButtonSettings.items[parseInt(count.toString(), 10)].iconCss;
                        this.isSelected = true;
                    }
                    count++;
                }
                var dropdown = new ej2_splitbuttons_1.DropDownButton({
                    iconCss: dropdownIcon,
                    target: btnContainerEle,
                    enableRtl: this.parent.enableRtl,
                    cssClass: 'e-ribbon-dropdown-group-button',
                    disabled: item.disabled
                }, buttonEle);
                if (groupBtnSettings.header) {
                    var dropDownPopup = dropdown.dropDown;
                    this.addGroupButtonHeader(item.id, groupBtnSettings, dropDownPopup.element);
                }
                buttonEle.onclick = buttonEle.onkeydown = function () {
                    _this.handleFocusState(item, itemElement);
                };
                btnContainerEle.onkeydown = function (e) {
                    Eif (_this.parent.activeLayout === 'Simplified') {
                        _this.handleGroupButtonNavigation(e, item);
                    }
                };
                utils_1.createTooltip(btnContainerEle, this.parent);
                this.isSelected = false;
            }
        };
        RibbonGroupButton.prototype.groupButtonClicked = function (itemIndex, item, grpBtnSettings) {
            var previousItems = [];
            var selectingItems = [];
            var selectedItems = [];
            var groupButtonEle = document.querySelector('#' + item.id);
            var dropdown;
            for (var j = 0; j < grpBtnSettings.items.length; j++) {
                Eif (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + j)) {
                    if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + j).classList.contains('e-active')) {
                        previousItems.push(grpBtnSettings.items[parseInt(j.toString(), 10)]);
                    }
                }
            }
            if (!(document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.contains('e-active'))) {
                selectingItems.push(grpBtnSettings.items[parseInt(itemIndex.toString(), 10)]);
            }
            var eventArgs = {
                cancel: false, previousItems: previousItems, selectingItems: selectingItems
            };
            if (grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].beforeClick) {
                grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].beforeClick.call(this, eventArgs);
            }
            if (eventArgs.cancel) {
                return;
            }
            else {
                if (grpBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Single) {
                    if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID).classList.contains(constants.RIBBON_MULTIPLE_BUTTON_SELECTION)) {
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID).classList.remove(constants.RIBBON_MULTIPLE_BUTTON_SELECTION);
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID).classList.add(constants.RIBBON_SINGLE_BUTTON_SELECTION);
                    }
                    for (var j = 0; j < grpBtnSettings.items.length; j++) {
                        if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + j) && document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + j).classList.contains('e-active')) {
                            document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + j).classList.remove('e-active');
                            grpBtnSettings.items[parseInt(j.toString(), 10)].
                                setProperties({ selected: false }, true);
                        }
                    }
                    document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.toggle('e-active');
                    grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].setProperties({ selected: true }, true);
                    if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.contains('e-active') && this.parent.activeLayout === 'Simplified') {
                        this.grpBtnIndex = itemIndex;
                        dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                        dropdown.setProperties({
                            iconCss: grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].iconCss
                        });
                    }
                }
                else {
                    if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID).classList.contains(constants.RIBBON_SINGLE_BUTTON_SELECTION)) {
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID).classList.remove(constants.RIBBON_SINGLE_BUTTON_SELECTION);
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID).classList.add(constants.RIBBON_MULTIPLE_BUTTON_SELECTION);
                    }
                    document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.toggle('e-active');
                    if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.contains('e-active')) {
                        grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].
                            setProperties({ selected: true }, true);
                    }
                    else {
                        grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].
                            setProperties({ selected: false }, true);
                    }
                    var activeEleCount = 0;
                    for (var n = 0; n < grpBtnSettings.items.length; n++) {
                        if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + n) && document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + n).classList.contains('e-active') && this.parent.activeLayout === 'Simplified' && n !== itemIndex) {
                            this.isSelected = true;
                            activeEleCount++;
                        }
                    }
                    if (this.parent.activeLayout === 'Simplified') {
                        var dropdownIcon = null;
                        var itemsCount = 0;
                        dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                        if (!this.isSelected) {
                            if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.contains('e-active')) {
                                dropdownIcon = grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].iconCss;
                            }
                        }
                        else {
                            if (activeEleCount === 1 && !(document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.contains('e-active'))) {
                                for (var n = 0; n < grpBtnSettings.items.length; n++) {
                                    if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + n) && document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + n).classList.contains('e-active')) {
                                        dropdownIcon = grpBtnSettings.items[parseInt(n.toString(), 10)].iconCss;
                                    }
                                }
                            }
                        }
                        while (itemsCount < grpBtnSettings.items.length && !dropdownIcon) {
                            Eif (grpBtnSettings.items[parseInt(itemsCount.toString(), 10)].iconCss) {
                                dropdownIcon = grpBtnSettings.items[parseInt(itemsCount.toString(), 10)].iconCss;
                            }
                            itemsCount++;
                        }
                        dropdown.setProperties({ iconCss: dropdownIcon });
                        this.grpBtnIndex = itemIndex;
                    }
                    this.isSelected = false;
                }
                if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + itemIndex).classList.contains('e-active')) {
                    selectedItems.push(grpBtnSettings.items[parseInt(itemIndex.toString(), 10)]);
                }
                var eventArgs_1 = { previousItems: previousItems, selectedItems: selectedItems };
                if (grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].click) {
                    grpBtnSettings.items[parseInt(itemIndex.toString(), 10)].click.call(this, eventArgs_1);
                }
                if (this.parent.activeLayout === 'Simplified' && groupButtonEle) {
                    dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                    dropdown.toggle();
                }
            }
        };
        RibbonGroupButton.prototype.switchGroupButton = function (item, itemElement) {
            var _this = this;
            var groupBtnSettings = item.groupButtonSettings;
            var dropdownIcon = null;
            var activeEleCount = 0;
            var itemsCount = 0;
            if (this.parent.activeLayout === 'Simplified') {
                var containerEle = itemElement.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID);
                var buttonEle = this.parent.createElement('button', {
                    id: item.id
                });
                itemElement.appendChild(buttonEle);
                for (var i = 0; i < groupBtnSettings.items.length; i++) {
                    Eif (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + i)) {
                        if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + i).classList.contains('e-active') && groupBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Single) {
                            dropdownIcon = groupBtnSettings.items[parseInt(i.toString(), 10)].iconCss;
                        }
                        else if (document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + i).classList.contains('e-active') && groupBtnSettings.selection === interface_1.RibbonGroupButtonSelection.Multiple) {
                            activeEleCount++;
                            if (activeEleCount === 1) {
                                dropdownIcon = groupBtnSettings.items[parseInt(i.toString(), 10)].iconCss;
                            }
                            else Eif (activeEleCount > 1) {
                                dropdownIcon = null;
                            }
                        }
                    }
                }
                while (itemsCount < groupBtnSettings.items.length && !dropdownIcon) {
                    Eif (groupBtnSettings.items[parseInt(itemsCount.toString(), 10)].iconCss) {
                        dropdownIcon = groupBtnSettings.items[parseInt(itemsCount.toString(), 10)].iconCss;
                    }
                    itemsCount++;
                }
                var dropdown = new ej2_splitbuttons_1.DropDownButton({
                    iconCss: dropdownIcon,
                    target: containerEle,
                    enableRtl: this.parent.enableRtl,
                    cssClass: 'e-ribbon-dropdown-group-button',
                    disabled: item.disabled
                }, buttonEle);
                if (groupBtnSettings.header) {
                    var dropDownPopup = dropdown.dropDown;
                    this.addGroupButtonHeader(item.id, groupBtnSettings, dropDownPopup.element);
                }
                buttonEle.onclick = buttonEle.onkeydown = function () {
                    _this.handleFocusState(item, itemElement);
                };
                containerEle.onkeydown = function (e) {
                    Eif (_this.parent.activeLayout === 'Simplified') {
                        _this.handleGroupButtonNavigation(e, item);
                    }
                };
                utils_1.createTooltip(containerEle, this.parent);
            }
            else {
                var groupButtonEle = itemElement.querySelector('#' + item.id);
                var dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                itemElement.appendChild(dropdown.target);
                Eif (groupButtonEle) {
                    dropdown.destroy();
                    ej2_base_1.remove(groupButtonEle);
                }
            }
        };
        RibbonGroupButton.prototype.handleFocusState = function (item, itemElement) {
            if (itemElement.querySelector('#' + item.id).classList.contains('e-active')) {
                var defaultSelectedBtn = document.querySelector('#' + item.id + '_grpbtn').querySelector('.' + constants.RIBBON_GROUP_BUTTON + '.e-active');
                if (defaultSelectedBtn) {
                    defaultSelectedBtn.focus();
                }
                else {
                    document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + 0).focus();
                }
            }
        };
        RibbonGroupButton.prototype.addGroupButtonHeader = function (itemID, groupBtnSettings, popupEle) {
            var groupButtonHeader = this.parent.createElement('div', {
                className: 'e-ribbon-groupbutton-header',
                id: itemID + constants.HEADER_ID,
                innerHTML: groupBtnSettings.header
            });
            popupEle.insertBefore(groupButtonHeader, popupEle.firstChild);
        };
        RibbonGroupButton.prototype.handleGroupButtonNavigation = function (e, item) {
            var groupButtonEle = document.querySelector('#' + item.id);
            var dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
            var targetEle = dropdown.target;
            var isOverflowPopup = false;
            if (this.parent.activeLayout === 'Simplified' && targetEle.closest('.e-ribbon-dropdown-group-button').classList.contains(constants.RIBBON_GROUP_BUTTON_OVERFLOW_POPUP)) {
                isOverflowPopup = true;
            }
            if (e.key === 'Tab') {
                e.preventDefault();
            }
            var groupBtnSettings = item.groupButtonSettings;
            if ((e.key === 'ArrowRight' && !isOverflowPopup) || (e.key === 'ArrowDown' && isOverflowPopup)) {
                if (!this.parent.enableRtl || (e.key === 'ArrowDown' && isOverflowPopup)) {
                    this.grpBtnIndex++;
                    if (this.grpBtnIndex < groupBtnSettings.items.length) {
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                    else {
                        this.grpBtnIndex = 0;
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                }
                else {
                    if (this.grpBtnIndex === 0) {
                        this.grpBtnIndex = groupBtnSettings.items.length - 1;
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                    else {
                        this.grpBtnIndex--;
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                }
            }
            else if ((e.key === 'ArrowLeft' && !isOverflowPopup) || (e.key === 'ArrowUp' && isOverflowPopup)) {
                if (!this.parent.enableRtl || (e.key === 'ArrowUp' && isOverflowPopup)) {
                    if (this.grpBtnIndex === 0) {
                        this.grpBtnIndex = groupBtnSettings.items.length - 1;
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                    else {
                        this.grpBtnIndex--;
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                }
                else {
                    this.grpBtnIndex++;
                    if (this.grpBtnIndex < groupBtnSettings.items.length) {
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                    else {
                        this.grpBtnIndex = 0;
                        document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + (this.grpBtnIndex)).focus();
                    }
                }
            }
        };
        RibbonGroupButton.prototype.addOverFlowEvents = function (item, itemEle, overflowButton) {
            var _this = this;
            var groupBtnSettings = item.groupButtonSettings;
            var isIconOnly = true;
            var groupButtonEle = itemEle.querySelector('#' + item.id);
            if (groupButtonEle) {
                var dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                dropdown.setProperties({ cssClass: dropdown.cssClass + constants.SPACE + constants.RIBBON_GROUP_BUTTON_OVERFLOW_POPUP, content: groupBtnSettings.header ? groupBtnSettings.header : '' });
                var targetEle_1 = dropdown.target;
                Eif (targetEle_1.children.length) {
                    for (var i = 0; i < targetEle_1.children.length; i++) {
                        if (groupBtnSettings.items[parseInt(i.toString(), 10)].content) {
                            isIconOnly = false;
                            break;
                        }
                    }
                    if (isIconOnly) {
                        targetEle_1.classList.add('e-icon-btn');
                    }
                }
                targetEle_1.onclick = function () {
                    Eif (_this.parent.activeLayout === 'Simplified' && targetEle_1.closest('.e-ribbon-dropdown-group-button').classList.contains(constants.RIBBON_GROUP_BUTTON_OVERFLOW_POPUP)) {
                        Eif (overflowButton.element.classList.contains('e-active')) {
                            overflowButton.toggle();
                        }
                    }
                };
            }
            var overflowGroupButtonEle = itemEle.querySelector('#' + item.id + '_grpbtn');
            if (this.parent.activeLayout === 'Classic' && overflowGroupButtonEle) {
                overflowGroupButtonEle.onclick = function () {
                    if (overflowButton.element.classList.contains('e-active')) {
                        overflowButton.toggle();
                    }
                };
            }
        };
        RibbonGroupButton.prototype.removeOverFlowEvents = function (item, itemEle) {
            var groupButtonEle = itemEle.querySelector('#' + item.id);
            Eif (groupButtonEle) {
                var dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                var targetEle = dropdown.target;
                if (targetEle.classList.contains('e-icon-btn')) {
                    targetEle.classList.remove('e-icon-btn');
                }
                var cssClass = dropdown.cssClass.split(constants.SPACE);
                cssClass = cssClass.filter(function (value) { return value !== constants.RIBBON_GROUP_BUTTON_OVERFLOW_POPUP; });
                dropdown.setProperties({ cssClass: cssClass.join(constants.SPACE), content: '' });
            }
        };
        RibbonGroupButton.prototype.destroyDropDown = function (item) {
            var groupButtonEle = document.querySelector('#' + item.id);
            if (groupButtonEle) {
                var dropdown = ej2_base_1.getComponent(groupButtonEle, ej2_splitbuttons_1.DropDownButton);
                var tooltip = ej2_base_1.getComponent(dropdown.target, ej2_popups_1.Tooltip);
                tooltip.destroy();
                dropdown.destroy();
                ej2_base_1.remove(groupButtonEle);
            }
        };
        RibbonGroupButton.prototype.updateGroupButtonSize = function (itemElement, item) {
            var groupBtnSettings = item.groupButtonSettings;
            var buttonEle;
            for (var i = 0; i < groupBtnSettings.items.length; i++) {
                if (this.parent.activeLayout === 'Classic') {
                    buttonEle = itemElement.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + i);
                }
                else {
                    buttonEle = document.querySelector('#' + item.id + constants.RIBBON_GROUP_BUTTON_ID + i);
                }
                Eif (buttonEle) {
                    var buttonObj = ej2_base_1.getComponent(buttonEle, ej2_buttons_1.Button);
                    buttonObj.setProperties({
                        iconPosition: item.activeSize === interface_1.RibbonItemSize.Large ? 'Top' : 'Left',
                        content: item.activeSize === interface_1.RibbonItemSize.Small ? '' : groupBtnSettings.items[parseInt(i.toString(), 10)].content
                    });
                }
            }
        };
        return RibbonGroupButton;
    }());
    exports.RibbonGroupButton = RibbonGroupButton;
});