UNPKG

@exadel/esl

Version:

Exadel Smart Library (ESL) is the lightweight custom elements library that provide a set of super-flexible components

72 lines (54 loc) 2.51 kB
# [ESL](h../../../) Tab & Tab Container Version: *2.1.0*. Authors: *Julia Murashko*. <a name="intro"></a> **ESLTabs** is a container component for tabs trigger group. Uses `ESLTab` as an item. Each individual `ESLTab` can control `ESLToggleable` or, usually, `ESLPanel`. **NOTE** (update `5.8.0`): Starting from `5.8.0` version, default `ESLTab` styles handle missing target panel by setting `display: none` to the trigger element. If you want to keep the trigger visible, you can override default styles for the `no-target` attribute of the tab `esl-tab[no-target] { display: block; }`. It is also important to note that there is no more indirect console warning about missing target element, use selector query with `no-target` attribute or rely on hidden state of the tab element that comes out of the box now. ### ESLTabs Attributes / Properties - `container` - inner element to contain {@link ESLTab} collection. Will be scrolled in a scrollable state. - `scrollable` - scrollable mode. Supported types for different breakpoints ('disabled' by default) : - 'disabled' or not defined - scroll behavior is disabled; - 'center' - scroll behavior is enabled, tabs are center-aligned; - 'side' - scroll behavior is enabled, tabs are side-aligned; - empty or unsupported value is equal to 'side' behavior; NOTE: ESLTabs supports alignments: center (via 'center-alignment' class) and right ('right-alignment'). ### Events - `esl:change:active` - thrown when tab changes its state ### Example ```html <div class="tabs"> <esl-tabs scrollable> <!-- Left arrow --> <div class="arrow-prev" data-tab-direction="left"><span class="icon-arrow-prev"></span></div> <ul class="esl-tab-container" role="tablist"> <li> <esl-tab target="::parent(.tabs)::find(.tab-1)">Tab #1</esl-tab> </li> <li class="nav-item"> <esl-tab target="::parent(.tabs)::find(.tab-1)">Tab #2</esl-tab> </li> <li class="nav-item"> <esl-tab target="::parent(.tabs)::find(.tab-1)">Tab #3</esl-tab> </li> </ul> <!-- Right arrow --> <div class="arrow-next" data-tab-direction="right"><span class="icon-arrow-next"></span></div> </esl-tabs> <esl-panel-group mode="tabs"> <esl-panel class="tab tab-1"> Content for tab 1 </esl-panel> <esl-panel class="tab tab-2"> Content for tab 2 </esl-panel> <esl-panel class="tab tab-3"> Content for tab 3 </esl-panel> </esl-panel-group> </div> ```