UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

381 lines • 25.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Input, HostBinding, Output, EventEmitter } from '@angular/core'; import { Navigate } from './drop-down.common'; import { DropDownActionKey } from './drop-down.common'; /** @type {?} */ let NEXT_ID = 0; /** * An abstract class, defining a drop-down component, with: * Properties for display styles and classes * A collection items of type `IgxDropDownItemBase` * Properties and methods for navigating (highlighting/focusing) items from the collection * Properties and methods for selecting items from the collection * @abstract */ export class IgxDropDownBase { /** * @param {?} elementRef * @param {?} cdr */ constructor(elementRef, cdr) { this.elementRef = elementRef; this.cdr = cdr; this._focusedItem = null; this._id = `igx-drop-down-${NEXT_ID++}`; /** * Emitted when item selection is changing, before the selection completes * * ```html * <igx-drop-down (onSelection)='handleSelection()'></igx-drop-down> * ``` */ this.onSelection = new EventEmitter(); /** * Gets/Sets the drop down's container max height. * * ```typescript * // get * let maxHeight = this.dropdown.maxHeight; * ``` * ```html * <!--set--> * <igx-drop-down [maxHeight]='200px'></igx-drop-down> * ``` */ this.maxHeight = null; /** * @hidden \@internal */ this.cssClass = true; } /** * Get dropdown's html element of it scroll container * @protected * @return {?} */ get scrollContainer() { return this.element; } /** * Get all non-header items * * ```typescript * let myDropDownItems = this.dropdown.items; * ``` * @return {?} */ get items() { /** @type {?} */ const items = []; if (this.children !== undefined) { for (const child of this.children.toArray()) { if (!child.isHeader) { items.push(child); } } } return items; } /** * Get all header items * * ```typescript * let myDropDownHeaderItems = this.dropdown.headers; * ``` * @return {?} */ get headers() { /** @type {?} */ const headers = []; if (this.children !== undefined) { for (const child of this.children.toArray()) { if (child.isHeader) { headers.push(child); } } } return headers; } /** * Get dropdown html element * * ```typescript * let myDropDownElement = this.dropdown.element; * ``` * @return {?} */ get element() { return this.elementRef.nativeElement; } /** * Keydown Handler * @param {?} key * @param {?=} event * @return {?} */ onItemActionKey(key, event) { switch (key) { case DropDownActionKey.ENTER: case DropDownActionKey.SPACE: this.selectItem(this.focusedItem, event); break; case DropDownActionKey.ESCAPE: } } /** * Emits onSelection with the target item & event * @hidden \@internal * @param {?=} newSelection the item selected * @param {?=} event the event that triggered the call * @return {?} */ selectItem(newSelection, event) { this.onSelection.emit({ newSelection, oldSelection: null, cancel: false }); } /** * @hidden \@internal * @return {?} */ get focusedItem() { return this._focusedItem; } /** * @hidden \@internal * @param {?} item * @return {?} */ set focusedItem(item) { this._focusedItem = item; } /** * @protected * @param {?} direction * @param {?=} currentIndex * @return {?} */ navigate(direction, currentIndex) { /** @type {?} */ let index = -1; if (this._focusedItem) { index = currentIndex ? currentIndex : this._focusedItem.itemIndex; } /** @type {?} */ const newIndex = this.getNearestSiblingFocusableItemIndex(index, direction); this.navigateItem(newIndex); } /** * @protected * @param {?} startIndex * @param {?} direction * @return {?} */ getNearestSiblingFocusableItemIndex(startIndex, direction) { /** @type {?} */ let index = startIndex; /** @type {?} */ const items = this.items; while (items[index + direction] && items[index + direction].disabled) { index += direction; } index += direction; if (index >= 0 && index < items.length) { return index; } else { return -1; } } /** * Navigates to the item on the specified index * @param {?} newIndex number - the index of the item in the `items` collection * @return {?} */ navigateItem(newIndex) { if (newIndex !== -1) { /** @type {?} */ const oldItem = this._focusedItem; /** @type {?} */ const newItem = this.items[newIndex]; if (oldItem) { oldItem.focused = false; } this._focusedItem = newItem; this.scrollToHiddenItem(newItem); this._focusedItem.focused = true; } } /** * @hidden \@internal * @return {?} */ navigateFirst() { this.navigate(Navigate.Down, -1); } /** * @hidden \@internal * @return {?} */ navigateLast() { this.navigate(Navigate.Up, this.items.length); } /** * @hidden \@internal * @return {?} */ navigateNext() { this.navigate(Navigate.Down); } /** * @hidden \@internal * @return {?} */ navigatePrev() { this.navigate(Navigate.Up); } /** * @protected * @param {?} newItem * @return {?} */ scrollToHiddenItem(newItem) { /** @type {?} */ const elementRect = newItem.element.nativeElement.getBoundingClientRect(); /** @type {?} */ const parentRect = this.scrollContainer.getBoundingClientRect(); if (parentRect.top > elementRect.top) { this.scrollContainer.scrollTop -= (parentRect.top - elementRect.top); } if (parentRect.bottom < elementRect.bottom) { this.scrollContainer.scrollTop += (elementRect.bottom - parentRect.bottom); } } } IgxDropDownBase.propDecorators = { onSelection: [{ type: Output }], width: [{ type: Input }], height: [{ type: Input }], id: [{ type: Input }], maxHeight: [{ type: Input }, { type: HostBinding, args: ['style.maxHeight',] }], cssClass: [{ type: HostBinding, args: ['class.igx-drop-down',] }] }; if (false) { /** * @type {?} * @protected */ IgxDropDownBase.prototype._width; /** * @type {?} * @protected */ IgxDropDownBase.prototype._height; /** * @type {?} * @protected */ IgxDropDownBase.prototype._focusedItem; /** * @type {?} * @protected */ IgxDropDownBase.prototype._id; /** * @hidden * \@internal * @type {?} */ IgxDropDownBase.prototype.children; /** * Emitted when item selection is changing, before the selection completes * * ```html * <igx-drop-down (onSelection)='handleSelection()'></igx-drop-down> * ``` * @type {?} */ IgxDropDownBase.prototype.onSelection; /** * Gets/Sets the width of the drop down * * ```typescript * // get * let myDropDownCurrentWidth = this.dropdown.width; * ``` * ```html * <!--set--> * <igx-drop-down [width]='160px'></igx-drop-down> * ``` * @type {?} */ IgxDropDownBase.prototype.width; /** * Gets/Sets the height of the drop down * * ```typescript * // get * let myDropDownCurrentHeight = this.dropdown.height; * ``` * ```html * <!--set--> * <igx-drop-down [height]='400px'></igx-drop-down> * ``` * @type {?} */ IgxDropDownBase.prototype.height; /** * Gets/Sets the drop down's id * * ```typescript * // get * let myDropDownCurrentId = this.dropdown.id; * ``` * ```html * <!--set--> * <igx-drop-down [id]='newDropDownId'></igx-drop-down> * ``` * @type {?} */ IgxDropDownBase.prototype.id; /** * Gets/Sets the drop down's container max height. * * ```typescript * // get * let maxHeight = this.dropdown.maxHeight; * ``` * ```html * <!--set--> * <igx-drop-down [maxHeight]='200px'></igx-drop-down> * ``` * @type {?} */ IgxDropDownBase.prototype.maxHeight; /** * @hidden \@internal * @type {?} */ IgxDropDownBase.prototype.cssClass; /** * Gets if the dropdown is collapsed * @type {?} */ IgxDropDownBase.prototype.collapsed; /** * @type {?} * @protected */ IgxDropDownBase.prototype.elementRef; /** * @type {?} * @protected */ IgxDropDownBase.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-down.base.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/drop-down/drop-down.base.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACH,KAAK,EAAE,WAAW,EAAyB,MAAM,EAAE,YAAY,EAClE,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,QAAQ,EAAuB,MAAM,oBAAoB,CAAC;AAEnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;;IAGnD,OAAO,GAAG,CAAC;;;;;;;;;AASf,MAAM,OAAgB,eAAe;;;;;IAwJjC,YACc,UAAsB,EACtB,GAAsB;QADtB,eAAU,GAAV,UAAU,CAAY;QACtB,QAAG,GAAH,GAAG,CAAmB;QAvJ1B,iBAAY,GAAQ,IAAI,CAAC;QACzB,QAAG,GAAG,iBAAiB,OAAO,EAAE,EAAE,CAAC;;;;;;;;QAuBtC,gBAAW,GAAG,IAAI,YAAY,EAAuB,CAAC;;;;;;;;;;;;;QA6DtD,cAAS,GAAG,IAAI,CAAC;;;;QAMjB,aAAQ,GAAG,IAAI,CAAC;IA4DiB,CAAC;;;;;;IAjJzC,IAAc,eAAe;QACzB,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;;;;;;;;;IA4FD,IAAW,KAAK;;cACN,KAAK,GAA0B,EAAE;QACvC,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC7B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE;gBACzC,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;oBACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACrB;aACJ;SACJ;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;;;;;;;;;IASD,IAAW,OAAO;;cACR,OAAO,GAA0B,EAAE;QACzC,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC7B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE;gBACzC,IAAI,KAAK,CAAC,QAAQ,EAAE;oBAChB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACvB;aACJ;SACJ;QAED,OAAO,OAAO,CAAC;IACnB,CAAC;;;;;;;;;IASD,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACzC,CAAC;;;;;;;IAYM,eAAe,CAAC,GAAsB,EAAE,KAAa;QACxD,QAAQ,GAAG,EAAE;YACT,KAAK,iBAAiB,CAAC,KAAK,CAAC;YAC7B,KAAK,iBAAiB,CAAC,KAAK;gBACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;gBACzC,MAAM;YACV,KAAK,iBAAiB,CAAC,MAAM,CAAC;SACjC;IACL,CAAC;;;;;;;;IAQM,UAAU,CAAC,YAAkC,EAAE,KAAa;QAC/D,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAClB,YAAY;YACZ,YAAY,EAAE,IAAI;YAClB,MAAM,EAAE,KAAK;SAChB,CAAC,CAAC;IACP,CAAC;;;;;IAKD,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;;;;;;IAKD,IAAW,WAAW,CAAC,IAAyB;QAC5C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC7B,CAAC;;;;;;;IAES,QAAQ,CAAC,SAAmB,EAAE,YAAqB;;YACrD,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,KAAK,GAAG,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;SACrE;;cACK,QAAQ,GAAG,IAAI,CAAC,mCAAmC,CAAC,KAAK,EAAE,SAAS,CAAC;QAC3E,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC;;;;;;;IAES,mCAAmC,CAAC,UAAkB,EAAE,SAAmB;;YAC7E,KAAK,GAAG,UAAU;;cAChB,KAAK,GAAG,IAAI,CAAC,KAAK;QACxB,OAAO,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC,QAAQ,EAAE;YAClE,KAAK,IAAI,SAAS,CAAC;SACtB;QAED,KAAK,IAAI,SAAS,CAAC;QACnB,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,EAAE;YACpC,OAAO,KAAK,CAAC;SAChB;aAAM;YACH,OAAO,CAAC,CAAC,CAAC;SACb;IACL,CAAC;;;;;;IAMM,YAAY,CAAC,QAAgB;QAChC,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE;;kBACX,OAAO,GAAG,IAAI,CAAC,YAAY;;kBAC3B,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YACpC,IAAI,OAAO,EAAE;gBACT,OAAO,CAAC,OAAO,GAAG,KAAK,CAAC;aAC3B;YACD,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;YAC5B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;YACjC,IAAI,CAAC,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC;SACpC;IACL,CAAC;;;;;IAKM,aAAa;QAChB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC;;;;;IAKM,YAAY;QACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAClD,CAAC;;;;;IAKM,YAAY;QACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;;;;;IAKM,YAAY;QACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;;;;;;IAES,kBAAkB,CAAC,OAA4B;;cAC/C,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,qBAAqB,EAAE;;cACnE,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE;QAC/D,IAAI,UAAU,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,eAAe,CAAC,SAAS,IAAI,CAAC,UAAU,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC;SACxE;QAED,IAAI,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,EAAE;YACxC,IAAI,CAAC,eAAe,CAAC,SAAS,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;SAC9E;IACL,CAAC;;;0BAxPA,MAAM;oBAeN,KAAK;qBAeL,KAAK;iBAeL,KAAK;wBAeL,KAAK,YACL,WAAW,SAAC,iBAAiB;uBAM7B,WAAW,SAAC,qBAAqB;;;;;;;IA5FlC,iCAAiB;;;;;IACjB,kCAAkB;;;;;IAClB,uCAAmC;;;;;IACnC,8BAA6C;;;;;;IAa7C,mCAAgD;;;;;;;;;IAShD,sCAC6D;;;;;;;;;;;;;;IAc7D,gCACqB;;;;;;;;;;;;;;IAcrB,iCACsB;;;;;;;;;;;;;;IActB,6BACkB;;;;;;;;;;;;;;IAclB,oCAEwB;;;;;IAKxB,mCACuB;;;;;IAwDvB,oCAAmC;;;;;IAG/B,qCAAgC;;;;;IAChC,8BAAgC","sourcesContent":["import {\n    Input, HostBinding, ElementRef, QueryList, Output, EventEmitter, ChangeDetectorRef\n} from '@angular/core';\n\nimport { Navigate, ISelectionEventArgs } from './drop-down.common';\nimport { IDropDownList } from './drop-down.common';\nimport { DropDownActionKey } from './drop-down.common';\nimport { IgxDropDownItemBase } from './drop-down-item.base';\n\nlet NEXT_ID = 0;\n\n/**\n * An abstract class, defining a drop-down component, with:\n * Properties for display styles and classes\n * A collection items of type `IgxDropDownItemBase`\n * Properties and methods for navigating (highlighting/focusing) items from the collection\n * Properties and methods for selecting items from the collection\n */\nexport abstract class IgxDropDownBase implements IDropDownList {\n    protected _width;\n    protected _height;\n    protected _focusedItem: any = null;\n    protected _id = `igx-drop-down-${NEXT_ID++}`;\n\n    /**\n     * Get dropdown's html element of it scroll container\n     */\n    protected get scrollContainer() {\n        return this.element;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public children: QueryList<IgxDropDownItemBase>;\n\n    /**\n     * Emitted when item selection is changing, before the selection completes\n     *\n     * ```html\n     * <igx-drop-down (onSelection)='handleSelection()'></igx-drop-down>\n     * ```\n     */\n    @Output()\n    public onSelection = new EventEmitter<ISelectionEventArgs>();\n\n    /**\n     *  Gets/Sets the width of the drop down\n     *\n     * ```typescript\n     * // get\n     * let myDropDownCurrentWidth = this.dropdown.width;\n     * ```\n     * ```html\n     * <!--set-->\n     * <igx-drop-down [width]='160px'></igx-drop-down>\n     * ```\n     */\n    @Input()\n    public width: string;\n\n    /**\n     * Gets/Sets the height of the drop down\n     *\n     * ```typescript\n     * // get\n     * let myDropDownCurrentHeight = this.dropdown.height;\n     * ```\n     * ```html\n     * <!--set-->\n     * <igx-drop-down [height]='400px'></igx-drop-down>\n     * ```\n     */\n    @Input()\n    public height: string;\n\n    /**\n     * Gets/Sets the drop down's id\n     *\n     * ```typescript\n     * // get\n     * let myDropDownCurrentId = this.dropdown.id;\n     * ```\n     * ```html\n     * <!--set-->\n     * <igx-drop-down [id]='newDropDownId'></igx-drop-down>\n     * ```\n     */\n    @Input()\n    public id: string;\n\n    /**\n     * Gets/Sets the drop down's container max height.\n     *\n     * ```typescript\n     * // get\n     * let maxHeight = this.dropdown.maxHeight;\n     * ```\n     * ```html\n     * <!--set-->\n     * <igx-drop-down [maxHeight]='200px'></igx-drop-down>\n     * ```\n     */\n    @Input()\n    @HostBinding('style.maxHeight')\n    public maxHeight = null;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-drop-down')\n    public cssClass = true;\n\n    /**\n     * Get all non-header items\n     *\n     * ```typescript\n     * let myDropDownItems = this.dropdown.items;\n     * ```\n     */\n    public get items(): IgxDropDownItemBase[] {\n        const items: IgxDropDownItemBase[] = [];\n        if (this.children !== undefined) {\n            for (const child of this.children.toArray()) {\n                if (!child.isHeader) {\n                    items.push(child);\n                }\n            }\n        }\n\n        return items;\n    }\n\n    /**\n     * Get all header items\n     *\n     * ```typescript\n     * let myDropDownHeaderItems = this.dropdown.headers;\n     * ```\n     */\n    public get headers(): IgxDropDownItemBase[] {\n        const headers: IgxDropDownItemBase[] = [];\n        if (this.children !== undefined) {\n            for (const child of this.children.toArray()) {\n                if (child.isHeader) {\n                    headers.push(child);\n                }\n            }\n        }\n\n        return headers;\n    }\n\n    /**\n     * Get dropdown html element\n     *\n     * ```typescript\n     * let myDropDownElement = this.dropdown.element;\n     * ```\n     */\n    public get element() {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * Gets if the dropdown is collapsed\n     */\n    public abstract collapsed: boolean;\n\n    constructor(\n        protected elementRef: ElementRef,\n        protected cdr: ChangeDetectorRef) { }\n\n    /** Keydown Handler */\n    public onItemActionKey(key: DropDownActionKey, event?: Event) {\n        switch (key) {\n            case DropDownActionKey.ENTER:\n            case DropDownActionKey.SPACE:\n                this.selectItem(this.focusedItem, event);\n                break;\n            case DropDownActionKey.ESCAPE:\n        }\n    }\n\n    /**\n     * Emits onSelection with the target item & event\n     * @hidden @internal\n     * @param newSelection the item selected\n     * @param event the event that triggered the call\n     */\n    public selectItem(newSelection?: IgxDropDownItemBase, event?: Event) {\n        this.onSelection.emit({\n            newSelection,\n            oldSelection: null,\n            cancel: false\n        });\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public get focusedItem(): IgxDropDownItemBase {\n        return this._focusedItem;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public set focusedItem(item: IgxDropDownItemBase) {\n        this._focusedItem = item;\n    }\n\n    protected navigate(direction: Navigate, currentIndex?: number) {\n        let index = -1;\n        if (this._focusedItem) {\n            index = currentIndex ? currentIndex : this._focusedItem.itemIndex;\n        }\n        const newIndex = this.getNearestSiblingFocusableItemIndex(index, direction);\n        this.navigateItem(newIndex);\n    }\n\n    protected getNearestSiblingFocusableItemIndex(startIndex: number, direction: Navigate): number {\n        let index = startIndex;\n        const items = this.items;\n        while (items[index + direction] && items[index + direction].disabled) {\n            index += direction;\n        }\n\n        index += direction;\n        if (index >= 0 && index < items.length) {\n            return index;\n        } else {\n            return -1;\n        }\n    }\n\n    /**\n     * Navigates to the item on the specified index\n     * @param newIndex number - the index of the item in the `items` collection\n     */\n    public navigateItem(newIndex: number) {\n        if (newIndex !== -1) {\n            const oldItem = this._focusedItem;\n            const newItem = this.items[newIndex];\n            if (oldItem) {\n                oldItem.focused = false;\n            }\n            this._focusedItem = newItem;\n            this.scrollToHiddenItem(newItem);\n            this._focusedItem.focused = true;\n        }\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public navigateFirst() {\n        this.navigate(Navigate.Down, -1);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public navigateLast() {\n        this.navigate(Navigate.Up, this.items.length);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public navigateNext() {\n        this.navigate(Navigate.Down);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    public navigatePrev() {\n        this.navigate(Navigate.Up);\n    }\n\n    protected scrollToHiddenItem(newItem: IgxDropDownItemBase) {\n        const elementRect = newItem.element.nativeElement.getBoundingClientRect();\n        const parentRect = this.scrollContainer.getBoundingClientRect();\n        if (parentRect.top > elementRect.top) {\n            this.scrollContainer.scrollTop -= (parentRect.top - elementRect.top);\n        }\n\n        if (parentRect.bottom < elementRect.bottom) {\n            this.scrollContainer.scrollTop += (elementRect.bottom - parentRect.bottom);\n        }\n    }\n}\n"]}