@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.
- package/CHANGELOG.md +44 -0
- package/dist/components/primary-tablist/Component.d.ts +6 -0
- package/{components → dist/components}/primary-tablist/Component.desktop.d.ts +0 -0
- package/{components → dist/components}/primary-tablist/Component.desktop.js +2 -2
- package/dist/components/primary-tablist/Component.js +55 -0
- package/{esm → dist}/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/{components → dist/components}/primary-tablist/Component.mobile.js +3 -3
- package/dist/components/primary-tablist/Component.responsive.d.ts +4 -0
- package/{components → dist/components}/primary-tablist/Component.responsive.js +4 -4
- package/{components → dist/components}/primary-tablist/index.css +27 -21
- package/{components → dist/components}/primary-tablist/mobile.css +30 -24
- package/{cssm → dist}/components/scrollable-container/Component.d.ts +2 -1
- package/{components → dist/components}/scrollable-container/Component.js +14 -4
- package/{components → dist/components}/scrollable-container/index.css +11 -6
- package/{components → dist/components}/scrollable-container/index.d.ts +0 -0
- package/{components → dist/components}/scrollable-container/index.js +0 -0
- package/dist/components/secondary-tablist/Component.d.ts +8 -0
- package/{esm → dist}/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/{components → dist/components}/secondary-tablist/Component.desktop.js +2 -2
- package/dist/components/secondary-tablist/Component.js +38 -0
- package/{components → dist/components}/secondary-tablist/Component.mobile.d.ts +1 -1
- package/{components → dist/components}/secondary-tablist/Component.mobile.js +3 -3
- package/{cssm → dist}/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/{components → dist/components}/secondary-tablist/Component.responsive.js +4 -4
- package/{components → dist/components}/secondary-tablist/index.css +15 -14
- package/{modern → dist}/components/secondary-tablist/mobile.css +17 -16
- package/{components → dist/components}/tab/Component.d.ts +0 -0
- package/{components → dist/components}/tab/Component.js +1 -1
- package/dist/components/tab/index.css +8 -0
- package/{components → dist/components}/tab/index.d.ts +0 -0
- package/{components → dist/components}/tab/index.js +0 -0
- package/dist/components/tabs/Component.d.ts +4 -0
- package/{cssm → dist}/components/tabs/Component.desktop.d.ts +1 -1
- package/{components → dist/components}/tabs/Component.desktop.js +3 -3
- package/{cssm → dist}/components/tabs/Component.js +4 -3
- package/{cssm → dist}/components/tabs/Component.mobile.d.ts +1 -1
- package/{components → dist/components}/tabs/Component.mobile.js +3 -3
- package/{cssm → dist}/components/tabs/Component.responsive.d.ts +1 -1
- package/{components → dist/components}/tabs/Component.responsive.js +3 -3
- package/dist/cssm/components/primary-tablist/Component.d.ts +6 -0
- package/{cssm → dist/cssm}/components/primary-tablist/Component.desktop.d.ts +0 -0
- package/{cssm → dist/cssm}/components/primary-tablist/Component.desktop.js +1 -1
- package/dist/cssm/components/primary-tablist/Component.js +56 -0
- package/{components → dist/cssm/components}/primary-tablist/Component.mobile.d.ts +1 -1
- package/{cssm → dist/cssm}/components/primary-tablist/Component.mobile.js +1 -1
- package/dist/cssm/components/primary-tablist/Component.responsive.d.ts +4 -0
- package/{cssm → dist/cssm}/components/primary-tablist/Component.responsive.js +3 -3
- package/{cssm → dist/cssm}/components/primary-tablist/index.module.css +8 -2
- package/{cssm → dist/cssm}/components/primary-tablist/mobile.module.css +0 -0
- package/{esm → dist/cssm}/components/scrollable-container/Component.d.ts +2 -1
- package/{cssm → dist/cssm}/components/scrollable-container/Component.js +13 -3
- package/{cssm → dist/cssm}/components/scrollable-container/index.d.ts +0 -0
- package/{cssm → dist/cssm}/components/scrollable-container/index.js +0 -0
- package/{cssm → dist/cssm}/components/scrollable-container/index.module.css +7 -2
- package/dist/cssm/components/secondary-tablist/Component.d.ts +8 -0
- package/{components → dist/cssm/components}/secondary-tablist/Component.desktop.d.ts +1 -1
- package/{cssm → dist/cssm}/components/secondary-tablist/Component.desktop.js +1 -1
- package/dist/cssm/components/secondary-tablist/Component.js +39 -0
- package/{cssm → dist/cssm}/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/{cssm → dist/cssm}/components/secondary-tablist/Component.mobile.js +1 -1
- package/{components → dist/cssm/components}/secondary-tablist/Component.responsive.d.ts +1 -1
- package/{cssm → dist/cssm}/components/secondary-tablist/Component.responsive.js +3 -3
- package/{cssm → dist/cssm}/components/secondary-tablist/index.module.css +5 -4
- package/{cssm → dist/cssm}/components/secondary-tablist/mobile.module.css +0 -0
- package/{cssm → dist/cssm}/components/tab/Component.d.ts +0 -0
- package/{cssm → dist/cssm}/components/tab/Component.js +0 -0
- package/{cssm → dist/cssm}/components/tab/index.d.ts +0 -0
- package/{cssm → dist/cssm}/components/tab/index.js +0 -0
- package/{cssm → dist/cssm}/components/tab/index.module.css +0 -0
- package/dist/cssm/components/tabs/Component.d.ts +4 -0
- package/{esm → dist/cssm}/components/tabs/Component.desktop.d.ts +1 -1
- package/{cssm → dist/cssm}/components/tabs/Component.desktop.js +2 -2
- package/{components → dist/cssm/components}/tabs/Component.js +4 -3
- package/{esm → dist/cssm}/components/tabs/Component.mobile.d.ts +1 -1
- package/{cssm → dist/cssm}/components/tabs/Component.mobile.js +2 -2
- package/{esm → dist/cssm}/components/tabs/Component.responsive.d.ts +1 -1
- package/{cssm → dist/cssm}/components/tabs/Component.responsive.js +2 -2
- package/{cssm → dist/cssm}/desktop.d.ts +0 -0
- package/{cssm → dist/cssm}/desktop.js +2 -2
- package/{cssm → dist/cssm}/index.d.ts +0 -0
- package/{cssm → dist/cssm}/index.js +2 -2
- package/{cssm → dist/cssm}/mobile.d.ts +0 -0
- package/{cssm → dist/cssm}/mobile.js +2 -2
- package/{cssm → dist/cssm}/responsive.d.ts +0 -0
- package/{cssm → dist/cssm}/responsive.js +2 -2
- package/{cssm → dist/cssm}/tslib.es6-ce870b46.d.ts +0 -0
- package/{cssm → dist/cssm}/tslib.es6-ce870b46.js +0 -0
- package/{esm → dist/cssm}/typings.d.ts +21 -11
- package/{cssm → dist/cssm}/typings.js +0 -0
- package/{cssm → dist/cssm}/useTabs.d.ts +0 -0
- package/{cssm → dist/cssm}/useTabs.js +0 -0
- package/{cssm → dist/cssm}/vars.css +0 -0
- package/{desktop.d.ts → dist/desktop.d.ts} +0 -0
- package/{desktop.js → dist/desktop.js} +3 -3
- package/dist/esm/components/primary-tablist/Component.d.ts +6 -0
- package/{esm → dist/esm}/components/primary-tablist/Component.desktop.d.ts +0 -0
- package/{esm → dist/esm}/components/primary-tablist/Component.desktop.js +3 -3
- package/dist/esm/components/primary-tablist/Component.js +46 -0
- package/{modern → dist/esm}/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/{esm → dist/esm}/components/primary-tablist/Component.mobile.js +4 -4
- package/dist/esm/components/primary-tablist/Component.responsive.d.ts +4 -0
- package/{esm → dist/esm}/components/primary-tablist/Component.responsive.js +5 -5
- package/{modern → dist/esm}/components/primary-tablist/index.css +27 -21
- package/{modern → dist/esm}/components/primary-tablist/mobile.css +30 -24
- package/{modern → dist/esm}/components/scrollable-container/Component.d.ts +2 -1
- package/{esm → dist/esm}/components/scrollable-container/Component.js +14 -4
- package/{esm → dist/esm}/components/scrollable-container/index.css +11 -6
- package/{esm → dist/esm}/components/scrollable-container/index.d.ts +0 -0
- package/{esm → dist/esm}/components/scrollable-container/index.js +0 -0
- package/dist/esm/components/secondary-tablist/Component.d.ts +8 -0
- package/{cssm → dist/esm}/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/{esm → dist/esm}/components/secondary-tablist/Component.desktop.js +3 -3
- package/dist/esm/components/secondary-tablist/Component.js +29 -0
- package/{esm → dist/esm}/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/{esm → dist/esm}/components/secondary-tablist/Component.mobile.js +4 -4
- package/{esm → dist/esm}/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/{esm → dist/esm}/components/secondary-tablist/Component.responsive.js +5 -5
- package/{esm → dist/esm}/components/secondary-tablist/index.css +15 -14
- package/{components → dist/esm/components}/secondary-tablist/mobile.css +17 -16
- package/{esm → dist/esm}/components/tab/Component.d.ts +0 -0
- package/{esm → dist/esm}/components/tab/Component.js +1 -1
- package/dist/esm/components/tab/index.css +8 -0
- package/{esm → dist/esm}/components/tab/index.d.ts +0 -0
- package/{esm → dist/esm}/components/tab/index.js +0 -0
- package/dist/esm/components/tabs/Component.d.ts +4 -0
- package/{modern → dist/esm}/components/tabs/Component.desktop.d.ts +1 -1
- package/{esm → dist/esm}/components/tabs/Component.desktop.js +5 -5
- package/{esm → dist/esm}/components/tabs/Component.js +4 -3
- package/{modern → dist/esm}/components/tabs/Component.mobile.d.ts +1 -1
- package/{esm → dist/esm}/components/tabs/Component.mobile.js +5 -5
- package/{modern → dist/esm}/components/tabs/Component.responsive.d.ts +1 -1
- package/{esm → dist/esm}/components/tabs/Component.responsive.js +5 -5
- package/{esm → dist/esm}/desktop.d.ts +0 -0
- package/{esm → dist/esm}/desktop.js +5 -5
- package/{esm → dist/esm}/index.d.ts +0 -0
- package/{esm → dist/esm}/index.js +5 -5
- package/dist/esm/index.module-3d17828f.js +4 -0
- package/dist/esm/index.module-d00881c2.js +4 -0
- package/{esm → dist/esm}/mobile.d.ts +0 -0
- package/{esm → dist/esm}/mobile.js +5 -5
- package/{esm → dist/esm}/responsive.d.ts +0 -0
- package/{esm → dist/esm}/responsive.js +5 -5
- package/{esm/tslib.es6-d595f357.d.ts → dist/esm/tslib.es6-5a4d264a.d.ts} +0 -0
- package/{esm/tslib.es6-d595f357.js → dist/esm/tslib.es6-5a4d264a.js} +0 -0
- package/{modern → dist/esm}/typings.d.ts +21 -11
- package/{esm → dist/esm}/typings.js +0 -0
- package/{esm → dist/esm}/useTabs.d.ts +0 -0
- package/{esm → dist/esm}/useTabs.js +0 -0
- package/{index.d.ts → dist/index.d.ts} +0 -0
- package/{index.js → dist/index.js} +3 -3
- package/dist/index.module-4b779b53.js +6 -0
- package/dist/index.module-8e427b33.js +6 -0
- package/{mobile.d.ts → dist/mobile.d.ts} +0 -0
- package/{mobile.js → dist/mobile.js} +3 -3
- package/dist/modern/components/primary-tablist/Component.d.ts +6 -0
- package/{modern → dist/modern}/components/primary-tablist/Component.desktop.d.ts +0 -0
- package/{modern → dist/modern}/components/primary-tablist/Component.desktop.js +2 -2
- package/{modern → dist/modern}/components/primary-tablist/Component.js +8 -6
- package/{cssm → dist/modern}/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/{modern → dist/modern}/components/primary-tablist/Component.mobile.js +3 -3
- package/dist/modern/components/primary-tablist/Component.responsive.d.ts +4 -0
- package/{modern → dist/modern}/components/primary-tablist/Component.responsive.js +4 -4
- package/{esm → dist/modern}/components/primary-tablist/index.css +27 -21
- package/{esm → dist/modern}/components/primary-tablist/mobile.css +30 -24
- package/{components → dist/modern/components}/scrollable-container/Component.d.ts +2 -1
- package/{modern → dist/modern}/components/scrollable-container/Component.js +13 -4
- package/{modern → dist/modern}/components/scrollable-container/index.css +11 -6
- package/{modern → dist/modern}/components/scrollable-container/index.d.ts +0 -0
- package/{modern → dist/modern}/components/scrollable-container/index.js +0 -0
- package/dist/modern/components/secondary-tablist/Component.d.ts +8 -0
- package/{modern → dist/modern}/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/{modern → dist/modern}/components/secondary-tablist/Component.desktop.js +2 -2
- package/dist/modern/components/secondary-tablist/Component.js +24 -0
- package/{modern → dist/modern}/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/{modern → dist/modern}/components/secondary-tablist/Component.mobile.js +3 -3
- package/{modern → dist/modern}/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/{modern → dist/modern}/components/secondary-tablist/Component.responsive.js +4 -4
- package/{modern → dist/modern}/components/secondary-tablist/index.css +15 -14
- package/{esm → dist/modern}/components/secondary-tablist/mobile.css +17 -16
- package/{modern → dist/modern}/components/tab/Component.d.ts +0 -0
- package/{modern → dist/modern}/components/tab/Component.js +1 -1
- package/dist/modern/components/tab/index.css +8 -0
- package/{modern → dist/modern}/components/tab/index.d.ts +0 -0
- package/{modern → dist/modern}/components/tab/index.js +0 -0
- package/dist/modern/components/tabs/Component.d.ts +4 -0
- package/{components → dist/modern/components}/tabs/Component.desktop.d.ts +2 -2
- package/{modern → dist/modern}/components/tabs/Component.desktop.js +4 -4
- package/{modern → dist/modern}/components/tabs/Component.js +4 -3
- package/{components → dist/modern/components}/tabs/Component.mobile.d.ts +1 -1
- package/{modern → dist/modern}/components/tabs/Component.mobile.js +4 -4
- package/{components → dist/modern/components}/tabs/Component.responsive.d.ts +1 -1
- package/{modern → dist/modern}/components/tabs/Component.responsive.js +4 -4
- package/{modern → dist/modern}/desktop.d.ts +0 -0
- package/{modern → dist/modern}/desktop.js +4 -4
- package/{modern → dist/modern}/index.d.ts +0 -0
- package/{modern → dist/modern}/index.js +4 -4
- package/dist/modern/index.module-3d17828f.js +4 -0
- package/dist/modern/index.module-d00881c2.js +4 -0
- package/{modern → dist/modern}/mobile.d.ts +0 -0
- package/{modern → dist/modern}/mobile.js +4 -4
- package/{modern → dist/modern}/responsive.d.ts +0 -0
- package/{modern → dist/modern}/responsive.js +4 -4
- package/{cssm → dist/modern}/typings.d.ts +21 -11
- package/{modern → dist/modern}/typings.js +0 -0
- package/{modern → dist/modern}/useTabs.d.ts +0 -0
- package/{modern → dist/modern}/useTabs.js +0 -0
- package/{responsive.d.ts → dist/responsive.d.ts} +0 -0
- package/{responsive.js → dist/responsive.js} +3 -3
- package/{send-stats.js → dist/send-stats.js} +0 -0
- package/{tslib.es6-21f3b6da.d.ts → dist/tslib.es6-1df23a7b.d.ts} +0 -0
- package/{tslib.es6-21f3b6da.js → dist/tslib.es6-1df23a7b.js} +0 -0
- package/{typings.d.ts → dist/typings.d.ts} +21 -11
- package/{typings.js → dist/typings.js} +0 -0
- package/{useTabs.d.ts → dist/useTabs.d.ts} +0 -0
- package/{useTabs.js → dist/useTabs.js} +0 -0
- package/package.json +15 -12
- package/components/primary-tablist/Component.d.ts +0 -13
- package/components/primary-tablist/Component.js +0 -50
- package/components/primary-tablist/Component.responsive.d.ts +0 -4
- package/components/secondary-tablist/Component.d.ts +0 -15
- package/components/secondary-tablist/Component.js +0 -33
- package/components/tab/index.css +0 -8
- package/components/tabs/Component.d.ts +0 -4
- package/cssm/components/primary-tablist/Component.d.ts +0 -13
- package/cssm/components/primary-tablist/Component.js +0 -51
- package/cssm/components/primary-tablist/Component.responsive.d.ts +0 -4
- package/cssm/components/secondary-tablist/Component.d.ts +0 -15
- package/cssm/components/secondary-tablist/Component.js +0 -34
- package/cssm/components/tabs/Component.d.ts +0 -4
- package/esm/components/primary-tablist/Component.d.ts +0 -13
- package/esm/components/primary-tablist/Component.js +0 -41
- package/esm/components/primary-tablist/Component.responsive.d.ts +0 -4
- package/esm/components/secondary-tablist/Component.d.ts +0 -15
- package/esm/components/secondary-tablist/Component.js +0 -24
- package/esm/components/tab/index.css +0 -8
- package/esm/components/tabs/Component.d.ts +0 -4
- package/esm/index.module-7be29ac4.js +0 -4
- package/esm/index.module-a7445354.js +0 -4
- package/index.module-5ed9b0e6.js +0 -6
- package/index.module-fa5020d4.js +0 -6
- package/modern/components/primary-tablist/Component.d.ts +0 -13
- package/modern/components/primary-tablist/Component.responsive.d.ts +0 -4
- package/modern/components/secondary-tablist/Component.d.ts +0 -15
- package/modern/components/secondary-tablist/Component.js +0 -20
- package/modern/components/tab/index.css +0 -8
- package/modern/components/tabs/Component.d.ts +0 -4
- package/modern/index.module-7be29ac4.js +0 -4
- 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
|
-
|
|
48
|
+
display: inline-flex;
|
|
49
|
+
}
|
|
50
|
+
.fullWidthScroll {
|
|
51
|
+
margin: 0 var(--gap-m);
|
|
50
52
|
}
|
|
51
53
|
.container {
|
|
52
|
-
|
|
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
|
|
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.
|
|
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
|
|
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?:
|
|
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-
|
|
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-
|
|
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-
|
|
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 };
|
|
File without changes
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { _ as __rest, a as __assign } from '../../tslib.es6-
|
|
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-
|
|
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-
|
|
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-
|
|
9
|
+
import { c as commonStyles } from '../../index.module-d00881c2.js';
|
|
10
10
|
|
|
11
|
-
var mobileStyles = {"title":"
|
|
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);
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import { _ as __rest, a as __assign } from '../../tslib.es6-
|
|
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-
|
|
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 };
|