Current Path : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/tabs/src/ |
Current File : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/tabs/src/tabs.js |
import { Tag, Dom, Event, Type, Runtime } from 'main.core'; import { OrderedArray } from 'main.core.collections'; import { TabsOptionsType, TabOptionsType } from './types'; import { EventEmitter } from 'main.core.events'; import { Tab } from './tab'; const justCounter = { localId: 0, }; export class Tabs extends EventEmitter { #index: number; #id: string; #items: OrderedArray<string, Tab>; #activeItem: ?Tab = null; #body: ?HTMLElement; title: string; titleIconClasses: string; content: ?HTMLElement; constructor(options: ?TabsOptionsType) { super(); options = Type.isObjectLike(options) ? options : {}; this.#index = (++justCounter.localId); this.#id = Type.isStringFilled(options.id) ? options.id : ('TabsId' + this.#index); this.setEventNamespace('UI:Tabs:' + options.id); this.#items = new OrderedArray((tabA: Tab, tabB: Tab) => { return tabA.getSort() > tabB.getSort() ? 1 : -1; }); Array.from(options.items ?? []).forEach( (TabOptionsType: TabOptionsType) => this.addItem(new Tab(TabOptionsType)) ); this.activateItemDebounced = Runtime.debounce(this.activateItemDebounced, 100, this); if (this.#items.count() > 0 && !(this.#activeItem instanceof Tab)) { this.activateItem(this.#items.getFirst()); } } getIndex(): string { return this.#index; } getId(): string { return this.#id; } addItem(tab: Tab) { this.#items.add(tab); tab.setParent(this); if (tab.isActive()) { this.activateItem(tab); } tab.subscribe('changeTab', () => { this.activateItem(tab); }); } activateItem(tab: Tab, withAnimation: boolean = true) { if (this.#items.has(tab) && this.#activeItem !== tab) { let inactiveTab = null; if (this.#activeItem instanceof Tab) { inactiveTab = this.#activeItem; } this.#activeItem = tab; this.activateItemDebounced(tab, inactiveTab, withAnimation); } } activateItemDebounced(activeTab: Tab, inactiveTab: ?Tab = null, withAnimation: boolean = true) { if (inactiveTab) { inactiveTab.inactivate(withAnimation); } activeTab.activate(withAnimation); } getBodyContainer(): HTMLElement { if (!this.#body) { this.#body = Tag.render` <div class="ui-tabs__tabs-body-container" data-bx-role="bodies"></div> `; } return this.#body; } getContainer(): HTMLElement { if (this.content) { return this.content; } this.content = Tag.render` <div class="ui-tabs__tabs-container"> <div class="ui-tabs__tabs-header-container" data-bx-role="headers"></div> ${this.getBodyContainer()} </div>`; const headers = this.content.querySelector('[data-bx-role="headers"]'); this.#items.forEach( (tab: Tab) => { Dom.append(tab.getHeader(), headers); Dom.append(tab.getBody(), this.getBodyContainer()); } ) ; return this.content; } getItems(): Array<Tab> { return this.#items; } }