@alfalab/core-components-navigation-bar 0.8.6 → 1.0.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.
Files changed (126) hide show
  1. package/Component.d.ts +70 -5
  2. package/Component.js +25 -128
  3. package/components/action-icon-addon/Component.d.ts +22 -0
  4. package/components/action-icon-addon/Component.js +32 -0
  5. package/components/action-icon-addon/index.css +44 -0
  6. package/components/action-icon-addon/index.js +9 -0
  7. package/components/action-text-addon/Component.d.ts +26 -0
  8. package/components/action-text-addon/Component.js +25 -0
  9. package/{cssm/components/closer/index.module.css → components/action-text-addon/index.css} +8 -32
  10. package/components/action-text-addon/index.js +9 -0
  11. package/cssm/Component.d.ts +70 -5
  12. package/cssm/Component.js +24 -127
  13. package/cssm/components/action-icon-addon/Component.d.ts +22 -0
  14. package/cssm/components/action-icon-addon/Component.js +31 -0
  15. package/cssm/components/action-icon-addon/index.js +9 -0
  16. package/{modern/components/closer/index.css → cssm/components/action-icon-addon/index.module.css} +23 -28
  17. package/cssm/components/action-text-addon/Component.d.ts +26 -0
  18. package/cssm/components/action-text-addon/Component.js +24 -0
  19. package/cssm/components/action-text-addon/index.js +9 -0
  20. package/cssm/{vars.css → components/action-text-addon/index.module.css} +6 -4
  21. package/cssm/index.d.ts +0 -1
  22. package/cssm/index.module.css +46 -76
  23. package/cssm/shared/index.d.ts +3 -2
  24. package/cssm/shared/index.js +6 -4
  25. package/cssm/utils.d.ts +6 -0
  26. package/cssm/utils.js +15 -0
  27. package/esm/Component.d.ts +70 -5
  28. package/esm/Component.js +26 -128
  29. package/esm/components/action-icon-addon/Component.d.ts +22 -0
  30. package/esm/components/action-icon-addon/Component.js +23 -0
  31. package/esm/components/action-icon-addon/index.css +44 -0
  32. package/esm/components/action-icon-addon/index.js +1 -0
  33. package/esm/components/action-text-addon/Component.d.ts +26 -0
  34. package/esm/components/action-text-addon/Component.js +16 -0
  35. package/esm/components/{closer → action-text-addon}/index.css +8 -33
  36. package/esm/components/action-text-addon/index.js +1 -0
  37. package/esm/index.css +49 -78
  38. package/esm/index.d.ts +0 -1
  39. package/esm/shared/index.d.ts +3 -2
  40. package/esm/shared/index.js +3 -2
  41. package/esm/utils.d.ts +6 -0
  42. package/esm/utils.js +11 -0
  43. package/index.css +49 -78
  44. package/index.d.ts +0 -1
  45. package/modern/Component.d.ts +70 -5
  46. package/modern/Component.js +26 -133
  47. package/modern/components/action-icon-addon/Component.d.ts +22 -0
  48. package/modern/components/action-icon-addon/Component.js +18 -0
  49. package/modern/components/action-icon-addon/index.css +44 -0
  50. package/modern/components/action-icon-addon/index.js +1 -0
  51. package/modern/components/action-text-addon/Component.d.ts +26 -0
  52. package/modern/components/action-text-addon/Component.js +12 -0
  53. package/{components/closer → modern/components/action-text-addon}/index.css +8 -33
  54. package/modern/components/action-text-addon/index.js +1 -0
  55. package/modern/index.css +49 -78
  56. package/modern/index.d.ts +0 -1
  57. package/modern/shared/index.d.ts +3 -2
  58. package/modern/shared/index.js +3 -2
  59. package/modern/utils.d.ts +6 -0
  60. package/modern/utils.js +11 -0
  61. package/package.json +6 -9
  62. package/shared/index.d.ts +3 -2
  63. package/shared/index.js +6 -4
  64. package/src/Component.tsx +183 -264
  65. package/src/components/action-icon-addon/Component.tsx +58 -0
  66. package/src/components/action-icon-addon/index.module.css +40 -0
  67. package/src/components/action-text-addon/Component.tsx +61 -0
  68. package/src/components/action-text-addon/index.module.css +9 -0
  69. package/src/index.module.css +39 -79
  70. package/src/index.ts +0 -1
  71. package/src/shared/index.ts +3 -2
  72. package/src/utils.ts +9 -0
  73. package/utils.d.ts +6 -0
  74. package/utils.js +15 -0
  75. package/components/back-arrow-addon/Component.d.ts +0 -26
  76. package/components/back-arrow-addon/Component.js +0 -35
  77. package/components/back-arrow-addon/index.css +0 -76
  78. package/components/back-arrow-addon/index.js +0 -9
  79. package/components/closer/Component.d.ts +0 -35
  80. package/components/closer/Component.js +0 -32
  81. package/components/closer/index.js +0 -9
  82. package/cssm/components/back-arrow-addon/Component.d.ts +0 -26
  83. package/cssm/components/back-arrow-addon/Component.js +0 -34
  84. package/cssm/components/back-arrow-addon/index.js +0 -9
  85. package/cssm/components/back-arrow-addon/index.module.css +0 -75
  86. package/cssm/components/closer/Component.d.ts +0 -35
  87. package/cssm/components/closer/Component.js +0 -31
  88. package/cssm/components/closer/index.js +0 -9
  89. package/cssm/types.d.ts +0 -118
  90. package/cssm/types.js +0 -2
  91. package/esm/components/back-arrow-addon/Component.d.ts +0 -26
  92. package/esm/components/back-arrow-addon/Component.js +0 -26
  93. package/esm/components/back-arrow-addon/index.css +0 -76
  94. package/esm/components/back-arrow-addon/index.js +0 -1
  95. package/esm/components/closer/Component.d.ts +0 -35
  96. package/esm/components/closer/Component.js +0 -23
  97. package/esm/components/closer/index.js +0 -1
  98. package/esm/types.d.ts +0 -118
  99. package/esm/types.js +0 -1
  100. package/modern/components/back-arrow-addon/Component.d.ts +0 -26
  101. package/modern/components/back-arrow-addon/Component.js +0 -23
  102. package/modern/components/back-arrow-addon/index.css +0 -76
  103. package/modern/components/back-arrow-addon/index.js +0 -1
  104. package/modern/components/closer/Component.d.ts +0 -35
  105. package/modern/components/closer/Component.js +0 -20
  106. package/modern/components/closer/index.js +0 -1
  107. package/modern/types.d.ts +0 -118
  108. package/modern/types.js +0 -1
  109. package/src/components/back-arrow-addon/Component.tsx +0 -79
  110. package/src/components/back-arrow-addon/index.module.css +0 -69
  111. package/src/components/closer/Component.tsx +0 -80
  112. package/src/components/closer/index.module.css +0 -32
  113. package/src/types.ts +0 -143
  114. package/src/vars.css +0 -9
  115. package/types.d.ts +0 -118
  116. package/types.js +0 -2
  117. /package/components/{back-arrow-addon → action-icon-addon}/index.d.ts +0 -0
  118. /package/components/{closer → action-text-addon}/index.d.ts +0 -0
  119. /package/cssm/components/{back-arrow-addon → action-icon-addon}/index.d.ts +0 -0
  120. /package/cssm/components/{closer → action-text-addon}/index.d.ts +0 -0
  121. /package/esm/components/{back-arrow-addon → action-icon-addon}/index.d.ts +0 -0
  122. /package/esm/components/{closer → action-text-addon}/index.d.ts +0 -0
  123. /package/modern/components/{back-arrow-addon → action-icon-addon}/index.d.ts +0 -0
  124. /package/modern/components/{closer → action-text-addon}/index.d.ts +0 -0
  125. /package/src/components/{back-arrow-addon → action-icon-addon}/index.ts +0 -0
  126. /package/src/components/{closer → action-text-addon}/index.ts +0 -0
package/cssm/Component.js CHANGED
@@ -4,47 +4,26 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var tslib = require('tslib');
6
6
  var React = require('react');
7
- var mergeRefs = require('react-merge-refs');
8
7
  var cn = require('classnames');
9
8
  var coreComponentsShared = require('@alfalab/core-components-shared/cssm');
10
- var hooks = require('@alfalab/hooks');
11
- var components_backArrowAddon_Component = require('./components/back-arrow-addon/Component.js');
12
- var components_closer_Component = require('./components/closer/Component.js');
13
9
  var styles = require('./index.module.css');
14
10
 
15
11
  function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
16
12
 
17
13
  var React__default = /*#__PURE__*/_interopDefaultCompat(React);
18
- var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
19
14
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
20
15
  var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
21
16
 
22
- var ADDONS_HEIGHT = 48;
23
- var NavigationBar = React.forwardRef(function (_a, ref) {
17
+ var NavigationBar = function (_a) {
24
18
  var _b, _c, _d;
25
- var addonClassName = _a.addonClassName, className = _a.className, contentClassName = _a.contentClassName, closerClassName = _a.closerClassName, leftAddons = _a.leftAddons, rightAddons = _a.rightAddons, bottomAddons = _a.bottomAddons, bottomAddonsClassName = _a.bottomAddonsClassName, children = _a.children, _e = _a.align, align = _e === void 0 ? 'left' : _e, _f = _a.trim, trim = _f === void 0 ? true : _f, title = _a.title, _g = _a.titleSize, titleSize = _g === void 0 ? 'default' : _g, subtitle = _a.subtitle, hasCloser = _a.hasCloser, hasBackButton = _a.hasBackButton, backButtonClassName = _a.backButtonClassName, backButtonProps = _a.backButtonProps, dataTestId = _a.dataTestId, imageUrl = _a.imageUrl, closerIcon = _a.closerIcon, onClose = _a.onClose, view = _a.view, scrollableParentRef = _a.scrollableParentRef, sticky = _a.sticky, onBack = _a.onBack;
26
- var _h = React.useState(0), scrollTop = _h[0], setScrollTop = _h[1];
27
- var _j = React.useState({ left: 0, right: 0 }), titleMargin = _j[0], setTitleMargin = _j[1];
28
- var bottomContentRef = React.useRef(null);
29
- var headerRef = React.useRef(null);
30
- var mainLinePaddingTopRef = React.useRef('0px');
19
+ var _e = _a.align, align = _e === void 0 ? 'center' : _e, rightAddons = _a.rightAddons, leftAddons = _a.leftAddons, bottomAddons = _a.bottomAddons, sticky = _a.sticky, border = _a.border, subtitle = _a.subtitle, title = _a.title, children = _a.children, _f = _a.backgroundColor, backgroundColor = _f === void 0 ? 'var(--color-light-base-bg-primary)' : _f, className = _a.className, contentClassName = _a.contentClassName, rightAddonsClassName = _a.rightAddonsClassName, leftAddonsClassName = _a.leftAddonsClassName, bottomAddonsClassName = _a.bottomAddonsClassName, dataTestId = _a.dataTestId;
20
+ var _g = React.useState({ left: 0, right: 0 }), titleMargin = _g[0], setTitleMargin = _g[1];
31
21
  var leftAddonsRef = React.useRef(null);
32
22
  var rightAddonsRef = React.useRef(null);
33
- var compactTitle = view === 'mobile' && titleSize === 'compact';
34
- var hasLeftPart = Boolean(leftAddons || hasBackButton);
35
- var hasRightPart = Boolean(rightAddons || hasCloser);
36
- var hasContent = Boolean(title || children);
37
- var withAnimation = Boolean(view === 'mobile' && hasLeftPart && sticky && !compactTitle);
38
- var showContentOnTop = hasContent && (compactTitle || !hasLeftPart);
39
- var showContentOnBot = hasContent && !compactTitle && hasLeftPart;
40
- var showStaticContentOnTop = !withAnimation && showContentOnTop;
41
- var showStaticContentOnBot = !withAnimation && showContentOnBot;
42
- var showAnimatedContentOnTop = withAnimation && showContentOnBot && scrollTop > ADDONS_HEIGHT;
43
- var showAnimatedContentOnBot = withAnimation && showContentOnBot;
44
- var headerPaddingTop = mainLinePaddingTopRef.current;
45
- hooks.useLayoutEffect_SAFE_FOR_SSR(function () {
23
+ var hasLeftAddons = leftAddons && align !== 'left';
24
+ React.useEffect(function () {
46
25
  var _a, _b;
47
- if (align === 'center' && (showStaticContentOnTop || showAnimatedContentOnTop)) {
26
+ if (hasLeftAddons) {
48
27
  var leftAddonsWidth = ((_a = leftAddonsRef.current) === null || _a === void 0 ? void 0 : _a.offsetWidth) || 0;
49
28
  var rightAddonsWidth = ((_b = rightAddonsRef.current) === null || _b === void 0 ? void 0 : _b.offsetWidth) || 0;
50
29
  var marginSize_1 = Math.abs(rightAddonsWidth - leftAddonsWidth);
@@ -57,108 +36,26 @@ var NavigationBar = React.forwardRef(function (_a, ref) {
57
36
  return isStateChanged ? newState : prev;
58
37
  });
59
38
  }
60
- }, [
61
- align,
62
- showStaticContentOnTop,
63
- showAnimatedContentOnTop,
64
- leftAddons,
65
- rightAddons,
66
- hasBackButton,
67
- hasCloser,
68
- ]);
69
- React.useEffect(function () {
70
- var parent = scrollableParentRef === null || scrollableParentRef === void 0 ? void 0 : scrollableParentRef.current;
71
- var handleScroll = function (ev) {
72
- var divElement = ev.target;
73
- setScrollTop(divElement.scrollTop);
74
- };
75
- if (withAnimation && headerRef.current) {
76
- mainLinePaddingTopRef.current = getComputedStyle(headerRef.current).paddingTop;
77
- }
78
- if (withAnimation && parent) {
79
- parent.addEventListener('scroll', handleScroll);
80
- }
81
- return function () { return parent === null || parent === void 0 ? void 0 : parent.removeEventListener('scroll', handleScroll); };
82
- }, [scrollableParentRef, withAnimation]);
83
- var renderBackButton = function () {
84
- var textOpacity = 1;
85
- if (withAnimation) {
86
- var height = hasContent ? ADDONS_HEIGHT : ADDONS_HEIGHT / 2;
87
- textOpacity = Math.max(0, 1 - scrollTop / height);
88
- }
89
- else if (compactTitle) {
90
- textOpacity = 0;
91
- }
92
- return (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.addon, backButtonClassName) },
93
- React__default.default.createElement(components_backArrowAddon_Component.BackArrowAddon, tslib.__assign({ "data-test-id": coreComponentsShared.getDataTestId(dataTestId, 'back-button') }, backButtonProps, { textOpacity: textOpacity, view: view, onClick: onBack }))));
94
- };
95
- var renderContent = function (args) {
96
- var _a;
97
- if (args === void 0) { args = {}; }
98
- var extraClassName = args.extraClassName, wrapperRef = args.wrapperRef, style = args.style, hidden = args.hidden;
99
- return (React__default.default.createElement("div", { style: tslib.__assign(tslib.__assign({}, style), { visibility: hidden ? 'hidden' : 'visible' }), ref: wrapperRef, className: cn__default.default(styles__default.default.content, extraClassName, contentClassName, styles__default.default[align], (_a = {},
100
- _a[styles__default.default.trim] = trim,
101
- _a[styles__default.default.withCompactTitle] = view === 'mobile' && compactTitle && hasContent,
102
- _a)), "aria-hidden": hidden },
39
+ }, [hasLeftAddons, leftAddons, rightAddons]);
40
+ return (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.component, (_b = {},
41
+ _b[styles__default.default.border] = border,
42
+ _b[styles__default.default.sticky] = sticky,
43
+ _b), className), style: tslib.__assign({}, (backgroundColor && { backgroundColor: backgroundColor })), "data-test-id": dataTestId },
44
+ React__default.default.createElement("div", { className: cn__default.default(styles__default.default.mainLine, styles__default.default[align], contentClassName) },
45
+ hasLeftAddons && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.addons, leftAddonsClassName), ref: leftAddonsRef }, leftAddons)),
103
46
  children && React__default.default.createElement("div", { className: styles__default.default.children }, children),
104
- title && (React__default.default.createElement("div", { className: styles__default.default.title, "data-test-id": hidden ? undefined : coreComponentsShared.getDataTestId(dataTestId, 'title') }, title)),
105
- compactTitle && subtitle && React__default.default.createElement("div", { className: styles__default.default.subtitle }, subtitle)));
106
- };
107
- var renderCloser = function () { return (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.addon, styles__default.default.closer, closerClassName) },
108
- React__default.default.createElement(components_closer_Component.Closer, { view: view, icon: closerIcon, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'closer'), onClose: onClose }))); };
109
- return (React__default.default.createElement("div", { ref: mergeRefs__default.default([ref, headerRef]), className: cn__default.default(styles__default.default.header, className, (_b = {}, _b[styles__default.default.backgroundImage] = imageUrl, _b)), "data-test-id": coreComponentsShared.getDataTestId(dataTestId), style: tslib.__assign(tslib.__assign({}, (imageUrl && { backgroundImage: "url(".concat(imageUrl, ")") })), (withAnimation &&
110
- bottomContentRef.current && {
111
- top: -bottomContentRef.current.scrollHeight,
112
- })) },
113
- React__default.default.createElement("div", { className: cn__default.default(styles__default.default.mainLine, (_c = {},
114
- _c[styles__default.default.mainLineSticky] = withAnimation,
115
- _c[styles__default.default.mainLineWithImageBg] = imageUrl,
116
- _c)), style: tslib.__assign({}, (withAnimation
117
- ? {
118
- marginTop: "-".concat(headerPaddingTop),
119
- paddingTop: headerPaddingTop,
120
- }
121
- : null)) },
122
- hasLeftPart && (React__default.default.createElement("div", { className: styles__default.default.addonsWrapper, ref: leftAddonsRef },
123
- hasBackButton && renderBackButton(),
124
- leftAddons && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.addon, addonClassName) }, leftAddons)))),
125
- showStaticContentOnTop &&
126
- renderContent(tslib.__assign({}, (align === 'center'
47
+ title && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.content, (_c = {}, _c[styles__default.default[align]] = !hasLeftAddons, _c)), style: tslib.__assign({}, (align === 'center'
127
48
  ? {
128
- style: {
129
- marginLeft: titleMargin.left,
130
- marginRight: titleMargin.right,
131
- },
49
+ marginLeft: titleMargin.left,
50
+ marginRight: titleMargin.right,
132
51
  }
133
- : null))),
134
- showAnimatedContentOnTop &&
135
- renderContent({
136
- extraClassName: styles__default.default.withBothAddons,
137
- style: tslib.__assign({ opacity: Math.min(1, (scrollTop - ADDONS_HEIGHT) / ADDONS_HEIGHT) }, (align === 'center'
138
- ? {
139
- marginLeft: titleMargin.left,
140
- marginRight: titleMargin.right,
141
- }
142
- : null)),
143
- }),
144
- hasRightPart && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.addonsWrapper, styles__default.default.rightAddons), ref: rightAddonsRef },
145
- rightAddons && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.addon, addonClassName) }, rightAddons)),
146
- hasCloser && renderCloser()))),
147
- showAnimatedContentOnBot &&
148
- renderContent({
149
- wrapperRef: bottomContentRef,
150
- extraClassName: styles__default.default.underAddons,
151
- style: { opacity: Math.max(0, 1 - scrollTop / ADDONS_HEIGHT) },
152
- hidden: scrollTop / ADDONS_HEIGHT > 1,
153
- }),
154
- showStaticContentOnBot &&
155
- renderContent({
156
- extraClassName: cn__default.default((_d = {},
157
- _d[styles__default.default.contentOnBotDesktop] = view === 'desktop',
158
- _d[styles__default.default.contentOnBotMobile] = view === 'mobile',
159
- _d)),
160
- }),
161
- bottomAddons && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.bottomAddons, bottomAddonsClassName) }, bottomAddons))));
162
- });
52
+ : null)) },
53
+ React__default.default.createElement("div", { className: cn__default.default(styles__default.default.title, (_d = {},
54
+ _d[styles__default.default[align]] = !hasLeftAddons && !subtitle,
55
+ _d)), "data-test-id": coreComponentsShared.getDataTestId(dataTestId, 'title') }, title),
56
+ subtitle && (React__default.default.createElement("div", { className: styles__default.default.subtitle, "data-test-id": coreComponentsShared.getDataTestId(dataTestId, 'subtitle') }, subtitle)))),
57
+ rightAddons && (React__default.default.createElement("div", { className: cn__default.default(styles__default.default.rightAddons, styles__default.default.addons, rightAddonsClassName), ref: rightAddonsRef }, rightAddons))),
58
+ bottomAddons && React__default.default.createElement("div", { className: bottomAddonsClassName }, bottomAddons)));
59
+ };
163
60
 
164
61
  exports.NavigationBar = NavigationBar;
@@ -0,0 +1,22 @@
1
+ /// <reference types="react" />
2
+ import React from 'react';
3
+ interface ActionIconAddonProps extends React.HTMLAttributes<HTMLButtonElement> {
4
+ /**
5
+ * Тип действия
6
+ */
7
+ action?: 'back' | 'floatingBack' | 'close';
8
+ /**
9
+ * Дополнительный класс
10
+ */
11
+ className?: string;
12
+ /**
13
+ * Обработчик клика
14
+ */
15
+ onClick?: () => void;
16
+ /**
17
+ * Идентификатор для систем автоматизированного тестирования.
18
+ */
19
+ dataTestId?: string;
20
+ }
21
+ declare const ActionIconAddon: React.FC<ActionIconAddonProps>;
22
+ export { ActionIconAddonProps, ActionIconAddon };
@@ -0,0 +1,31 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var tslib = require('tslib');
6
+ var React = require('react');
7
+ var cn = require('classnames');
8
+ var desktop = require('@alfalab/core-components-button/cssm/desktop');
9
+ var ChevronLeftMIcon = require('@alfalab/icons-glyph/ChevronLeftMIcon');
10
+ var CrossMIcon = require('@alfalab/icons-glyph/CrossMIcon');
11
+ var styles = require('./index.module.css');
12
+
13
+ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
14
+
15
+ var React__default = /*#__PURE__*/_interopDefaultCompat(React);
16
+ var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
17
+ var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
18
+
19
+ var iconComponents = {
20
+ back: React__default.default.createElement(ChevronLeftMIcon.ChevronLeftMIcon, null),
21
+ floatingBack: React__default.default.createElement(ChevronLeftMIcon.ChevronLeftMIcon, { className: styles__default.default.floating }),
22
+ close: React__default.default.createElement(CrossMIcon.CrossMIcon, { className: styles__default.default.floating }),
23
+ };
24
+ var ActionIconAddon = function (_a) {
25
+ var _b;
26
+ var onClick = _a.onClick, className = _a.className, _c = _a.action, action = _c === void 0 ? 'back' : _c, dataTestId = _a.dataTestId, htmlAttributes = tslib.__rest(_a, ["onClick", "className", "action", "dataTestId"]);
27
+ return (React__default.default.createElement(desktop.ButtonDesktop, tslib.__assign({ view: 'text', size: 's', onClick: onClick, "aria-label": action === 'close' ? 'закрыть' : 'назад', className: cn__default.default(styles__default.default.component, className), dataTestId: dataTestId }, htmlAttributes),
28
+ React__default.default.createElement("div", { className: cn__default.default(styles__default.default.iconWrapper, (_b = {}, _b[styles__default.default[action]] = Boolean(styles__default.default[action]), _b)) }, iconComponents[action])));
29
+ };
30
+
31
+ exports.ActionIconAddon = ActionIconAddon;
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var components_actionIconAddon_Component = require('./Component.js');
6
+
7
+
8
+
9
+ exports.ActionIconAddon = components_actionIconAddon_Component.ActionIconAddon;
@@ -1,10 +1,9 @@
1
- /* hash: esnlp */
2
1
  :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
3
2
  } /* deprecated */ :root {
4
- --color-light-neutral-1500: #0e0e0e;
5
3
  --color-light-neutral-translucent-100: rgba(38, 55, 88, 0.06);
6
- --color-light-neutral-translucent-700: rgba(4, 4, 21, 0.47); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
7
- --color-light-bg-primary-alpha-40: rgba(255, 255, 255, 0.4);
4
+ --color-light-neutral-translucent-700: rgba(4, 4, 21, 0.47);
5
+ --color-light-neutral-translucent-700-hover: rgba(4, 4, 19, 0.55);
6
+ --color-light-neutral-translucent-700-press: rgba(1, 1, 12, 0.63); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
8
7
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
9
8
  } :root {
10
9
  } :root {
@@ -16,33 +15,29 @@
16
15
  /* Hard up */
17
16
  } :root {
18
17
  --border-radius-circle: 50%;
18
+ --border-radius-pill: 99px;
19
19
  } :root {
20
20
  } :root {
21
21
  } :root {
22
- } :root {
23
- /* closer-mobile */
24
- --navigation-bar-closer-mobile-color: var(--color-light-neutral-translucent-700);
25
-
26
- /* back-arrow */
27
- } .navigation-bar__closer_1a9q8 {
28
- flex-shrink: 0;
29
- width: 48px;
30
- height: 48px;
31
- margin-left: auto;
32
- display: flex;
22
+ } .component {
23
+ height: 100%;
24
+ border-radius: var(--border-radius-pill);
25
+ min-width: 48px;
26
+ } .iconWrapper {
27
+ display: inline-flex;
33
28
  align-items: center;
34
29
  justify-content: center;
35
- } .navigation-bar__button_1a9q8 {
36
- background: var(--color-light-bg-primary-alpha-40);
37
- -webkit-backdrop-filter: blur(10px);
38
- backdrop-filter: blur(10px);
39
- color: var(--color-light-neutral-1500)
40
- } .navigation-bar__button_1a9q8.navigation-bar__mobile_1a9q8 {
41
- background: var(--color-light-neutral-translucent-100);
42
- color: var(--navigation-bar-closer-mobile-color);
43
- } .navigation-bar__button_1a9q8.navigation-bar__button_1a9q8 {
30
+ height: 30px;
31
+ width: 30px;
44
32
  border-radius: var(--border-radius-circle);
45
- } .navigation-bar__sticky_1a9q8 {
46
- position: sticky;
47
- top: 0;
48
- }
33
+ background: var(--color-light-neutral-translucent-100);
34
+ vertical-align: middle
35
+ } .iconWrapper.back {
36
+ background: transparent;
37
+ } .floating path {
38
+ fill: var(--color-light-neutral-translucent-700);
39
+ } .floating:hover path {
40
+ fill: var(--color-light-neutral-translucent-700-hover);
41
+ } .floating:active path {
42
+ fill: var(--color-light-neutral-translucent-700-press);
43
+ }
@@ -0,0 +1,26 @@
1
+ /// <reference types="react" />
2
+ import React from 'react';
3
+ interface ActionTextAddonProps extends React.HTMLAttributes<HTMLButtonElement> {
4
+ /**
5
+ * Текст после иконки
6
+ */
7
+ text: string;
8
+ /**
9
+ * Тип действия
10
+ */
11
+ action?: 'primary' | 'secondary';
12
+ /**
13
+ * Дополнительный класс
14
+ */
15
+ className?: string;
16
+ /**
17
+ * Обработчик клика
18
+ */
19
+ onClick?: () => void;
20
+ /**
21
+ * Идентификатор для систем автоматизированного тестирования.
22
+ */
23
+ dataTestId?: string;
24
+ }
25
+ declare const ActionTextAddon: React.FC<ActionTextAddonProps>;
26
+ export { ActionTextAddonProps, ActionTextAddon };
@@ -0,0 +1,24 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var tslib = require('tslib');
6
+ var React = require('react');
7
+ var cn = require('classnames');
8
+ var desktop = require('@alfalab/core-components-button/cssm/desktop');
9
+ var coreComponentsTypography = require('@alfalab/core-components-typography/cssm');
10
+ var styles = require('./index.module.css');
11
+
12
+ function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
13
+
14
+ var React__default = /*#__PURE__*/_interopDefaultCompat(React);
15
+ var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
16
+ var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
17
+
18
+ var ActionTextAddon = function (_a) {
19
+ var _b = _a.text, text = _b === void 0 ? 'Назад' : _b, onClick = _a.onClick, className = _a.className, action = _a.action, dataTestId = _a.dataTestId, htmlAttributes = tslib.__rest(_a, ["text", "onClick", "className", "action", "dataTestId"]);
20
+ return (React__default.default.createElement(desktop.ButtonDesktop, tslib.__assign({ view: 'text', size: 's', onClick: onClick, "aria-label": text, className: cn__default.default(styles__default.default.component, className), dataTestId: dataTestId }, htmlAttributes),
21
+ React__default.default.createElement(coreComponentsTypography.Typography.Text, { className: styles__default.default.text, view: 'component', weight: action === 'primary' ? 'medium' : 'regular' }, text)));
22
+ };
23
+
24
+ exports.ActionTextAddon = ActionTextAddon;
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var components_actionTextAddon_Component = require('./Component.js');
6
+
7
+
8
+
9
+ exports.ActionTextAddon = components_actionTextAddon_Component.ActionTextAddon;
@@ -11,10 +11,12 @@
11
11
  /* Hard up */
12
12
  } :root {
13
13
  } :root {
14
+ --gap-xs: 8px;
15
+ --gap-m: 16px;
14
16
  } :root {
15
17
  } :root {
16
- } :root {
17
- /* closer-mobile */
18
-
19
- /* back-arrow */
18
+ } .component {
19
+ height: 100%;
20
+ } .text {
21
+ padding: var(--gap-xs) var(--gap-m);
20
22
  }
package/cssm/index.d.ts CHANGED
@@ -1,2 +1 @@
1
1
  export * from "./Component";
2
- export type { NavigationBarProps } from "./types";
@@ -1,6 +1,7 @@
1
1
  :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
2
2
  } /* deprecated */ :root {
3
- --color-light-text-primary: #0e0e0e;
3
+ --color-light-neutral-300: #e7e8eb;
4
+ --color-light-text-primary: rgba(3, 3, 6, 0.88);
4
5
  --color-light-text-secondary: rgba(4, 4, 19, 0.55); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
5
6
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
6
7
  } :root {
@@ -14,95 +15,64 @@
14
15
  } :root {
15
16
  } :root {
16
17
  --gap-2xs: 4px;
17
- --gap-s: 12px;
18
+ --gap-xs: 8px;
19
+ --gap-m: 16px;
18
20
  } :root {
19
21
  } :root {
20
- } .header {
21
- width: 100%;
22
+ } .component {
23
+ padding: var(--gap-xs) var(--gap-2xs);
22
24
  box-sizing: border-box;
23
- transition: box-shadow 0.2s ease, background 0.2s ease
24
- } .header.header.backgroundImage {
25
- background-repeat: no-repeat;
26
- background-position: center;
27
- background-size: cover;
28
- } .mainLine {
29
- display: flex;
30
- align-items: stretch;
31
- justify-content: space-between;
32
- z-index: 1;
33
- background-color: inherit;
34
- } .mainLineSticky {
25
+ width: 100%;
26
+ } .sticky {
35
27
  position: sticky;
36
28
  top: 0;
37
- } .mainLineWithImageBg {
38
- background-color: transparent;
39
- background-color: initial;
29
+ z-index: 1;
30
+ } .border {
31
+ box-shadow: 0 1px 0 0 var(--color-light-neutral-300);
32
+ } .mainLine {
33
+ display: flex;
34
+ background-color: inherit;
35
+ justify-content: space-between;
36
+ min-height: 40px;
37
+ align-items: stretch;
38
+ } .left {
39
+ text-align: left;
40
+ } .center {
41
+ text-align: center;
42
+ } .children {
43
+ width: 100%;
40
44
  } .content {
41
- color: var(--color-light-text-primary);
42
45
  display: flex;
43
- flex-flow: column nowrap;
44
- justify-content: center;
45
46
  flex-grow: 1;
46
- align-self: baseline;
47
- box-sizing: border-box;
48
- min-height: 48px
49
- } .content.withBothAddons,
50
- .content.withCompactTitle {
51
- font-size: 16px;
52
- line-height: 20px;
53
- font-weight: 500;
54
- align-self: center;
55
- padding-top: var(--gap-2xs);
56
- padding-bottom: var(--gap-2xs)
57
- } .content.withBothAddons > .children,
58
- .content.withBothAddons > .title,
59
- .content.withCompactTitle > .children,
60
- .content.withCompactTitle > .title {
61
- -webkit-line-clamp: 1;
62
- word-break: break-all;
63
- } .content.contentOnBotDesktop.contentOnBotDesktop {
64
- padding-top: var(--gap-s);
65
- } .content.contentOnBotMobile.contentOnBotMobile {
66
- padding-top: var(--gap-s);
47
+ justify-content: center;
48
+ flex-flow: column nowrap;
49
+ color: var(--color-light-text-primary)
50
+ } .content.left {
51
+ padding: 0 var(--gap-m);
52
+ } .content > .title,
53
+ .content > .subtitle {
54
+ -webkit-line-clamp: 1;
55
+ display: -webkit-box;
56
+ -webkit-box-orient: vertical;
57
+ overflow: hidden;
58
+ word-break: break-all;
67
59
  } .title {
68
- word-break: break-word;
69
- } .subtitle {
60
+ font-size: 16px;
61
+ line-height: 20px;
62
+ font-weight: 500
63
+ } .title.left {
64
+ font-size: 20px;
65
+ line-height: 28px;
66
+ font-weight: 600;
67
+ } .subtitle {
70
68
  font-size: 14px;
71
69
  line-height: 20px;
72
70
  font-weight: 400;
73
- -webkit-line-clamp: 1;
74
- display: -webkit-box;
75
- -webkit-box-orient: vertical;
76
- overflow: hidden;
77
-
78
71
  color: var(--color-light-text-secondary);
79
- word-break: break-all;
80
- } .addonsWrapper {
81
- display: flex;
82
- } .rightAddons {
83
- margin-left: auto;
84
- } .addon {
72
+ } .addons {
85
73
  min-width: 48px;
86
- height: 48px;
87
74
  display: flex;
88
75
  justify-content: center;
89
- align-items: center;
90
- flex-shrink: 0;
91
- pointer-events: all;
92
- } .bottomAddons {
93
- pointer-events: all;
94
- } .closer {
76
+ } .rightAddons {
95
77
  margin-left: auto;
96
- } .left {
97
- text-align: left;
98
- } .center {
99
- text-align: center;
100
- } .trim {
101
- overflow: hidden
102
- } .trim .title,
103
- .trim .children {
104
- -webkit-line-clamp: 2;
105
- display: -webkit-box;
106
- -webkit-box-orient: vertical;
107
- overflow: hidden;
108
- }
78
+ }
@@ -1,2 +1,3 @@
1
- export * from "../components/closer/index";
2
- export * from "../components/back-arrow-addon/index";
1
+ export * from "../components/action-icon-addon/index";
2
+ export * from "../components/action-text-addon/index";
3
+ export { getNavigationBarTestIds } from "../utils";
@@ -2,10 +2,12 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var components_closer_Component = require('../components/closer/Component.js');
6
- var components_backArrowAddon_Component = require('../components/back-arrow-addon/Component.js');
5
+ var components_actionIconAddon_Component = require('../components/action-icon-addon/Component.js');
6
+ var components_actionTextAddon_Component = require('../components/action-text-addon/Component.js');
7
+ var utils = require('../utils.js');
7
8
 
8
9
 
9
10
 
10
- exports.Closer = components_closer_Component.Closer;
11
- exports.BackArrowAddon = components_backArrowAddon_Component.BackArrowAddon;
11
+ exports.ActionIconAddon = components_actionIconAddon_Component.ActionIconAddon;
12
+ exports.ActionTextAddon = components_actionTextAddon_Component.ActionTextAddon;
13
+ exports.getNavigationBarTestIds = utils.getNavigationBarTestIds;
@@ -0,0 +1,6 @@
1
+ declare function getNavigationBarTestIds(dataTestId: string): {
2
+ navigationBar: string;
3
+ title: string;
4
+ subtitle: string;
5
+ };
6
+ export { getNavigationBarTestIds };
package/cssm/utils.js ADDED
@@ -0,0 +1,15 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var coreComponentsShared = require('@alfalab/core-components-shared/cssm');
6
+
7
+ function getNavigationBarTestIds(dataTestId) {
8
+ return {
9
+ navigationBar: dataTestId,
10
+ title: coreComponentsShared.getDataTestId(dataTestId, 'title'),
11
+ subtitle: coreComponentsShared.getDataTestId(dataTestId, 'subtitle'),
12
+ };
13
+ }
14
+
15
+ exports.getNavigationBarTestIds = getNavigationBarTestIds;