@alfalab/core-components-tabs 6.3.2 → 6.6.1

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 (248) hide show
  1. package/CHANGELOG.md +44 -0
  2. package/dist/components/primary-tablist/Component.d.ts +6 -0
  3. package/{components → dist/components}/primary-tablist/Component.desktop.d.ts +0 -0
  4. package/{components → dist/components}/primary-tablist/Component.desktop.js +2 -2
  5. package/dist/components/primary-tablist/Component.js +55 -0
  6. package/{esm → dist}/components/primary-tablist/Component.mobile.d.ts +1 -1
  7. package/{components → dist/components}/primary-tablist/Component.mobile.js +3 -3
  8. package/dist/components/primary-tablist/Component.responsive.d.ts +4 -0
  9. package/{components → dist/components}/primary-tablist/Component.responsive.js +4 -4
  10. package/{components → dist/components}/primary-tablist/index.css +27 -21
  11. package/{components → dist/components}/primary-tablist/mobile.css +30 -24
  12. package/{cssm → dist}/components/scrollable-container/Component.d.ts +2 -1
  13. package/{components → dist/components}/scrollable-container/Component.js +14 -4
  14. package/{components → dist/components}/scrollable-container/index.css +11 -6
  15. package/{components → dist/components}/scrollable-container/index.d.ts +0 -0
  16. package/{components → dist/components}/scrollable-container/index.js +0 -0
  17. package/dist/components/secondary-tablist/Component.d.ts +8 -0
  18. package/{esm → dist}/components/secondary-tablist/Component.desktop.d.ts +1 -1
  19. package/{components → dist/components}/secondary-tablist/Component.desktop.js +2 -2
  20. package/dist/components/secondary-tablist/Component.js +38 -0
  21. package/{components → dist/components}/secondary-tablist/Component.mobile.d.ts +1 -1
  22. package/{components → dist/components}/secondary-tablist/Component.mobile.js +3 -3
  23. package/{cssm → dist}/components/secondary-tablist/Component.responsive.d.ts +1 -1
  24. package/{components → dist/components}/secondary-tablist/Component.responsive.js +4 -4
  25. package/{components → dist/components}/secondary-tablist/index.css +15 -14
  26. package/{modern → dist}/components/secondary-tablist/mobile.css +17 -16
  27. package/{components → dist/components}/tab/Component.d.ts +0 -0
  28. package/{components → dist/components}/tab/Component.js +1 -1
  29. package/dist/components/tab/index.css +8 -0
  30. package/{components → dist/components}/tab/index.d.ts +0 -0
  31. package/{components → dist/components}/tab/index.js +0 -0
  32. package/dist/components/tabs/Component.d.ts +4 -0
  33. package/{cssm → dist}/components/tabs/Component.desktop.d.ts +1 -1
  34. package/{components → dist/components}/tabs/Component.desktop.js +3 -3
  35. package/{cssm → dist}/components/tabs/Component.js +4 -3
  36. package/{cssm → dist}/components/tabs/Component.mobile.d.ts +1 -1
  37. package/{components → dist/components}/tabs/Component.mobile.js +3 -3
  38. package/{cssm → dist}/components/tabs/Component.responsive.d.ts +1 -1
  39. package/{components → dist/components}/tabs/Component.responsive.js +3 -3
  40. package/dist/cssm/components/primary-tablist/Component.d.ts +6 -0
  41. package/{cssm → dist/cssm}/components/primary-tablist/Component.desktop.d.ts +0 -0
  42. package/{cssm → dist/cssm}/components/primary-tablist/Component.desktop.js +1 -1
  43. package/dist/cssm/components/primary-tablist/Component.js +56 -0
  44. package/{components → dist/cssm/components}/primary-tablist/Component.mobile.d.ts +1 -1
  45. package/{cssm → dist/cssm}/components/primary-tablist/Component.mobile.js +1 -1
  46. package/dist/cssm/components/primary-tablist/Component.responsive.d.ts +4 -0
  47. package/{cssm → dist/cssm}/components/primary-tablist/Component.responsive.js +3 -3
  48. package/{cssm → dist/cssm}/components/primary-tablist/index.module.css +8 -2
  49. package/{cssm → dist/cssm}/components/primary-tablist/mobile.module.css +0 -0
  50. package/{esm → dist/cssm}/components/scrollable-container/Component.d.ts +2 -1
  51. package/{cssm → dist/cssm}/components/scrollable-container/Component.js +13 -3
  52. package/{cssm → dist/cssm}/components/scrollable-container/index.d.ts +0 -0
  53. package/{cssm → dist/cssm}/components/scrollable-container/index.js +0 -0
  54. package/{cssm → dist/cssm}/components/scrollable-container/index.module.css +7 -2
  55. package/dist/cssm/components/secondary-tablist/Component.d.ts +8 -0
  56. package/{components → dist/cssm/components}/secondary-tablist/Component.desktop.d.ts +1 -1
  57. package/{cssm → dist/cssm}/components/secondary-tablist/Component.desktop.js +1 -1
  58. package/dist/cssm/components/secondary-tablist/Component.js +39 -0
  59. package/{cssm → dist/cssm}/components/secondary-tablist/Component.mobile.d.ts +1 -1
  60. package/{cssm → dist/cssm}/components/secondary-tablist/Component.mobile.js +1 -1
  61. package/{components → dist/cssm/components}/secondary-tablist/Component.responsive.d.ts +1 -1
  62. package/{cssm → dist/cssm}/components/secondary-tablist/Component.responsive.js +3 -3
  63. package/{cssm → dist/cssm}/components/secondary-tablist/index.module.css +5 -4
  64. package/{cssm → dist/cssm}/components/secondary-tablist/mobile.module.css +0 -0
  65. package/{cssm → dist/cssm}/components/tab/Component.d.ts +0 -0
  66. package/{cssm → dist/cssm}/components/tab/Component.js +0 -0
  67. package/{cssm → dist/cssm}/components/tab/index.d.ts +0 -0
  68. package/{cssm → dist/cssm}/components/tab/index.js +0 -0
  69. package/{cssm → dist/cssm}/components/tab/index.module.css +0 -0
  70. package/dist/cssm/components/tabs/Component.d.ts +4 -0
  71. package/{esm → dist/cssm}/components/tabs/Component.desktop.d.ts +1 -1
  72. package/{cssm → dist/cssm}/components/tabs/Component.desktop.js +2 -2
  73. package/{components → dist/cssm/components}/tabs/Component.js +4 -3
  74. package/{esm → dist/cssm}/components/tabs/Component.mobile.d.ts +1 -1
  75. package/{cssm → dist/cssm}/components/tabs/Component.mobile.js +2 -2
  76. package/{esm → dist/cssm}/components/tabs/Component.responsive.d.ts +1 -1
  77. package/{cssm → dist/cssm}/components/tabs/Component.responsive.js +2 -2
  78. package/{cssm → dist/cssm}/desktop.d.ts +0 -0
  79. package/{cssm → dist/cssm}/desktop.js +2 -2
  80. package/{cssm → dist/cssm}/index.d.ts +0 -0
  81. package/{cssm → dist/cssm}/index.js +2 -2
  82. package/{cssm → dist/cssm}/mobile.d.ts +0 -0
  83. package/{cssm → dist/cssm}/mobile.js +2 -2
  84. package/{cssm → dist/cssm}/responsive.d.ts +0 -0
  85. package/{cssm → dist/cssm}/responsive.js +2 -2
  86. package/{cssm → dist/cssm}/tslib.es6-ce870b46.d.ts +0 -0
  87. package/{cssm → dist/cssm}/tslib.es6-ce870b46.js +0 -0
  88. package/{esm → dist/cssm}/typings.d.ts +21 -11
  89. package/{cssm → dist/cssm}/typings.js +0 -0
  90. package/{cssm → dist/cssm}/useTabs.d.ts +0 -0
  91. package/{cssm → dist/cssm}/useTabs.js +0 -0
  92. package/{cssm → dist/cssm}/vars.css +0 -0
  93. package/{desktop.d.ts → dist/desktop.d.ts} +0 -0
  94. package/{desktop.js → dist/desktop.js} +3 -3
  95. package/dist/esm/components/primary-tablist/Component.d.ts +6 -0
  96. package/{esm → dist/esm}/components/primary-tablist/Component.desktop.d.ts +0 -0
  97. package/{esm → dist/esm}/components/primary-tablist/Component.desktop.js +3 -3
  98. package/dist/esm/components/primary-tablist/Component.js +46 -0
  99. package/{modern → dist/esm}/components/primary-tablist/Component.mobile.d.ts +1 -1
  100. package/{esm → dist/esm}/components/primary-tablist/Component.mobile.js +4 -4
  101. package/dist/esm/components/primary-tablist/Component.responsive.d.ts +4 -0
  102. package/{esm → dist/esm}/components/primary-tablist/Component.responsive.js +5 -5
  103. package/{modern → dist/esm}/components/primary-tablist/index.css +27 -21
  104. package/{modern → dist/esm}/components/primary-tablist/mobile.css +30 -24
  105. package/{modern → dist/esm}/components/scrollable-container/Component.d.ts +2 -1
  106. package/{esm → dist/esm}/components/scrollable-container/Component.js +14 -4
  107. package/{esm → dist/esm}/components/scrollable-container/index.css +11 -6
  108. package/{esm → dist/esm}/components/scrollable-container/index.d.ts +0 -0
  109. package/{esm → dist/esm}/components/scrollable-container/index.js +0 -0
  110. package/dist/esm/components/secondary-tablist/Component.d.ts +8 -0
  111. package/{cssm → dist/esm}/components/secondary-tablist/Component.desktop.d.ts +1 -1
  112. package/{esm → dist/esm}/components/secondary-tablist/Component.desktop.js +3 -3
  113. package/dist/esm/components/secondary-tablist/Component.js +29 -0
  114. package/{esm → dist/esm}/components/secondary-tablist/Component.mobile.d.ts +1 -1
  115. package/{esm → dist/esm}/components/secondary-tablist/Component.mobile.js +4 -4
  116. package/{esm → dist/esm}/components/secondary-tablist/Component.responsive.d.ts +1 -1
  117. package/{esm → dist/esm}/components/secondary-tablist/Component.responsive.js +5 -5
  118. package/{esm → dist/esm}/components/secondary-tablist/index.css +15 -14
  119. package/{components → dist/esm/components}/secondary-tablist/mobile.css +17 -16
  120. package/{esm → dist/esm}/components/tab/Component.d.ts +0 -0
  121. package/{esm → dist/esm}/components/tab/Component.js +1 -1
  122. package/dist/esm/components/tab/index.css +8 -0
  123. package/{esm → dist/esm}/components/tab/index.d.ts +0 -0
  124. package/{esm → dist/esm}/components/tab/index.js +0 -0
  125. package/dist/esm/components/tabs/Component.d.ts +4 -0
  126. package/{modern → dist/esm}/components/tabs/Component.desktop.d.ts +1 -1
  127. package/{esm → dist/esm}/components/tabs/Component.desktop.js +5 -5
  128. package/{esm → dist/esm}/components/tabs/Component.js +4 -3
  129. package/{modern → dist/esm}/components/tabs/Component.mobile.d.ts +1 -1
  130. package/{esm → dist/esm}/components/tabs/Component.mobile.js +5 -5
  131. package/{modern → dist/esm}/components/tabs/Component.responsive.d.ts +1 -1
  132. package/{esm → dist/esm}/components/tabs/Component.responsive.js +5 -5
  133. package/{esm → dist/esm}/desktop.d.ts +0 -0
  134. package/{esm → dist/esm}/desktop.js +5 -5
  135. package/{esm → dist/esm}/index.d.ts +0 -0
  136. package/{esm → dist/esm}/index.js +5 -5
  137. package/dist/esm/index.module-3d17828f.js +4 -0
  138. package/dist/esm/index.module-d00881c2.js +4 -0
  139. package/{esm → dist/esm}/mobile.d.ts +0 -0
  140. package/{esm → dist/esm}/mobile.js +5 -5
  141. package/{esm → dist/esm}/responsive.d.ts +0 -0
  142. package/{esm → dist/esm}/responsive.js +5 -5
  143. package/{esm/tslib.es6-d595f357.d.ts → dist/esm/tslib.es6-5a4d264a.d.ts} +0 -0
  144. package/{esm/tslib.es6-d595f357.js → dist/esm/tslib.es6-5a4d264a.js} +0 -0
  145. package/{modern → dist/esm}/typings.d.ts +21 -11
  146. package/{esm → dist/esm}/typings.js +0 -0
  147. package/{esm → dist/esm}/useTabs.d.ts +0 -0
  148. package/{esm → dist/esm}/useTabs.js +0 -0
  149. package/{index.d.ts → dist/index.d.ts} +0 -0
  150. package/{index.js → dist/index.js} +3 -3
  151. package/dist/index.module-4b779b53.js +6 -0
  152. package/dist/index.module-8e427b33.js +6 -0
  153. package/{mobile.d.ts → dist/mobile.d.ts} +0 -0
  154. package/{mobile.js → dist/mobile.js} +3 -3
  155. package/dist/modern/components/primary-tablist/Component.d.ts +6 -0
  156. package/{modern → dist/modern}/components/primary-tablist/Component.desktop.d.ts +0 -0
  157. package/{modern → dist/modern}/components/primary-tablist/Component.desktop.js +2 -2
  158. package/{modern → dist/modern}/components/primary-tablist/Component.js +8 -6
  159. package/{cssm → dist/modern}/components/primary-tablist/Component.mobile.d.ts +1 -1
  160. package/{modern → dist/modern}/components/primary-tablist/Component.mobile.js +3 -3
  161. package/dist/modern/components/primary-tablist/Component.responsive.d.ts +4 -0
  162. package/{modern → dist/modern}/components/primary-tablist/Component.responsive.js +4 -4
  163. package/{esm → dist/modern}/components/primary-tablist/index.css +27 -21
  164. package/{esm → dist/modern}/components/primary-tablist/mobile.css +30 -24
  165. package/{components → dist/modern/components}/scrollable-container/Component.d.ts +2 -1
  166. package/{modern → dist/modern}/components/scrollable-container/Component.js +13 -4
  167. package/{modern → dist/modern}/components/scrollable-container/index.css +11 -6
  168. package/{modern → dist/modern}/components/scrollable-container/index.d.ts +0 -0
  169. package/{modern → dist/modern}/components/scrollable-container/index.js +0 -0
  170. package/dist/modern/components/secondary-tablist/Component.d.ts +8 -0
  171. package/{modern → dist/modern}/components/secondary-tablist/Component.desktop.d.ts +1 -1
  172. package/{modern → dist/modern}/components/secondary-tablist/Component.desktop.js +2 -2
  173. package/dist/modern/components/secondary-tablist/Component.js +24 -0
  174. package/{modern → dist/modern}/components/secondary-tablist/Component.mobile.d.ts +1 -1
  175. package/{modern → dist/modern}/components/secondary-tablist/Component.mobile.js +3 -3
  176. package/{modern → dist/modern}/components/secondary-tablist/Component.responsive.d.ts +1 -1
  177. package/{modern → dist/modern}/components/secondary-tablist/Component.responsive.js +4 -4
  178. package/{modern → dist/modern}/components/secondary-tablist/index.css +15 -14
  179. package/{esm → dist/modern}/components/secondary-tablist/mobile.css +17 -16
  180. package/{modern → dist/modern}/components/tab/Component.d.ts +0 -0
  181. package/{modern → dist/modern}/components/tab/Component.js +1 -1
  182. package/dist/modern/components/tab/index.css +8 -0
  183. package/{modern → dist/modern}/components/tab/index.d.ts +0 -0
  184. package/{modern → dist/modern}/components/tab/index.js +0 -0
  185. package/dist/modern/components/tabs/Component.d.ts +4 -0
  186. package/{components → dist/modern/components}/tabs/Component.desktop.d.ts +2 -2
  187. package/{modern → dist/modern}/components/tabs/Component.desktop.js +4 -4
  188. package/{modern → dist/modern}/components/tabs/Component.js +4 -3
  189. package/{components → dist/modern/components}/tabs/Component.mobile.d.ts +1 -1
  190. package/{modern → dist/modern}/components/tabs/Component.mobile.js +4 -4
  191. package/{components → dist/modern/components}/tabs/Component.responsive.d.ts +1 -1
  192. package/{modern → dist/modern}/components/tabs/Component.responsive.js +4 -4
  193. package/{modern → dist/modern}/desktop.d.ts +0 -0
  194. package/{modern → dist/modern}/desktop.js +4 -4
  195. package/{modern → dist/modern}/index.d.ts +0 -0
  196. package/{modern → dist/modern}/index.js +4 -4
  197. package/dist/modern/index.module-3d17828f.js +4 -0
  198. package/dist/modern/index.module-d00881c2.js +4 -0
  199. package/{modern → dist/modern}/mobile.d.ts +0 -0
  200. package/{modern → dist/modern}/mobile.js +4 -4
  201. package/{modern → dist/modern}/responsive.d.ts +0 -0
  202. package/{modern → dist/modern}/responsive.js +4 -4
  203. package/{cssm → dist/modern}/typings.d.ts +21 -11
  204. package/{modern → dist/modern}/typings.js +0 -0
  205. package/{modern → dist/modern}/useTabs.d.ts +0 -0
  206. package/{modern → dist/modern}/useTabs.js +0 -0
  207. package/{responsive.d.ts → dist/responsive.d.ts} +0 -0
  208. package/{responsive.js → dist/responsive.js} +3 -3
  209. package/{send-stats.js → dist/send-stats.js} +0 -0
  210. package/{tslib.es6-21f3b6da.d.ts → dist/tslib.es6-1df23a7b.d.ts} +0 -0
  211. package/{tslib.es6-21f3b6da.js → dist/tslib.es6-1df23a7b.js} +0 -0
  212. package/{typings.d.ts → dist/typings.d.ts} +21 -11
  213. package/{typings.js → dist/typings.js} +0 -0
  214. package/{useTabs.d.ts → dist/useTabs.d.ts} +0 -0
  215. package/{useTabs.js → dist/useTabs.js} +0 -0
  216. package/package.json +15 -12
  217. package/components/primary-tablist/Component.d.ts +0 -13
  218. package/components/primary-tablist/Component.js +0 -50
  219. package/components/primary-tablist/Component.responsive.d.ts +0 -4
  220. package/components/secondary-tablist/Component.d.ts +0 -15
  221. package/components/secondary-tablist/Component.js +0 -33
  222. package/components/tab/index.css +0 -8
  223. package/components/tabs/Component.d.ts +0 -4
  224. package/cssm/components/primary-tablist/Component.d.ts +0 -13
  225. package/cssm/components/primary-tablist/Component.js +0 -51
  226. package/cssm/components/primary-tablist/Component.responsive.d.ts +0 -4
  227. package/cssm/components/secondary-tablist/Component.d.ts +0 -15
  228. package/cssm/components/secondary-tablist/Component.js +0 -34
  229. package/cssm/components/tabs/Component.d.ts +0 -4
  230. package/esm/components/primary-tablist/Component.d.ts +0 -13
  231. package/esm/components/primary-tablist/Component.js +0 -41
  232. package/esm/components/primary-tablist/Component.responsive.d.ts +0 -4
  233. package/esm/components/secondary-tablist/Component.d.ts +0 -15
  234. package/esm/components/secondary-tablist/Component.js +0 -24
  235. package/esm/components/tab/index.css +0 -8
  236. package/esm/components/tabs/Component.d.ts +0 -4
  237. package/esm/index.module-7be29ac4.js +0 -4
  238. package/esm/index.module-a7445354.js +0 -4
  239. package/index.module-5ed9b0e6.js +0 -6
  240. package/index.module-fa5020d4.js +0 -6
  241. package/modern/components/primary-tablist/Component.d.ts +0 -13
  242. package/modern/components/primary-tablist/Component.responsive.d.ts +0 -4
  243. package/modern/components/secondary-tablist/Component.d.ts +0 -15
  244. package/modern/components/secondary-tablist/Component.js +0 -20
  245. package/modern/components/tab/index.css +0 -8
  246. package/modern/components/tabs/Component.d.ts +0 -4
  247. package/modern/index.module-7be29ac4.js +0 -4
  248. package/modern/index.module-a7445354.js +0 -4
@@ -0,0 +1,39 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var tslib_es6 = require('../../tslib.es6-ce870b46.js');
6
+ var React = require('react');
7
+ var cn = require('classnames');
8
+ require('compute-scroll-into-view');
9
+ require('../scrollable-container/index.module.css');
10
+ var components_scrollableContainer_Component = require('../scrollable-container/Component.js');
11
+ var useTabs = require('../../useTabs.js');
12
+ var coreComponentsTag = require('@alfalab/core-components-tag/dist/cssm');
13
+
14
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
15
+
16
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
17
+ var cn__default = /*#__PURE__*/_interopDefaultLegacy(cn);
18
+
19
+ var SecondaryTabList = function (_a) {
20
+ var _b = _a.styles, styles = _b === void 0 ? {} : _b, className = _a.className, containerClassName = _a.containerClassName, size = _a.size, _c = _a.titles, titles = _c === void 0 ? [] : _c, _d = _a.selectedId, selectedId = _d === void 0 ? titles.length ? titles[0].id : undefined : _d, _e = _a.scrollable, scrollable = _e === void 0 ? true : _e, fullWidthScroll = _a.fullWidthScroll, _f = _a.tagSize, tagSize = _f === void 0 ? 'xs' : _f, onChange = _a.onChange, dataTestId = _a.dataTestId;
21
+ var _g = useTabs.useTabs({
22
+ titles: titles,
23
+ selectedId: selectedId,
24
+ onChange: onChange,
25
+ }), focusedTab = _g.focusedTab, selectedTab = _g.selectedTab, getTabListItemProps = _g.getTabListItemProps;
26
+ var renderContent = function () {
27
+ var _a;
28
+ return (React__default['default'].createElement("div", { role: 'tablist', "data-test-id": dataTestId, className: cn__default['default'](styles.component, className, size && styles[size], (_a = {},
29
+ _a[styles.fullWidthScroll] = fullWidthScroll,
30
+ _a)) }, titles.map(function (item, index) {
31
+ if (item.hidden)
32
+ return null;
33
+ return (React__default['default'].createElement(coreComponentsTag.Tag, tslib_es6.__assign({}, getTabListItemProps(index), { key: item.id, className: cn__default['default'](styles.title, item.toggleClassName), checked: item.id === selectedId, size: tagSize, rightAddons: item.rightAddons }), item.title));
34
+ })));
35
+ };
36
+ return scrollable ? (React__default['default'].createElement(components_scrollableContainer_Component.ScrollableContainer, { activeChild: focusedTab || selectedTab, containerClassName: containerClassName, fullWidthScroll: fullWidthScroll }, renderContent())) : (React__default['default'].createElement("div", { className: cn__default['default'](styles.container, containerClassName) }, renderContent()));
37
+ };
38
+
39
+ exports.SecondaryTabList = SecondaryTabList;
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { SecondaryTabListProps } from "../../typings";
3
3
  type SecondaryTabListMobileProps = Omit<SecondaryTabListProps, 'size' | 'tagSize'>;
4
- declare const SecondaryTabListMobile: ({ className, ...restProps }: Pick<SecondaryTabListProps, "className" | "onChange" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "titles">) => JSX.Element;
4
+ declare const SecondaryTabListMobile: ({ className, ...restProps }: Pick<SecondaryTabListProps, "className" | "onChange" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll" | "titles">) => JSX.Element;
5
5
  export { SecondaryTabListMobileProps, SecondaryTabListMobile };
@@ -9,7 +9,7 @@ require('compute-scroll-into-view');
9
9
  require('../scrollable-container/index.module.css');
10
10
  require('../scrollable-container/Component.js');
11
11
  require('../../useTabs.js');
12
- require('@alfalab/core-components-tag/cssm');
12
+ require('@alfalab/core-components-tag/dist/cssm');
13
13
  var components_secondaryTablist_Component = require('./Component.js');
14
14
  var commonStyles = require('./index.module.css');
15
15
  var mobileStyles = require('./mobile.module.css');
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import { SecondaryTabListProps } from "../../typings";
3
- declare const SecondaryTabListResponsive: ({ size, defaultMatch, ...restProps }: SecondaryTabListProps) => JSX.Element;
3
+ declare const SecondaryTabListResponsive: ({ size, defaultMatch, fullWidthScroll, ...restProps }: SecondaryTabListProps) => JSX.Element;
4
4
  export { SecondaryTabListResponsive };
@@ -9,7 +9,7 @@ require('compute-scroll-into-view');
9
9
  require('../scrollable-container/index.module.css');
10
10
  require('../scrollable-container/Component.js');
11
11
  require('../../useTabs.js');
12
- require('@alfalab/core-components-tag/cssm');
12
+ require('@alfalab/core-components-tag/dist/cssm');
13
13
  require('./Component.js');
14
14
  require('./index.module.css');
15
15
  var components_secondaryTablist_Component_desktop = require('./Component.desktop.js');
@@ -22,12 +22,12 @@ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'defau
22
22
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
23
23
 
24
24
  var SecondaryTabListResponsive = function (_a) {
25
- var size = _a.size, _b = _a.defaultMatch, defaultMatch = _b === void 0 ? 'desktop' : _b, restProps = tslib_es6.__rest(_a, ["size", "defaultMatch"]);
25
+ var size = _a.size, _b = _a.defaultMatch, defaultMatch = _b === void 0 ? 'desktop' : _b, fullWidthScroll = _a.fullWidthScroll, restProps = tslib_es6.__rest(_a, ["size", "defaultMatch", "fullWidthScroll"]);
26
26
  var view = hooks.useMedia([
27
27
  ['mobile', '(max-width: 767px)'],
28
28
  ['desktop', '(min-width: 768px)'],
29
29
  ], defaultMatch)[0];
30
- return view === 'desktop' ? (React__default['default'].createElement(components_secondaryTablist_Component_desktop.SecondaryTabListDesktop, tslib_es6.__assign({ size: size }, restProps))) : (React__default['default'].createElement(components_secondaryTablist_Component_mobile.SecondaryTabListMobile, tslib_es6.__assign({}, restProps)));
30
+ return view === 'desktop' ? (React__default['default'].createElement(components_secondaryTablist_Component_desktop.SecondaryTabListDesktop, tslib_es6.__assign({ size: size }, restProps))) : (React__default['default'].createElement(components_secondaryTablist_Component_mobile.SecondaryTabListMobile, tslib_es6.__assign({ fullWidthScroll: fullWidthScroll }, restProps)));
31
31
  };
32
32
 
33
33
  exports.SecondaryTabListResponsive = SecondaryTabListResponsive;
@@ -45,12 +45,13 @@
45
45
  }
46
46
  .component {
47
47
  position: relative;
48
- display: flex;
49
- align-items: center;
48
+ display: inline-flex;
49
+ }
50
+ .fullWidthScroll {
51
+ margin: 0 var(--gap-m);
50
52
  }
51
53
  .container {
52
- display: flex;
53
- align-items: center;
54
+ overflow: hidden;
54
55
  }
55
56
  .title {
56
57
  white-space: nowrap;
File without changes
File without changes
File without changes
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { TabsProps } from "../../typings";
3
+ declare const Tabs: ({ TabList, className, containerClassName, size, defaultMatch, children, selectedId, scrollable, fullWidthScroll, keepMounted, dataTestId, onChange, }: Pick<TabsProps, "children" | "className" | "onChange" | "size" | "dataTestId" | "mobile" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll" | "keepMounted" | "TabList">) => JSX.Element;
4
+ export { Tabs };
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { TabsProps } from "../../typings";
3
- type TabsDesktopProps = Omit<TabsProps, 'TabList'>;
3
+ type TabsDesktopProps = Omit<TabsProps, 'TabList' | 'fullWidthScroll'>;
4
4
  declare const TabsDesktop: ({ view, scrollable, size, ...restProps }: Pick<TabsProps, "children" | "className" | "onChange" | "size" | "dataTestId" | "view" | "mobile" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "keepMounted">) => JSX.Element;
5
5
  export { TabsDesktopProps, TabsDesktop };
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var tslib_es6 = require('../../tslib.es6-ce870b46.js');
6
6
  var React = require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('../scrollable-container/index.module.css');
@@ -13,7 +13,7 @@ require('../../useTabs.js');
13
13
  require('../primary-tablist/Component.js');
14
14
  require('../primary-tablist/index.module.css');
15
15
  var components_primaryTablist_Component_desktop = require('../primary-tablist/Component.desktop.js');
16
- require('@alfalab/core-components-tag/cssm');
16
+ require('@alfalab/core-components-tag/dist/cssm');
17
17
  require('../secondary-tablist/Component.js');
18
18
  require('../secondary-tablist/index.module.css');
19
19
  var components_secondaryTablist_Component_desktop = require('../secondary-tablist/Component.desktop.js');
@@ -9,21 +9,22 @@ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'defau
9
9
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
10
10
 
11
11
  var Tabs = function (_a) {
12
- var TabList = _a.TabList, className = _a.className, containerClassName = _a.containerClassName, size = _a.size, defaultMatch = _a.defaultMatch, children = _a.children, selectedId = _a.selectedId, scrollable = _a.scrollable, _b = _a.keepMounted, keepMounted = _b === void 0 ? false : _b, dataTestId = _a.dataTestId, onChange = _a.onChange;
12
+ var TabList = _a.TabList, className = _a.className, containerClassName = _a.containerClassName, size = _a.size, defaultMatch = _a.defaultMatch, children = _a.children, selectedId = _a.selectedId, scrollable = _a.scrollable, _b = _a.fullWidthScroll, fullWidthScroll = _b === void 0 ? false : _b, _c = _a.keepMounted, keepMounted = _c === void 0 ? false : _c, dataTestId = _a.dataTestId, onChange = _a.onChange;
13
13
  var tabsArray = React__default['default'].Children.toArray(children);
14
14
  var titles = tabsArray.map(function (_a) {
15
- var _b = _a.props, title = _b.title, id = _b.id, rightAddons = _b.rightAddons, disabled = _b.disabled, hidden = _b.hidden;
15
+ var _b = _a.props, title = _b.title, id = _b.id, rightAddons = _b.rightAddons, disabled = _b.disabled, hidden = _b.hidden, toggleClassName = _b.toggleClassName;
16
16
  return ({
17
17
  title: title,
18
18
  id: id,
19
19
  disabled: disabled,
20
20
  rightAddons: rightAddons,
21
21
  hidden: hidden,
22
+ toggleClassName: toggleClassName,
22
23
  });
23
24
  });
24
25
  var tabs = tabsArray.filter(function (tab) { return tab.props.id === selectedId || tab.props.keepMounted || keepMounted; });
25
26
  return (React__default['default'].createElement("div", { className: className },
26
- React__default['default'].createElement(TabList, { containerClassName: containerClassName, size: size, titles: titles, selectedId: selectedId, scrollable: scrollable, onChange: onChange, dataTestId: dataTestId, defaultMatch: defaultMatch }),
27
+ React__default['default'].createElement(TabList, { containerClassName: containerClassName, size: size, titles: titles, selectedId: selectedId, scrollable: scrollable, onChange: onChange, dataTestId: dataTestId, defaultMatch: defaultMatch, fullWidthScroll: fullWidthScroll }),
27
28
  tabs.map(function (tab) { return React.cloneElement(tab, { hidden: tab.props.id !== selectedId }); })));
28
29
  };
29
30
 
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { TabsProps } from "../../typings";
3
3
  type TabsMobileProps = Omit<TabsProps, 'TabList' | 'size'>;
4
- declare const TabsMobile: ({ view, scrollable, ...restProps }: Pick<TabsProps, "children" | "className" | "onChange" | "dataTestId" | "view" | "mobile" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "keepMounted">) => JSX.Element;
4
+ declare const TabsMobile: ({ view, scrollable, ...restProps }: Pick<TabsProps, "children" | "className" | "onChange" | "dataTestId" | "view" | "mobile" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll" | "keepMounted">) => JSX.Element;
5
5
  export { TabsMobileProps, TabsMobile };
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var tslib_es6 = require('../../tslib.es6-ce870b46.js');
6
6
  var React = require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('../scrollable-container/index.module.css');
@@ -12,7 +12,7 @@ require('../scrollable-container/Component.js');
12
12
  require('../../useTabs.js');
13
13
  require('../primary-tablist/Component.js');
14
14
  require('../primary-tablist/index.module.css');
15
- require('@alfalab/core-components-tag/cssm');
15
+ require('@alfalab/core-components-tag/dist/cssm');
16
16
  require('../secondary-tablist/Component.js');
17
17
  require('../secondary-tablist/index.module.css');
18
18
  var components_tabs_Component = require('./Component.js');
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { TabsProps } from "../../typings";
3
3
  type TabsResponsiveProps = Omit<TabsProps, 'TabList'>;
4
- declare const TabsResponsive: ({ view, scrollable, ...restProps }: Pick<TabsProps, "children" | "className" | "onChange" | "size" | "dataTestId" | "view" | "mobile" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "keepMounted">) => JSX.Element;
4
+ declare const TabsResponsive: ({ view, scrollable, ...restProps }: Pick<TabsProps, "children" | "className" | "onChange" | "size" | "dataTestId" | "view" | "mobile" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll" | "keepMounted">) => JSX.Element;
5
5
  export { TabsResponsiveProps, TabsResponsive };
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var tslib_es6 = require('../../tslib.es6-ce870b46.js');
6
6
  var React = require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('../scrollable-container/index.module.css');
@@ -13,7 +13,7 @@ require('../../useTabs.js');
13
13
  require('../primary-tablist/Component.js');
14
14
  require('../primary-tablist/index.module.css');
15
15
  require('../primary-tablist/Component.desktop.js');
16
- require('@alfalab/core-components-tag/cssm');
16
+ require('@alfalab/core-components-tag/dist/cssm');
17
17
  require('../secondary-tablist/Component.js');
18
18
  require('../secondary-tablist/index.module.css');
19
19
  require('../secondary-tablist/Component.desktop.js');
File without changes
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('./tslib.es6-ce870b46.js');
6
6
  require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('./components/scrollable-container/index.module.css');
@@ -13,7 +13,7 @@ var useTabs = require('./useTabs.js');
13
13
  require('./components/primary-tablist/Component.js');
14
14
  require('./components/primary-tablist/index.module.css');
15
15
  var components_primaryTablist_Component_desktop = require('./components/primary-tablist/Component.desktop.js');
16
- require('@alfalab/core-components-tag/cssm');
16
+ require('@alfalab/core-components-tag/dist/cssm');
17
17
  require('./components/secondary-tablist/Component.js');
18
18
  require('./components/secondary-tablist/index.module.css');
19
19
  var components_secondaryTablist_Component_desktop = require('./components/secondary-tablist/Component.desktop.js');
File without changes
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('./tslib.es6-ce870b46.js');
6
6
  require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('./components/scrollable-container/index.module.css');
@@ -13,7 +13,7 @@ var useTabs = require('./useTabs.js');
13
13
  require('./components/primary-tablist/Component.js');
14
14
  require('./components/primary-tablist/index.module.css');
15
15
  require('./components/primary-tablist/Component.desktop.js');
16
- require('@alfalab/core-components-tag/cssm');
16
+ require('@alfalab/core-components-tag/dist/cssm');
17
17
  require('./components/secondary-tablist/Component.js');
18
18
  require('./components/secondary-tablist/index.module.css');
19
19
  require('./components/secondary-tablist/Component.desktop.js');
File without changes
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('./tslib.es6-ce870b46.js');
6
6
  require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('./components/scrollable-container/index.module.css');
@@ -12,7 +12,7 @@ var components_scrollableContainer_Component = require('./components/scrollable-
12
12
  var useTabs = require('./useTabs.js');
13
13
  require('./components/primary-tablist/Component.js');
14
14
  require('./components/primary-tablist/index.module.css');
15
- require('@alfalab/core-components-tag/cssm');
15
+ require('@alfalab/core-components-tag/dist/cssm');
16
16
  require('./components/secondary-tablist/Component.js');
17
17
  require('./components/secondary-tablist/index.module.css');
18
18
  require('./components/tab/index.module.css');
File without changes
@@ -4,7 +4,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('./tslib.es6-ce870b46.js');
6
6
  require('react');
7
- require('@alfalab/core-components-keyboard-focusable/cssm');
7
+ require('@alfalab/core-components-keyboard-focusable/dist/cssm');
8
8
  require('classnames');
9
9
  require('compute-scroll-into-view');
10
10
  require('./components/scrollable-container/index.module.css');
@@ -13,7 +13,7 @@ var useTabs = require('./useTabs.js');
13
13
  require('./components/primary-tablist/Component.js');
14
14
  require('./components/primary-tablist/index.module.css');
15
15
  require('./components/primary-tablist/Component.desktop.js');
16
- require('@alfalab/core-components-tag/cssm');
16
+ require('@alfalab/core-components-tag/dist/cssm');
17
17
  require('./components/secondary-tablist/Component.js');
18
18
  require('./components/secondary-tablist/index.module.css');
19
19
  require('./components/secondary-tablist/Component.desktop.js');
File without changes
File without changes
@@ -1,4 +1,4 @@
1
- import { FC, ReactElement, ReactNode } from 'react';
1
+ import { MouseEvent, FC, ReactElement, ReactNode } from 'react';
2
2
  import { TagProps } from "@alfalab/core-components-tag";
3
3
  type SelectedId = string | number;
4
4
  type TabsMatchMedia = 'desktop' | 'mobile';
@@ -39,6 +39,10 @@ type TabsProps = {
39
39
  * Рендерить заголовки табов в контейнере со скроллом
40
40
  */
41
41
  scrollable?: boolean;
42
+ /**
43
+ * При скроле табы будут уходить в край экрана
44
+ */
45
+ fullWidthScroll?: boolean;
42
46
  /**
43
47
  * Компоненты табов
44
48
  */
@@ -68,9 +72,13 @@ type TabProps = {
68
72
  */
69
73
  title: string;
70
74
  /**
71
- * Дополнительный класс
75
+ * Дополнительный класс для контейнера содержимого таба
72
76
  */
73
77
  className?: string;
78
+ /**
79
+ * Дополнительный класс для кнопки таба
80
+ */
81
+ toggleClassName?: string;
74
82
  /**
75
83
  * Блокирует таб
76
84
  */
@@ -96,17 +104,19 @@ type TabProps = {
96
104
  */
97
105
  dataTestId?: string;
98
106
  };
99
- type TabListProps = Pick<TabsProps, 'className' | 'containerClassName' | 'size' | 'defaultMatch' | 'selectedId' | 'scrollable' | 'onChange' | 'dataTestId'> & {
107
+ type TabListTitle = {
108
+ title: string;
109
+ id: SelectedId;
110
+ disabled?: boolean;
111
+ rightAddons?: ReactNode;
112
+ hidden?: boolean;
113
+ toggleClassName?: string;
114
+ };
115
+ type TabListProps = Pick<TabsProps, 'className' | 'containerClassName' | 'size' | 'defaultMatch' | 'selectedId' | 'scrollable' | 'onChange' | 'dataTestId' | 'fullWidthScroll'> & {
100
116
  /**
101
117
  * Заголовки табов
102
118
  */
103
- titles?: Array<{
104
- title: string;
105
- id: SelectedId;
106
- disabled?: boolean;
107
- rightAddons?: ReactNode;
108
- hidden?: boolean;
109
- }>;
119
+ titles?: TabListTitle[];
110
120
  };
111
121
  type SecondaryTabListProps = TabListProps & {
112
122
  tagSize?: TagProps['size'];
@@ -117,4 +127,4 @@ type Styles = {
117
127
  [key: string]: string;
118
128
  };
119
129
  };
120
- export { SelectedId, TabsMatchMedia, TabsProps, TabProps, TabListProps, SecondaryTabListProps, UseTabsProps, Styles };
130
+ export { SelectedId, TabsMatchMedia, TabsProps, TabProps, TabListTitle, TabListProps, SecondaryTabListProps, UseTabsProps, Styles };
File without changes
File without changes
File without changes
File without changes
File without changes
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- require('./tslib.es6-21f3b6da.js');
5
+ require('./tslib.es6-1df23a7b.js');
6
6
  require('react');
7
7
  require('@alfalab/core-components-keyboard-focusable');
8
8
  require('classnames');
@@ -10,11 +10,11 @@ require('compute-scroll-into-view');
10
10
  var components_scrollableContainer_Component = require('./components/scrollable-container/Component.js');
11
11
  var useTabs = require('./useTabs.js');
12
12
  require('./components/primary-tablist/Component.js');
13
- require('./index.module-5ed9b0e6.js');
13
+ require('./index.module-4b779b53.js');
14
14
  var components_primaryTablist_Component_desktop = require('./components/primary-tablist/Component.desktop.js');
15
15
  require('@alfalab/core-components-tag');
16
16
  require('./components/secondary-tablist/Component.js');
17
- require('./index.module-fa5020d4.js');
17
+ require('./index.module-8e427b33.js');
18
18
  var components_secondaryTablist_Component_desktop = require('./components/secondary-tablist/Component.desktop.js');
19
19
  var components_tab_Component = require('./components/tab/Component.js');
20
20
  require('./components/tabs/Component.js');
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ import { Styles } from "../../typings";
3
+ declare const PrimaryTabList: ({ size, styles, className, containerClassName, titles, selectedId, scrollable, fullWidthScroll, onChange, dataTestId, }: Pick<import("../../typings").TabsProps, "className" | "onChange" | "size" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll"> & {
4
+ titles?: import("../../typings").TabListTitle[] | undefined;
5
+ } & Styles) => JSX.Element;
6
+ export { PrimaryTabList };
@@ -1,12 +1,12 @@
1
- import { _ as __rest, a as __assign } from '../../tslib.es6-d595f357.js';
1
+ import { _ as __rest, a as __assign } from '../../tslib.es6-5a4d264a.js';
2
2
  import React from 'react';
3
- import '@alfalab/core-components-keyboard-focusable/esm';
3
+ import '@alfalab/core-components-keyboard-focusable/dist/esm';
4
4
  import 'classnames';
5
5
  import 'compute-scroll-into-view';
6
6
  import '../scrollable-container/Component.js';
7
7
  import '../../useTabs.js';
8
8
  import { PrimaryTabList } from './Component.js';
9
- import { c as commonStyles } from '../../index.module-7be29ac4.js';
9
+ import { c as commonStyles } from '../../index.module-d00881c2.js';
10
10
 
11
11
  var PrimaryTabListDesktop = function (_a) {
12
12
  var _b = _a.size, size = _b === void 0 ? 'm' : _b, restProps = __rest(_a, ["size"]);
@@ -0,0 +1,46 @@
1
+ import { a as __assign } from '../../tslib.es6-5a4d264a.js';
2
+ import React, { useRef, useEffect } from 'react';
3
+ import { KeyboardFocusable } from '@alfalab/core-components-keyboard-focusable/dist/esm';
4
+ import cn from 'classnames';
5
+ import 'compute-scroll-into-view';
6
+ import { ScrollableContainer } from '../scrollable-container/Component.js';
7
+ import { useTabs } from '../../useTabs.js';
8
+
9
+ var PrimaryTabList = function (_a) {
10
+ var size = _a.size, _b = _a.styles, styles = _b === void 0 ? {} : _b, className = _a.className, containerClassName = _a.containerClassName, _c = _a.titles, titles = _c === void 0 ? [] : _c, _d = _a.selectedId, selectedId = _d === void 0 ? titles.length ? titles[0].id : undefined : _d, _e = _a.scrollable, scrollable = _e === void 0 ? true : _e, fullWidthScroll = _a.fullWidthScroll, onChange = _a.onChange, dataTestId = _a.dataTestId;
11
+ var lineRef = useRef(null);
12
+ var _f = useTabs({
13
+ titles: titles,
14
+ selectedId: selectedId,
15
+ onChange: onChange,
16
+ }), selectedTab = _f.selectedTab, focusedTab = _f.focusedTab, getTabListItemProps = _f.getTabListItemProps;
17
+ useEffect(function () {
18
+ if (selectedTab && lineRef.current) {
19
+ lineRef.current.style.width = selectedTab.offsetWidth + "px";
20
+ lineRef.current.style.transform = "translateX(" + selectedTab.offsetLeft + "px)";
21
+ }
22
+ }, [selectedTab]);
23
+ var renderContent = function () {
24
+ var _a;
25
+ return (React.createElement("div", { role: 'tablist', "data-test-id": dataTestId, className: cn(styles.component, className, size && styles[size], (_a = {},
26
+ _a[styles.fullWidthScroll] = fullWidthScroll,
27
+ _a)) },
28
+ titles.map(function (item, index) {
29
+ if (item.hidden)
30
+ return null;
31
+ return (React.createElement(KeyboardFocusable, { key: item.id }, function (ref, focused) {
32
+ var _a;
33
+ return (React.createElement("button", __assign({}, getTabListItemProps(index, ref), { type: 'button', className: cn(styles.title, (_a = {},
34
+ _a[styles.selected] = item.id === selectedId,
35
+ _a[styles.disabled] = item.disabled,
36
+ _a), item.toggleClassName) }),
37
+ React.createElement("span", { className: focused ? styles.focused : undefined }, item.title),
38
+ item.rightAddons && (React.createElement("span", { className: styles.rightAddons }, item.rightAddons))));
39
+ }));
40
+ }),
41
+ React.createElement("div", { className: styles.line, ref: lineRef })));
42
+ };
43
+ return scrollable ? (React.createElement(ScrollableContainer, { activeChild: focusedTab || selectedTab, containerClassName: containerClassName, fullWidthScroll: fullWidthScroll }, renderContent())) : (React.createElement("div", { className: cn(styles.container, containerClassName) }, renderContent()));
44
+ };
45
+
46
+ export { PrimaryTabList };
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
2
  import { TabListProps } from "../../typings";
3
3
  type PrimaryTabListMobileProps = Omit<TabListProps, 'size'>;
4
- declare const PrimaryTabListMobile: ({ className, ...restProps }: Pick<TabListProps, "className" | "onChange" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "titles">) => JSX.Element;
4
+ declare const PrimaryTabListMobile: ({ className, ...restProps }: Pick<TabListProps, "className" | "onChange" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll" | "titles">) => JSX.Element;
5
5
  export { PrimaryTabListMobileProps, PrimaryTabListMobile };
@@ -1,14 +1,14 @@
1
- import { a as __assign, _ as __rest } from '../../tslib.es6-d595f357.js';
1
+ import { a as __assign, _ as __rest } from '../../tslib.es6-5a4d264a.js';
2
2
  import React from 'react';
3
- import '@alfalab/core-components-keyboard-focusable/esm';
3
+ import '@alfalab/core-components-keyboard-focusable/dist/esm';
4
4
  import cn from 'classnames';
5
5
  import 'compute-scroll-into-view';
6
6
  import '../scrollable-container/Component.js';
7
7
  import '../../useTabs.js';
8
8
  import { PrimaryTabList } from './Component.js';
9
- import { c as commonStyles } from '../../index.module-7be29ac4.js';
9
+ import { c as commonStyles } from '../../index.module-d00881c2.js';
10
10
 
11
- var mobileStyles = {"title":"tabs__title_1q8rm tabs__title_1dx1o","mobile":"tabs__mobile_1q8rm"};
11
+ var mobileStyles = {"title":"tabs__title_15atz tabs__title_1i10x","mobile":"tabs__mobile_15atz"};
12
12
  require('./mobile.css')
13
13
 
14
14
  var styles = __assign(__assign({}, commonStyles), mobileStyles);
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { TabListProps } from "../../typings";
3
+ declare const PrimaryTabListResponsive: ({ size, defaultMatch, fullWidthScroll, ...restProps }: TabListProps) => JSX.Element;
4
+ export { PrimaryTabListResponsive };
@@ -1,23 +1,23 @@
1
- import { _ as __rest, a as __assign } from '../../tslib.es6-d595f357.js';
1
+ import { _ as __rest, a as __assign } from '../../tslib.es6-5a4d264a.js';
2
2
  import React from 'react';
3
- import '@alfalab/core-components-keyboard-focusable/esm';
3
+ import '@alfalab/core-components-keyboard-focusable/dist/esm';
4
4
  import 'classnames';
5
5
  import 'compute-scroll-into-view';
6
6
  import '../scrollable-container/Component.js';
7
7
  import '../../useTabs.js';
8
8
  import './Component.js';
9
- import '../../index.module-7be29ac4.js';
9
+ import '../../index.module-d00881c2.js';
10
10
  import { PrimaryTabListDesktop } from './Component.desktop.js';
11
11
  import { useMedia } from '@alfalab/hooks';
12
12
  import { PrimaryTabListMobile } from './Component.mobile.js';
13
13
 
14
14
  var PrimaryTabListResponsive = function (_a) {
15
- var size = _a.size, _b = _a.defaultMatch, defaultMatch = _b === void 0 ? 'desktop' : _b, restProps = __rest(_a, ["size", "defaultMatch"]);
15
+ var size = _a.size, _b = _a.defaultMatch, defaultMatch = _b === void 0 ? 'desktop' : _b, fullWidthScroll = _a.fullWidthScroll, restProps = __rest(_a, ["size", "defaultMatch", "fullWidthScroll"]);
16
16
  var view = useMedia([
17
17
  ['mobile', '(max-width: 767px)'],
18
18
  ['desktop', '(min-width: 768px)'],
19
19
  ], defaultMatch)[0];
20
- return view === 'desktop' ? (React.createElement(PrimaryTabListDesktop, __assign({ size: size }, restProps))) : (React.createElement(PrimaryTabListMobile, __assign({}, restProps)));
20
+ return view === 'desktop' ? (React.createElement(PrimaryTabListDesktop, __assign({ size: size }, restProps))) : (React.createElement(PrimaryTabListMobile, __assign({ fullWidthScroll: fullWidthScroll }, restProps)));
21
21
  };
22
22
 
23
23
  export { PrimaryTabListResponsive };