@wavemaker/app-ng-runtime 11.11.0-rc.6109 → 11.11.0-rc.6112

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/components/base/bundles/index.umd.js +3 -1
  2. package/components/base/esm2022/widgets/common/base/base-field-validations.mjs +4 -2
  3. package/components/base/fesm2022/index.mjs +3 -1
  4. package/components/base/fesm2022/index.mjs.map +1 -1
  5. package/components/containers/tabs/bundles/index.umd.js +28 -4
  6. package/components/containers/tabs/esm2022/tabs.component.mjs +27 -6
  7. package/components/containers/tabs/esm2022/tabs.props.mjs +2 -1
  8. package/components/containers/tabs/fesm2022/index.mjs +27 -5
  9. package/components/containers/tabs/fesm2022/index.mjs.map +1 -1
  10. package/components/containers/tabs/tabs.component.d.ts +2 -0
  11. package/components/containers/wizard/bundles/index.umd.js +7 -10
  12. package/components/containers/wizard/esm2022/wizard.component.mjs +8 -11
  13. package/components/containers/wizard/fesm2022/index.mjs +7 -10
  14. package/components/containers/wizard/fesm2022/index.mjs.map +1 -1
  15. package/components/containers/wizard/wizard.component.d.ts +2 -2
  16. package/components/data/table/bundles/index.umd.js +8 -7
  17. package/components/data/table/esm2022/table.component.mjs +6 -4
  18. package/components/data/table/fesm2022/index.mjs +5 -3
  19. package/components/data/table/fesm2022/index.mjs.map +1 -1
  20. package/components/input/calendar/bundles/index.umd.js +3 -0
  21. package/components/input/calendar/esm2022/calendar.component.mjs +4 -1
  22. package/components/input/calendar/fesm2022/index.mjs +3 -0
  23. package/components/input/calendar/fesm2022/index.mjs.map +1 -1
  24. package/components/input/color-picker/bundles/index.umd.js +5 -3
  25. package/components/input/color-picker/esm2022/color-picker.component.mjs +7 -5
  26. package/components/input/color-picker/fesm2022/index.mjs +6 -4
  27. package/components/input/color-picker/fesm2022/index.mjs.map +1 -1
  28. package/npm-shrinkwrap.json +2 -2
  29. package/package-lock.json +2 -2
  30. package/package.json +1 -1
  31. package/runtime/base/bundles/index.umd.js +1 -0
  32. package/runtime/base/esm2022/services/i18n.service.mjs +2 -1
  33. package/runtime/base/fesm2022/index.mjs +1 -0
  34. package/runtime/base/fesm2022/index.mjs.map +1 -1
  35. package/runtime/dynamic/app/app.config.d.ts +5 -0
  36. package/runtime/dynamic/bundles/index.umd.js +165 -56
  37. package/runtime/dynamic/esm2022/app/app.config.mjs +136 -0
  38. package/runtime/dynamic/esm2022/app/services/component-ref-provider.service.mjs +2 -4
  39. package/runtime/dynamic/esm2022/main.mjs +10 -10
  40. package/runtime/dynamic/fesm2022/index.mjs +189 -78
  41. package/runtime/dynamic/fesm2022/index.mjs.map +1 -1
@@ -121,6 +121,7 @@
121
121
  ['transition', i3.PROP_STRING],
122
122
  ['type', i3.PROP_STRING],
123
123
  ['iconposition', i3.PROP_STRING],
124
+ ['autotabactivation', { value: true, ...i3.PROP_BOOLEAN }]
124
125
  ]);
125
126
  i3.register('wm-tabs', props);
126
127
  };
@@ -677,6 +678,9 @@
677
678
  setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);
678
679
  }
679
680
  }
681
+ else if (key === 'autotabactivation') {
682
+ this.autoActivation = nv;
683
+ }
680
684
  else {
681
685
  super.onPropertyChange(key, nv, ov);
682
686
  }
@@ -698,18 +702,34 @@
698
702
  });
699
703
  }
700
704
  onkeydown(event) {
705
+ let newPane;
701
706
  switch (event.key) {
702
707
  case 'ArrowLeft':
703
708
  case 'ArrowUp':
704
- this.prev(null, true);
705
- event.preventDefault();
709
+ newPane = this.autoActivation ? (this.prev(null, true), null) : this.getSelectableTabBeforeIndex(this.getSelectedPaneIndex());
706
710
  break;
707
711
  case 'ArrowRight':
708
712
  case 'ArrowDown':
709
- this.next(null, true);
710
- event.preventDefault();
713
+ newPane = this.autoActivation ? (this.next(null, true), null) : this.getSelectableTabAfterIndex(this.getSelectedPaneIndex());
711
714
  break;
715
+ case 'Enter': {
716
+ const pane = this.getSelectableTabAfterIndex(this.getSelectedPaneIndex() - 1);
717
+ if (pane) {
718
+ const enterEvent = new KeyboardEvent('keydown', { key: 'Enter', code: 'Enter', bubbles: true, cancelable: true });
719
+ pane.nativeElement.dispatchEvent(enterEvent);
720
+ pane.select(enterEvent, true);
721
+ }
722
+ event.preventDefault();
723
+ return;
724
+ }
725
+ default:
726
+ return;
712
727
  }
728
+ if (newPane) {
729
+ this.nativeElement.querySelector('li.select')?.classList.remove('select');
730
+ this.nativeElement.querySelector(`li[data-paneid="${newPane.widgetId}"]`)?.classList.add('select');
731
+ }
732
+ event.preventDefault();
713
733
  }
714
734
  ngAfterContentInit() {
715
735
  this.promiseResolverFn();
@@ -725,6 +745,10 @@
725
745
  super.ngAfterViewInit();
726
746
  this.registerTabsScroll();
727
747
  }
748
+ getSelectedPaneIndex() {
749
+ const index = this.panes.toArray().findIndex(pane => this.nativeElement.querySelector(`li[data-paneid="${pane.widgetId}"]`)?.classList.contains("select"));
750
+ return index >= 0 ? index : this.getActiveTabIndex();
751
+ }
728
752
  static { this.ɵfac = function TabsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TabsComponent)(i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i1__namespace.DynamicComponentRefProvider), i0__namespace.ɵɵinjectAttribute('transition'), i0__namespace.ɵɵinjectAttribute('tabsposition'), i0__namespace.ɵɵdirectiveInject(i1__namespace.StatePersistence), i0__namespace.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
729
753
  static { this.ɵcmp = /*@__PURE__*/ i0__namespace.ɵɵdefineComponent({ type: TabsComponent, selectors: [["div", "wmTabs", ""]], contentQueries: function TabsComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
730
754
  i0__namespace.ɵɵcontentQuery(dirIndex, TabPaneComponent, 4);
@@ -376,6 +376,9 @@ export class TabsComponent extends StylableComponent {
376
376
  setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);
377
377
  }
378
378
  }
379
+ else if (key === 'autotabactivation') {
380
+ this.autoActivation = nv;
381
+ }
379
382
  else {
380
383
  super.onPropertyChange(key, nv, ov);
381
384
  }
@@ -397,20 +400,34 @@ export class TabsComponent extends StylableComponent {
397
400
  });
398
401
  }
399
402
  onkeydown(event) {
403
+ let newPane;
400
404
  switch (event.key) {
401
405
  case 'ArrowLeft':
402
406
  case 'ArrowUp':
403
- this.prev(null, true);
404
- event.preventDefault();
407
+ newPane = this.autoActivation ? (this.prev(null, true), null) : this.getSelectableTabBeforeIndex(this.getSelectedPaneIndex());
405
408
  break;
406
409
  case 'ArrowRight':
407
410
  case 'ArrowDown':
408
- this.next(null, true);
409
- event.preventDefault();
411
+ newPane = this.autoActivation ? (this.next(null, true), null) : this.getSelectableTabAfterIndex(this.getSelectedPaneIndex());
410
412
  break;
413
+ case 'Enter': {
414
+ const pane = this.getSelectableTabAfterIndex(this.getSelectedPaneIndex() - 1);
415
+ if (pane) {
416
+ const enterEvent = new KeyboardEvent('keydown', { key: 'Enter', code: 'Enter', bubbles: true, cancelable: true });
417
+ pane.nativeElement.dispatchEvent(enterEvent);
418
+ pane.select(enterEvent, true);
419
+ }
420
+ event.preventDefault();
421
+ return;
422
+ }
411
423
  default:
412
- break;
424
+ return;
413
425
  }
426
+ if (newPane) {
427
+ this.nativeElement.querySelector('li.select')?.classList.remove('select');
428
+ this.nativeElement.querySelector(`li[data-paneid="${newPane.widgetId}"]`)?.classList.add('select');
429
+ }
430
+ event.preventDefault();
414
431
  }
415
432
  ngAfterContentInit() {
416
433
  this.promiseResolverFn();
@@ -426,6 +443,10 @@ export class TabsComponent extends StylableComponent {
426
443
  super.ngAfterViewInit();
427
444
  this.registerTabsScroll();
428
445
  }
446
+ getSelectedPaneIndex() {
447
+ const index = this.panes.toArray().findIndex(pane => this.nativeElement.querySelector(`li[data-paneid="${pane.widgetId}"]`)?.classList.contains("select"));
448
+ return index >= 0 ? index : this.getActiveTabIndex();
449
+ }
429
450
  static { this.ɵfac = function TabsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TabsComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.DynamicComponentRefProvider), i0.ɵɵinjectAttribute('transition'), i0.ɵɵinjectAttribute('tabsposition'), i0.ɵɵdirectiveInject(i1.StatePersistence), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
430
451
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TabsComponent, selectors: [["div", "wmTabs", ""]], contentQueries: function TabsComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
431
452
  i0.ɵɵcontentQuery(dirIndex, TabPaneComponent, 4);
@@ -476,4 +497,4 @@ export class TabsComponent extends StylableComponent {
476
497
  args: [TabPaneComponent]
477
498
  }] }); })();
478
499
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TabsComponent, { className: "TabsComponent", filePath: "tabs.component.ts", lineNumber: 55 }); })();
479
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/containers/tabs/src/tabs.component.ts","../../../../../projects/components/widgets/containers/tabs/src/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { WmComponentsModule } from \"@wm/components/base\";\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    Attribute,\n    Component,\n    ContentChildren, HostBinding, Inject,\n    Injector,\n    OnInit,\n    Optional,\n    QueryList\n} from '@angular/core';\n\nimport {\n    addClass,\n    appendNode,\n    DynamicComponentRefProvider,\n    noop,\n    removeClass,\n    StatePersistence\n} from '@wm/core';\nimport {\n    APPLY_STYLES_TYPE,\n    IWidgetConfig,\n    provideAsWidgetRef,\n    styler,\n    StylableComponent,\n    createArrayFrom\n} from '@wm/components/base';\n\nimport { TabsAnimator } from './tabs.animator';\nimport { registerProps } from './tabs.props';\nimport { TabPaneComponent } from './tab-pane/tab-pane.component';\nimport {find, findIndex, forEach, get, indexOf, isArray, isEmpty} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-tabs clearfix';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-tabs',\n    hostClass: DEFAULT_CLS\n};\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, WmComponentsModule],\n    selector: 'div[wmTabs]',\n    templateUrl: './tabs.component.html',\n    exportAs: 'wmTabs',\n    providers: [\n        provideAsWidgetRef(TabsComponent)\n    ]\n})\nexport class TabsComponent extends StylableComponent implements AfterContentInit, OnInit, AfterViewInit {\n    static initializeProps = registerProps();\n\n    public defaultpaneindex: number;\n    public transition: string;\n    public tabsposition: string;\n    public statehandler: any;\n    private statePersistence: StatePersistence;\n\n    public vertical: boolean;\n    public justified: boolean;\n    private activeTab: TabPaneComponent;\n    private readonly promiseResolverFn: Function;\n    private tabsAnimator: TabsAnimator;\n    private _oldPaneIndex: number;\n    private isPageLoadCall: boolean;\n    private dynamicComponentProvider;\n    private _dynamicContext;\n    private dynamicPaneIndex;\n    public dynamicTabs;\n    public fieldDefs;\n    public type;\n    public nodatamessage;\n\n    @HostBinding('attr.icon-position') iconposition: string = '';\n\n    @ContentChildren(TabPaneComponent) panes: QueryList<TabPaneComponent>;\n\n    constructor(\n        inj: Injector,\n        dynamicComponentProvider: DynamicComponentRefProvider,\n        @Attribute('transition') _transition: string,\n        @Attribute('tabsposition') _tabsPosition: string,\n        statePersistence: StatePersistence,\n        @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any\n    ) {\n        // handle to the promise resolver\n        let resolveFn: Function = noop;\n        super(inj, WIDGET_CONFIG, explicitContext, new Promise(res => resolveFn = res));\n\n        this.transition = _transition;\n        this.tabsposition = _tabsPosition;\n        this.statePersistence = statePersistence;\n        this.dynamicComponentProvider = dynamicComponentProvider;\n        this.dynamicTabs = [];\n        this.dynamicPaneIndex = 0;\n\n        this.promiseResolverFn = resolveFn;\n\n        styler(this.nativeElement, this, APPLY_STYLES_TYPE.CONTAINER);\n\n    }\n\n    animateIn (element: HTMLElement) {\n        const tabHeader = $(element);\n        // when the animation is not present toggle the active class.\n        tabHeader.siblings('.active').removeClass('active');\n        tabHeader.addClass('active');\n\n        const ul = this.nativeElement.querySelector('ul.nav.nav-tabs');\n\n        // move the tabheader into the viewport\n        const $prevHeaderEle = tabHeader.prev();\n        if ($prevHeaderEle.length) {\n            ul.scrollLeft = $prevHeaderEle[0].offsetLeft;\n        } else {\n            ul.scrollLeft = 0;\n        }\n    }\n\n    /**\n     * This method is used to register the dynamic panes.\n     * After all panes are initialzed, update the querylist manually based on index.\n     * @param paneRef - refrence of the tabpane\n     */\n    public registerDynamicTab(paneRef) {\n        this.dynamicTabs.push(paneRef);\n        const isLastPane =  this.dynamicTabs.length === this.dynamicPaneIndex;\n        if (isLastPane) {\n            for (let i = 0; i < this.dynamicTabs.length; i++) {\n                const newPaneRef = find(this.dynamicTabs, pane => pane.dynamicPaneIndex === i);\n                const isPaneAlreadyExist = find(this.panes.toArray(), newPaneRef);\n                if (!isPaneAlreadyExist) {\n                    this.panes.reset([...this.panes.toArray(), newPaneRef]);\n                    if (newPaneRef.active) {\n                        setTimeout(() => {\n                            newPaneRef.select();\n                        }, 20);\n                    }\n                }\n            }\n        }\n    }\n\n    /**\n     * This method is to add the tabpane dynamically\n     * @param tabpanes - list of tabpanes\n     */\n    public addPane(tabpanes) {\n        if (!isArray(tabpanes)) {\n            tabpanes = [tabpanes];\n        }\n        const paneNamesList = [];\n        forEach(tabpanes, (pane, index) => {\n            const isPaneAlreadyCreated = find(this.panes.toArray(), {name: pane.name});\n            const isPaneNameExist = indexOf(paneNamesList, pane.name);\n            // If user tries to add tabpane with the same name which is already exists then do not create the pane\n            if (isPaneAlreadyCreated || isPaneNameExist > 0) {\n                console.warn(`The tab pane with name ${pane.name} already exists`);\n                return;\n            }\n\n            let paramMarkup = '';\n            let propsTmpl = '';\n            this.dynamicPaneIndex++;\n            const name = pane.name ? pane.name : `tabpane${this.panes.toArray().length + (index + 1)}`;\n            paneNamesList.push(name);\n            const partialParams = get(pane, 'params');\n\n            forEach(pane, (value, key) => {\n                if (key !== 'params') {\n                    propsTmpl = `${propsTmpl} ${key}=\"${value}\"`;\n                }\n            });\n\n            forEach(partialParams, (value, key) => {\n                paramMarkup = `${paramMarkup} <wm-param name=\"${key}\" value=\"${value}\"></wm-param>`;\n            });\n            const markup = `<wm-tabpane dynamicPaneIndex=\"${this.dynamicPaneIndex - 1}\" isdynamic=\"true\" name=\"${name}\" ${propsTmpl}>\n                            ${paramMarkup}\n                        </wm-tabpane>`;\n\n            if (!this._dynamicContext) {\n                this._dynamicContext = Object.create(this.viewParent);\n                this._dynamicContext[this.getAttr('wmTab')] = this;\n            }\n\n            this.dynamicComponentProvider.addComponent(this.getNativeElement().querySelector('.tab-content'), markup, this._dynamicContext, {inj: this.inj});\n\n        });\n        return paneNamesList;\n    }\n\n    /**\n     * This method is to remove the tabpane\n     * @param paneIndex - index of the pane\n     */\n    public removePane(paneName) {\n        const paneRef = this.getPaneRefByName(paneName);\n        if (paneRef) {\n            paneRef.remove();\n        }\n    }\n\n    /**\n     * TabPane children components invoke this method to communicate with the parent\n     * if the evt argument is defined on-change callback will be invoked.\n     */\n    public notifyChange(paneRef: TabPaneComponent, evt: Event, isKeyBoardEvent: boolean) {\n        if (!this.isSelectableTab(paneRef)) {\n            return;\n        }\n\n        let headerElement;\n        // invoke deselect event callback on the preset active tab\n        if (!isEmpty(this.activeTab)) {\n            this.activeTab.deselect();\n        }\n\n\n        this.activeTab = paneRef.getWidget();\n        const newPaneIndex = this.getPaneIndexByRef(paneRef);\n        const mode = this.statePersistence.computeMode(this.statehandler);\n        if (!this.isPageLoadCall && mode && mode.toLowerCase() !== 'none') {\n            this.statePersistence.setWidgetState(this, this.activeTab.name);\n        } else {\n            this.defaultpaneindex = this.getPaneIndexByRef(paneRef);\n            this.isPageLoadCall = false;\n        }\n\n        // invoke select callback on the selected tab\n        paneRef.invokeOnSelectCallback(evt);\n\n        // invoke change callback if the evt is present, select a tab programmatically will not have the event\n        if (evt) {\n            this.invokeEventCallback('change', {\n                $event: evt,\n                newPaneIndex: newPaneIndex,\n                oldPaneIndex: this._oldPaneIndex || 0\n            });\n        }\n        this._oldPaneIndex = newPaneIndex;\n\n        if (evt) {\n            headerElement = $(evt.target as HTMLElement).closest('li.tab-header');\n        }\n        if (!evt || !headerElement || !headerElement.length) {\n            headerElement = this.nativeElement.querySelector(`li[data-paneid=${paneRef.widgetId}]`);\n            const insideTabs = !!$(headerElement).closest('.app-tabs')\n                .parent().closest('.app-tabs').length;\n            if (!insideTabs && isKeyBoardEvent) {\n                $(headerElement).children().focus();\n            }\n        }\n        this.animateIn(headerElement);\n\n        // this.setTabsLeftPosition(this.getPaneIndexByRef(this.activeTab), this.panes.length);\n        if (this.canSlide()) {\n            if (!this.tabsAnimator) {\n                this.tabsAnimator = new TabsAnimator(this);\n                this.tabsAnimator.setGesturesEnabled(this.canSlide());\n            }\n            this.tabsAnimator.transitionTabIntoView();\n        }\n    }\n\n    public goToTab(tabIndex) {\n        if (this.isValidPaneIndex(tabIndex - 1)) {\n            const tab = this.getPaneRefByIndex(tabIndex - 1);\n            tab.select();\n        }\n    }\n\n    private getPaneIndexByRef(paneRef: TabPaneComponent): number {\n        return this.panes.toArray().indexOf(paneRef);\n    }\n\n    // Returns the active tab index from tabs.\n    public getActiveTabIndex(): number {\n        return findIndex(this.panes.toArray(), {isActive: true});\n    }\n\n    private isValidPaneIndex(index: number): boolean {\n        return (index >= 0 && index < this.panes.length);\n    }\n\n    private getPaneRefByIndex(index: number): TabPaneComponent {\n        return this.panes.toArray()[index];\n    }\n\n    private getPaneRefByName(name: string): TabPaneComponent {\n        return find(this.panes.toArray(), {name: name});\n    }\n\n    // returns false if the pane is hidden or disabled\n    private isSelectableTab(paneRef: TabPaneComponent): boolean {\n        return paneRef.show && !paneRef.disabled;\n    }\n\n    private canSlide() {\n        return this.transition === 'slide' && !this.vertical;\n    }\n\n    private getSelectableTabAfterIndex(index: number): TabPaneComponent {\n        for (let i = index + 1; i < this.panes.length; i++) {\n            const pane = this.getPaneRefByIndex(i);\n            if (this.isSelectableTab(pane)) {\n                return pane;\n            }\n        }\n        if (index === this.panes.length - 1) {\n            const pane = this.getPaneRefByIndex(0);\n             if (this.isSelectableTab(pane)) {\n                return pane;\n             }\n        }\n    }\n\n    private getSelectableTabBeforeIndex(index: number): TabPaneComponent {\n        for (let i = index - 1; i >= 0; i--) {\n            const pane = this.getPaneRefByIndex(i);\n            if (this.isSelectableTab(pane)) {\n                return pane;\n            }\n        }\n        if (index === 0) {\n            const pane = this.getPaneRefByIndex(this.panes.length - 1);\n            if (this.isSelectableTab(pane)) {\n                return pane;\n            }\n        }\n    }\n\n    // select next tab relative to the current active tab\n    public next($event?: Event, isKeyBoardEvent?: boolean) {\n        const pane = this.getSelectableTabAfterIndex(this.getActiveTabIndex());\n        if (pane) {\n            pane.select($event, isKeyBoardEvent);\n        }\n    }\n\n    // select prev tab relative to the current active tab\n    public prev($event?: Event, isKeyBoardEvent?: boolean) {\n        const pane = this.getSelectableTabBeforeIndex(this.getActiveTabIndex());\n        if (pane) {\n            pane.select($event, isKeyBoardEvent);\n        }\n    }\n\n    /**\n     * this method will be invoked during the initialization of the component and on defaultpaneindex property change,\n     * if the provided defaultpaneindex is not valid, find the first pane index which can be shown and select it\n     */\n    private selectDefaultPaneByIndex(index: number) {\n        if (!this.isValidPaneIndex(index)) {\n            return;\n        }\n\n        let paneRef = this.getPaneRefByIndex(index);\n        if (!this.isSelectableTab(paneRef)) {\n            paneRef = this.getSelectableTabAfterIndex(0);\n        }\n        if (paneRef) {\n            paneRef.select();\n        }\n    }\n\n    // update the postion of tab header\n    private setTabsPosition() {\n        const ul = this.nativeElement.children[0];\n\n        this.vertical = (this.tabsposition === 'left' || this.tabsposition === 'right');\n\n        removeClass(this.nativeElement, 'inverted');\n        if (this.tabsposition === 'bottom' || this.tabsposition === 'right') {\n            appendNode(ul as HTMLElement, this.nativeElement);\n            addClass(this.nativeElement, 'inverted');\n        }\n    }\n\n    private onDataChange(newVal) {\n        this.fieldDefs = createArrayFrom(newVal);\n        setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0));\n    }\n\n    onPropertyChange(key: string, nv: any, ov) {\n\n        if (key === 'defaultpaneindex') {\n            this.defaultpaneindex = nv;\n        } else if (key === 'dataset') {\n            this.onDataChange(nv);\n        } else if (key === 'statehandler') {\n            this.isPageLoadCall = true;\n            const widgetState = this.statePersistence.getWidgetState(this);\n            if (nv !== 'none' && widgetState) {\n                const paneToSelect: any = this.panes.filter(function(pane) {\n                    return widgetState === pane.name;\n                });\n                if (!paneToSelect.length) {\n                    console.warn('Tab pane name ' + widgetState + ' in State is incorrect. Falling back to the default pane');\n                    setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);\n                } else {\n                    const index = this.getPaneIndexByRef(paneToSelect[0]);\n                    setTimeout(() => this.selectDefaultPaneByIndex(index), 20);\n                }\n            } else {\n                setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);\n            }\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n\n    registerTabsScroll() {\n        setTimeout(() => {\n            const $ul = this.$element.find('> ul');\n            let $liPosition;\n\n            const  $li = $ul.children();\n            $liPosition = $li.last().position();\n            if ($liPosition && ($liPosition.left > $ul.width())) {\n                $ul.on('mousewheel', (e) => {\n                    const left = $ul[0].scrollLeft,\n                        _delta = -1 * e.originalEvent.wheelDelta;\n                    e.stopPropagation();\n                    e.preventDefault();\n                    $ul.animate({scrollLeft: left + _delta}, {'duration': 10});\n                });\n            }\n        });\n    }\n    onkeydown(event) {\n        switch (event.key) {\n            case 'ArrowLeft':\n            case 'ArrowUp':\n                this.prev(null, true);\n                event.preventDefault();\n                break;\n\n            case 'ArrowRight':\n            case 'ArrowDown':\n                this.next(null, true);\n                event.preventDefault();\n                break;\n            default:\n                break;\n        }\n    }\n\n    ngAfterContentInit() {\n        this.promiseResolverFn();\n        super.ngAfterContentInit();\n        this.setTabsPosition();\n        this.panes.changes.subscribe( slides => {\n            if (this.panes.length) {\n                this.selectDefaultPaneByIndex(this.defaultpaneindex || 0);\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        this.registerTabsScroll();\n    }\n}\n","<ul class=\"nav nav-tabs\" [ngClass]=\"{'nav-stacked': vertical, 'nav-justified': justified}\" role=\"tablist\">\n  @for (pane of panes; track pane; let i = $index) {\n    <li class=\"tab-header\" [attr.data-paneid]=\"pane.widgetId\" [ngClass]=\"{'active': pane.isActive, 'disabled': pane.disabled}\"\n      [hidden]=\"!pane.show\" role=\"presentation\">\n      <a [attr.aria-label]=\"pane.badgevalue ? pane.title + ' ' + pane.badgevalue : pane.title\"\n        [attr.icon-position]=\"iconposition\"\n        [attr.title]=\"pane.title\"\n        [tabindex]=\"pane.isActive ? '0' : '-1'\"\n        class=\"tab-heading\" href=\"javascript:void(0);\"\n        [attr.aria-selected]=\"pane.isActive\" role=\"tab\" (click)=\"pane.select($event); pane.tabpaneHeaderClick($event, i);\" (keydown)=\"onkeydown($event)\">\n        @if (pane.paneicon) {\n          <i [ngClass]=\"['app-icon', pane.paneicon]\"></i>\n        }\n        <span [textContent]=\"pane.title\"></span>\n        @if (pane.badgevalue) {\n          <span class=\"label label-{{pane.badgetype}}\" [textContent]=\"pane.badgevalue\"></span>\n        }\n      </a>\n    </li>\n  }\n</ul>\n@if (type !== 'dynamic') {\n  <div class=\"tab-content\" [ngClass]=\"{'tab-stacked': vertical, 'tab-justified': justified}\">\n    <ng-content ngProjectAs=\"div[wmTabPane]\"></ng-content>\n  </div>\n}\n@if (type === 'dynamic') {\n  <div class=\"tab-content\" [ngClass]=\"{'tab-stacked': vertical, 'tab-justified': justified}\">\n    @if (fieldDefs && !fieldDefs.length) {\n      <div>{{nodatamessage}}</div>\n    }\n    <ng-content select=\"div[wmRepeatTemplate]\"></ng-content>\n  </div>\n}\n"]}
500
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/containers/tabs/src/tabs.component.ts","../../../../../projects/components/widgets/containers/tabs/src/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { WmComponentsModule } from \"@wm/components/base\";\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    Attribute,\n    Component,\n    ContentChildren, HostBinding, Inject,\n    Injector,\n    OnInit,\n    Optional,\n    QueryList\n} from '@angular/core';\n\nimport {\n    addClass,\n    appendNode,\n    DynamicComponentRefProvider,\n    noop,\n    removeClass,\n    StatePersistence\n} from '@wm/core';\nimport {\n    APPLY_STYLES_TYPE,\n    IWidgetConfig,\n    provideAsWidgetRef,\n    styler,\n    StylableComponent,\n    createArrayFrom\n} from '@wm/components/base';\n\nimport { TabsAnimator } from './tabs.animator';\nimport { registerProps } from './tabs.props';\nimport { TabPaneComponent } from './tab-pane/tab-pane.component';\nimport {find, findIndex, forEach, get, indexOf, isArray, isEmpty} from \"lodash-es\";\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-tabs clearfix';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-tabs',\n    hostClass: DEFAULT_CLS\n};\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, WmComponentsModule],\n    selector: 'div[wmTabs]',\n    templateUrl: './tabs.component.html',\n    exportAs: 'wmTabs',\n    providers: [\n        provideAsWidgetRef(TabsComponent)\n    ]\n})\nexport class TabsComponent extends StylableComponent implements AfterContentInit, OnInit, AfterViewInit {\n    static initializeProps = registerProps();\n\n    public defaultpaneindex: number;\n    public transition: string;\n    public tabsposition: string;\n    public statehandler: any;\n    private statePersistence: StatePersistence;\n\n    public vertical: boolean;\n    public justified: boolean;\n    private activeTab: TabPaneComponent;\n    private readonly promiseResolverFn: Function;\n    private tabsAnimator: TabsAnimator;\n    private _oldPaneIndex: number;\n    private isPageLoadCall: boolean;\n    private dynamicComponentProvider;\n    private _dynamicContext;\n    private dynamicPaneIndex;\n    public dynamicTabs;\n    public fieldDefs;\n    public type;\n    public nodatamessage;\n    public autoActivation:boolean;\n\n    @HostBinding('attr.icon-position') iconposition: string = '';\n\n    @ContentChildren(TabPaneComponent) panes: QueryList<TabPaneComponent>;\n\n    constructor(\n        inj: Injector,\n        dynamicComponentProvider: DynamicComponentRefProvider,\n        @Attribute('transition') _transition: string,\n        @Attribute('tabsposition') _tabsPosition: string,\n        statePersistence: StatePersistence,\n        @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any\n    ) {\n        // handle to the promise resolver\n        let resolveFn: Function = noop;\n        super(inj, WIDGET_CONFIG, explicitContext, new Promise(res => resolveFn = res));\n\n        this.transition = _transition;\n        this.tabsposition = _tabsPosition;\n        this.statePersistence = statePersistence;\n        this.dynamicComponentProvider = dynamicComponentProvider;\n        this.dynamicTabs = [];\n        this.dynamicPaneIndex = 0;\n\n        this.promiseResolverFn = resolveFn;\n\n        styler(this.nativeElement, this, APPLY_STYLES_TYPE.CONTAINER);\n\n    }\n\n    animateIn (element: HTMLElement) {\n        const tabHeader = $(element);\n        // when the animation is not present toggle the active class.\n        tabHeader.siblings('.active').removeClass('active');\n        tabHeader.addClass('active');\n\n        const ul = this.nativeElement.querySelector('ul.nav.nav-tabs');\n\n        // move the tabheader into the viewport\n        const $prevHeaderEle = tabHeader.prev();\n        if ($prevHeaderEle.length) {\n            ul.scrollLeft = $prevHeaderEle[0].offsetLeft;\n        } else {\n            ul.scrollLeft = 0;\n        }\n    }\n\n    /**\n     * This method is used to register the dynamic panes.\n     * After all panes are initialzed, update the querylist manually based on index.\n     * @param paneRef - refrence of the tabpane\n     */\n    public registerDynamicTab(paneRef) {\n        this.dynamicTabs.push(paneRef);\n        const isLastPane =  this.dynamicTabs.length === this.dynamicPaneIndex;\n        if (isLastPane) {\n            for (let i = 0; i < this.dynamicTabs.length; i++) {\n                const newPaneRef = find(this.dynamicTabs, pane => pane.dynamicPaneIndex === i);\n                const isPaneAlreadyExist = find(this.panes.toArray(), newPaneRef);\n                if (!isPaneAlreadyExist) {\n                    this.panes.reset([...this.panes.toArray(), newPaneRef]);\n                    if (newPaneRef.active) {\n                        setTimeout(() => {\n                            newPaneRef.select();\n                        }, 20);\n                    }\n                }\n            }\n        }\n    }\n\n    /**\n     * This method is to add the tabpane dynamically\n     * @param tabpanes - list of tabpanes\n     */\n    public addPane(tabpanes) {\n        if (!isArray(tabpanes)) {\n            tabpanes = [tabpanes];\n        }\n        const paneNamesList = [];\n        forEach(tabpanes, (pane, index) => {\n            const isPaneAlreadyCreated = find(this.panes.toArray(), {name: pane.name});\n            const isPaneNameExist = indexOf(paneNamesList, pane.name);\n            // If user tries to add tabpane with the same name which is already exists then do not create the pane\n            if (isPaneAlreadyCreated || isPaneNameExist > 0) {\n                console.warn(`The tab pane with name ${pane.name} already exists`);\n                return;\n            }\n\n            let paramMarkup = '';\n            let propsTmpl = '';\n            this.dynamicPaneIndex++;\n            const name = pane.name ? pane.name : `tabpane${this.panes.toArray().length + (index + 1)}`;\n            paneNamesList.push(name);\n            const partialParams = get(pane, 'params');\n\n            forEach(pane, (value, key) => {\n                if (key !== 'params') {\n                    propsTmpl = `${propsTmpl} ${key}=\"${value}\"`;\n                }\n            });\n\n            forEach(partialParams, (value, key) => {\n                paramMarkup = `${paramMarkup} <wm-param name=\"${key}\" value=\"${value}\"></wm-param>`;\n            });\n            const markup = `<wm-tabpane dynamicPaneIndex=\"${this.dynamicPaneIndex - 1}\" isdynamic=\"true\" name=\"${name}\" ${propsTmpl}>\n                            ${paramMarkup}\n                        </wm-tabpane>`;\n\n            if (!this._dynamicContext) {\n                this._dynamicContext = Object.create(this.viewParent);\n                this._dynamicContext[this.getAttr('wmTab')] = this;\n            }\n\n            this.dynamicComponentProvider.addComponent(this.getNativeElement().querySelector('.tab-content'), markup, this._dynamicContext, {inj: this.inj});\n\n        });\n        return paneNamesList;\n    }\n\n    /**\n     * This method is to remove the tabpane\n     * @param paneIndex - index of the pane\n     */\n    public removePane(paneName) {\n        const paneRef = this.getPaneRefByName(paneName);\n        if (paneRef) {\n            paneRef.remove();\n        }\n    }\n\n    /**\n     * TabPane children components invoke this method to communicate with the parent\n     * if the evt argument is defined on-change callback will be invoked.\n     */\n    public notifyChange(paneRef: TabPaneComponent, evt: Event, isKeyBoardEvent: boolean) {\n        if (!this.isSelectableTab(paneRef)) {\n            return;\n        }\n\n        let headerElement;\n        // invoke deselect event callback on the preset active tab\n        if (!isEmpty(this.activeTab)) {\n            this.activeTab.deselect();\n        }\n\n\n        this.activeTab = paneRef.getWidget();\n        const newPaneIndex = this.getPaneIndexByRef(paneRef);\n        const mode = this.statePersistence.computeMode(this.statehandler);\n        if (!this.isPageLoadCall && mode && mode.toLowerCase() !== 'none') {\n            this.statePersistence.setWidgetState(this, this.activeTab.name);\n        } else {\n            this.defaultpaneindex = this.getPaneIndexByRef(paneRef);\n            this.isPageLoadCall = false;\n        }\n\n        // invoke select callback on the selected tab\n        paneRef.invokeOnSelectCallback(evt);\n\n        // invoke change callback if the evt is present, select a tab programmatically will not have the event\n        if (evt) {\n            this.invokeEventCallback('change', {\n                $event: evt,\n                newPaneIndex: newPaneIndex,\n                oldPaneIndex: this._oldPaneIndex || 0\n            });\n        }\n        this._oldPaneIndex = newPaneIndex;\n\n        if (evt) {\n            headerElement = $(evt.target as HTMLElement).closest('li.tab-header');\n        }\n        if (!evt || !headerElement || !headerElement.length) {\n            headerElement = this.nativeElement.querySelector(`li[data-paneid=${paneRef.widgetId}]`);\n            const insideTabs = !!$(headerElement).closest('.app-tabs')\n                .parent().closest('.app-tabs').length;\n            if (!insideTabs && isKeyBoardEvent) {\n                $(headerElement).children().focus();\n            }\n        }\n        this.animateIn(headerElement);\n\n        // this.setTabsLeftPosition(this.getPaneIndexByRef(this.activeTab), this.panes.length);\n        if (this.canSlide()) {\n            if (!this.tabsAnimator) {\n                this.tabsAnimator = new TabsAnimator(this);\n                this.tabsAnimator.setGesturesEnabled(this.canSlide());\n            }\n            this.tabsAnimator.transitionTabIntoView();\n        }\n    }\n\n    public goToTab(tabIndex) {\n        if (this.isValidPaneIndex(tabIndex - 1)) {\n            const tab = this.getPaneRefByIndex(tabIndex - 1);\n            tab.select();\n        }\n    }\n\n    private getPaneIndexByRef(paneRef: TabPaneComponent): number {\n        return this.panes.toArray().indexOf(paneRef);\n    }\n\n    // Returns the active tab index from tabs.\n    public getActiveTabIndex(): number {\n        return findIndex(this.panes.toArray(), {isActive: true});\n    }\n\n    private isValidPaneIndex(index: number): boolean {\n        return (index >= 0 && index < this.panes.length);\n    }\n\n    private getPaneRefByIndex(index: number): TabPaneComponent {\n        return this.panes.toArray()[index];\n    }\n\n    private getPaneRefByName(name: string): TabPaneComponent {\n        return find(this.panes.toArray(), {name: name});\n    }\n\n    // returns false if the pane is hidden or disabled\n    private isSelectableTab(paneRef: TabPaneComponent): boolean {\n        return paneRef.show && !paneRef.disabled;\n    }\n\n    private canSlide() {\n        return this.transition === 'slide' && !this.vertical;\n    }\n\n    private getSelectableTabAfterIndex(index: number): TabPaneComponent {\n        for (let i = index + 1; i < this.panes.length; i++) {\n            const pane = this.getPaneRefByIndex(i);\n            if (this.isSelectableTab(pane)) {\n                return pane;\n            }\n        }\n        if (index === this.panes.length - 1) {\n            const pane = this.getPaneRefByIndex(0);\n             if (this.isSelectableTab(pane)) {\n                return pane;\n             }\n        }\n    }\n\n    private getSelectableTabBeforeIndex(index: number): TabPaneComponent {\n        for (let i = index - 1; i >= 0; i--) {\n            const pane = this.getPaneRefByIndex(i);\n            if (this.isSelectableTab(pane)) {\n                return pane;\n            }\n        }\n        if (index === 0) {\n            const pane = this.getPaneRefByIndex(this.panes.length - 1);\n            if (this.isSelectableTab(pane)) {\n                return pane;\n            }\n        }\n    }\n\n    // select next tab relative to the current active tab\n    public next($event?: Event, isKeyBoardEvent?: boolean) {\n        const pane = this.getSelectableTabAfterIndex(this.getActiveTabIndex());\n        if (pane) {\n            pane.select($event, isKeyBoardEvent);\n        }\n    }\n\n    // select prev tab relative to the current active tab\n    public prev($event?: Event, isKeyBoardEvent?: boolean) {\n        const pane = this.getSelectableTabBeforeIndex(this.getActiveTabIndex());\n        if (pane) {\n            pane.select($event, isKeyBoardEvent);\n        }\n    }\n\n    /**\n     * this method will be invoked during the initialization of the component and on defaultpaneindex property change,\n     * if the provided defaultpaneindex is not valid, find the first pane index which can be shown and select it\n     */\n    private selectDefaultPaneByIndex(index: number) {\n        if (!this.isValidPaneIndex(index)) {\n            return;\n        }\n\n        let paneRef = this.getPaneRefByIndex(index);\n        if (!this.isSelectableTab(paneRef)) {\n            paneRef = this.getSelectableTabAfterIndex(0);\n        }\n        if (paneRef) {\n            paneRef.select();\n        }\n    }\n\n    // update the postion of tab header\n    private setTabsPosition() {\n        const ul = this.nativeElement.children[0];\n\n        this.vertical = (this.tabsposition === 'left' || this.tabsposition === 'right');\n\n        removeClass(this.nativeElement, 'inverted');\n        if (this.tabsposition === 'bottom' || this.tabsposition === 'right') {\n            appendNode(ul as HTMLElement, this.nativeElement);\n            addClass(this.nativeElement, 'inverted');\n        }\n    }\n\n    private onDataChange(newVal) {\n        this.fieldDefs = createArrayFrom(newVal);\n        setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0));\n    }\n\n    onPropertyChange(key: string, nv: any, ov) {\n\n        if (key === 'defaultpaneindex') {\n            this.defaultpaneindex = nv;\n        } else if (key === 'dataset') {\n            this.onDataChange(nv);\n        } else if (key === 'statehandler') {\n            this.isPageLoadCall = true;\n            const widgetState = this.statePersistence.getWidgetState(this);\n            if (nv !== 'none' && widgetState) {\n                const paneToSelect: any = this.panes.filter(function(pane) {\n                    return widgetState === pane.name;\n                });\n                if (!paneToSelect.length) {\n                    console.warn('Tab pane name ' + widgetState + ' in State is incorrect. Falling back to the default pane');\n                    setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);\n                } else {\n                    const index = this.getPaneIndexByRef(paneToSelect[0]);\n                    setTimeout(() => this.selectDefaultPaneByIndex(index), 20);\n                }\n            } else {\n                setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);\n            }\n        } else if (key === 'autotabactivation'){\n            this.autoActivation = nv;\n        } else {\n            super.onPropertyChange(key, nv, ov);\n        }\n    }\n\n    registerTabsScroll() {\n        setTimeout(() => {\n            const $ul = this.$element.find('> ul');\n            let $liPosition;\n\n            const  $li = $ul.children();\n            $liPosition = $li.last().position();\n            if ($liPosition && ($liPosition.left > $ul.width())) {\n                $ul.on('mousewheel', (e) => {\n                    const left = $ul[0].scrollLeft,\n                        _delta = -1 * e.originalEvent.wheelDelta;\n                    e.stopPropagation();\n                    e.preventDefault();\n                    $ul.animate({scrollLeft: left + _delta}, {'duration': 10});\n                });\n            }\n        });\n    }\n    onkeydown(event) {\n        let newPane;\n        switch (event.key) {\n            case 'ArrowLeft':\n            case 'ArrowUp':\n                newPane = this.autoActivation ? (this.prev(null, true), null) : this.getSelectableTabBeforeIndex(this.getSelectedPaneIndex());\n                break;\n\n            case 'ArrowRight':\n            case 'ArrowDown':\n                newPane = this.autoActivation ? (this.next(null, true), null) : this.getSelectableTabAfterIndex(this.getSelectedPaneIndex());\n                break;\n\n            case 'Enter': {\n                const pane = this.getSelectableTabAfterIndex(this.getSelectedPaneIndex()-1);\n                if (pane) {\n                    const enterEvent = new KeyboardEvent('keydown', {key: 'Enter', code: 'Enter', bubbles: true, cancelable: true});\n                    pane.nativeElement.dispatchEvent(enterEvent);\n                    pane.select(enterEvent, true);\n                }\n                event.preventDefault();\n                return ;\n            }\n            default:\n                return;\n        }\n        if (newPane) {\n            this.nativeElement.querySelector('li.select')?.classList.remove('select');\n            this.nativeElement.querySelector(`li[data-paneid=\"${newPane.widgetId}\"]`)?.classList.add('select');\n        }\n        event.preventDefault();\n    }\n\n    ngAfterContentInit() {\n        this.promiseResolverFn();\n        super.ngAfterContentInit();\n        this.setTabsPosition();\n        this.panes.changes.subscribe( slides => {\n            if (this.panes.length) {\n                this.selectDefaultPaneByIndex(this.defaultpaneindex || 0);\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        this.registerTabsScroll();\n    }\n\n    getSelectedPaneIndex() {\n        const index = this.panes.toArray().findIndex(pane =>\n            this.nativeElement.querySelector(`li[data-paneid=\"${pane.widgetId}\"]`)?.classList.contains(\"select\"));\n        return index >= 0 ? index : this.getActiveTabIndex();\n    }\n}\n","<ul class=\"nav nav-tabs\" [ngClass]=\"{'nav-stacked': vertical, 'nav-justified': justified}\" role=\"tablist\">\n  @for (pane of panes; track pane; let i = $index) {\n    <li class=\"tab-header\" [attr.data-paneid]=\"pane.widgetId\" [ngClass]=\"{'active': pane.isActive, 'disabled': pane.disabled}\"\n      [hidden]=\"!pane.show\" role=\"presentation\">\n      <a [attr.aria-label]=\"pane.badgevalue ? pane.title + ' ' + pane.badgevalue : pane.title\"\n        [attr.icon-position]=\"iconposition\"\n        [attr.title]=\"pane.title\"\n        [tabindex]=\"pane.isActive ? '0' : '-1'\"\n        class=\"tab-heading\" href=\"javascript:void(0);\"\n        [attr.aria-selected]=\"pane.isActive\" role=\"tab\" (click)=\"pane.select($event); pane.tabpaneHeaderClick($event, i);\" (keydown)=\"onkeydown($event)\">\n        @if (pane.paneicon) {\n          <i [ngClass]=\"['app-icon', pane.paneicon]\"></i>\n        }\n        <span [textContent]=\"pane.title\"></span>\n        @if (pane.badgevalue) {\n          <span class=\"label label-{{pane.badgetype}}\" [textContent]=\"pane.badgevalue\"></span>\n        }\n      </a>\n    </li>\n  }\n</ul>\n@if (type !== 'dynamic') {\n  <div class=\"tab-content\" [ngClass]=\"{'tab-stacked': vertical, 'tab-justified': justified}\">\n    <ng-content ngProjectAs=\"div[wmTabPane]\"></ng-content>\n  </div>\n}\n@if (type === 'dynamic') {\n  <div class=\"tab-content\" [ngClass]=\"{'tab-stacked': vertical, 'tab-justified': justified}\">\n    @if (fieldDefs && !fieldDefs.length) {\n      <div>{{nodatamessage}}</div>\n    }\n    <ng-content select=\"div[wmRepeatTemplate]\"></ng-content>\n  </div>\n}\n"]}
@@ -13,7 +13,8 @@ export const registerProps = () => {
13
13
  ['transition', PROP_STRING],
14
14
  ['type', PROP_STRING],
15
15
  ['iconposition', PROP_STRING],
16
+ ['autotabactivation', { value: true, ...PROP_BOOLEAN }]
16
17
  ]);
17
18
  register('wm-tabs', props);
18
19
  };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5wcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvd2lkZ2V0cy9jb250YWluZXJzL3RhYnMvc3JjL3RhYnMucHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUVoRyxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsR0FBRyxFQUFFO0lBQzlCLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUNqQjtRQUNJLENBQUMsT0FBTyxFQUFFLFdBQVcsQ0FBQztRQUN0QixDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUM7UUFDckIsQ0FBQyxrQkFBa0IsRUFBRSxFQUFDLEtBQUssRUFBRSxDQUFDLEVBQUUsR0FBRyxXQUFXLEVBQUMsQ0FBQztRQUNoRCxDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUM7UUFDM0IsQ0FBQyxjQUFjLEVBQUUsRUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEdBQUcsV0FBVyxFQUFDLENBQUM7UUFDaEQsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDO1FBQ3JCLENBQUMsZUFBZSxFQUFFLEVBQUMsS0FBSyxFQUFFLGVBQWUsRUFBRSxHQUFJLFdBQVcsRUFBQyxDQUFDO1FBQzVELENBQUMsTUFBTSxFQUFFLEVBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLFlBQVksRUFBQyxDQUFDO1FBQ3hDLENBQUMsY0FBYyxFQUFFLEVBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLFdBQVcsRUFBQyxDQUFDO1FBQ2pELENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztRQUMzQixDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUM7UUFDckIsQ0FBQyxjQUFjLEVBQUUsV0FBVyxDQUFDO0tBQ2hDLENBQ0osQ0FBQztJQUNGLFFBQVEsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFDL0IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUFJPUF9BTlksIFBST1BfQk9PTEVBTiwgUFJPUF9OVU1CRVIsIFBST1BfU1RSSU5HLCByZWdpc3Rlcn0gZnJvbSAnQHdtL2NvbXBvbmVudHMvYmFzZSc7XG5cbmV4cG9ydCBjb25zdCByZWdpc3RlclByb3BzID0gKCkgPT4ge1xuICAgIGNvbnN0IHByb3BzID0gbmV3IE1hcChcbiAgICAgICAgW1xuICAgICAgICAgICAgWydjbGFzcycsIFBST1BfU1RSSU5HXSxcbiAgICAgICAgICAgIFsnZGF0YXNldCcsIFBST1BfQU5ZXSxcbiAgICAgICAgICAgIFsnZGVmYXVsdHBhbmVpbmRleCcsIHt2YWx1ZTogMCwgLi4uUFJPUF9OVU1CRVJ9XSxcbiAgICAgICAgICAgIFsnanVzdGlmaWVkJywgUFJPUF9CT09MRUFOXSxcbiAgICAgICAgICAgIFsndGFic3Bvc2l0aW9uJywge3ZhbHVlOiAndG9wJywgLi4uUFJPUF9TVFJJTkd9XSxcbiAgICAgICAgICAgIFsnbmFtZScsIFBST1BfU1RSSU5HXSxcbiAgICAgICAgICAgIFsnbm9kYXRhbWVzc2FnZScsIHt2YWx1ZTogJ05vIERhdGEgRm91bmQnLCAuLi4gUFJPUF9TVFJJTkd9XSxcbiAgICAgICAgICAgIFsnc2hvdycsIHt2YWx1ZTogdHJ1ZSwgLi4uUFJPUF9CT09MRUFOfV0sXG4gICAgICAgICAgICBbJ3N0YXRlaGFuZGxlcicsIHt2YWx1ZTogJ25vbmUnLCAuLi5QUk9QX1NUUklOR31dLFxuICAgICAgICAgICAgWyd0cmFuc2l0aW9uJywgUFJPUF9TVFJJTkddLFxuICAgICAgICAgICAgWyd0eXBlJywgUFJPUF9TVFJJTkddLFxuICAgICAgICAgICAgWydpY29ucG9zaXRpb24nLCBQUk9QX1NUUklOR10sXG4gICAgICAgIF1cbiAgICApO1xuICAgIHJlZ2lzdGVyKCd3bS10YWJzJywgcHJvcHMpO1xufTtcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5wcm9wcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvd2lkZ2V0cy9jb250YWluZXJzL3RhYnMvc3JjL3RhYnMucHJvcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUVoRyxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsR0FBRyxFQUFFO0lBQzlCLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUNqQjtRQUNJLENBQUMsT0FBTyxFQUFFLFdBQVcsQ0FBQztRQUN0QixDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUM7UUFDckIsQ0FBQyxrQkFBa0IsRUFBRSxFQUFDLEtBQUssRUFBRSxDQUFDLEVBQUUsR0FBRyxXQUFXLEVBQUMsQ0FBQztRQUNoRCxDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUM7UUFDM0IsQ0FBQyxjQUFjLEVBQUUsRUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEdBQUcsV0FBVyxFQUFDLENBQUM7UUFDaEQsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDO1FBQ3JCLENBQUMsZUFBZSxFQUFFLEVBQUMsS0FBSyxFQUFFLGVBQWUsRUFBRSxHQUFJLFdBQVcsRUFBQyxDQUFDO1FBQzVELENBQUMsTUFBTSxFQUFFLEVBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLFlBQVksRUFBQyxDQUFDO1FBQ3hDLENBQUMsY0FBYyxFQUFFLEVBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLFdBQVcsRUFBQyxDQUFDO1FBQ2pELENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztRQUMzQixDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUM7UUFDckIsQ0FBQyxjQUFjLEVBQUUsV0FBVyxDQUFDO1FBQzdCLENBQUMsbUJBQW1CLEVBQUUsRUFBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLEdBQUcsWUFBWSxFQUFDLENBQUM7S0FDeEQsQ0FDSixDQUFDO0lBQ0YsUUFBUSxDQUFDLFNBQVMsRUFBRSxLQUFLLENBQUMsQ0FBQztBQUMvQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQUk9QX0FOWSwgUFJPUF9CT09MRUFOLCBQUk9QX05VTUJFUiwgUFJPUF9TVFJJTkcsIHJlZ2lzdGVyfSBmcm9tICdAd20vY29tcG9uZW50cy9iYXNlJztcblxuZXhwb3J0IGNvbnN0IHJlZ2lzdGVyUHJvcHMgPSAoKSA9PiB7XG4gICAgY29uc3QgcHJvcHMgPSBuZXcgTWFwKFxuICAgICAgICBbXG4gICAgICAgICAgICBbJ2NsYXNzJywgUFJPUF9TVFJJTkddLFxuICAgICAgICAgICAgWydkYXRhc2V0JywgUFJPUF9BTlldLFxuICAgICAgICAgICAgWydkZWZhdWx0cGFuZWluZGV4Jywge3ZhbHVlOiAwLCAuLi5QUk9QX05VTUJFUn1dLFxuICAgICAgICAgICAgWydqdXN0aWZpZWQnLCBQUk9QX0JPT0xFQU5dLFxuICAgICAgICAgICAgWyd0YWJzcG9zaXRpb24nLCB7dmFsdWU6ICd0b3AnLCAuLi5QUk9QX1NUUklOR31dLFxuICAgICAgICAgICAgWyduYW1lJywgUFJPUF9TVFJJTkddLFxuICAgICAgICAgICAgWydub2RhdGFtZXNzYWdlJywge3ZhbHVlOiAnTm8gRGF0YSBGb3VuZCcsIC4uLiBQUk9QX1NUUklOR31dLFxuICAgICAgICAgICAgWydzaG93Jywge3ZhbHVlOiB0cnVlLCAuLi5QUk9QX0JPT0xFQU59XSxcbiAgICAgICAgICAgIFsnc3RhdGVoYW5kbGVyJywge3ZhbHVlOiAnbm9uZScsIC4uLlBST1BfU1RSSU5HfV0sXG4gICAgICAgICAgICBbJ3RyYW5zaXRpb24nLCBQUk9QX1NUUklOR10sXG4gICAgICAgICAgICBbJ3R5cGUnLCBQUk9QX1NUUklOR10sXG4gICAgICAgICAgICBbJ2ljb25wb3NpdGlvbicsIFBST1BfU1RSSU5HXSxcbiAgICAgICAgICAgIFsnYXV0b3RhYmFjdGl2YXRpb24nLCB7dmFsdWU6IHRydWUsIC4uLlBST1BfQk9PTEVBTn1dXG4gICAgICAgIF1cbiAgICApO1xuICAgIHJlZ2lzdGVyKCd3bS10YWJzJywgcHJvcHMpO1xufTtcbiJdfQ==
@@ -104,6 +104,7 @@ const registerProps$1 = () => {
104
104
  ['transition', PROP_STRING],
105
105
  ['type', PROP_STRING],
106
106
  ['iconposition', PROP_STRING],
107
+ ['autotabactivation', { value: true, ...PROP_BOOLEAN }]
107
108
  ]);
108
109
  register('wm-tabs', props);
109
110
  };
@@ -660,6 +661,9 @@ class TabsComponent extends StylableComponent {
660
661
  setTimeout(() => this.selectDefaultPaneByIndex(this.defaultpaneindex || 0), 20);
661
662
  }
662
663
  }
664
+ else if (key === 'autotabactivation') {
665
+ this.autoActivation = nv;
666
+ }
663
667
  else {
664
668
  super.onPropertyChange(key, nv, ov);
665
669
  }
@@ -681,20 +685,34 @@ class TabsComponent extends StylableComponent {
681
685
  });
682
686
  }
683
687
  onkeydown(event) {
688
+ let newPane;
684
689
  switch (event.key) {
685
690
  case 'ArrowLeft':
686
691
  case 'ArrowUp':
687
- this.prev(null, true);
688
- event.preventDefault();
692
+ newPane = this.autoActivation ? (this.prev(null, true), null) : this.getSelectableTabBeforeIndex(this.getSelectedPaneIndex());
689
693
  break;
690
694
  case 'ArrowRight':
691
695
  case 'ArrowDown':
692
- this.next(null, true);
693
- event.preventDefault();
696
+ newPane = this.autoActivation ? (this.next(null, true), null) : this.getSelectableTabAfterIndex(this.getSelectedPaneIndex());
694
697
  break;
698
+ case 'Enter': {
699
+ const pane = this.getSelectableTabAfterIndex(this.getSelectedPaneIndex() - 1);
700
+ if (pane) {
701
+ const enterEvent = new KeyboardEvent('keydown', { key: 'Enter', code: 'Enter', bubbles: true, cancelable: true });
702
+ pane.nativeElement.dispatchEvent(enterEvent);
703
+ pane.select(enterEvent, true);
704
+ }
705
+ event.preventDefault();
706
+ return;
707
+ }
695
708
  default:
696
- break;
709
+ return;
697
710
  }
711
+ if (newPane) {
712
+ this.nativeElement.querySelector('li.select')?.classList.remove('select');
713
+ this.nativeElement.querySelector(`li[data-paneid="${newPane.widgetId}"]`)?.classList.add('select');
714
+ }
715
+ event.preventDefault();
698
716
  }
699
717
  ngAfterContentInit() {
700
718
  this.promiseResolverFn();
@@ -710,6 +728,10 @@ class TabsComponent extends StylableComponent {
710
728
  super.ngAfterViewInit();
711
729
  this.registerTabsScroll();
712
730
  }
731
+ getSelectedPaneIndex() {
732
+ const index = this.panes.toArray().findIndex(pane => this.nativeElement.querySelector(`li[data-paneid="${pane.widgetId}"]`)?.classList.contains("select"));
733
+ return index >= 0 ? index : this.getActiveTabIndex();
734
+ }
713
735
  static { this.ɵfac = function TabsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TabsComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.DynamicComponentRefProvider), i0.ɵɵinjectAttribute('transition'), i0.ɵɵinjectAttribute('tabsposition'), i0.ɵɵdirectiveInject(i1.StatePersistence), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
714
736
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TabsComponent, selectors: [["div", "wmTabs", ""]], contentQueries: function TabsComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
715
737
  i0.ɵɵcontentQuery(dirIndex, TabPaneComponent, 4);