@alfalab/core-components-tabs 6.3.2 → 6.5.0
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 +22 -0
- package/components/primary-tablist/Component.d.ts +2 -1
- package/components/primary-tablist/Component.desktop.js +2 -2
- package/components/primary-tablist/Component.js +24 -19
- package/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/components/primary-tablist/Component.mobile.js +3 -3
- package/components/primary-tablist/Component.responsive.d.ts +1 -1
- package/components/primary-tablist/Component.responsive.js +4 -4
- package/components/primary-tablist/index.css +27 -21
- package/components/primary-tablist/mobile.css +30 -24
- package/components/scrollable-container/Component.d.ts +2 -1
- package/components/scrollable-container/Component.js +14 -4
- package/components/scrollable-container/index.css +11 -6
- package/components/secondary-tablist/Component.d.ts +2 -1
- package/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/components/secondary-tablist/Component.desktop.js +2 -2
- package/components/secondary-tablist/Component.js +11 -6
- package/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/components/secondary-tablist/Component.mobile.js +3 -3
- package/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/components/secondary-tablist/Component.responsive.js +4 -4
- package/components/secondary-tablist/index.css +15 -14
- package/components/secondary-tablist/mobile.css +17 -16
- package/components/tab/Component.js +1 -1
- package/components/tab/index.css +3 -3
- package/components/tabs/Component.d.ts +1 -1
- package/components/tabs/Component.desktop.d.ts +1 -1
- package/components/tabs/Component.desktop.js +3 -3
- package/components/tabs/Component.js +4 -3
- package/components/tabs/Component.mobile.d.ts +1 -1
- package/components/tabs/Component.mobile.js +3 -3
- package/components/tabs/Component.responsive.d.ts +1 -1
- package/components/tabs/Component.responsive.js +3 -3
- package/cssm/components/primary-tablist/Component.d.ts +2 -1
- package/cssm/components/primary-tablist/Component.js +23 -18
- package/cssm/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/cssm/components/primary-tablist/Component.responsive.d.ts +1 -1
- package/cssm/components/primary-tablist/Component.responsive.js +2 -2
- package/cssm/components/primary-tablist/index.module.css +8 -2
- package/cssm/components/scrollable-container/Component.d.ts +2 -1
- package/cssm/components/scrollable-container/Component.js +13 -3
- package/cssm/components/scrollable-container/index.module.css +7 -2
- package/cssm/components/secondary-tablist/Component.d.ts +2 -1
- package/cssm/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/cssm/components/secondary-tablist/Component.js +10 -5
- package/cssm/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/cssm/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/cssm/components/secondary-tablist/Component.responsive.js +2 -2
- package/cssm/components/secondary-tablist/index.module.css +5 -4
- package/cssm/components/tabs/Component.d.ts +1 -1
- package/cssm/components/tabs/Component.desktop.d.ts +1 -1
- package/cssm/components/tabs/Component.js +4 -3
- package/cssm/components/tabs/Component.mobile.d.ts +1 -1
- package/cssm/components/tabs/Component.responsive.d.ts +1 -1
- package/cssm/typings.d.ts +11 -2
- package/desktop.js +3 -3
- package/esm/components/primary-tablist/Component.d.ts +2 -1
- package/esm/components/primary-tablist/Component.desktop.js +2 -2
- package/esm/components/primary-tablist/Component.js +24 -19
- package/esm/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/esm/components/primary-tablist/Component.mobile.js +3 -3
- package/esm/components/primary-tablist/Component.responsive.d.ts +1 -1
- package/esm/components/primary-tablist/Component.responsive.js +4 -4
- package/esm/components/primary-tablist/index.css +27 -21
- package/esm/components/primary-tablist/mobile.css +30 -24
- package/esm/components/scrollable-container/Component.d.ts +2 -1
- package/esm/components/scrollable-container/Component.js +14 -4
- package/esm/components/scrollable-container/index.css +11 -6
- package/esm/components/secondary-tablist/Component.d.ts +2 -1
- package/esm/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/esm/components/secondary-tablist/Component.desktop.js +2 -2
- package/esm/components/secondary-tablist/Component.js +11 -6
- package/esm/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/esm/components/secondary-tablist/Component.mobile.js +3 -3
- package/esm/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/esm/components/secondary-tablist/Component.responsive.js +4 -4
- package/esm/components/secondary-tablist/index.css +15 -14
- package/esm/components/secondary-tablist/mobile.css +17 -16
- package/esm/components/tab/Component.js +1 -1
- package/esm/components/tab/index.css +3 -3
- package/esm/components/tabs/Component.d.ts +1 -1
- package/esm/components/tabs/Component.desktop.d.ts +1 -1
- package/esm/components/tabs/Component.desktop.js +3 -3
- package/esm/components/tabs/Component.js +4 -3
- package/esm/components/tabs/Component.mobile.d.ts +1 -1
- package/esm/components/tabs/Component.mobile.js +3 -3
- package/esm/components/tabs/Component.responsive.d.ts +1 -1
- package/esm/components/tabs/Component.responsive.js +3 -3
- package/esm/desktop.js +3 -3
- package/esm/index.js +3 -3
- package/esm/index.module-4bf6c045.js +4 -0
- package/esm/index.module-c15e7c79.js +4 -0
- package/esm/mobile.js +3 -3
- package/esm/responsive.js +3 -3
- package/esm/{tslib.es6-d595f357.d.ts → tslib.es6-b50bf201.d.ts} +0 -0
- package/esm/{tslib.es6-d595f357.js → tslib.es6-b50bf201.js} +0 -0
- package/esm/typings.d.ts +11 -2
- package/index.js +3 -3
- package/index.module-960245fb.js +6 -0
- package/index.module-d67ef5e7.js +6 -0
- package/mobile.js +3 -3
- package/modern/components/primary-tablist/Component.d.ts +2 -1
- package/modern/components/primary-tablist/Component.desktop.js +1 -1
- package/modern/components/primary-tablist/Component.js +7 -5
- package/modern/components/primary-tablist/Component.mobile.d.ts +1 -1
- package/modern/components/primary-tablist/Component.mobile.js +2 -2
- package/modern/components/primary-tablist/Component.responsive.d.ts +1 -1
- package/modern/components/primary-tablist/Component.responsive.js +3 -3
- package/modern/components/primary-tablist/index.css +27 -21
- package/modern/components/primary-tablist/mobile.css +30 -24
- package/modern/components/scrollable-container/Component.d.ts +2 -1
- package/modern/components/scrollable-container/Component.js +13 -4
- package/modern/components/scrollable-container/index.css +11 -6
- package/modern/components/secondary-tablist/Component.d.ts +2 -1
- package/modern/components/secondary-tablist/Component.desktop.d.ts +1 -1
- package/modern/components/secondary-tablist/Component.desktop.js +1 -1
- package/modern/components/secondary-tablist/Component.js +9 -5
- package/modern/components/secondary-tablist/Component.mobile.d.ts +1 -1
- package/modern/components/secondary-tablist/Component.mobile.js +2 -2
- package/modern/components/secondary-tablist/Component.responsive.d.ts +1 -1
- package/modern/components/secondary-tablist/Component.responsive.js +3 -3
- package/modern/components/secondary-tablist/index.css +15 -14
- package/modern/components/secondary-tablist/mobile.css +17 -16
- package/modern/components/tab/Component.js +1 -1
- package/modern/components/tab/index.css +3 -3
- package/modern/components/tabs/Component.d.ts +1 -1
- package/modern/components/tabs/Component.desktop.d.ts +1 -1
- package/modern/components/tabs/Component.desktop.js +2 -2
- package/modern/components/tabs/Component.js +4 -3
- package/modern/components/tabs/Component.mobile.d.ts +1 -1
- package/modern/components/tabs/Component.mobile.js +2 -2
- package/modern/components/tabs/Component.responsive.d.ts +1 -1
- package/modern/components/tabs/Component.responsive.js +2 -2
- package/modern/desktop.js +2 -2
- package/modern/index.js +2 -2
- package/modern/index.module-4bf6c045.js +4 -0
- package/modern/index.module-c15e7c79.js +4 -0
- package/modern/mobile.js +2 -2
- package/modern/responsive.js +2 -2
- package/modern/typings.d.ts +11 -2
- package/package.json +4 -4
- package/responsive.js +3 -3
- package/{tslib.es6-21f3b6da.d.ts → tslib.es6-996824db.d.ts} +0 -0
- package/{tslib.es6-21f3b6da.js → tslib.es6-996824db.js} +0 -0
- package/typings.d.ts +11 -2
- 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/index.module-7be29ac4.js +0 -4
- package/modern/index.module-a7445354.js +0 -4
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,28 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [6.5.0](https://github.com/core-ds/core-components/compare/@alfalab/core-components-tabs@6.4.0...@alfalab/core-components-tabs@6.5.0) (2022-07-18)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
### Features
|
|
10
|
+
|
|
11
|
+
* **tabs:** full width TabsMobile ([#124](https://github.com/core-ds/core-components/issues/124)) ([659763a](https://github.com/core-ds/core-components/commit/659763abefd2b3762713958e32272c762bb116c6))
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
# [6.4.0](https://github.com/core-ds/core-components/compare/@alfalab/core-components-tabs@6.3.2...@alfalab/core-components-tabs@6.4.0) (2022-07-15)
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
### Features
|
|
21
|
+
|
|
22
|
+
* **tabs:** add className fro tab button and tab children ([#132](https://github.com/core-ds/core-components/issues/132)) ([a1b19d2](https://github.com/core-ds/core-components/commit/a1b19d282d27159103f13205f9ea694489d65c51))
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
6
28
|
## [6.3.2](https://github.com/core-ds/core-components/compare/@alfalab/core-components-tabs@6.3.1...@alfalab/core-components-tabs@6.3.2) (2022-07-15)
|
|
7
29
|
|
|
8
30
|
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { Styles } from "../../typings";
|
|
4
|
-
declare const PrimaryTabList: ({ size, styles, className, containerClassName, titles, selectedId, scrollable, onChange, dataTestId, }: Pick<import("../../typings").TabsProps, "className" | "onChange" | "size" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable"> & {
|
|
4
|
+
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"> & {
|
|
5
5
|
titles?: {
|
|
6
6
|
title: string;
|
|
7
7
|
id: React.ReactText;
|
|
8
8
|
disabled?: boolean | undefined;
|
|
9
9
|
rightAddons?: React.ReactNode;
|
|
10
10
|
hidden?: boolean | undefined;
|
|
11
|
+
toggleClassName?: string | undefined;
|
|
11
12
|
}[] | undefined;
|
|
12
13
|
} & Styles) => JSX.Element;
|
|
13
14
|
export { PrimaryTabList };
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var tslib_es6 = require('../../tslib.es6-
|
|
5
|
+
var tslib_es6 = require('../../tslib.es6-996824db.js');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
require('@alfalab/core-components-keyboard-focusable');
|
|
8
8
|
require('classnames');
|
|
@@ -10,7 +10,7 @@ require('compute-scroll-into-view');
|
|
|
10
10
|
require('../scrollable-container/Component.js');
|
|
11
11
|
require('../../useTabs.js');
|
|
12
12
|
var components_primaryTablist_Component = require('./Component.js');
|
|
13
|
-
var index_module = require('../../index.module-
|
|
13
|
+
var index_module = require('../../index.module-d67ef5e7.js');
|
|
14
14
|
|
|
15
15
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
16
|
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var tslib_es6 = require('../../tslib.es6-
|
|
5
|
+
var tslib_es6 = require('../../tslib.es6-996824db.js');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var coreComponentsKeyboardFocusable = require('@alfalab/core-components-keyboard-focusable');
|
|
8
8
|
var cn = require('classnames');
|
|
@@ -16,7 +16,7 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
|
16
16
|
var cn__default = /*#__PURE__*/_interopDefaultLegacy(cn);
|
|
17
17
|
|
|
18
18
|
var PrimaryTabList = function (_a) {
|
|
19
|
-
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, onChange = _a.onChange, dataTestId = _a.dataTestId;
|
|
19
|
+
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;
|
|
20
20
|
var lineRef = React.useRef(null);
|
|
21
21
|
var _f = useTabs.useTabs({
|
|
22
22
|
titles: titles,
|
|
@@ -28,23 +28,28 @@ var PrimaryTabList = function (_a) {
|
|
|
28
28
|
lineRef.current.style.width = selectedTab.offsetWidth + "px";
|
|
29
29
|
lineRef.current.style.transform = "translateX(" + selectedTab.offsetLeft + "px)";
|
|
30
30
|
}
|
|
31
|
-
});
|
|
32
|
-
var renderContent = function () {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
React__default['default'].createElement("
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
31
|
+
}, [selectedTab]);
|
|
32
|
+
var renderContent = function () {
|
|
33
|
+
var _a;
|
|
34
|
+
return (React__default['default'].createElement("div", { role: 'tablist', "data-test-id": dataTestId, className: cn__default['default'](styles.component, className, size && styles[size], (_a = {},
|
|
35
|
+
_a[styles.fullWidthScroll] = fullWidthScroll,
|
|
36
|
+
_a)) },
|
|
37
|
+
titles.map(function (item, index) {
|
|
38
|
+
if (item.hidden)
|
|
39
|
+
return null;
|
|
40
|
+
return (React__default['default'].createElement(coreComponentsKeyboardFocusable.KeyboardFocusable, { key: item.id }, function (ref, focused) {
|
|
41
|
+
var _a;
|
|
42
|
+
return (React__default['default'].createElement("button", tslib_es6.__assign({}, getTabListItemProps(index, ref), { type: 'button', className: cn__default['default'](styles.title, (_a = {},
|
|
43
|
+
_a[styles.selected] = item.id === selectedId,
|
|
44
|
+
_a[styles.disabled] = item.disabled,
|
|
45
|
+
_a), item.toggleClassName) }),
|
|
46
|
+
React__default['default'].createElement("span", { className: focused ? styles.focused : undefined }, item.title),
|
|
47
|
+
item.rightAddons && (React__default['default'].createElement("span", { className: styles.rightAddons }, item.rightAddons))));
|
|
48
|
+
}));
|
|
49
|
+
}),
|
|
50
|
+
React__default['default'].createElement("div", { className: styles.line, ref: lineRef })));
|
|
51
|
+
};
|
|
52
|
+
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()));
|
|
48
53
|
};
|
|
49
54
|
|
|
50
55
|
exports.PrimaryTabList = 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 };
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var tslib_es6 = require('../../tslib.es6-
|
|
5
|
+
var tslib_es6 = require('../../tslib.es6-996824db.js');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
require('@alfalab/core-components-keyboard-focusable');
|
|
8
8
|
var cn = require('classnames');
|
|
@@ -10,14 +10,14 @@ require('compute-scroll-into-view');
|
|
|
10
10
|
require('../scrollable-container/Component.js');
|
|
11
11
|
require('../../useTabs.js');
|
|
12
12
|
var components_primaryTablist_Component = require('./Component.js');
|
|
13
|
-
var index_module = require('../../index.module-
|
|
13
|
+
var index_module = require('../../index.module-d67ef5e7.js');
|
|
14
14
|
|
|
15
15
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
16
|
|
|
17
17
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
18
18
|
var cn__default = /*#__PURE__*/_interopDefaultLegacy(cn);
|
|
19
19
|
|
|
20
|
-
var mobileStyles = {"title":"
|
|
20
|
+
var mobileStyles = {"title":"tabs__title_dhwzv tabs__title_astus","mobile":"tabs__mobile_dhwzv"};
|
|
21
21
|
require('./mobile.css')
|
|
22
22
|
|
|
23
23
|
var styles = tslib_es6.__assign(tslib_es6.__assign({}, index_module.commonStyles), mobileStyles);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { TabListProps } from "../../typings";
|
|
3
|
-
declare const PrimaryTabListResponsive: ({ size, defaultMatch, ...restProps }: TabListProps) => JSX.Element;
|
|
3
|
+
declare const PrimaryTabListResponsive: ({ size, defaultMatch, fullWidthScroll, ...restProps }: TabListProps) => JSX.Element;
|
|
4
4
|
export { PrimaryTabListResponsive };
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var tslib_es6 = require('../../tslib.es6-
|
|
5
|
+
var tslib_es6 = require('../../tslib.es6-996824db.js');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
require('@alfalab/core-components-keyboard-focusable');
|
|
8
8
|
require('classnames');
|
|
@@ -10,7 +10,7 @@ require('compute-scroll-into-view');
|
|
|
10
10
|
require('../scrollable-container/Component.js');
|
|
11
11
|
require('../../useTabs.js');
|
|
12
12
|
require('./Component.js');
|
|
13
|
-
require('../../index.module-
|
|
13
|
+
require('../../index.module-d67ef5e7.js');
|
|
14
14
|
var components_primaryTablist_Component_desktop = require('./Component.desktop.js');
|
|
15
15
|
var hooks = require('@alfalab/hooks');
|
|
16
16
|
var components_primaryTablist_Component_mobile = require('./Component.mobile.js');
|
|
@@ -20,12 +20,12 @@ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'defau
|
|
|
20
20
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
21
21
|
|
|
22
22
|
var PrimaryTabListResponsive = function (_a) {
|
|
23
|
-
var size = _a.size, _b = _a.defaultMatch, defaultMatch = _b === void 0 ? 'desktop' : _b, restProps = tslib_es6.__rest(_a, ["size", "defaultMatch"]);
|
|
23
|
+
var size = _a.size, _b = _a.defaultMatch, defaultMatch = _b === void 0 ? 'desktop' : _b, fullWidthScroll = _a.fullWidthScroll, restProps = tslib_es6.__rest(_a, ["size", "defaultMatch", "fullWidthScroll"]);
|
|
24
24
|
var view = hooks.useMedia([
|
|
25
25
|
['mobile', '(max-width: 767px)'],
|
|
26
26
|
['desktop', '(min-width: 768px)'],
|
|
27
27
|
], defaultMatch)[0];
|
|
28
|
-
return view === 'desktop' ? (React__default['default'].createElement(components_primaryTablist_Component_desktop.PrimaryTabListDesktop, tslib_es6.__assign({ size: size }, restProps))) : (React__default['default'].createElement(components_primaryTablist_Component_mobile.PrimaryTabListMobile, tslib_es6.__assign({}, restProps)));
|
|
28
|
+
return view === 'desktop' ? (React__default['default'].createElement(components_primaryTablist_Component_desktop.PrimaryTabListDesktop, tslib_es6.__assign({ size: size }, restProps))) : (React__default['default'].createElement(components_primaryTablist_Component_mobile.PrimaryTabListMobile, tslib_es6.__assign({ fullWidthScroll: fullWidthScroll }, restProps)));
|
|
29
29
|
};
|
|
30
30
|
|
|
31
31
|
exports.PrimaryTabListResponsive = PrimaryTabListResponsive;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: t09rb */
|
|
2
2
|
:root {
|
|
3
3
|
--color-light-border-accent: #ef3124;
|
|
4
4
|
--color-light-border-link: #007aff;
|
|
@@ -82,10 +82,12 @@
|
|
|
82
82
|
|
|
83
83
|
/* size xl */
|
|
84
84
|
}
|
|
85
|
-
.
|
|
86
|
-
position: relative
|
|
85
|
+
.tabs__component_astus {
|
|
86
|
+
position: relative;
|
|
87
|
+
display: inline-flex;
|
|
88
|
+
min-width: 100%
|
|
87
89
|
}
|
|
88
|
-
.
|
|
90
|
+
.tabs__component_astus:before {
|
|
89
91
|
content: '';
|
|
90
92
|
display: block;
|
|
91
93
|
position: absolute;
|
|
@@ -94,11 +96,15 @@
|
|
|
94
96
|
width: 100%;
|
|
95
97
|
background-color: var(--primary-tablist-bottom-border-color);
|
|
96
98
|
}
|
|
97
|
-
.
|
|
99
|
+
.tabs__fullWidthScroll_astus {
|
|
100
|
+
min-width: calc(100% - 2 * var(--gap-m));
|
|
101
|
+
margin: 0 var(--gap-m);
|
|
102
|
+
}
|
|
103
|
+
.tabs__container_astus {
|
|
98
104
|
position: relative;
|
|
99
|
-
|
|
105
|
+
overflow: hidden;
|
|
100
106
|
}
|
|
101
|
-
.
|
|
107
|
+
.tabs__title_astus {
|
|
102
108
|
display: flex;
|
|
103
109
|
align-items: center;
|
|
104
110
|
height: 100%;
|
|
@@ -116,22 +122,22 @@
|
|
|
116
122
|
cursor: pointer;
|
|
117
123
|
outline: none
|
|
118
124
|
}
|
|
119
|
-
.
|
|
125
|
+
.tabs__title_astus:not(.tabs__disabled_astus):hover {
|
|
120
126
|
color: var(--primary-tablist-hover-color);
|
|
121
127
|
}
|
|
122
|
-
.
|
|
128
|
+
.tabs__focused_astus {
|
|
123
129
|
outline: 2px solid var(--focus-color);
|
|
124
130
|
outline-offset: 2px;
|
|
125
131
|
}
|
|
126
|
-
.
|
|
132
|
+
.tabs__selected_astus {
|
|
127
133
|
cursor: default;
|
|
128
134
|
color: var(--primary-tablist-selected-color);
|
|
129
135
|
}
|
|
130
|
-
.
|
|
136
|
+
.tabs__disabled_astus {
|
|
131
137
|
cursor: var(--disabled-cursor);
|
|
132
138
|
color: var(--primary-tablist-disabled-color);
|
|
133
139
|
}
|
|
134
|
-
.
|
|
140
|
+
.tabs__line_astus {
|
|
135
141
|
position: absolute;
|
|
136
142
|
height: 3px;
|
|
137
143
|
bottom: 0;
|
|
@@ -140,46 +146,46 @@
|
|
|
140
146
|
transition: transform 0.2s ease, width 0.2s ease;
|
|
141
147
|
}
|
|
142
148
|
/* sizes */
|
|
143
|
-
.
|
|
149
|
+
.tabs__s_astus .tabs__title_astus, .tabs__xs_astus .tabs__title_astus, .tabs__xxs_astus .tabs__title_astus {
|
|
144
150
|
padding: var(--primary-tablist-s-padding);
|
|
145
151
|
font-size: var(--primary-tablist-s-font-size);
|
|
146
152
|
font-weight: var(--primary-tablist-s-font-weight);
|
|
147
153
|
font-family: var(--primary-tablist-s-font-family);
|
|
148
154
|
line-height: 24px;
|
|
149
155
|
}
|
|
150
|
-
.
|
|
156
|
+
.tabs__s_astus .tabs__title_astus + .tabs__title_astus, .tabs__xs_astus .tabs__title_astus + .tabs__title_astus, .tabs__xxs_astus .tabs__title_astus + .tabs__title_astus {
|
|
151
157
|
margin-left: var(--primary-tablist-s-gaps);
|
|
152
158
|
}
|
|
153
|
-
.
|
|
159
|
+
.tabs__m_astus .tabs__title_astus {
|
|
154
160
|
padding: var(--primary-tablist-m-padding);
|
|
155
161
|
font-size: var(--primary-tablist-m-font-size);
|
|
156
162
|
font-weight: var(--primary-tablist-m-font-weight);
|
|
157
163
|
font-family: var(--primary-tablist-m-font-family);
|
|
158
164
|
line-height: 24px;
|
|
159
165
|
}
|
|
160
|
-
.
|
|
166
|
+
.tabs__m_astus .tabs__title_astus + .tabs__title_astus {
|
|
161
167
|
margin-left: var(--primary-tablist-m-gaps);
|
|
162
168
|
}
|
|
163
|
-
.
|
|
169
|
+
.tabs__l_astus .tabs__title_astus {
|
|
164
170
|
padding: var(--primary-tablist-l-padding);
|
|
165
171
|
font-size: var(--primary-tablist-l-font-size);
|
|
166
172
|
font-weight: var(--primary-tablist-l-font-weight);
|
|
167
173
|
font-family: var(--primary-tablist-l-font-family);
|
|
168
174
|
line-height: 24px;
|
|
169
175
|
}
|
|
170
|
-
.
|
|
176
|
+
.tabs__l_astus .tabs__title_astus + .tabs__title_astus {
|
|
171
177
|
margin-left: var(--primary-tablist-l-gaps);
|
|
172
178
|
}
|
|
173
|
-
.
|
|
179
|
+
.tabs__xl_astus .tabs__title_astus {
|
|
174
180
|
padding: var(--primary-tablist-xl-padding);
|
|
175
181
|
font-size: var(--primary-tablist-xl-font-size);
|
|
176
182
|
font-weight: var(--primary-tablist-xl-font-weight);
|
|
177
183
|
font-family: var(--primary-tablist-xl-font-family);
|
|
178
184
|
line-height: 32px;
|
|
179
185
|
}
|
|
180
|
-
.
|
|
186
|
+
.tabs__xl_astus .tabs__title_astus + .tabs__title_astus {
|
|
181
187
|
margin-left: var(--primary-tablist-xl-gaps);
|
|
182
188
|
}
|
|
183
|
-
.
|
|
189
|
+
.tabs__rightAddons_astus {
|
|
184
190
|
margin-left: var(--gap-xs);
|
|
185
191
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: 1ae0x */
|
|
2
2
|
:root {
|
|
3
3
|
}:root {
|
|
4
4
|
}:root {
|
|
@@ -86,9 +86,11 @@
|
|
|
86
86
|
/* size l */
|
|
87
87
|
|
|
88
88
|
/* size xl */
|
|
89
|
-
}.
|
|
90
|
-
position: relative
|
|
91
|
-
|
|
89
|
+
}.tabs__component_astus {
|
|
90
|
+
position: relative;
|
|
91
|
+
display: inline-flex;
|
|
92
|
+
min-width: 100%
|
|
93
|
+
}.tabs__component_astus:before {
|
|
92
94
|
content: '';
|
|
93
95
|
display: block;
|
|
94
96
|
position: absolute;
|
|
@@ -96,10 +98,13 @@
|
|
|
96
98
|
height: 1px;
|
|
97
99
|
width: 100%;
|
|
98
100
|
background-color: var(--primary-tablist-bottom-border-color);
|
|
99
|
-
}.
|
|
101
|
+
}.tabs__fullWidthScroll_astus {
|
|
102
|
+
min-width: calc(100% - 2 * var(--gap-m));
|
|
103
|
+
margin: 0 var(--gap-m);
|
|
104
|
+
}.tabs__container_astus {
|
|
100
105
|
position: relative;
|
|
101
|
-
|
|
102
|
-
}.
|
|
106
|
+
overflow: hidden;
|
|
107
|
+
}.tabs__title_astus {
|
|
103
108
|
display: flex;
|
|
104
109
|
align-items: center;
|
|
105
110
|
height: 100%;
|
|
@@ -116,57 +121,57 @@
|
|
|
116
121
|
user-select: none;
|
|
117
122
|
cursor: pointer;
|
|
118
123
|
outline: none
|
|
119
|
-
}.
|
|
124
|
+
}.tabs__title_astus:not(.tabs__disabled_astus):hover {
|
|
120
125
|
color: var(--primary-tablist-hover-color);
|
|
121
|
-
}.
|
|
126
|
+
}.tabs__focused_astus {
|
|
122
127
|
outline: 2px solid var(--focus-color);
|
|
123
128
|
outline-offset: 2px;
|
|
124
|
-
}.
|
|
129
|
+
}.tabs__selected_astus {
|
|
125
130
|
cursor: default;
|
|
126
131
|
color: var(--primary-tablist-selected-color);
|
|
127
|
-
}.
|
|
132
|
+
}.tabs__disabled_astus {
|
|
128
133
|
cursor: var(--disabled-cursor);
|
|
129
134
|
color: var(--primary-tablist-disabled-color);
|
|
130
|
-
}.
|
|
135
|
+
}.tabs__line_astus {
|
|
131
136
|
position: absolute;
|
|
132
137
|
height: 3px;
|
|
133
138
|
bottom: 0;
|
|
134
139
|
left: 0;
|
|
135
140
|
background-color: var(--primary-tablist-line-color);
|
|
136
141
|
transition: transform 0.2s ease, width 0.2s ease;
|
|
137
|
-
}/* sizes */.
|
|
142
|
+
}/* sizes */.tabs__s_astus .tabs__title_astus, .tabs__xs_astus .tabs__title_astus, .tabs__xxs_astus .tabs__title_astus {
|
|
138
143
|
padding: var(--primary-tablist-s-padding);
|
|
139
144
|
font-size: var(--primary-tablist-s-font-size);
|
|
140
145
|
font-weight: var(--primary-tablist-s-font-weight);
|
|
141
146
|
font-family: var(--primary-tablist-s-font-family);
|
|
142
147
|
line-height: 24px;
|
|
143
|
-
}.
|
|
148
|
+
}.tabs__s_astus .tabs__title_astus + .tabs__title_astus, .tabs__xs_astus .tabs__title_astus + .tabs__title_astus, .tabs__xxs_astus .tabs__title_astus + .tabs__title_astus {
|
|
144
149
|
margin-left: var(--primary-tablist-s-gaps);
|
|
145
|
-
}.
|
|
150
|
+
}.tabs__m_astus .tabs__title_astus {
|
|
146
151
|
padding: var(--primary-tablist-m-padding);
|
|
147
152
|
font-size: var(--primary-tablist-m-font-size);
|
|
148
153
|
font-weight: var(--primary-tablist-m-font-weight);
|
|
149
154
|
font-family: var(--primary-tablist-m-font-family);
|
|
150
155
|
line-height: 24px;
|
|
151
|
-
}.
|
|
156
|
+
}.tabs__m_astus .tabs__title_astus + .tabs__title_astus {
|
|
152
157
|
margin-left: var(--primary-tablist-m-gaps);
|
|
153
|
-
}.
|
|
158
|
+
}.tabs__l_astus .tabs__title_astus {
|
|
154
159
|
padding: var(--primary-tablist-l-padding);
|
|
155
160
|
font-size: var(--primary-tablist-l-font-size);
|
|
156
161
|
font-weight: var(--primary-tablist-l-font-weight);
|
|
157
162
|
font-family: var(--primary-tablist-l-font-family);
|
|
158
163
|
line-height: 24px;
|
|
159
|
-
}.
|
|
164
|
+
}.tabs__l_astus .tabs__title_astus + .tabs__title_astus {
|
|
160
165
|
margin-left: var(--primary-tablist-l-gaps);
|
|
161
|
-
}.
|
|
166
|
+
}.tabs__xl_astus .tabs__title_astus {
|
|
162
167
|
padding: var(--primary-tablist-xl-padding);
|
|
163
168
|
font-size: var(--primary-tablist-xl-font-size);
|
|
164
169
|
font-weight: var(--primary-tablist-xl-font-weight);
|
|
165
170
|
font-family: var(--primary-tablist-xl-font-family);
|
|
166
171
|
line-height: 32px;
|
|
167
|
-
}.
|
|
172
|
+
}.tabs__xl_astus .tabs__title_astus + .tabs__title_astus {
|
|
168
173
|
margin-left: var(--primary-tablist-xl-gaps);
|
|
169
|
-
}.
|
|
174
|
+
}.tabs__rightAddons_astus {
|
|
170
175
|
margin-left: var(--gap-xs);
|
|
171
176
|
}
|
|
172
177
|
:root {
|
|
@@ -878,6 +883,7 @@
|
|
|
878
883
|
--border-radius-l: 12px;
|
|
879
884
|
--border-radius-xl: 16px;
|
|
880
885
|
--border-radius-xxl: 20px;
|
|
886
|
+
--border-radius-3xl: 24px;
|
|
881
887
|
--border-radius-circle: 50%;
|
|
882
888
|
--border-radius-pill: 99px;
|
|
883
889
|
}
|
|
@@ -960,15 +966,15 @@
|
|
|
960
966
|
/* size xl */
|
|
961
967
|
--secondary-tablist-xl-gaps: var(--gap-m);
|
|
962
968
|
}
|
|
963
|
-
.
|
|
969
|
+
.tabs__title_dhwzv {
|
|
964
970
|
}
|
|
965
|
-
.
|
|
971
|
+
.tabs__mobile_dhwzv .tabs__title_dhwzv {
|
|
966
972
|
padding: var(--primary-tablist-mobile-padding);
|
|
967
973
|
font-size: var(--primary-tablist-mobile-font-size);
|
|
968
974
|
font-weight: var(--primary-tablist-mobile-font-weight);
|
|
969
975
|
font-family: var(--primary-tablist-mobile-font-family);
|
|
970
976
|
line-height: 24px
|
|
971
977
|
}
|
|
972
|
-
.
|
|
978
|
+
.tabs__mobile_dhwzv .tabs__title_dhwzv + .tabs__title_dhwzv {
|
|
973
979
|
margin-left: var(--primary-tablist-mobile-gaps);
|
|
974
980
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { ReactNode } from 'react';
|
|
3
|
+
import { TabsProps } from "../../typings";
|
|
3
4
|
type ScrollableContainerProps = {
|
|
4
5
|
/**
|
|
5
6
|
* Дополнительный класс контейнера
|
|
@@ -14,5 +15,5 @@ type ScrollableContainerProps = {
|
|
|
14
15
|
*/
|
|
15
16
|
activeChild: HTMLElement | null;
|
|
16
17
|
};
|
|
17
|
-
declare const ScrollableContainer: ({ containerClassName, children, activeChild, }: ScrollableContainerProps) => JSX.Element;
|
|
18
|
+
declare const ScrollableContainer: ({ containerClassName, children, activeChild, fullWidthScroll, }: ScrollableContainerProps & Pick<TabsProps, "fullWidthScroll">) => JSX.Element;
|
|
18
19
|
export { ScrollableContainerProps, ScrollableContainer };
|
|
@@ -12,11 +12,16 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
|
12
12
|
var cn__default = /*#__PURE__*/_interopDefaultLegacy(cn);
|
|
13
13
|
var computeScrollIntoView__default = /*#__PURE__*/_interopDefaultLegacy(computeScrollIntoView);
|
|
14
14
|
|
|
15
|
-
var styles = {"container":"
|
|
15
|
+
var styles = {"container":"tabs__container_te8ps","fullWidthScroll":"tabs__fullWidthScroll_te8ps"};
|
|
16
16
|
require('./index.css')
|
|
17
17
|
|
|
18
|
+
/**
|
|
19
|
+
* Дополнительная прокрутка при клике на не поместившийся таб
|
|
20
|
+
*/
|
|
21
|
+
var ADDITIONAL_SCROLLLEFT_VALUE = 40;
|
|
18
22
|
var ScrollableContainer = function (_a) {
|
|
19
|
-
var
|
|
23
|
+
var _b;
|
|
24
|
+
var containerClassName = _a.containerClassName, children = _a.children, activeChild = _a.activeChild, fullWidthScroll = _a.fullWidthScroll;
|
|
20
25
|
React.useEffect(function () {
|
|
21
26
|
if (activeChild) {
|
|
22
27
|
var actions = computeScrollIntoView__default['default'](activeChild, {
|
|
@@ -28,11 +33,16 @@ var ScrollableContainer = function (_a) {
|
|
|
28
33
|
actions.forEach(function (_a) {
|
|
29
34
|
var el = _a.el, left = _a.left;
|
|
30
35
|
// eslint-disable-next-line no-param-reassign
|
|
31
|
-
el.scrollLeft =
|
|
36
|
+
el.scrollLeft =
|
|
37
|
+
el.scrollLeft > left
|
|
38
|
+
? left - ADDITIONAL_SCROLLLEFT_VALUE
|
|
39
|
+
: left + ADDITIONAL_SCROLLLEFT_VALUE;
|
|
32
40
|
});
|
|
33
41
|
}
|
|
34
42
|
}, [activeChild]);
|
|
35
|
-
return React__default['default'].createElement("div", { className: cn__default['default'](styles.container, containerClassName
|
|
43
|
+
return (React__default['default'].createElement("div", { className: cn__default['default'](styles.container, containerClassName, (_b = {},
|
|
44
|
+
_b[styles.fullWidthScroll] = fullWidthScroll,
|
|
45
|
+
_b)) }, children));
|
|
36
46
|
};
|
|
37
47
|
|
|
38
48
|
exports.ScrollableContainer = ScrollableContainer;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* hash:
|
|
1
|
+
/* hash: 31dvk */
|
|
2
2
|
:root {
|
|
3
3
|
|
|
4
4
|
/* Hard */
|
|
@@ -7,6 +7,9 @@
|
|
|
7
7
|
|
|
8
8
|
/* Hard up */
|
|
9
9
|
}
|
|
10
|
+
:root {
|
|
11
|
+
--gap-m-neg: -16px;
|
|
12
|
+
}
|
|
10
13
|
:root {
|
|
11
14
|
|
|
12
15
|
/* mobile */
|
|
@@ -33,17 +36,19 @@
|
|
|
33
36
|
|
|
34
37
|
/* size xl */
|
|
35
38
|
}
|
|
36
|
-
.
|
|
39
|
+
.tabs__container_te8ps {
|
|
37
40
|
position: relative;
|
|
38
|
-
display: flex;
|
|
39
|
-
align-items: center;
|
|
40
41
|
overflow-x: auto;
|
|
41
42
|
overflow-y: hidden;
|
|
43
|
+
scroll-behavior: smooth;
|
|
42
44
|
scrollbar-width: none
|
|
43
45
|
}
|
|
44
|
-
.
|
|
46
|
+
.tabs__container_te8ps::-webkit-scrollbar {
|
|
45
47
|
display: none;
|
|
46
48
|
}
|
|
47
|
-
.
|
|
49
|
+
.tabs__container_te8ps > * {
|
|
48
50
|
flex-shrink: 0;
|
|
49
51
|
}
|
|
52
|
+
.tabs__fullWidthScroll_te8ps {
|
|
53
|
+
margin: 0 var(--gap-m-neg);
|
|
54
|
+
}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { Styles } from "../../typings";
|
|
4
|
-
declare const SecondaryTabList: ({ styles, className, containerClassName, size, titles, selectedId, scrollable, tagSize, onChange, dataTestId, }: Pick<import("../../typings").TabsProps, "className" | "onChange" | "size" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable"> & {
|
|
4
|
+
declare const SecondaryTabList: ({ styles, className, containerClassName, size, titles, selectedId, scrollable, fullWidthScroll, tagSize, onChange, dataTestId, }: Pick<import("../../typings").TabsProps, "className" | "onChange" | "size" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll"> & {
|
|
5
5
|
titles?: {
|
|
6
6
|
title: string;
|
|
7
7
|
id: React.ReactText;
|
|
8
8
|
disabled?: boolean | undefined;
|
|
9
9
|
rightAddons?: React.ReactNode;
|
|
10
10
|
hidden?: boolean | undefined;
|
|
11
|
+
toggleClassName?: string | undefined;
|
|
11
12
|
}[] | undefined;
|
|
12
13
|
} & {
|
|
13
14
|
tagSize?: "xxs" | "xs" | "s" | "m" | "l" | "xl" | undefined;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { SecondaryTabListProps } from "../../typings";
|
|
3
3
|
type SecondaryTabListDesktopProps = Omit<SecondaryTabListProps, 'tagSize'>;
|
|
4
|
-
declare const SecondaryTabListDesktop: ({ size, ...restProps }: Pick<SecondaryTabListProps, "className" | "onChange" | "size" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "titles">) => JSX.Element;
|
|
4
|
+
declare const SecondaryTabListDesktop: ({ size, ...restProps }: Pick<SecondaryTabListProps, "className" | "onChange" | "size" | "dataTestId" | "containerClassName" | "defaultMatch" | "selectedId" | "scrollable" | "fullWidthScroll" | "titles">) => JSX.Element;
|
|
5
5
|
export { SecondaryTabListDesktopProps, SecondaryTabListDesktop };
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var tslib_es6 = require('../../tslib.es6-
|
|
5
|
+
var tslib_es6 = require('../../tslib.es6-996824db.js');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
require('classnames');
|
|
8
8
|
require('compute-scroll-into-view');
|
|
@@ -10,7 +10,7 @@ require('../scrollable-container/Component.js');
|
|
|
10
10
|
require('../../useTabs.js');
|
|
11
11
|
require('@alfalab/core-components-tag');
|
|
12
12
|
var components_secondaryTablist_Component = require('./Component.js');
|
|
13
|
-
var index_module = require('../../index.module-
|
|
13
|
+
var index_module = require('../../index.module-960245fb.js');
|
|
14
14
|
|
|
15
15
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
16
|
|