@aquera/nile-elements 1.6.7 → 1.6.9
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.
- package/README.md +12 -0
- package/dist/index.cjs.js +1 -1
- package/dist/index.esm.js +1 -1
- package/dist/index.js +1735 -495
- package/dist/internal/enum.cjs.js +1 -1
- package/dist/internal/enum.cjs.js.map +1 -1
- package/dist/internal/enum.esm.js +1 -1
- package/dist/nile-auto-complete/nile-auto-complete.cjs.js +1 -1
- package/dist/nile-auto-complete/nile-auto-complete.cjs.js.map +1 -1
- package/dist/nile-auto-complete/nile-auto-complete.esm.js +1 -1
- package/dist/nile-calendar/nile-calendar.cjs.js +1 -1
- package/dist/nile-calendar/nile-calendar.cjs.js.map +1 -1
- package/dist/nile-calendar/nile-calendar.css.cjs.js +1 -1
- package/dist/nile-calendar/nile-calendar.css.cjs.js.map +1 -1
- package/dist/nile-calendar/nile-calendar.css.esm.js +0 -3
- package/dist/nile-calendar/nile-calendar.esm.js +2 -2
- package/dist/nile-dropdown/nile-dropdown.cjs.js +1 -1
- package/dist/nile-dropdown/nile-dropdown.cjs.js.map +1 -1
- package/dist/nile-dropdown/nile-dropdown.esm.js +1 -1
- package/dist/nile-inline-sidebar/index.cjs.js +1 -1
- package/dist/nile-inline-sidebar/index.esm.js +1 -1
- package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js +1 -1
- package/dist/nile-inline-sidebar/nile-inline-sidebar.cjs.js.map +1 -1
- package/dist/nile-inline-sidebar/nile-inline-sidebar.css.cjs.js +1 -1
- package/dist/nile-inline-sidebar/nile-inline-sidebar.css.cjs.js.map +1 -1
- package/dist/nile-inline-sidebar/nile-inline-sidebar.css.esm.js +76 -19
- package/dist/nile-inline-sidebar/nile-inline-sidebar.esm.js +42 -23
- package/dist/nile-inline-sidebar-group/nile-inline-sidebar-group.css.cjs.js +1 -1
- package/dist/nile-inline-sidebar-group/nile-inline-sidebar-group.css.cjs.js.map +1 -1
- package/dist/nile-inline-sidebar-group/nile-inline-sidebar-group.css.esm.js +8 -9
- package/dist/nile-inline-sidebar-item/index.cjs.js +1 -1
- package/dist/nile-inline-sidebar-item/index.esm.js +1 -1
- package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.cjs.js +1 -1
- package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.cjs.js.map +1 -1
- package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.css.cjs.js +1 -1
- package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.css.cjs.js.map +1 -1
- package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.css.esm.js +16 -18
- package/dist/nile-inline-sidebar-item/nile-inline-sidebar-item.esm.js +22 -4
- package/dist/nile-inline-sidebar-item-body/index.cjs.js +2 -0
- package/dist/nile-inline-sidebar-item-body/index.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-item-body/index.esm.js +1 -0
- package/dist/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.cjs.js +2 -0
- package/dist/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.cjs.js +2 -0
- package/dist/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.esm.js +53 -0
- package/dist/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.esm.js +13 -0
- package/dist/nile-inline-sidebar-item-header/index.cjs.js +2 -0
- package/dist/nile-inline-sidebar-item-header/index.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-item-header/index.esm.js +1 -0
- package/dist/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.cjs.js +2 -0
- package/dist/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.cjs.js +2 -0
- package/dist/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.esm.js +27 -0
- package/dist/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.esm.js +16 -0
- package/dist/nile-inline-sidebar-panel/index.cjs.js +2 -0
- package/dist/nile-inline-sidebar-panel/index.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-panel/index.esm.js +1 -0
- package/dist/nile-inline-sidebar-panel/nile-inline-sidebar-panel.cjs.js +2 -0
- package/dist/nile-inline-sidebar-panel/nile-inline-sidebar-panel.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.cjs.js +2 -0
- package/dist/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.esm.js +19 -0
- package/dist/nile-inline-sidebar-panel/nile-inline-sidebar-panel.esm.js +5 -0
- package/dist/nile-inline-sidebar-panel-group/index.cjs.js +2 -0
- package/dist/nile-inline-sidebar-panel-group/index.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-panel-group/index.esm.js +1 -0
- package/dist/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.cjs.js +2 -0
- package/dist/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.cjs.js +2 -0
- package/dist/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.cjs.js.map +1 -0
- package/dist/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.esm.js +30 -0
- package/dist/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.esm.js +12 -0
- package/dist/nile-nav-tab/index.cjs.js +2 -0
- package/dist/nile-nav-tab/index.cjs.js.map +1 -0
- package/dist/nile-nav-tab/index.esm.js +1 -0
- package/dist/nile-nav-tab/nile-nav-tab.cjs.js +2 -0
- package/dist/nile-nav-tab/nile-nav-tab.cjs.js.map +1 -0
- package/dist/nile-nav-tab/nile-nav-tab.css.cjs.js +2 -0
- package/dist/nile-nav-tab/nile-nav-tab.css.cjs.js.map +1 -0
- package/dist/nile-nav-tab/nile-nav-tab.css.esm.js +190 -0
- package/dist/nile-nav-tab/nile-nav-tab.esm.js +36 -0
- package/dist/nile-nav-tab-group/index.cjs.js +2 -0
- package/dist/nile-nav-tab-group/index.cjs.js.map +1 -0
- package/dist/nile-nav-tab-group/index.esm.js +1 -0
- package/dist/nile-nav-tab-group/nile-nav-tab-group.cjs.js +4 -0
- package/dist/nile-nav-tab-group/nile-nav-tab-group.cjs.js.map +1 -0
- package/dist/nile-nav-tab-group/nile-nav-tab-group.css.cjs.js +2 -0
- package/dist/nile-nav-tab-group/nile-nav-tab-group.css.cjs.js.map +1 -0
- package/dist/nile-nav-tab-group/nile-nav-tab-group.css.esm.js +668 -0
- package/dist/nile-nav-tab-group/nile-nav-tab-group.esm.js +61 -0
- package/dist/nile-nav-tab-panel/index.cjs.js +2 -0
- package/dist/nile-nav-tab-panel/index.cjs.js.map +1 -0
- package/dist/nile-nav-tab-panel/index.esm.js +1 -0
- package/dist/nile-nav-tab-panel/nile-nav-tab-panel.cjs.js +2 -0
- package/dist/nile-nav-tab-panel/nile-nav-tab-panel.cjs.js.map +1 -0
- package/dist/nile-nav-tab-panel/nile-nav-tab-panel.css.cjs.js +2 -0
- package/dist/nile-nav-tab-panel/nile-nav-tab-panel.css.cjs.js.map +1 -0
- package/dist/nile-nav-tab-panel/nile-nav-tab-panel.css.esm.js +22 -0
- package/dist/nile-nav-tab-panel/nile-nav-tab-panel.esm.js +8 -0
- package/dist/nile-stepper-item/nile-stepper-item.cjs.js +1 -1
- package/dist/nile-stepper-item/nile-stepper-item.cjs.js.map +1 -1
- package/dist/nile-stepper-item/nile-stepper-item.esm.js +13 -13
- package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js +1 -1
- package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.cjs.js.map +1 -1
- package/dist/nile-vertical-stepper-item/nile-vertical-stepper-item.esm.js +1 -1
- package/dist/src/index.d.ts +7 -0
- package/dist/src/index.js +7 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/internal/enum.d.ts +6 -0
- package/dist/src/internal/enum.js +7 -0
- package/dist/src/internal/enum.js.map +1 -1
- package/dist/src/nile-auto-complete/nile-auto-complete.js +1 -1
- package/dist/src/nile-auto-complete/nile-auto-complete.js.map +1 -1
- package/dist/src/nile-calendar/nile-calendar.css.js +0 -3
- package/dist/src/nile-calendar/nile-calendar.css.js.map +1 -1
- package/dist/src/nile-calendar/nile-calendar.js +2 -2
- package/dist/src/nile-calendar/nile-calendar.js.map +1 -1
- package/dist/src/nile-dropdown/nile-dropdown.d.ts +2 -0
- package/dist/src/nile-dropdown/nile-dropdown.js +21 -5
- package/dist/src/nile-dropdown/nile-dropdown.js.map +1 -1
- package/dist/src/nile-inline-sidebar/nile-inline-sidebar.css.d.ts +1 -0
- package/dist/src/nile-inline-sidebar/nile-inline-sidebar.css.js +75 -17
- package/dist/src/nile-inline-sidebar/nile-inline-sidebar.css.js.map +1 -1
- package/dist/src/nile-inline-sidebar/nile-inline-sidebar.d.ts +17 -1
- package/dist/src/nile-inline-sidebar/nile-inline-sidebar.js +147 -18
- package/dist/src/nile-inline-sidebar/nile-inline-sidebar.js.map +1 -1
- package/dist/src/nile-inline-sidebar-group/nile-inline-sidebar-group.css.d.ts +1 -0
- package/dist/src/nile-inline-sidebar-group/nile-inline-sidebar-group.css.js +7 -7
- package/dist/src/nile-inline-sidebar-group/nile-inline-sidebar-group.css.js.map +1 -1
- package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.css.d.ts +1 -1
- package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.css.js +15 -17
- package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.css.js.map +1 -1
- package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.d.ts +7 -1
- package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.js +63 -4
- package/dist/src/nile-inline-sidebar-item/nile-inline-sidebar-item.js.map +1 -1
- package/dist/src/nile-inline-sidebar-item-body/index.d.ts +1 -0
- package/dist/src/nile-inline-sidebar-item-body/index.js +2 -0
- package/dist/src/nile-inline-sidebar-item-body/index.js.map +1 -0
- package/dist/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.d.ts +9 -0
- package/dist/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.js +62 -0
- package/dist/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.js.map +1 -0
- package/dist/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.d.ts +45 -0
- package/dist/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.js +110 -0
- package/dist/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.js.map +1 -0
- package/dist/src/nile-inline-sidebar-item-header/index.d.ts +1 -0
- package/dist/src/nile-inline-sidebar-item-header/index.js +2 -0
- package/dist/src/nile-inline-sidebar-item-header/index.js.map +1 -0
- package/dist/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.d.ts +9 -0
- package/dist/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.js +36 -0
- package/dist/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.js.map +1 -0
- package/dist/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.d.ts +34 -0
- package/dist/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.js +68 -0
- package/dist/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.js.map +1 -0
- package/dist/src/nile-inline-sidebar-panel/index.d.ts +1 -0
- package/dist/src/nile-inline-sidebar-panel/index.js +2 -0
- package/dist/src/nile-inline-sidebar-panel/index.js.map +1 -0
- package/dist/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.d.ts +9 -0
- package/dist/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.js +28 -0
- package/dist/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.js.map +1 -0
- package/dist/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.d.ts +35 -0
- package/dist/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.js +55 -0
- package/dist/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.js.map +1 -0
- package/dist/src/nile-inline-sidebar-panel-group/index.d.ts +1 -0
- package/dist/src/nile-inline-sidebar-panel-group/index.js +2 -0
- package/dist/src/nile-inline-sidebar-panel-group/index.js.map +1 -0
- package/dist/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.d.ts +9 -0
- package/dist/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.js +39 -0
- package/dist/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.js.map +1 -0
- package/dist/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.d.ts +43 -0
- package/dist/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.js +93 -0
- package/dist/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.js.map +1 -0
- package/dist/src/nile-nav-tab/index.d.ts +1 -0
- package/dist/src/nile-nav-tab/index.js +2 -0
- package/dist/src/nile-nav-tab/index.js.map +1 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.css.d.ts +9 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.css.js +199 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.css.js.map +1 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.d.ts +50 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.js +190 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.js.map +1 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.test.d.ts +1 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.test.js +656 -0
- package/dist/src/nile-nav-tab/nile-nav-tab.test.js.map +1 -0
- package/dist/src/nile-nav-tab-group/index.d.ts +1 -0
- package/dist/src/nile-nav-tab-group/index.js +2 -0
- package/dist/src/nile-nav-tab-group/index.js.map +1 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.css.d.ts +12 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.css.js +680 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.css.js.map +1 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.d.ts +119 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.js +765 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.js.map +1 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.test.d.ts +3 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.test.js +838 -0
- package/dist/src/nile-nav-tab-group/nile-nav-tab-group.test.js.map +1 -0
- package/dist/src/nile-nav-tab-panel/index.d.ts +1 -0
- package/dist/src/nile-nav-tab-panel/index.js +2 -0
- package/dist/src/nile-nav-tab-panel/index.js.map +1 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.css.d.ts +15 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.css.js +37 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.css.js.map +1 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.d.ts +37 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.js +75 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.js.map +1 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.test.d.ts +1 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.test.js +534 -0
- package/dist/src/nile-nav-tab-panel/nile-nav-tab-panel.test.js.map +1 -0
- package/dist/src/nile-stepper-item/nile-stepper-item.js +1 -1
- package/dist/src/nile-stepper-item/nile-stepper-item.js.map +1 -1
- package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js +1 -1
- package/dist/src/nile-vertical-stepper-item/nile-vertical-stepper-item.js.map +1 -1
- package/dist/src/version.js +1 -1
- package/dist/src/version.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -2
- package/src/index.ts +7 -0
- package/src/internal/enum.ts +8 -1
- package/src/nile-auto-complete/nile-auto-complete.ts +1 -1
- package/src/nile-calendar/nile-calendar.css.ts +0 -3
- package/src/nile-calendar/nile-calendar.ts +2 -2
- package/src/nile-dropdown/nile-dropdown.ts +23 -5
- package/src/nile-inline-sidebar/nile-inline-sidebar.css.ts +75 -17
- package/src/nile-inline-sidebar/nile-inline-sidebar.ts +148 -18
- package/src/nile-inline-sidebar-group/nile-inline-sidebar-group.css.ts +7 -7
- package/src/nile-inline-sidebar-item/nile-inline-sidebar-item.css.ts +15 -17
- package/src/nile-inline-sidebar-item/nile-inline-sidebar-item.ts +74 -9
- package/src/nile-inline-sidebar-item-body/index.ts +1 -0
- package/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.css.ts +64 -0
- package/src/nile-inline-sidebar-item-body/nile-inline-sidebar-item-body.ts +110 -0
- package/src/nile-inline-sidebar-item-header/index.ts +1 -0
- package/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.css.ts +38 -0
- package/src/nile-inline-sidebar-item-header/nile-inline-sidebar-item-header.ts +69 -0
- package/src/nile-inline-sidebar-panel/index.ts +1 -0
- package/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.css.ts +30 -0
- package/src/nile-inline-sidebar-panel/nile-inline-sidebar-panel.ts +53 -0
- package/src/nile-inline-sidebar-panel-group/index.ts +1 -0
- package/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.css.ts +41 -0
- package/src/nile-inline-sidebar-panel-group/nile-inline-sidebar-panel-group.ts +101 -0
- package/src/nile-nav-tab/index.ts +1 -0
- package/src/nile-nav-tab/nile-nav-tab.css.ts +201 -0
- package/src/nile-nav-tab/nile-nav-tab.test.ts +768 -0
- package/src/nile-nav-tab/nile-nav-tab.ts +198 -0
- package/src/nile-nav-tab-group/index.ts +1 -0
- package/src/nile-nav-tab-group/nile-nav-tab-group.css.ts +682 -0
- package/src/nile-nav-tab-group/nile-nav-tab-group.test.ts +1009 -0
- package/src/nile-nav-tab-group/nile-nav-tab-group.ts +845 -0
- package/src/nile-nav-tab-panel/index.ts +1 -0
- package/src/nile-nav-tab-panel/nile-nav-tab-panel.css.ts +39 -0
- package/src/nile-nav-tab-panel/nile-nav-tab-panel.test.ts +797 -0
- package/src/nile-nav-tab-panel/nile-nav-tab-panel.ts +78 -0
- package/src/nile-stepper-item/nile-stepper-item.ts +1 -1
- package/src/nile-vertical-stepper-item/nile-vertical-stepper-item.ts +1 -1
- package/vscode-html-custom-data.json +273 -3
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nile-nav-tab-group.css.js","sourceRoot":"","sources":["../../../src/nile-nav-tab-group/nile-nav-tab-group.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2pBxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2023\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { css } from 'lit';\n\n/**\n * NavTabGroup CSS\n */\nexport const styles = css`\n \n [hidden] {\n display: none;\n }\n\n :host {\n --indicator-color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n --track-color: var(--nile-colors-neutral-400, var(--ng-componentcolors-utility-gray-500));\n --track-width: var(--nile-border-width-1, var(--ng-border-width-1));\n --tab-gap: var(--nile-spacing-lg, var(--ng-spacing-lg));\n -webkit-font-smoothing: var(--nile-webkit-font-smoothing, var(--ng-webkit-font-smoothing));\n -moz-osx-font-smoothing: var(--nile-moz-osx-font-smoothing, var(--ng-moz-osx-font-smoothing));\n text-rendering: var(--nile-text-rendering, var(--ng-text-rendering));\n display: block;\n\n --nile-nav-tab-padding: var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-lg, var(--ng-spacing-lg)) var(--nile-spacing-none, var(--ng-spacing-none)) ; \n }\n\n \n .nav-tab-group {\n display: flex;\n border-radius: var(--nile-radius-none, var(--ng-radius-none));\n }\n\n .nav-tab-group__tabs {\n display: flex;\n position: relative;\n gap: var(--tab-gap);\n margin: 0;\n padding: 0;\n list-style: none;\n }\n\n .hide__track {\n --track-width: 0px;\n --tab-gap: var(--nile-spacing-3px, var(--ng-spacing-xs));\n }\n\n .nav-tab-group__body {\n display: block;\n overflow: auto;\n }\n\n /* --------------------------------------------------------------------------\n * Nav container, scroll buttons, RTL\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group--has-scroll-controls .nav-tab-group__nav-container {\n position: relative;\n padding: var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-10px, var(--ng-spacing-lg));\n }\n \n :host([variant='toggle']) .nav-tab-group--has-scroll-controls .nav-tab-group__nav-container,\n :host([variant='toggle-button']) .nav-tab-group--has-scroll-controls .nav-tab-group__nav-container {\n padding: 0;\n }\n\n :host([variant='toggle']) .nav-tab-group--has-scroll-controls .nav-tab-group__nav,\n :host([variant='toggle-button']) .nav-tab-group--has-scroll-controls .nav-tab-group__nav {\n scroll-padding-inline: var(--nile-width-20px, var(--ng-width-5));\n }\n\n .nav-tab-group__scroll-button {\n display: flex;\n align-items: center;\n justify-content: center;\n position: absolute;\n top: 0;\n bottom: 0;\n width: var(--nile-width-20px, var(--ng-width-5));\n }\n\n .nav-tab-group__scroll-button--start {\n left: 0;\n }\n\n .nav-tab-group__scroll-button--end {\n right: 0;\n }\n\n .nav-tab-group--rtl .nav-tab-group__scroll-button--start {\n left: auto;\n right: -20px;\n }\n\n .nav-tab-group--rtl .nav-tab-group__scroll-button--end {\n left: -20px;\n right: auto;\n }\n\n /* --------------------------------------------------------------------------\n * Indicator, path, pill, no-track\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group__indicator {\n position: absolute;\n transition: 0.3s translate ease, 0.3s width ease;\n z-index: 2;\n }\n\n .nav-tab-group__indicator__path {\n position: absolute;\n height: var(--track-width);\n width: 100%;\n background: var(--nile-colors-neutral-400, var(--ng-colors-bg-quaternary));\n bottom: 0px;\n z-index: 0;\n }\n\n\n\n .nav-tab-group__indicator--no-track {\n display: none;\n }\n\n .nav-tab-group__pill {\n position: absolute;\n top: 0;\n left: 0;\n z-index: 0;\n box-sizing: border-box;\n border-radius: var(--nile-nav-tab-radius);\n background: var(--nile-nav-tab-bg-active);\n box-shadow: var(--nile-nav-tab-active-box-shadow, none);\n opacity: 0;\n pointer-events: none;\n }\n\n .nav-tab-group__pill.nav-tab-group__pill--inactive {\n opacity: 0;\n transition: none;\n transform: none;\n left: 0;\n right: auto;\n top: 0;\n width: auto;\n height: auto;\n }\n\n /* Idle: stroke only on the active tab. While moving, .pill--transitioning matches tab border (see positionPill). */\n :host([variant='toggle']) .nav-tab-group__pill {\n border: none;\n \n }\n\n :host([variant='toggle']) .nav-tab-group__pill.nav-tab-group__pill--transitioning {\n border: var(--nile-nav-tab-border);\n overflow: hidden;\n }\n\n /* Shadow lives on the active tab container so selection never flashes unshaded while the pill moves. */\n :host([variant='toggle-button']) .nav-tab-group__pill {\n box-shadow: none;\n }\n\n /* --------------------------------------------------------------------------\n * Placement: top\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group--top {\n flex-direction: column;\n }\n\n .nav-tab-group--top .nav-tab-group__nav-container {\n order: 1;\n }\n\n .nav-tab-group--top .nav-tab-group__nav,\n .nav-tab-group--bottom .nav-tab-group__nav {\n display: flex;\n overflow-x: auto;\n scrollbar-width: none;\n }\n\n .nav-tab-group--top .nav-tab-group__nav::-webkit-scrollbar,\n .nav-tab-group--bottom .nav-tab-group__nav::-webkit-scrollbar {\n width: 0;\n height: 0;\n }\n\n .nav-tab-group--top .nav-tab-group__tabs {\n flex: 1 1 auto;\n position: relative;\n flex-direction: row;\n }\n\n .nav-tab-group--top .nav-tab-group__indicator {\n bottom: 0px;\n border-bottom: 2px solid var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n z-index: 0;\n }\n\n .nav-tab-group--top .nav-tab-group__body {\n order: 2;\n }\n\n .nav-tab-group--top ::slotted(nile-nav-tab-panel) {\n --padding: var(--nile-spacing-10px, var(--ng-spacing-lg)) var(--nile-spacing-none, var(--ng-spacing-none));\n }\n\n /* --------------------------------------------------------------------------\n * Placement: bottom\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group--bottom {\n flex-direction: column;\n }\n\n .nav-tab-group--bottom .nav-tab-group__nav-container {\n order: 2;\n }\n\n .nav-tab-group--bottom .nav-tab-group__tabs {\n flex: 1 1 auto;\n position: relative;\n flex-direction: row;\n border-top: solid var(--track-width) var(--track-color);\n }\n\n :host(:is([variant='filled'], [variant='neutral-filled'], [variant='toggle'], [variant='toggle-button']))\n .nav-tab-group--bottom .nav-tab-group__tabs {\n border-top: none;\n }\n\n :host(:is([variant='filled'], [variant='neutral-filled'], [variant='toggle-button'], [variant='toggle']))\n .nav-tab-group--top .nav-tab-group__nav,\n :host(:is([variant='filled'], [variant='neutral-filled'], [variant='toggle-button'], [variant='toggle']))\n .nav-tab-group--bottom .nav-tab-group__nav {\n overflow: auto;\n }\n\n /* Symmetric inset so box-shadow isn’t clipped and the strip stays vertically centered (end-only\n padding made top/bottom look uneven). */\n :host([variant='toggle-button']) .nav-tab-group--top .nav-tab-group__nav,\n :host([variant='toggle-button']) .nav-tab-group--bottom .nav-tab-group__nav {\n padding-block: var(--nile-spacing-xs, var(--ng-spacing-xs));\n box-sizing: border-box;\n align-items: center;\n padding-inline: var(--nile-spacing-xs, var(--ng-spacing-xs));\n }\n\n .nav-tab-group--bottom .nav-tab-group__indicator {\n top: calc(-1 * var(--track-width));\n border-top: solid var(--nile-border-width-2, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n .nav-tab-group--bottom .nav-tab-group__body {\n order: 1;\n }\n\n .nav-tab-group--bottom ::slotted(nile-nav-tab-panel) {\n --padding: var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-none, var(--ng-spacing-none))\n var(--nile-spacing-10px, var(--ng-spacing-lg)) var(--nile-spacing-none, var(--ng-spacing-none));\n }\n\n /* --------------------------------------------------------------------------\n * Placement: start\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group--start {\n flex-direction: row;\n }\n\n .nav-tab-group--start .nav-tab-group__nav-container {\n order: 1;\n }\n\n .nav-tab-group--start .nav-tab-group__tabs {\n flex: 0 0 auto;\n flex-direction: column;\n border-inline-end: solid var(--track-width) var(--track-color);\n }\n\n /* Block-level tab hosts match the flex column and full row height (wrap, multi-line labels). */\n .nav-tab-group--start slot[name='nav']::slotted(nile-nav-tab),\n .nav-tab-group--end slot[name='nav']::slotted(nile-nav-tab) {\n display: block;\n width: 100%;\n box-sizing: border-box;\n }\n\n :host([variant='filled']) .nav-tab-group--start .nav-tab-group__tabs {\n border-inline-end: none;\n }\n\n .nav-tab-group--start .nav-tab-group__indicator {\n top: 0;\n right: calc(-1 * var(--track-width));\n border-right: solid var(--nile-width-2px, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n .nav-tab-group--start .nav-tab-group__body {\n flex: 1 1 auto;\n order: 2;\n }\n\n .nav-tab-group--start .nav-tab-group__indicator__path,\n .nav-tab-group--bottom .nav-tab-group__indicator__path,\n .nav-tab-group--end .nav-tab-group__indicator__path {\n display: none;\n }\n\n /* --------------------------------------------------------------------------\n * Placement: end\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group--end {\n flex-direction: row;\n }\n\n .nav-tab-group--end .nav-tab-group__nav-container {\n order: 2;\n }\n\n .nav-tab-group--end .nav-tab-group__tabs {\n flex: 0 0 auto;\n flex-direction: column;\n border-inline-start: solid var(--track-width) var(--track-color);\n }\n\n :host([variant='filled']) .nav-tab-group--end .nav-tab-group__tabs {\n border-inline-start: none;\n }\n\n .nav-tab-group--end .nav-tab-group__indicator {\n top: 0;\n left: calc(-1 * var(--track-width));\n border-left: solid var(--nile-width-2px, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n .nav-tab-group--end .nav-tab-group__body {\n flex: 1 1 auto;\n order: 1;\n }\n\n /* Start & end: same horizontal panel padding */\n .nav-tab-group--start ::slotted(nile-nav-tab-panel),\n .nav-tab-group--end ::slotted(nile-nav-tab-panel) {\n --padding: var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-10px, var(--ng-spacing-lg));\n }\n\n /* --------------------------------------------------------------------------\n * hide__track: slotted tab tokens\n * -------------------------------------------------------------------------- */\n\n .hide__track slot::slotted(nile-nav-tab) {\n --nile-nav-tab-radius: var(--nile-radius-radius-xs, var(--ng-radius-xs));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --nile-nav-tab-height: auto;\n --nile-nav-tab-bg-hover: var(--nile-colors-neutral-100, var(--ng-colors-bg-secondary));\n --nile-nav-tab-bg-active: var(--nile-colors-brand-50, var(--ng-colors-bg-brand-primary-alt));\n }\n\n /* --------------------------------------------------------------------------\n * fullWidth\n * -------------------------------------------------------------------------- */\n\n :host([fullWidth]) .nav-tab-group__tabs {\n width: 100%;\n flex: 1 1 auto;\n }\n\n :host([fullWidth]) ::slotted(nile-nav-tab) {\n flex: 1;\n min-width: 0;\n }\n\n :host([fullWidth]) .nav-tab-group.nav-tab-group--top .nav-tab-group__tabs {\n display: flex;\n }\n\n :host([fullWidth]) {\n --justify-content: center;\n }\n\n /* --------------------------------------------------------------------------\n * Variants: filled, neutral-filled, toggle, toggle-button\n * -------------------------------------------------------------------------- */\n\n :host([variant='filled']) {\n --nile-nav-tab-radius: var(--nile-radius-radius-lg, var(--ng-radius-sm));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --nile-nav-tab-active-color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n --nile-nav-tab-bg-active: var(--nile-colors-primary-100, var(--ng-colors-bg-brand-primary-alt));\n --tab-gap: var(--nile-spacing-xs, var(--ng-spacing-xs));\n --nile-nav-tab-bg-hover: var(--nile-colors-primary-100, var(--ng-colors-bg-brand-primary-alt));\n }\n\n :host([variant='neutral-filled']) {\n --nile-nav-tab-radius: var(--nile-radius-radius-lg, var(--ng-radius-sm));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --nile-nav-tab-color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n --nile-nav-tab-bg-active: var(--nile-colors-dark-200, var(--ng-colors-bg-active));\n\n --tab-gap: var(--nile-spacing-xs, var(--ng-spacing-xs));\n --nile-nav-tab-bg-hover: var(--nile-colors-dark-200, var(--ng-colors-bg-active));\n --nile-nav-tab-text-color-hover: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n --nile-nav-tab-active-color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n }\n\n :host([variant='toggle-button']) .nav-tab-group__nav-container {\n background: var(--nile-colors-dark-200, var(--ng-colors-bg-secondary-alt));\n border: var(--nile-border-width-1, var(--ng-border-width-1)) var(--nile-border-style-solid, var(--ng-border-style-solid)) var(--nile-colors-neutral-500, var(--ng-colors-border-secondary));\n border-radius: var(--nile-radius-radius-lg, var(--ng-radius-lg));\n }\n :host([variant='toggle-button'][placement='start']) .nav-tab-group__nav-container,\n:host([variant='toggle-button'][placement='end']) .nav-tab-group__nav-container {\n padding-block: var(--nile-spacing-xs, var(--ng-spacing-xs));\n padding-inline: var(--nile-spacing-xs, var(--ng-spacing-xs));\n}\n\n :host([variant='toggle-button']) {\n --nile-nav-tab-bg-active: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --nile-nav-tab-radius: var(--nile-radius-radius-md, var(--ng-radius-sm));\n --nile-nav-tab-transparent-border: var(--nile-border-width-1, var(--ng-border-width-1)) var(--nile-border-style-solid, var(--ng-border-style-solid)) transparent;\n --tab-gap: var(--nile-spacing-xs, var(--ng-spacing-xs));\n position: relative;\n box-sizing: border-box;\n --nile-nav-tab-active-box-shadow: var(--nile-box-shadow-3, var(--ng-shadow-xs));\n --nile-nav-tab-container-overflow: visible;\n --nile-nav-tab-bg-hover: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-text-color-hover: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n --nile-nav-tab-active-color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n }\n\n :host([variant='toggle']) {\n --nile-nav-tab-radius: var(--nile-radius-radius-md, var(--ng-radius-sm));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --tab-gap: var(--nile-spacing-xxs, var(--ng-spacing-xxs));\n --nile-nav-tab-border: var(--nile-border-width-1, var(--ng-border-width-1)) var(--nile-border-style-solid, var(--ng-border-style-solid)) var(--nile-colors-neutral-500, var(--ng-colors-border-primary));\n --nile-nav-tab-active-box-shadow: var(--nile-box-shadow-3, var(--ng-shadow-xs));\n --nile-nav-transparent-border: var(--nile-border-width-1, var(--ng-border-width-1)) var(--nile-border-style-solid, var(--ng-border-style-solid)) transparent;\n --nile-nav-tab-bg-hover: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-text-color-hover: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n --nile-nav-tab-active-color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n --nile-nav-tab-bg-active: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n }\n\n :host([variant='toggle']) .nav-tab-group__nav-container {\n background: var(--nile-colors-dark-200, var(--ng-colors-bg-secondary-alt));\n border: none;\n border-radius: var(--nile-border-size-6, var(--ng-radius-sm));\n box-sizing: border-box;\n position: relative;\n overflow: visible;\n }\n\n :host([variant='toggle']) .nav-tab-group__toggle-frame {\n position: absolute;\n inset: 0;\n box-sizing: border-box;\n border: var(--nile-width-1px, var(--ng-border-width-1)) var(--nile-border-style-solid, var(--ng-border-style-solid))\n var(--nile-colors-neutral-500, var(--ng-colors-border-secondary));\n border-radius: inherit;\n pointer-events: none;\n z-index: 0;\n }\n\n :host([variant='toggle']) .nav-tab-group__nav {\n position: relative;\n z-index: 1;\n }\n\n /* --------------------------------------------------------------------------\n * Placement start / end: host token overrides\n * -------------------------------------------------------------------------- */\n\n :host([placement='start']) {\n --nile-nav-tab-bg-active: var(--nile-colors-primary-100, var(--ng-colors-bg-brand-primary-alt));\n --nile-nav-tab-radius: var(--nile-radius-sm, var(--ng-radius-sm)) var(--nile-radius-radius-none, var(--ng-radius-none)) var(--nile-radius-radius-none, var(--ng-radius-none)) var(--nile-radius-sm, var(--ng-radius-sm));\n --white-space: normal;\n --nile-nav-tab-height: auto; \n --word-break: break-word;\n --overflow-wrap: break-word;\n --text-align: left;\n }\n\n :host([placement='start'][variant='underline']),\n :host([placement='start']:not([variant])) {\n --nile-nav-tab-bg-hover: var(--nile-colors-neutral-100, var(--ng-colors-bg-primary-hover));\n --nile-nav-tab-text-color-hover: var(--nile-colors-dark-500, var(--ng-colors-text-placeholder));\n --nile-nav-tab-padding: var(--nile-spacing-lg, var(--ng-spacing-3));\n --nile-nav-tab-active-color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n }\n\n :host([variant='filled'][placement='start']) .nav-tab-group__tabs,\n :host([variant='neutral-filled'][placement='start']) .nav-tab-group__tabs,\n :host([variant='toggle'][placement='start']) .nav-tab-group__tabs,\n :host([variant='toggle-button'][placement='start']) .nav-tab-group__tabs {\n border-inline-end: none;\n --tab-gap: var(--nile-spacing-xs, var(--ng-spacing-xs));\n --nile-nav-tab-radius: var(--nile-radius-radius-lg, var(--ng-radius-sm));\n }\n\n :host([variant='neutral-filled'][placement='start']) {\n --nile-nav-tab-bg-active: var(--nile-colors-dark-200, var(--ng-colors-bg-active));\n --nile-nav-tab-active-color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n }\n\n :host([variant='toggle'][placement='start']) {\n --nile-nav-tab-bg-active: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-radius: var(--nile-radius-sm, var(--ng-radius-sm));\n }\n\n :host([variant='toggle-button'][placement='start']) {\n --nile-nav-tab-bg-active: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-radius: var(--nile-radius-sm, var(--ng-radius-sm));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --nile-nav-tab-bg-hover: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n padding-block: var(--nile-spacing-xs, var(--ng-spacing-xs));\n padding-inline: var(--nile-spacing-xs, var(--ng-spacing-xs));\n }\n\n :host([placement='end']) {\n --nile-nav-tab-bg-active: var(--nile-colors-primary-100, var(--ng-colors-bg-brand-primary-alt));\n --nile-nav-tab-radius: 0 var(--nile-radius-sm, var(--ng-radius-sm)) var(--nile-radius-sm, var(--ng-radius-sm)) 0;\n --white-space: normal;\n --nile-nav-tab-height: auto;\n --word-break: break-word;\n --overflow-wrap: break-word;\n }\n\n :host([placement='end'][variant='underline']),\n :host([placement='end']:not([variant])) {\n --nile-nav-tab-bg-hover: var(--nile-colors-neutral-100, var(--ng-colors-bg-primary-hover));\n --nile-nav-tab-text-color-hover: var(--nile-colors-dark-500, var(--ng-colors-text-placeholder));\n --nile-nav-tab-padding: var(--nile-spacing-lg, var(--ng-spacing-3));\n --white-space: normal;\n --nile-nav-tab-height: auto;\n --word-break: break-word;\n --overflow-wrap: break-word;\n --text-align: left;\n }\n\n :host([variant='filled'][placement='end']) .nav-tab-group__tabs,\n :host([variant='neutral-filled'][placement='end']) .nav-tab-group__tabs,\n :host([variant='toggle'][placement='end']) .nav-tab-group__tabs,\n :host([variant='toggle-button'][placement='end']) .nav-tab-group__tabs {\n border-inline-start: none;\n --tab-gap: var(--nile-spacing-xs, var(--ng-spacing-xs));\n --nile-nav-tab-radius: var(--nile-radius-radius-lg, var(--ng-radius-sm));\n \n }\n\n :host([variant='neutral-filled'][placement='end']) {\n --nile-nav-tab-bg-active: var(--nile-colors-dark-200, var(--ng-colors-bg-active));\n --nile-nav-tab-active-color: var(--nile-colors-dark-900, var(--ng-colors-text-secondary-700));\n }\n\n :host([variant='toggle'][placement='end']) {\n --nile-nav-tab-bg-active: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-radius: var(--nile-radius-sm, var(--ng-radius-sm));\n }\n\n :host([variant='toggle-button'][placement='end']) {\n --nile-nav-tab-bg-active: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n --nile-nav-tab-radius: var(--nile-radius-sm, var(--ng-radius-sm));\n --nile-nav-tab-padding: var(--nile-spacing-md, var(--ng-spacing-md)) var(--nile-spacing-lg, var(--ng-spacing-lg));\n --nile-nav-tab-bg-hover: var(--nile-colors-white-base, var(--ng-colors-bg-primary-alt));\n }\n\n /* --------------------------------------------------------------------------\n * Active tab: slotted token overrides (pill / underline variants)\n * -------------------------------------------------------------------------- */\n\n :host(:is([variant='filled'], [variant='neutral-filled'], [variant='toggle']))\n slot[name='nav']::slotted(nile-nav-tab[active]) {\n --nile-nav-tab-active-box-shadow: none;\n }\n\n /* Pill variants: paint fill/border only on .nav-tab-container; keep link layer transparent so a\n * second white plane can’t extend past the border (grey stroke + white fringe). */\n :host(:is([variant='filled'], [variant='neutral-filled'], [variant='toggle'], [variant='toggle-button']))\n slot[name='nav']::slotted(nile-nav-tab) {\n --tab-active-background-color: transparent;\n --tab-hover-background-color: transparent;\n position: relative;\n z-index: 1;\n }\n\n /* --------------------------------------------------------------------------\n * Indicator placement: left (vertical start rail)\n * -------------------------------------------------------------------------- */\n\n :host([indicatorPlacement='left'][placement='start']) {\n --nile-nav-tab-bg-active: none;\n --nile-nav-tab-bg-hover: none;\n --tab-gap: 8px;\n --nile-nav-tab-active-color: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n --nile-nav-tab-text-color-hover: var(--nile-colors-primary-600, var(--ng-colors-text-brand-secondary-700));\n }\n\n :host([indicatorPlacement='left']) .nav-tab-group--start .nav-tab-group__indicator {\n top: 0;\n right: auto;\n left: calc(-1 * var(--track-width));\n border-right: none;\n border-left: solid var(--nile-border-width-2, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n :host([indicatorPlacement='left']) .nav-tab-group--start .nav-tab-group__tabs {\n border-inline-end: none;\n }\n\n /* --------------------------------------------------------------------------\n * Hover indicator\n * -------------------------------------------------------------------------- */\n\n .nav-tab-group__hover-indicator {\n position: absolute;\n pointer-events: none;\n opacity: 0;\n transition: none;\n z-index: 2;\n }\n\n .nav-tab-group--top .nav-tab-group__hover-indicator {\n bottom: 0px;\n height: 0;\n border-bottom: 2px solid var(--indicator-color);\n }\n\n .nav-tab-group--bottom .nav-tab-group__hover-indicator {\n top: calc(-1 * var(--track-width));\n height: 0;\n border-top: solid var(--nile-border-width-2, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n .nav-tab-group--start .nav-tab-group__hover-indicator {\n top: 0;\n right: calc(-1 * var(--track-width));\n width: 0;\n border-right: solid var(--nile-border-width-2, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n .nav-tab-group--end .nav-tab-group__hover-indicator {\n top: 0;\n left: calc(-1 * var(--track-width));\n width: 0;\n border-left: solid var(--nile-border-width-2, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n :host([indicatorPlacement='left']) .nav-tab-group--start .nav-tab-group__hover-indicator {\n top: 0;\n right: auto;\n left: calc(-1 * var(--track-width));\n border-right: none;\n border-left: solid var(--nile-border-width-2, var(--ng-border-width-2)) var(--indicator-color);\n }\n\n /* --------------------------------------------------------------------------\n * Reduced motion\n * -------------------------------------------------------------------------- */\n\n @media (prefers-reduced-motion: reduce) {\n * {\n animation: none;\n transition: none;\n }\n }\n\n :host([placement='bottom'][variant='underline']),\n:host([placement='bottom']:not([variant])) {\n --nile-nav-tab-padding: var(--nile-spacing-lg, var(--ng-spacing-3)) var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-none, var(--ng-spacing-none)) var(--nile-spacing-none, var(--ng-spacing-none));\n}\n`;\n\nexport default [styles];\n"]}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright Aquera Inc 2023
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the BSD-3-Clause license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
import NileElement from '../internal/nile-element';
|
|
8
|
+
import type { CSSResultGroup, PropertyValueMap } from 'lit';
|
|
9
|
+
import '../nile-icon-button/nile-icon-button';
|
|
10
|
+
/**
|
|
11
|
+
* Tab group navigation component.
|
|
12
|
+
*
|
|
13
|
+
* @tag nile-nav-tab-group
|
|
14
|
+
*
|
|
15
|
+
* @slot - Used for grouping tab panels in the tab group. Must be `<nile-nav-tab-panel>` elements.
|
|
16
|
+
* @slot nav - Used for grouping tabs in the tab group. Must be `<nile-nav-tab>` elements.
|
|
17
|
+
*
|
|
18
|
+
* @csspart base - The component's base wrapper.
|
|
19
|
+
* @csspart nav - The tab group's navigation container where tabs are slotted in.
|
|
20
|
+
* @csspart tabs - The container that wraps the tabs.
|
|
21
|
+
* @csspart active-tab-indicator - The line that highlights the currently selected tab.
|
|
22
|
+
* @csspart toggle-frame - Toggle variant: absolutely positioned ring that draws the group chrome (tabs paint above it).
|
|
23
|
+
* @csspart body - The tab group's body where tab panels are slotted in.
|
|
24
|
+
* @csspart scroll-button - The previous/next scroll buttons that show when tabs are scrollable, an `<nile-icon-button>`.
|
|
25
|
+
* @csspart scroll-button--start - The starting scroll button.
|
|
26
|
+
* @csspart scroll-button--end - The ending scroll button.
|
|
27
|
+
* @csspart scroll-button__base - The scroll button's exported `base` part.
|
|
28
|
+
*
|
|
29
|
+
* @cssproperty --indicator-color - The color of the active tab indicator.
|
|
30
|
+
* @cssproperty --track-color - The color of the indicator's track (the line that separates tabs from panels).
|
|
31
|
+
* @cssproperty --track-width - The width of the indicator's track (the line that separates tabs from panels).
|
|
32
|
+
* @cssproperty --show-indicator-on-hover - Whether to show the indicator on hover.
|
|
33
|
+
*
|
|
34
|
+
* @event nile-close - Bubbled from a closable `<nile-nav-tab>`; re-emitted so parents can listen on this element.
|
|
35
|
+
*/
|
|
36
|
+
export declare class NileNavTabGroup extends NileElement {
|
|
37
|
+
static styles: CSSResultGroup;
|
|
38
|
+
/**
|
|
39
|
+
* Selection model (for reviewers):
|
|
40
|
+
* - `activeTabName` is the internal source of truth; clicks and keyboard update it.
|
|
41
|
+
* - `activeTabProp` / attribute `value` is the host-controlled API; changes in `updated()` copy into `activeTabName`.
|
|
42
|
+
* - `setActiveTab()` syncs each tab’s `active` flag, each panel’s `active`, `activeTabProp` / `value`, indicator/pill geometry, and optionally emits `nile-tab-change`.
|
|
43
|
+
* - `this.tabs` only includes non-disabled tabs (see `syncTabsAndPanels`); keyboard roving focus uses that list.
|
|
44
|
+
*/
|
|
45
|
+
private activeTab?;
|
|
46
|
+
private mutationObserver;
|
|
47
|
+
private resizeObserver;
|
|
48
|
+
private visibilityObserver;
|
|
49
|
+
private pillRepositionTimer;
|
|
50
|
+
private pillTransitionClassTimer;
|
|
51
|
+
private pillReady;
|
|
52
|
+
private observedTabs;
|
|
53
|
+
private tabs;
|
|
54
|
+
private panels;
|
|
55
|
+
/** Tabs emit `nile-close` on the host; bubble is stopped so we re-emit from the group with `{ panel }` for consumers. */
|
|
56
|
+
private readonly handleCloseEvent;
|
|
57
|
+
/** Tracks visibility for snapping the indicator when a hidden parent (e.g. dropdown) is reopened. */
|
|
58
|
+
private tabGroupWasIntersecting;
|
|
59
|
+
/** Last measured nav width; used to detect layout resume after display:none / collapse. */
|
|
60
|
+
private lastNavClientWidth;
|
|
61
|
+
tabGroup: HTMLElement;
|
|
62
|
+
body: HTMLSlotElement;
|
|
63
|
+
nav: HTMLElement;
|
|
64
|
+
indicator: HTMLElement;
|
|
65
|
+
hoverIndicator: HTMLElement;
|
|
66
|
+
hasScrollControls: boolean;
|
|
67
|
+
/** The placement of the tabs. */
|
|
68
|
+
placement: 'top' | 'bottom' | 'start' | 'end';
|
|
69
|
+
/** The currently active tab value. */
|
|
70
|
+
activeTabProp: string;
|
|
71
|
+
/** Track for showing Indicators and Background. */
|
|
72
|
+
noTrack: boolean;
|
|
73
|
+
/** Disables the scroll arrows that appear when tabs overflow. */
|
|
74
|
+
noScrollControls: boolean;
|
|
75
|
+
/** Controls whether tabs are centered and have equal width. */
|
|
76
|
+
centered: boolean;
|
|
77
|
+
variant: 'underline' | 'filled' | 'toggle' | 'neutral-filled' | 'toggle-button';
|
|
78
|
+
indicatorPlacement: string;
|
|
79
|
+
fullWidth: boolean;
|
|
80
|
+
width: string;
|
|
81
|
+
showIndicatorOnHover: boolean;
|
|
82
|
+
activeTabName: string;
|
|
83
|
+
private get showScrollControlButtons();
|
|
84
|
+
connectedCallback(): void;
|
|
85
|
+
disconnectedCallback(): void;
|
|
86
|
+
protected updated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void;
|
|
87
|
+
syncIndicator(): void;
|
|
88
|
+
private handleNavClick;
|
|
89
|
+
private positionPill;
|
|
90
|
+
private debouncedPositionPill;
|
|
91
|
+
private handleTabHover;
|
|
92
|
+
private handleTabHoverLeave;
|
|
93
|
+
private positionHoverIndicator;
|
|
94
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
95
|
+
private getAllTabs;
|
|
96
|
+
private getAllPanels;
|
|
97
|
+
/**
|
|
98
|
+
* Resolves the tab to treat as selected for indicator/pill wiring.
|
|
99
|
+
* Prefer `activeTabName` match; if empty (before init), fall back to `.active` or first usable tab.
|
|
100
|
+
*/
|
|
101
|
+
private getActiveTab;
|
|
102
|
+
/** Reflects horizontal overflow into `hasScrollControls` (top/bottom only; vertical stacks do not scroll this strip). */
|
|
103
|
+
setScrollControls(): void;
|
|
104
|
+
private handleKeyDown;
|
|
105
|
+
private handleScrollToStart;
|
|
106
|
+
private handleScrollToEnd;
|
|
107
|
+
private setActiveTab;
|
|
108
|
+
private setAriaLabels;
|
|
109
|
+
private getRelativeOffsetToAncestor;
|
|
110
|
+
private getLayoutBoxRelativeToContainer;
|
|
111
|
+
private repositionIndicator;
|
|
112
|
+
private syncTabsAndPanels;
|
|
113
|
+
}
|
|
114
|
+
export default NileNavTabGroup;
|
|
115
|
+
declare global {
|
|
116
|
+
interface HTMLElementTagNameMap {
|
|
117
|
+
'nile-nav-tab-group': NileNavTabGroup;
|
|
118
|
+
}
|
|
119
|
+
}
|