@redneckz/wildless-cms-uni-blocks 0.14.874 → 0.14.876

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 (141) hide show
  1. package/bundle/bundle.umd.js +127 -93
  2. package/bundle/bundle.umd.min.js +1 -1
  3. package/bundle/components/Header/DropdownButton.d.ts +2 -0
  4. package/bundle/components/Header/DropdownMenu.d.ts +5 -2
  5. package/bundle/components/Header/HeaderMoreMenuItem.d.ts +9 -0
  6. package/bundle/components/Header/HeaderSubMenuItem.d.ts +3 -0
  7. package/bundle/components/Header/useDropdownSubMenu.d.ts +11 -0
  8. package/bundle/data/NavigationData.d.ts +1 -0
  9. package/bundle/ui-kit/FormField/Fields/ApplicationDateField.d.ts +2 -0
  10. package/dist/components/Header/DropdownButton.d.ts +2 -0
  11. package/dist/components/Header/DropdownButton.js +11 -0
  12. package/dist/components/Header/DropdownButton.js.map +1 -0
  13. package/dist/components/Header/DropdownMenu.d.ts +5 -2
  14. package/dist/components/Header/DropdownMenu.js +2 -36
  15. package/dist/components/Header/DropdownMenu.js.map +1 -1
  16. package/dist/components/Header/HeaderMoreMenuItem.d.ts +9 -0
  17. package/dist/components/Header/HeaderMoreMenuItem.js +27 -0
  18. package/dist/components/Header/HeaderMoreMenuItem.js.map +1 -0
  19. package/dist/components/Header/HeaderSubMenu.js +2 -2
  20. package/dist/components/Header/HeaderSubMenu.js.map +1 -1
  21. package/dist/components/Header/HeaderSubMenuItem.d.ts +3 -0
  22. package/dist/components/Header/HeaderSubMenuItem.js +19 -2
  23. package/dist/components/Header/HeaderSubMenuItem.js.map +1 -1
  24. package/dist/components/Header/HeaderTopMenu.js +2 -2
  25. package/dist/components/Header/HeaderTopMenu.js.map +1 -1
  26. package/dist/components/Header/useDropdownSubMenu.d.ts +11 -0
  27. package/dist/components/Header/useDropdownSubMenu.js +37 -0
  28. package/dist/components/Header/useDropdownSubMenu.js.map +1 -0
  29. package/dist/data/NavigationData.d.ts +1 -0
  30. package/dist/ui-kit/FormField/Fields/ApplicationDateField.d.ts +2 -0
  31. package/dist/ui-kit/FormField/Fields/ApplicationDateField.js +7 -0
  32. package/dist/ui-kit/FormField/Fields/ApplicationDateField.js.map +1 -0
  33. package/dist/ui-kit/FormField/getField.js +2 -2
  34. package/dist/ui-kit/FormField/getField.js.map +1 -1
  35. package/lib/components/Header/DropdownButton.d.ts +2 -0
  36. package/lib/components/Header/DropdownButton.js +9 -0
  37. package/lib/components/Header/DropdownButton.js.map +1 -0
  38. package/lib/components/Header/DropdownMenu.d.ts +5 -2
  39. package/lib/components/Header/DropdownMenu.js +2 -37
  40. package/lib/components/Header/DropdownMenu.js.map +1 -1
  41. package/lib/components/Header/HeaderMoreMenuItem.d.ts +9 -0
  42. package/lib/components/Header/HeaderMoreMenuItem.js +25 -0
  43. package/lib/components/Header/HeaderMoreMenuItem.js.map +1 -0
  44. package/lib/components/Header/HeaderSubMenu.js +2 -2
  45. package/lib/components/Header/HeaderSubMenu.js.map +1 -1
  46. package/lib/components/Header/HeaderSubMenuItem.d.ts +3 -0
  47. package/lib/components/Header/HeaderSubMenuItem.js +20 -3
  48. package/lib/components/Header/HeaderSubMenuItem.js.map +1 -1
  49. package/lib/components/Header/HeaderTopMenu.js +2 -2
  50. package/lib/components/Header/HeaderTopMenu.js.map +1 -1
  51. package/lib/components/Header/useDropdownSubMenu.d.ts +11 -0
  52. package/lib/components/Header/useDropdownSubMenu.js +34 -0
  53. package/lib/components/Header/useDropdownSubMenu.js.map +1 -0
  54. package/lib/data/NavigationData.d.ts +1 -0
  55. package/lib/ui-kit/FormField/Fields/ApplicationDateField.d.ts +2 -0
  56. package/lib/ui-kit/FormField/Fields/ApplicationDateField.js +5 -0
  57. package/lib/ui-kit/FormField/Fields/ApplicationDateField.js.map +1 -0
  58. package/lib/ui-kit/FormField/getField.js +2 -2
  59. package/lib/ui-kit/FormField/getField.js.map +1 -1
  60. package/mobile/bundle/bundle.umd.js +50 -48
  61. package/mobile/bundle/bundle.umd.min.js +1 -1
  62. package/mobile/bundle/components/Header/DropdownButton.d.ts +2 -0
  63. package/mobile/bundle/components/Header/DropdownMenu.d.ts +5 -2
  64. package/mobile/bundle/components/Header/HeaderMoreMenuItem.d.ts +9 -0
  65. package/mobile/bundle/components/Header/HeaderSubMenuItem.d.ts +3 -0
  66. package/mobile/bundle/components/Header/useDropdownSubMenu.d.ts +11 -0
  67. package/mobile/bundle/data/NavigationData.d.ts +1 -0
  68. package/mobile/bundle/ui-kit/FormField/Fields/ApplicationDateField.d.ts +2 -0
  69. package/mobile/dist/components/Header/DropdownButton.d.ts +2 -0
  70. package/mobile/dist/components/Header/DropdownButton.js +11 -0
  71. package/mobile/dist/components/Header/DropdownButton.js.map +1 -0
  72. package/mobile/dist/components/Header/DropdownMenu.d.ts +5 -2
  73. package/mobile/dist/components/Header/DropdownMenu.js +2 -36
  74. package/mobile/dist/components/Header/DropdownMenu.js.map +1 -1
  75. package/mobile/dist/components/Header/HeaderMoreMenuItem.d.ts +9 -0
  76. package/mobile/dist/components/Header/HeaderMoreMenuItem.js +27 -0
  77. package/mobile/dist/components/Header/HeaderMoreMenuItem.js.map +1 -0
  78. package/mobile/dist/components/Header/HeaderSubMenu.js +2 -2
  79. package/mobile/dist/components/Header/HeaderSubMenu.js.map +1 -1
  80. package/mobile/dist/components/Header/HeaderSubMenuItem.d.ts +3 -0
  81. package/mobile/dist/components/Header/HeaderSubMenuItem.js +19 -2
  82. package/mobile/dist/components/Header/HeaderSubMenuItem.js.map +1 -1
  83. package/mobile/dist/components/Header/HeaderTopMenu.js +2 -2
  84. package/mobile/dist/components/Header/HeaderTopMenu.js.map +1 -1
  85. package/mobile/dist/components/Header/useDropdownSubMenu.d.ts +11 -0
  86. package/mobile/dist/components/Header/useDropdownSubMenu.js +37 -0
  87. package/mobile/dist/components/Header/useDropdownSubMenu.js.map +1 -0
  88. package/mobile/dist/data/NavigationData.d.ts +1 -0
  89. package/mobile/dist/ui-kit/FormField/Fields/ApplicationDateField.d.ts +2 -0
  90. package/mobile/dist/ui-kit/FormField/Fields/ApplicationDateField.js +7 -0
  91. package/mobile/dist/ui-kit/FormField/Fields/ApplicationDateField.js.map +1 -0
  92. package/mobile/dist/ui-kit/FormField/getField.js +2 -2
  93. package/mobile/dist/ui-kit/FormField/getField.js.map +1 -1
  94. package/mobile/lib/components/Header/DropdownButton.d.ts +2 -0
  95. package/mobile/lib/components/Header/DropdownButton.js +9 -0
  96. package/mobile/lib/components/Header/DropdownButton.js.map +1 -0
  97. package/mobile/lib/components/Header/DropdownMenu.d.ts +5 -2
  98. package/mobile/lib/components/Header/DropdownMenu.js +2 -37
  99. package/mobile/lib/components/Header/DropdownMenu.js.map +1 -1
  100. package/mobile/lib/components/Header/HeaderMoreMenuItem.d.ts +9 -0
  101. package/mobile/lib/components/Header/HeaderMoreMenuItem.js +25 -0
  102. package/mobile/lib/components/Header/HeaderMoreMenuItem.js.map +1 -0
  103. package/mobile/lib/components/Header/HeaderSubMenu.js +2 -2
  104. package/mobile/lib/components/Header/HeaderSubMenu.js.map +1 -1
  105. package/mobile/lib/components/Header/HeaderSubMenuItem.d.ts +3 -0
  106. package/mobile/lib/components/Header/HeaderSubMenuItem.js +20 -3
  107. package/mobile/lib/components/Header/HeaderSubMenuItem.js.map +1 -1
  108. package/mobile/lib/components/Header/HeaderTopMenu.js +2 -2
  109. package/mobile/lib/components/Header/HeaderTopMenu.js.map +1 -1
  110. package/mobile/lib/components/Header/useDropdownSubMenu.d.ts +11 -0
  111. package/mobile/lib/components/Header/useDropdownSubMenu.js +34 -0
  112. package/mobile/lib/components/Header/useDropdownSubMenu.js.map +1 -0
  113. package/mobile/lib/data/NavigationData.d.ts +1 -0
  114. package/mobile/lib/ui-kit/FormField/Fields/ApplicationDateField.d.ts +2 -0
  115. package/mobile/lib/ui-kit/FormField/Fields/ApplicationDateField.js +5 -0
  116. package/mobile/lib/ui-kit/FormField/Fields/ApplicationDateField.js.map +1 -0
  117. package/mobile/lib/ui-kit/FormField/getField.js +2 -2
  118. package/mobile/lib/ui-kit/FormField/getField.js.map +1 -1
  119. package/mobile/src/components/Header/DropdownButton.tsx +26 -0
  120. package/mobile/src/components/Header/DropdownMenu.tsx +15 -85
  121. package/mobile/src/components/Header/HeaderMoreMenuItem.tsx +60 -0
  122. package/mobile/src/components/Header/HeaderSubMenu.tsx +3 -2
  123. package/mobile/src/components/Header/HeaderSubMenuItem.tsx +31 -5
  124. package/mobile/src/components/Header/HeaderTopMenu.tsx +3 -3
  125. package/mobile/src/components/Header/useDropdownSubMenu.tsx +48 -0
  126. package/mobile/src/data/NavigationData.ts +1 -0
  127. package/mobile/src/ui-kit/FormField/Fields/ApplicationDateField.tsx +7 -0
  128. package/mobile/src/ui-kit/FormField/getField.tsx +2 -4
  129. package/package.json +1 -1
  130. package/src/components/Header/DropdownButton.tsx +26 -0
  131. package/src/components/Header/DropdownMenu.tsx +15 -85
  132. package/src/components/Header/Header.fixture.tsx +4 -0
  133. package/src/components/Header/HeaderMoreMenuItem.tsx +60 -0
  134. package/src/components/Header/HeaderSubMenu.tsx +3 -2
  135. package/src/components/Header/HeaderSubMenuItem.tsx +31 -5
  136. package/src/components/Header/HeaderTopMenu.tsx +3 -3
  137. package/src/components/Header/useDropdownSubMenu.tsx +48 -0
  138. package/src/data/NavigationData.ts +1 -0
  139. package/src/icons/IconName.ts +4 -4
  140. package/src/ui-kit/FormField/Fields/ApplicationDateField.tsx +7 -0
  141. package/src/ui-kit/FormField/getField.tsx +2 -4
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx } from "@redneckz/uni-jsx/jsx-runtime";
2
+ import { JSX } from '@redneckz/uni-jsx';
3
+ import { useEffect } from '@redneckz/uni-jsx/lib/hooks';
4
+ import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
5
+ import { style } from '../../utils/style.js';
6
+ import { useDropdownSubMenu } from './useDropdownSubMenu.js';
7
+ export const HeaderMoreMenuItem = JSX(({ className = '', items, activeItem, ariaLabel = 'Меню' }) => {
8
+ const [isOpenDropdown, { setFalse, toggle }] = useBool(false);
9
+ const dropdownMenu = useDropdownSubMenu({
10
+ items,
11
+ onClose: setFalse,
12
+ isOpen: isOpenDropdown,
13
+ activeItem,
14
+ });
15
+ useEffect(() => {
16
+ dropdownMenu.current?.addEventListener('mouseleave', setFalse);
17
+ return () => {
18
+ dropdownMenu.current?.removeEventListener('mouseleave', setFalse);
19
+ };
20
+ }, []);
21
+ return (_jsx("div", { className: style(isOpenDropdown ? 'rounded-md shadow-blue-gray' : '', className), ref: dropdownMenu, role: "navigation", children: _jsx("button", { type: "button", className: "group/btn flex justify-between items-center h-6", "aria-label": ariaLabel, onClick: toggle, role: "button", "aria-labelledby": "labeldiv", children: Array(3)
22
+ .fill(null)
23
+ .map((_, i) => (_jsx("div", { className: "w-[3px] h-[3px] rounded mr-2xs bg-primary-text group-hover/btn:bg-primary-hover group-data-transparent:bg-white" }, String(i)))) }) }));
24
+ });
25
+ //# sourceMappingURL=HeaderMoreMenuItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeaderMoreMenuItem.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderMoreMenuItem.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAG9D,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAQ1D,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAG,CACnC,CAAC,EAAE,SAAS,GAAG,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,SAAS,GAAG,MAAM,EAAE,EAAE,EAAE;IAC5D,MAAM,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IAE9D,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK;QACL,OAAO,EAAE,QAAQ;QACjB,MAAM,EAAE,cAAc;QACtB,UAAU;KACX,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,YAAY,CAAC,OAAO,EAAE,gBAAgB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAE/D,OAAO,GAAG,EAAE;YACV,YAAY,CAAC,OAAO,EAAE,mBAAmB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACpE,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,cACE,SAAS,EAAE,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC,EAAE,EAAE,SAAS,CAAC,EAChF,GAAG,EAAE,YAAY,EACjB,IAAI,EAAC,YAAY,YAEjB,iBACE,IAAI,EAAC,QAAQ,EACb,SAAS,EAAC,iDAAiD,gBAC/C,SAAS,EACrB,OAAO,EAAE,MAAM,EACf,IAAI,EAAC,QAAQ,qBACG,UAAU,YAEzB,KAAK,CAAC,CAAC,CAAC;iBACN,IAAI,CAAC,IAAI,CAAC;iBACV,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CACb,cAEE,SAAS,EAAC,iHAAiH,IADtH,MAAM,CAAC,CAAC,CAAC,CAEd,CACH,CAAC,GACG,GACL,CACP,CAAC;AACJ,CAAC,CACF,CAAC"}
@@ -3,8 +3,8 @@ import { JSX } from '@redneckz/uni-jsx';
3
3
  import { useMemo, useRef, useState } from '@redneckz/uni-jsx/lib/hooks';
4
4
  import { useActiveRoute } from '../../hooks/useActiveRoute.js';
5
5
  import { projectSettings } from '../../ProjectSettings.js';
6
- import { DropdownMenu } from './DropdownMenu.js';
7
6
  import { HeaderChatBotButton } from './HeaderChatBotButton.js';
7
+ import { HeaderMoreMenuItem } from './HeaderMoreMenuItem.js';
8
8
  import { HeaderSubMenuItem } from './HeaderSubMenuItem.js';
9
9
  import { InternetBankButton } from './InternetBankButton.js';
10
10
  export const HeaderSubMenu = JSX(({ subItems = [], version, internetBankButton, dropdownMenuAriaLabel, chatBotAriaLabel }) => {
@@ -19,7 +19,7 @@ export const HeaderSubMenu = JSX(({ subItems = [], version, internetBankButton,
19
19
  ? handleIntersectionActivation(index)
20
20
  : handleIntersectionDeactivation(index));
21
21
  }), [subItems]);
22
- return (_jsxs("nav", { className: "mt-s flex gap-s items-center justify-between", children: [_jsx("div", { ref: subItemsListRef, className: "overflow-hidden whitespace-nowrap pb-s mt-xs space-x-lg", role: "menu", children: subItems.map((_, i) => (_jsx(HeaderSubMenuItem, { className: visibleItemsCount - 1 < i ? 'invisible' : '', active: _ === activeSubItem, observerOptions: observerOptions, onVisibilityChange: subItemsVisibilityHandlers[i], data: _.dataHeader, ..._ }, String(i)))) }), dropDownMenuItems.length ? (_jsx(DropdownMenu, { items: dropDownMenuItems, activeItem: activeSubItem, ariaLabel: dropdownMenuAriaLabel })) : null, projectSettings.CHAT_BOT ? (_jsx(HeaderChatBotButton, { version: version, iconVersion: iconVersion, ariaLabel: chatBotAriaLabel })) : null, _jsx(InternetBankButton, { version: version, ...internetBankButton })] }));
22
+ return (_jsxs("nav", { className: "mt-s flex gap-s items-center justify-between", children: [_jsx("div", { ref: subItemsListRef, className: "overflow-hidden whitespace-nowrap pb-s mt-xs space-x-lg", role: "menu", children: subItems.map((_, i) => (_jsx(HeaderSubMenuItem, { className: visibleItemsCount - 1 < i ? 'invisible' : '', active: _ === activeSubItem, activeItem: activeSubItem, observerOptions: observerOptions, onVisibilityChange: subItemsVisibilityHandlers[i], data: _.dataHeader, ..._ }, String(i)))) }), dropDownMenuItems.length ? (_jsx(HeaderMoreMenuItem, { items: dropDownMenuItems, activeItem: activeSubItem, ariaLabel: dropdownMenuAriaLabel })) : null, projectSettings.CHAT_BOT ? (_jsx(HeaderChatBotButton, { version: version, iconVersion: iconVersion, ariaLabel: chatBotAriaLabel })) : null, _jsx(InternetBankButton, { version: version, ...internetBankButton })] }));
23
23
  });
24
24
  const handleIntersectionActivation = (index) => (prev) => Math.max(prev, index + 1);
25
25
  const handleIntersectionDeactivation = (index) => (prev) => Math.min(prev, index);
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderSubMenu.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderSubMenu.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"HeaderSubMenu.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderSubMenu.tsx"],"names":[],"mappings":"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"}
@@ -1,9 +1,12 @@
1
+ import { type NavigationLinkProps } from '../../data/NavigationData';
1
2
  import { type IntersectionObserverOptions } from '../../hooks/useIntersectionObserver';
2
3
  import { type ComponentType } from '../../model/ComponentType';
3
4
  import { type LinkProps } from '../../model/LinkProps';
4
5
  export interface HeaderSubMenuItemProps extends LinkProps, ComponentType {
5
6
  active?: boolean;
7
+ activeItem?: LinkProps;
6
8
  observerOptions?: IntersectionObserverOptions;
7
9
  onVisibilityChange?: (isIntersecting: boolean) => void;
10
+ items?: NavigationLinkProps[];
8
11
  }
9
12
  export declare const HeaderSubMenuItem: import("@redneckz/uni-jsx").UNIComponent<HeaderSubMenuItemProps, any, any>;
@@ -1,9 +1,12 @@
1
1
  import { jsx as _jsx } from "@redneckz/uni-jsx/jsx-runtime";
2
2
  import { JSX } from '@redneckz/uni-jsx';
3
- import { useCallback } from '@redneckz/uni-jsx/lib/hooks';
3
+ import { useCallback, useEffect } from '@redneckz/uni-jsx/lib/hooks';
4
+ import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
4
5
  import { useIntersectionObserver, } from '../../hooks/useIntersectionObserver.js';
5
6
  import { HeaderItem } from '../../ui-kit/HeaderItem/HeaderItem.js';
6
- export const HeaderSubMenuItem = JSX(({ observerOptions, onVisibilityChange, children, className, ...rest }) => {
7
+ import { useDropdownSubMenu } from './useDropdownSubMenu.js';
8
+ export const HeaderSubMenuItem = JSX(({ observerOptions, onVisibilityChange, children, className, items, activeItem, ...rest }) => {
9
+ const [isOpenDropdown, { setFalse, setTrue }] = useBool(false);
7
10
  const observerCallback = useCallback((entries) => {
8
11
  if (!entries.length || !onVisibilityChange) {
9
12
  return;
@@ -13,6 +16,20 @@ export const HeaderSubMenuItem = JSX(({ observerOptions, onVisibilityChange, chi
13
16
  onVisibilityChange(entry.isIntersecting);
14
17
  }, [onVisibilityChange]);
15
18
  const ref = useIntersectionObserver(observerCallback, observerOptions);
16
- return (_jsx("span", { ref: ref, className: className, role: "menuitem", children: _jsx(HeaderItem, { ...rest, children: children }) }));
19
+ const dropdownMenu = useDropdownSubMenu({
20
+ items,
21
+ onClose: setFalse,
22
+ isOpen: isOpenDropdown,
23
+ activeItem,
24
+ });
25
+ useEffect(() => {
26
+ dropdownMenu.current?.addEventListener('mouseenter', setTrue);
27
+ dropdownMenu.current?.addEventListener('mouseleave', setFalse);
28
+ return () => {
29
+ dropdownMenu.current?.addEventListener('mouseenter', setTrue);
30
+ dropdownMenu.current?.removeEventListener('mouseleave', setFalse);
31
+ };
32
+ }, []);
33
+ return (_jsx("div", { className: "inline-block", ref: dropdownMenu, children: _jsx("span", { ref: ref, className: className, role: "menuitem", children: _jsx(HeaderItem, { ...rest, children: children }) }) }));
17
34
  });
18
35
  //# sourceMappingURL=HeaderSubMenuItem.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderSubMenuItem.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderSubMenuItem.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EACL,uBAAuB,GAExB,MAAM,qCAAqC,CAAC;AAG7C,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAQhE,MAAM,CAAC,MAAM,iBAAiB,GAAG,GAAG,CAClC,CAAC,EAAE,eAAe,EAAE,kBAAkB,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACxE,MAAM,gBAAgB,GAAG,WAAW,CAClC,CAAC,OAAoC,EAAE,EAAE;QACvC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,kBAAkB,EAAE;YAC1C,OAAO;SACR;QAED,2CAA2C;QAC3C,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAE1C,kBAAkB,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IAC3C,CAAC,EACD,CAAC,kBAAkB,CAAC,CACrB,CAAC;IACF,MAAM,GAAG,GAAG,uBAAuB,CAAkB,gBAAgB,EAAE,eAAe,CAAC,CAAC;IAExF,OAAO,CACL,eAAM,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAC,UAAU,YACnD,KAAC,UAAU,OAAK,IAAI,YAAG,QAAQ,GAAc,GACxC,CACR,CAAC;AACJ,CAAC,CACF,CAAC"}
1
+ {"version":3,"file":"HeaderSubMenuItem.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderSubMenuItem.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAE9D,OAAO,EACL,uBAAuB,GAExB,MAAM,qCAAqC,CAAC;AAG7C,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAU1D,MAAM,CAAC,MAAM,iBAAiB,GAAG,GAAG,CAClC,CAAC,EAAE,eAAe,EAAE,kBAAkB,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IAC3F,MAAM,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IAE/D,MAAM,gBAAgB,GAAG,WAAW,CAClC,CAAC,OAAoC,EAAE,EAAE;QACvC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,kBAAkB,EAAE;YAC1C,OAAO;SACR;QAED,2CAA2C;QAC3C,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAE1C,kBAAkB,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IAC3C,CAAC,EACD,CAAC,kBAAkB,CAAC,CACrB,CAAC;IACF,MAAM,GAAG,GAAG,uBAAuB,CAAkB,gBAAgB,EAAE,eAAe,CAAC,CAAC;IAExF,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK;QACL,OAAO,EAAE,QAAQ;QACjB,MAAM,EAAE,cAAc;QACtB,UAAU;KACX,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,YAAY,CAAC,OAAO,EAAE,gBAAgB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QAC9D,YAAY,CAAC,OAAO,EAAE,gBAAgB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAE/D,OAAO,GAAG,EAAE;YACV,YAAY,CAAC,OAAO,EAAE,gBAAgB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAC9D,YAAY,CAAC,OAAO,EAAE,mBAAmB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACpE,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,cAAK,SAAS,EAAC,cAAc,EAAC,GAAG,EAAE,YAAY,YAC7C,eAAM,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAC,UAAU,YACnD,KAAC,UAAU,OAAK,IAAI,YAAG,QAAQ,GAAc,GACxC,GACH,CACP,CAAC;AACJ,CAAC,CACF,CAAC"}
@@ -2,7 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "@redneckz/uni-jsx/jsx-runtime";
2
2
  import { JSX } from '@redneckz/uni-jsx';
3
3
  import { useMemo, useRef, useState } from '@redneckz/uni-jsx/lib/hooks';
4
4
  import { Logo } from '../../ui-kit/Logo/Logo.js';
5
- import { DropdownMenu } from './DropdownMenu.js';
5
+ import { HeaderMoreMenuItem } from './HeaderMoreMenuItem.js';
6
6
  import { HeaderSecondaryMenu } from './HeaderSecondaryMenu.js';
7
7
  import { HeaderTopMenuItem } from './HeaderTopMenuItem.js';
8
8
  export const HeaderTopMenu = JSX(({ navigationItems = [], activeTopItem, dropdownMenuAriaLabel, version, headerData, search, bgColor, logo, }) => {
@@ -17,7 +17,7 @@ export const HeaderTopMenu = JSX(({ navigationItems = [], activeTopItem, dropdow
17
17
  }), [navigationItems]);
18
18
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
19
19
  const { dataFooter, dataHeader, ...logoProps } = logo ?? {};
20
- return (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx(Logo, { className: "mr-3xl", bgColor: bgColor, logo: logoProps, data: dataHeader, showTitle: false }), _jsx("div", { ref: topItemsListRef, className: "overflow-hidden min-w-40 pb-xs mt-xs", role: "menu", children: navigationItems.map((_, i) => (_jsx(HeaderTopMenuItem, { className: visibleItemsCount - 1 < i ? 'invisible' : '', active: _ === activeTopItem, observerOptions: observerOptions, onVisibilityChange: topItemsVisibilityHandlers[i], data: _.dataHeader, ..._ }, String(i)))) }), dropDownMenuItems.length ? (_jsx(DropdownMenu, { className: "mx-xs", items: dropDownMenuItems, activeItem: activeTopItem, ariaLabel: dropdownMenuAriaLabel })) : null, _jsx(HeaderSecondaryMenu, { version: version, className: "ml-auto", search: search, navigationItems: navigationItems, ...headerData })] }));
20
+ return (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx(Logo, { className: "mr-3xl", bgColor: bgColor, logo: logoProps, data: dataHeader, showTitle: false }), _jsx("div", { ref: topItemsListRef, className: "overflow-hidden min-w-40 pb-xs mt-xs", role: "menu", children: navigationItems.map((_, i) => (_jsx(HeaderTopMenuItem, { className: visibleItemsCount - 1 < i ? 'invisible' : '', active: _ === activeTopItem, observerOptions: observerOptions, onVisibilityChange: topItemsVisibilityHandlers[i], data: _.dataHeader, ..._ }, String(i)))) }), dropDownMenuItems.length ? (_jsx(HeaderMoreMenuItem, { className: "mx-xs rounded-md shadow-blue-gray", items: dropDownMenuItems, activeItem: activeTopItem, ariaLabel: dropdownMenuAriaLabel })) : null, _jsx(HeaderSecondaryMenu, { version: version, className: "ml-auto", search: search, navigationItems: navigationItems, ...headerData })] }));
21
21
  });
22
22
  const handleIntersectionActivation = (index) => (prev) => Math.max(prev, index + 1);
23
23
  const handleIntersectionDeactivation = (index) => (prev) => Math.min(prev, index);
@@ -1 +1 @@
1
- {"version":3,"file":"HeaderTopMenu.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderTopMenu.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAUxE,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAaxD,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,CAC9B,CAAC,EACC,eAAe,GAAG,EAAE,EACpB,aAAa,EACb,qBAAqB,EACrB,OAAO,EACP,UAAU,EACV,MAAM,EACN,OAAO,EACP,IAAI,GACL,EAAE,EAAE;IACH,MAAM,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,GAAG,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IAEnF,MAAM,iBAAiB,GAAG,eAAe,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IAEnE,MAAM,eAAe,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAC;IAC5D,MAAM,eAAe,GAAgC,EAAE,OAAO,EAAE,eAAe,EAAE,CAAC;IAClF,MAAM,0BAA0B,GAAG,OAAO,CACxC,GAAG,EAAE,CACH,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,cAAuB,EAAE,EAAE;QAC5D,oBAAoB,CAClB,cAAc;YACZ,CAAC,CAAC,4BAA4B,CAAC,KAAK,CAAC;YACrC,CAAC,CAAC,8BAA8B,CAAC,KAAK,CAAC,CAC1C,CAAC;IACJ,CAAC,CAAC,EACJ,CAAC,eAAe,CAAC,CAClB,CAAC;IAEF,6DAA6D;IAC7D,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,SAAS,EAAE,GAAG,IAAI,IAAI,EAAE,CAAC;IAE5D,OAAO,CACL,eAAK,SAAS,EAAC,mCAAmC,aAChD,KAAC,IAAI,IACH,SAAS,EAAC,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,SAAS,EACf,IAAI,EAAE,UAAU,EAChB,SAAS,EAAE,KAAK,GAChB,EACF,cAAK,GAAG,EAAE,eAAe,EAAE,SAAS,EAAC,sCAAsC,EAAC,IAAI,EAAC,MAAM,YACpF,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAC7B,KAAC,iBAAiB,IAEhB,SAAS,EAAE,iBAAiB,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,EACvD,MAAM,EAAE,CAAC,KAAK,aAAa,EAC3B,eAAe,EAAE,eAAe,EAChC,kBAAkB,EAAE,0BAA0B,CAAC,CAAC,CAAC,EACjD,IAAI,EAAE,CAAC,CAAC,UAAU,KACd,CAAC,IANA,MAAM,CAAC,CAAC,CAAC,CAOd,CACH,CAAC,GACE,EACL,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,CAC1B,KAAC,YAAY,IACX,SAAS,EAAC,OAAO,EACjB,KAAK,EAAE,iBAAiB,EACxB,UAAU,EAAE,aAAa,EACzB,SAAS,EAAE,qBAAqB,GAChC,CACH,CAAC,CAAC,CAAC,IAAI,EACR,KAAC,mBAAmB,IAClB,OAAO,EAAE,OAAO,EAChB,SAAS,EAAC,SAAS,EACnB,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,eAAe,KAC5B,UAAU,GACd,IACE,CACP,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,MAAM,4BAA4B,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;AACpG,MAAM,8BAA8B,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC"}
1
+ {"version":3,"file":"HeaderTopMenu.js","sourceRoot":"","sources":["../../../src/components/Header/HeaderTopMenu.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { type LinkProps } from '../../model/LinkProps';
2
+ import type { OnCloseProps } from '../../model/OnCloseProps';
3
+ interface DropdownSubMenuOptions extends OnCloseProps {
4
+ isOpen?: boolean;
5
+ activeItem?: LinkProps;
6
+ items?: LinkProps[];
7
+ }
8
+ export declare function useDropdownSubMenu({ items, activeItem, onClose, isOpen }: DropdownSubMenuOptions): {
9
+ current: HTMLDivElement | null;
10
+ };
11
+ export {};
@@ -0,0 +1,34 @@
1
+ import { jsx as _jsx } from "@redneckz/uni-jsx/jsx-runtime";
2
+ import { useCallback, useEffect, useRef } from '@redneckz/uni-jsx/lib/hooks';
3
+ import { useOutsideClick } from '@redneckz/uni-jsx/lib/hooks/useOutsideClick';
4
+ import { usePopupManager } from '../../ui-kit/PopupManager/usePopupManager.js';
5
+ import { DropdownMenu } from './DropdownMenu.js';
6
+ export function useDropdownSubMenu({ items, activeItem, onClose, isOpen }) {
7
+ const popup = usePopupManager();
8
+ useEffect(() => {
9
+ if (isOpen) {
10
+ popup.close();
11
+ }
12
+ }, [isOpen]);
13
+ const close = useCallback(() => {
14
+ popup.close();
15
+ onClose?.();
16
+ }, [onClose]);
17
+ const parentRef = useRef(null);
18
+ const popupRef = useOutsideClick(close);
19
+ useEffect(() => {
20
+ if (!isOpen || !parentRef.current || !items?.length) {
21
+ return;
22
+ }
23
+ const parentElement = parentRef.current;
24
+ const { top, left, width, height } = parentElement.getBoundingClientRect();
25
+ popup.open({
26
+ popup: _jsx(DropdownMenu, { dropdownRef: popupRef, items: items, activeItem: activeItem }),
27
+ top: top + window.scrollY + height,
28
+ left,
29
+ width,
30
+ });
31
+ }, [isOpen, items, close]);
32
+ return parentRef;
33
+ }
34
+ //# sourceMappingURL=useDropdownSubMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDropdownSubMenu.js","sourceRoot":"","sources":["../../../src/components/Header/useDropdownSubMenu.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,6CAA6C,CAAC;AAG9E,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAC5E,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAQ9C,MAAM,UAAU,kBAAkB,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAA0B;IAC/F,MAAM,KAAK,GAAG,eAAe,EAAE,CAAC;IAEhC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,MAAM,EAAE;YACV,KAAK,CAAC,KAAK,EAAE,CAAC;SACf;IACH,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,OAAO,EAAE,EAAE,CAAC;IACd,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,MAAM,SAAS,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAC;IACtD,MAAM,QAAQ,GAAG,eAAe,CAAiB,KAAK,CAAC,CAAC;IAExD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE;YACnD,OAAO;SACR;QAED,MAAM,aAAa,GAAG,SAAS,CAAC,OAAO,CAAC;QACxC,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC;QAE3E,KAAK,CAAC,IAAI,CAAC;YACT,KAAK,EAAE,KAAC,YAAY,IAAC,WAAW,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,UAAU,GAAI;YACpF,GAAG,EAAE,GAAG,GAAG,MAAM,CAAC,OAAO,GAAG,MAAM;YAClC,IAAI;YACJ,KAAK;SACN,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IAE3B,OAAO,SAAS,CAAC;AACnB,CAAC"}
@@ -5,6 +5,7 @@ export interface NavigationLinkProps extends LinkProps {
5
5
  displayArea?: string;
6
6
  dataHeader?: AspectsDef[];
7
7
  dataFooter?: AspectsDef[];
8
+ items?: NavigationLinkProps[];
8
9
  }
9
10
  /**
10
11
  * @title Ссылка
@@ -0,0 +1,2 @@
1
+ import { type CustomFieldProps } from '../CustomFieldProps';
2
+ export declare const ApplicationDateField: import("@redneckz/uni-jsx").UNIComponent<CustomFieldProps, any, any>;
@@ -0,0 +1,5 @@
1
+ import { jsx as _jsx } from "@redneckz/uni-jsx/jsx-runtime";
2
+ import { JSX } from '@redneckz/uni-jsx';
3
+ import { InputControl } from '../../Input/InputControl.js';
4
+ export const ApplicationDateField = JSX(({ field, input }) => (_jsx(InputControl, { label: "\u0414\u0430\u0442\u0430 \u0438 \u0432\u0440\u0435\u043C\u044F \u043E\u0431\u0440\u0430\u0449\u0435\u043D\u0438\u044F \u0432 \u0411\u0430\u043D\u043A", ...field(input?.name ?? '') })));
5
+ //# sourceMappingURL=ApplicationDateField.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApplicationDateField.js","sourceRoot":"","sources":["../../../../src/ui-kit/FormField/Fields/ApplicationDateField.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAGxD,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,CAAmB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAC9E,KAAC,YAAY,IAAC,KAAK,EAAC,uJAA+B,KAAK,KAAK,CAAC,KAAK,EAAE,IAAI,IAAI,EAAE,CAAC,GAAI,CACrF,CAAC,CAAC"}
@@ -1,9 +1,9 @@
1
1
  import { jsx as _jsx } from "@redneckz/uni-jsx/jsx-runtime";
2
- import { InputControl } from '../Input/InputControl.js';
3
2
  import { AcquiringField } from './Fields/AcquiringField.js';
4
3
  import { AddressBranchField } from './Fields/AddressBranchField.js';
5
4
  import { AmountField } from './Fields/AmountField.js';
6
5
  import { AnnualRevenueField } from './Fields/AnnualRevenueField.js';
6
+ import { ApplicationDateField } from './Fields/ApplicationDateField.js';
7
7
  import { ApplierTypeField } from './Fields/ApplierTypeField.js';
8
8
  import { BankEmpoleeField } from './Fields/BankEmpoleeField.js';
9
9
  import { BirthdayField } from './Fields/BirthdayField.js';
@@ -61,7 +61,7 @@ const InputsMap = {
61
61
  serviceDirection: ServiceDirectionField,
62
62
  bankEmpolee: BankEmpoleeField,
63
63
  secondaryPhone: SecondaryPhoneField,
64
- applicationDate: (props) => (_jsx(InputControl, { label: "\u0414\u0430\u0442\u0430 \u0438 \u0432\u0440\u0435\u043C\u044F \u043E\u0431\u0440\u0430\u0449\u0435\u043D\u0438\u044F \u0432 \u0411\u0430\u043D\u043A", ...props })),
64
+ applicationDate: ApplicationDateField,
65
65
  region: (props) => getPremium(props?.params?.typeForm) ? (_jsx(RegionPremiumField, { ...props })) : (_jsx(RegionField, { ...props })),
66
66
  consentToReceiveMaterials: ConsentToReceiveMaterialsField,
67
67
  sufferedFrom: SufferedFromField,
@@ -1 +1 @@
1
- {"version":3,"file":"getField.js","sourceRoot":"","sources":["../../../src/ui-kit/FormField/getField.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"getField.js","sourceRoot":"","sources":["../../../src/ui-kit/FormField/getField.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { JSX } from '@redneckz/uni-jsx';
2
+ import { type ButtonProps } from '../../ui-kit/Button/Button';
3
+
4
+ export const DropdownButton = JSX<ButtonProps>(({ onClick, children, ariaLabel }) => {
5
+ if (children) {
6
+ return children;
7
+ }
8
+
9
+ return (
10
+ <button
11
+ type="button"
12
+ className="flex justify-between items-center group/btn h-6 gap-2xs"
13
+ aria-label={ariaLabel}
14
+ onClick={onClick}
15
+ role="button"
16
+ aria-labelledby="labeldiv"
17
+ >
18
+ {Array.from({ length: 3 }, (_, i) => (
19
+ <div
20
+ key={i}
21
+ className="w-[3px] h-[3px] rounded bg-primary-text group-hover/btn:bg-primary-hover group-data-transparent:bg-white"
22
+ />
23
+ ))}
24
+ </button>
25
+ );
26
+ });
@@ -1,8 +1,4 @@
1
1
  import { JSX } from '@redneckz/uni-jsx';
2
- import { useCallback, useEffect, useRef } from '@redneckz/uni-jsx/lib/hooks';
3
- import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
4
- import { useEventListener } from '@redneckz/uni-jsx/lib/hooks/useEventListener';
5
- import { useOutsideClick } from '@redneckz/uni-jsx/lib/hooks/useOutsideClick';
6
2
  import { useLink } from '../../hooks/useLink';
7
3
  import { type ComponentType } from '../../model/ComponentType';
8
4
  import { type LinkProps } from '../../model/LinkProps';
@@ -10,91 +6,25 @@ import { getAspectsAttributes } from '../../utils/dataAttributes';
10
6
  import { style } from '../../utils/style';
11
7
 
12
8
  interface DropdownMenuProps extends ComponentType {
13
- items: LinkProps[];
9
+ dropdownRef?: { current: HTMLDivElement | null };
10
+ items?: LinkProps[];
14
11
  activeItem?: LinkProps;
15
12
  ariaLabel?: string;
16
13
  }
17
14
 
18
- interface ChangeDropdownPositionParams {
19
- isOpened: boolean;
20
- buttonRef: {
21
- current: HTMLDivElement | null;
22
- };
23
- menuRef: {
24
- current: HTMLDivElement | null;
25
- };
26
- }
27
-
28
- export const DropdownMenu = JSX<DropdownMenuProps>(
29
- ({ className = '', items, activeItem, ariaLabel = 'Меню' }) => {
30
- const [isVisible, { setFalse, toggle }] = useBool(false);
31
- const ref = useOutsideClick<HTMLDivElement>(setFalse);
32
- const dropdownRef = useRef<HTMLDivElement | null>(null);
33
-
34
- const changeDropdownPosition = useCallback(
35
- ({ isOpened, buttonRef, menuRef }: ChangeDropdownPositionParams) => {
36
- if (isOpened && buttonRef.current && menuRef.current) {
37
- const dropdownRect = menuRef.current.getBoundingClientRect();
38
- const dropdownButtonRect = buttonRef.current.getBoundingClientRect();
39
- const newDropdownPosition = globalThis.innerWidth - dropdownRect.width;
40
-
41
- if (dropdownRect.right >= globalThis.innerWidth) {
42
- menuRef.current.style.left = `${newDropdownPosition}px`;
43
- } else if (dropdownButtonRect.left > dropdownRect.left) {
44
- if (newDropdownPosition > dropdownButtonRect.left) {
45
- menuRef.current.style.left = '';
46
- } else {
47
- menuRef.current.style.left = `${newDropdownPosition}px`;
48
- }
49
- }
50
- }
51
- },
52
- [isVisible],
53
- );
54
-
55
- useEventListener(globalThis, 'resize', () =>
56
- changeDropdownPosition({ isOpened: isVisible, buttonRef: ref, menuRef: dropdownRef }),
57
- );
58
-
59
- useEffect(() => {
60
- changeDropdownPosition({ isOpened: isVisible, buttonRef: ref, menuRef: dropdownRef });
61
- }, [isVisible]);
62
-
63
- return (
64
- <div
65
- className={style(isVisible ? 'rounded-md shadow-blue-gray' : '', className)}
66
- ref={ref}
67
- role="navigation"
68
- >
69
- <button
70
- type="button"
71
- className="group/btn flex justify-between items-center h-6"
72
- aria-label={ariaLabel}
73
- onClick={toggle}
74
- role="button"
75
- aria-labelledby="labeldiv"
76
- >
77
- {Array(3)
78
- .fill(null)
79
- .map((_, i) => (
80
- <div
81
- key={String(i)}
82
- className="w-[3px] h-[3px] rounded mr-2xs bg-primary-text group-hover/btn:bg-primary-hover group-data-transparent:bg-white"
83
- />
84
- ))}
85
- </button>
86
- <div
87
- ref={dropdownRef}
88
- className={style('absolute flex flex-col rounded-md bg-white p-xl pb-xs w-56 z-40', {
89
- hidden: !isVisible,
90
- })}
91
- aria-hidden={!isVisible}
92
- >
93
- {renderDropdownItems(items, activeItem)}
94
- </div>
95
- </div>
96
- );
97
- },
15
+ export const DropdownMenu = ({
16
+ dropdownRef,
17
+ items = [],
18
+ activeItem,
19
+ ariaLabel,
20
+ }: DropdownMenuProps) => (
21
+ <div
22
+ ref={dropdownRef}
23
+ className="absolute flex flex-col rounded-md bg-white p-xl pb-xs w-56 z-40"
24
+ aria-label={ariaLabel}
25
+ >
26
+ {renderDropdownItems(items, activeItem)}
27
+ </div>
98
28
  );
99
29
 
100
30
  export const DropdownMenuItem = JSX<LinkProps & { isActive?: boolean }>(({ isActive, ...rest }) => {
@@ -0,0 +1,60 @@
1
+ import { JSX } from '@redneckz/uni-jsx';
2
+ import { useEffect } from '@redneckz/uni-jsx/lib/hooks';
3
+ import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
4
+ import { type ComponentType } from '../../model/ComponentType';
5
+ import { type LinkProps } from '../../model/LinkProps';
6
+ import { style } from '../../utils/style';
7
+ import { useDropdownSubMenu } from './useDropdownSubMenu';
8
+
9
+ interface HeaderMoreMenuItemProps extends ComponentType {
10
+ items: LinkProps[];
11
+ activeItem?: LinkProps;
12
+ ariaLabel?: string;
13
+ }
14
+
15
+ export const HeaderMoreMenuItem = JSX<HeaderMoreMenuItemProps>(
16
+ ({ className = '', items, activeItem, ariaLabel = 'Меню' }) => {
17
+ const [isOpenDropdown, { setFalse, toggle }] = useBool(false);
18
+
19
+ const dropdownMenu = useDropdownSubMenu({
20
+ items,
21
+ onClose: setFalse,
22
+ isOpen: isOpenDropdown,
23
+ activeItem,
24
+ });
25
+
26
+ useEffect(() => {
27
+ dropdownMenu.current?.addEventListener('mouseleave', setFalse);
28
+
29
+ return () => {
30
+ dropdownMenu.current?.removeEventListener('mouseleave', setFalse);
31
+ };
32
+ }, []);
33
+
34
+ return (
35
+ <div
36
+ className={style(isOpenDropdown ? 'rounded-md shadow-blue-gray' : '', className)}
37
+ ref={dropdownMenu}
38
+ role="navigation"
39
+ >
40
+ <button
41
+ type="button"
42
+ className="group/btn flex justify-between items-center h-6"
43
+ aria-label={ariaLabel}
44
+ onClick={toggle}
45
+ role="button"
46
+ aria-labelledby="labeldiv"
47
+ >
48
+ {Array(3)
49
+ .fill(null)
50
+ .map((_, i) => (
51
+ <div
52
+ key={String(i)}
53
+ className="w-[3px] h-[3px] rounded mr-2xs bg-primary-text group-hover/btn:bg-primary-hover group-data-transparent:bg-white"
54
+ />
55
+ ))}
56
+ </button>
57
+ </div>
58
+ );
59
+ },
60
+ );
@@ -6,8 +6,8 @@ import { type IntersectionObserverOptions } from '../../hooks/useIntersectionObs
6
6
  import { type BlockVersion } from '../../model/BlockVersion';
7
7
  import { type IconVersion } from '../../model/IconVersion';
8
8
  import { projectSettings } from '../../ProjectSettings';
9
- import { DropdownMenu } from './DropdownMenu';
10
9
  import { HeaderChatBotButton } from './HeaderChatBotButton';
10
+ import { HeaderMoreMenuItem } from './HeaderMoreMenuItem';
11
11
  import { type InternetButtonProps } from './HeaderProps';
12
12
  import { HeaderSubMenuItem } from './HeaderSubMenuItem';
13
13
  import { InternetBankButton } from './InternetBankButton';
@@ -56,6 +56,7 @@ export const HeaderSubMenu = JSX<HeaderSubMenuProps>(
56
56
  key={String(i)}
57
57
  className={visibleItemsCount - 1 < i ? 'invisible' : ''}
58
58
  active={_ === activeSubItem}
59
+ activeItem={activeSubItem}
59
60
  observerOptions={observerOptions}
60
61
  onVisibilityChange={subItemsVisibilityHandlers[i]}
61
62
  data={_.dataHeader}
@@ -64,7 +65,7 @@ export const HeaderSubMenu = JSX<HeaderSubMenuProps>(
64
65
  ))}
65
66
  </div>
66
67
  {dropDownMenuItems.length ? (
67
- <DropdownMenu
68
+ <HeaderMoreMenuItem
68
69
  items={dropDownMenuItems}
69
70
  activeItem={activeSubItem}
70
71
  ariaLabel={dropdownMenuAriaLabel}
@@ -1,5 +1,7 @@
1
1
  import { JSX } from '@redneckz/uni-jsx';
2
- import { useCallback } from '@redneckz/uni-jsx/lib/hooks';
2
+ import { useCallback, useEffect } from '@redneckz/uni-jsx/lib/hooks';
3
+ import { useBool } from '@redneckz/uni-jsx/lib/hooks/useBool';
4
+ import { type NavigationLinkProps } from '../../data/NavigationData';
3
5
  import {
4
6
  useIntersectionObserver,
5
7
  type IntersectionObserverOptions,
@@ -7,15 +9,20 @@ import {
7
9
  import { type ComponentType } from '../../model/ComponentType';
8
10
  import { type LinkProps } from '../../model/LinkProps';
9
11
  import { HeaderItem } from '../../ui-kit/HeaderItem/HeaderItem';
12
+ import { useDropdownSubMenu } from './useDropdownSubMenu';
10
13
 
11
14
  export interface HeaderSubMenuItemProps extends LinkProps, ComponentType {
12
15
  active?: boolean;
16
+ activeItem?: LinkProps;
13
17
  observerOptions?: IntersectionObserverOptions;
14
18
  onVisibilityChange?: (isIntersecting: boolean) => void;
19
+ items?: NavigationLinkProps[];
15
20
  }
16
21
 
17
22
  export const HeaderSubMenuItem = JSX<HeaderSubMenuItemProps>(
18
- ({ observerOptions, onVisibilityChange, children, className, ...rest }) => {
23
+ ({ observerOptions, onVisibilityChange, children, className, items, activeItem, ...rest }) => {
24
+ const [isOpenDropdown, { setFalse, setTrue }] = useBool(false);
25
+
19
26
  const observerCallback = useCallback(
20
27
  (entries: IntersectionObserverEntry[]) => {
21
28
  if (!entries.length || !onVisibilityChange) {
@@ -31,10 +38,29 @@ export const HeaderSubMenuItem = JSX<HeaderSubMenuItemProps>(
31
38
  );
32
39
  const ref = useIntersectionObserver<HTMLSpanElement>(observerCallback, observerOptions);
33
40
 
41
+ const dropdownMenu = useDropdownSubMenu({
42
+ items,
43
+ onClose: setFalse,
44
+ isOpen: isOpenDropdown,
45
+ activeItem,
46
+ });
47
+
48
+ useEffect(() => {
49
+ dropdownMenu.current?.addEventListener('mouseenter', setTrue);
50
+ dropdownMenu.current?.addEventListener('mouseleave', setFalse);
51
+
52
+ return () => {
53
+ dropdownMenu.current?.addEventListener('mouseenter', setTrue);
54
+ dropdownMenu.current?.removeEventListener('mouseleave', setFalse);
55
+ };
56
+ }, []);
57
+
34
58
  return (
35
- <span ref={ref} className={className} role="menuitem">
36
- <HeaderItem {...rest}>{children}</HeaderItem>
37
- </span>
59
+ <div className="inline-block" ref={dropdownMenu}>
60
+ <span ref={ref} className={className} role="menuitem">
61
+ <HeaderItem {...rest}>{children}</HeaderItem>
62
+ </span>
63
+ </div>
38
64
  );
39
65
  },
40
66
  );
@@ -10,7 +10,7 @@ import { type BlockVersion } from '../../model/BlockVersion';
10
10
  import { type ComponentType } from '../../model/ComponentType';
11
11
  import { type LogoType } from '../../model/LogoType';
12
12
  import { Logo } from '../../ui-kit/Logo/Logo';
13
- import { DropdownMenu } from './DropdownMenu';
13
+ import { HeaderMoreMenuItem } from './HeaderMoreMenuItem';
14
14
  import { HeaderSecondaryMenu } from './HeaderSecondaryMenu';
15
15
  import { HeaderTopMenuItem } from './HeaderTopMenuItem';
16
16
 
@@ -80,8 +80,8 @@ export const HeaderTopMenu = JSX<HeaderMenuProps>(
80
80
  ))}
81
81
  </div>
82
82
  {dropDownMenuItems.length ? (
83
- <DropdownMenu
84
- className="mx-xs"
83
+ <HeaderMoreMenuItem
84
+ className="mx-xs rounded-md shadow-blue-gray"
85
85
  items={dropDownMenuItems}
86
86
  activeItem={activeTopItem}
87
87
  ariaLabel={dropdownMenuAriaLabel}