@axos-web-dev/shared-components 2.0.0-dev.17 → 2.0.0-dev.17-nav-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (262) hide show
  1. package/README.md +111 -111
  2. package/dist/ATMLocator/ATMLocator.js +14 -84
  3. package/dist/Accordion/Accordion.css.js +1 -1
  4. package/dist/Accordion/Accordion.js +4 -4
  5. package/dist/AlertBanner/AlertBanner.css.js +1 -1
  6. package/dist/AlertBanner/index.js +2 -2
  7. package/dist/Article/Article.css.js +1 -1
  8. package/dist/Article/Article.js +1 -1
  9. package/dist/ArticlesSet/ArticlesSet.css.js +1 -1
  10. package/dist/Auth/ErrorAlert.css.js +1 -1
  11. package/dist/Auth/ErrorAlert.js +6 -88
  12. package/dist/Auth/Logout.js +1 -1
  13. package/dist/Auth/SignIn.css.js +1 -1
  14. package/dist/Auth/SignInPassword.js +1 -1
  15. package/dist/Avatar/Avatar.module.js +7 -7
  16. package/dist/AwardsBanner/AwardsBanner.css.js +1 -1
  17. package/dist/AwardsItem/AwardsItem.css.js +1 -1
  18. package/dist/Blockquote/Blockquote.module.js +3 -3
  19. package/dist/BulletItem/BulletItem.css.js +1 -1
  20. package/dist/BulletItem/BulletItem.js +1 -1
  21. package/dist/Button/Button.css.js +1 -1
  22. package/dist/Button/Button.js +6 -120
  23. package/dist/Calculators/AnnualFeeCalculator/AnnualFeeCalculator.css.js +1 -1
  24. package/dist/Calculators/AnnualFeeCalculator/index.js +1 -1
  25. package/dist/Calculators/ApyCalculator/ApyCalculator.css.js +1 -1
  26. package/dist/Calculators/ApyCalculator/index.js +1 -1
  27. package/dist/Calculators/AxosOneCalculator/BalanceAPYCalculator.css.js +1 -1
  28. package/dist/Calculators/AxosOneCalculator/index.js +2 -2
  29. package/dist/Calculators/BalanceAPYCalculator/BalanceAPYCalculator.css.js +1 -1
  30. package/dist/Calculators/BalanceAPYCalculator/index.js +2 -2
  31. package/dist/Calculators/BuyDownCalculator/BuyDownCalculator.css.js +1 -1
  32. package/dist/Calculators/BuyDownCalculator/index.js +2 -2
  33. package/dist/Calculators/Calculator.d.ts +1 -1
  34. package/dist/Calculators/Calculator.js +18 -89
  35. package/dist/Calculators/MarginTradingCalculator/MarginTradingCalculator.css.js +1 -1
  36. package/dist/Calculators/MarginTradingCalculator/index.js +5 -115
  37. package/dist/Calculators/MarineLoanMonthlyPaymentCalculator/index.js +1 -1
  38. package/dist/Calculators/MaxLoanCalculator/index.js +1 -1
  39. package/dist/Calculators/MonthlyPaymentCalculator/MonthlyPaymentCalculator.css.js +1 -1
  40. package/dist/Calculators/MonthlyPaymentCalculator/index.js +1 -1
  41. package/dist/Calculators/MonthlyPaymentLVFCalculator/MonthlyPaymentCalculator.css.js +1 -1
  42. package/dist/Calculators/MonthlyPaymentLVFCalculator/index.js +1 -1
  43. package/dist/Calculators/SummitApyCalculator/BalanceAPYCalculator.css.js +1 -1
  44. package/dist/Calculators/SummitApyCalculator/index.js +2 -2
  45. package/dist/Calculators/calculator.css.js +1 -1
  46. package/dist/CallToActionBar/CallToActionBar.css.js +1 -1
  47. package/dist/CallToActionBar/index.js +1 -1
  48. package/dist/Carousel/Carousel.css.js +1 -1
  49. package/dist/Carousel/index.js +5 -110
  50. package/dist/Chatbot/AnimatedGradientBorder.css.js +1 -1
  51. package/dist/Chatbot/Bubble.css.js +1 -1
  52. package/dist/Chatbot/Bubble.js +1 -1
  53. package/dist/Chatbot/ChatWindow.css.js +1 -1
  54. package/dist/Chatbot/ChatWindow.js +2 -2
  55. package/dist/Chatbot/Chatbot.css.js +1 -1
  56. package/dist/Chatbot/ChatbotMessage.js +2 -2
  57. package/dist/Chatbot/ThankYouMessage.js +2 -2
  58. package/dist/Chevron/Chevron.css.js +1 -1
  59. package/dist/Chevron/index.js +4 -114
  60. package/dist/CollectInformationAlert/CollectInformationAlert.css.js +1 -1
  61. package/dist/CollectInformationAlert/index.js +1 -1
  62. package/dist/Comparison/Comparison.css.js +1 -1
  63. package/dist/Comparison/Comparison.js +5 -121
  64. package/dist/Comparison/ComparisonSet.js +1 -1
  65. package/dist/ContentBanner/ContentBanner.css.js +1 -1
  66. package/dist/ContentBanner/index.js +1 -1
  67. package/dist/DownloadTile/DownloadTile.css.js +1 -1
  68. package/dist/ExecutiveBio/ExecutiveBio.css.js +1 -1
  69. package/dist/ExecutiveBio/ExecutiveBio.interface.d.ts +3 -2
  70. package/dist/ExecutiveBio/ExecutiveBio.js +4 -126
  71. package/dist/ExecutiveBio/ExecutiveBioSet.js +1 -1
  72. package/dist/FaqAccordion/FaqAccordion.css.js +1 -1
  73. package/dist/FaqAccordion/index.js +8 -111
  74. package/dist/FdicCallout/FdicCallout.module.js +2 -2
  75. package/dist/FooterDisclosure/FooterDisclosure.css.js +1 -1
  76. package/dist/FooterDisclosure/FooterDisclosure.js +1 -1
  77. package/dist/FooterDisclosure/LVF/LaVictorieFooter.css.js +1 -1
  78. package/dist/FooterDisclosure/LVF/LaVictorieFooter.js +2 -2
  79. package/dist/FooterSiteMap/AxosBank/FooterSiteMap.css.js +1 -1
  80. package/dist/FooterSiteMap/AxosBank/FooterSiteMap.js +5 -110
  81. package/dist/Forms/ApplicationStart.js +2 -2
  82. package/dist/Forms/ApplyNow.js +5 -110
  83. package/dist/Forms/BoatMooringLocation.js +2 -2
  84. package/dist/Forms/ClearingForm.js +2 -2
  85. package/dist/Forms/CommercialDeposits.js +2 -2
  86. package/dist/Forms/CommercialDepositsNoLendingOption.js +2 -2
  87. package/dist/Forms/CommercialLending.js +2 -2
  88. package/dist/Forms/CommercialPremiumFinance.js +2 -2
  89. package/dist/Forms/ConstructionLendingDynamic.js +2 -2
  90. package/dist/Forms/ContactCompany.d.ts +1 -1
  91. package/dist/Forms/ContactCompany.js +2 -2
  92. package/dist/Forms/ContactCompanyTitle.d.ts +1 -1
  93. package/dist/Forms/ContactCompanyTitle.js +2 -2
  94. package/dist/Forms/ContactUs.js +2 -2
  95. package/dist/Forms/ContactUsAAS.js +2 -2
  96. package/dist/Forms/ContactUsBusiness.js +8 -105
  97. package/dist/Forms/ContactUsBusinessNameEmail.js +9 -105
  98. package/dist/Forms/ContactUsLVF.js +2 -2
  99. package/dist/Forms/ContactUsNMLSId.js +8 -105
  100. package/dist/Forms/CpraRequest.js +3 -97
  101. package/dist/Forms/CraPublicFile.js +8 -105
  102. package/dist/Forms/DealerServices.d.ts +1 -1
  103. package/dist/Forms/DealerServices.js +2 -2
  104. package/dist/Forms/EmailOnly.js +8 -105
  105. package/dist/Forms/EmailUs.js +2 -2
  106. package/dist/Forms/Forms.css.js +1 -1
  107. package/dist/Forms/HoneyPot/HoneyPot.css.js +1 -1
  108. package/dist/Forms/MortgageRate/MortgageRateForm.js +9 -97
  109. package/dist/Forms/MortgageRate/MortgageRateQuoteFilters.js +1 -1
  110. package/dist/Forms/MortgageRate/MortgageRateWatch.js +4 -92
  111. package/dist/Forms/MortgageWarehouseLending.js +8 -105
  112. package/dist/Forms/QuickPricer/QuickPricerForm.js +3 -3
  113. package/dist/Forms/QuickPricer/QuickPricerResults.css.js +1 -1
  114. package/dist/Forms/QuickPricer/UserInformation.css.js +1 -1
  115. package/dist/Forms/ScheduleCall.js +2 -2
  116. package/dist/Forms/ScheduleCallPremier.js +2 -2
  117. package/dist/Forms/SuccesForm.js +9 -92
  118. package/dist/Forms/VendorQuestionnaire.js +1 -1
  119. package/dist/Forms/WcplSurvey.js +2 -2
  120. package/dist/HelpArticle/HelpArticle.css.js +1 -1
  121. package/dist/HeroBanner/HeroBanner.css.js +1 -1
  122. package/dist/HeroBanner/HeroBanner.js +3 -3
  123. package/dist/HeroBanner/LargeBanner.css.js +1 -1
  124. package/dist/HeroBanner/LargeHeroBanner.js +3 -3
  125. package/dist/HeroBanner/SelectionBanner.css.js +1 -1
  126. package/dist/Hyperlink/Hyperlink.css.js +1 -1
  127. package/dist/Hyperlink/index.js +5 -110
  128. package/dist/IconBillboard/IconBillboard.css.js +1 -1
  129. package/dist/IconBillboard/IconBillboard.js +1 -1
  130. package/dist/IconBillboard/IconBillboardSet.js +1 -1
  131. package/dist/ImageBillboard/ImageBillboard.css.js +1 -1
  132. package/dist/ImageBillboard/ImageBillboard.js +2 -2
  133. package/dist/ImageBillboard/ImageBillboardSet.js +2 -2
  134. package/dist/ImageLink/ImageLink.css.js +1 -1
  135. package/dist/ImageLink/ImageLink.js +6 -106
  136. package/dist/ImageLink/ImageLinkSet.js +6 -114
  137. package/dist/ImageLink/index.js +6 -105
  138. package/dist/Input/Checkbox.css.js +1 -1
  139. package/dist/Input/Checkbox.js +2 -2
  140. package/dist/Input/DownPaymentInput.js +1 -1
  141. package/dist/Input/Dropdown.css.js +1 -1
  142. package/dist/Input/Dropdown.js +1 -1
  143. package/dist/Input/Input.css.js +1 -1
  144. package/dist/Input/Input.js +1 -1
  145. package/dist/Input/InputTextArea.js +1 -1
  146. package/dist/Input/RadioButton.css.js +1 -1
  147. package/dist/Inputs/Input.css.js +1 -1
  148. package/dist/Insight/Featured/CategorySelector.css.js +1 -1
  149. package/dist/Insight/Featured/CategorySelector.d.ts +1 -1
  150. package/dist/Insight/Featured/CategorySelector.js +6 -110
  151. package/dist/Insight/Featured/Featured.css.js +1 -1
  152. package/dist/Insight/Featured/Featured.js +10 -108
  153. package/dist/Insight/Featured/Header.css.js +1 -1
  154. package/dist/Insight/Featured/Header.js +5 -110
  155. package/dist/Insight/Insight.css.js +1 -1
  156. package/dist/Interstitial/Interstitial-variants.css.js +1 -1
  157. package/dist/Interstitial/Interstitial.module.js +10 -10
  158. package/dist/LandingPageHeader/LandingPageHeader.css.js +1 -1
  159. package/dist/LandingPageHeader/LandingPageHeader.d.ts +1 -1
  160. package/dist/LandingPageHeader/LandingPageHeader.js +2 -2
  161. package/dist/LoadingIndicator/LoadingIndicator.css.js +1 -1
  162. package/dist/Modal/Modal.css.js +1 -1
  163. package/dist/Modal/Modal.js +2 -122
  164. package/dist/NavigationMenu/AxosALTS/NavBar.css.js +1 -1
  165. package/dist/NavigationMenu/AxosALTS/NavBar.module.js +23 -23
  166. package/dist/NavigationMenu/AxosALTS/index.js +6 -111
  167. package/dist/NavigationMenu/AxosAdvisor/NavBar.css.js +1 -1
  168. package/dist/NavigationMenu/AxosAdvisor/NavBar.module.js +52 -52
  169. package/dist/NavigationMenu/AxosAdvisor/SubNavbar.css.js +1 -1
  170. package/dist/NavigationMenu/AxosAdvisorServices/NavBar.css.js +1 -1
  171. package/dist/NavigationMenu/AxosAdvisorServices/NavBar.module.js +53 -53
  172. package/dist/NavigationMenu/AxosAdvisorServices/SubNavbar.css.js +1 -1
  173. package/dist/NavigationMenu/AxosBank/DropwdownButton.d.ts +7 -0
  174. package/dist/NavigationMenu/AxosBank/DropwdownButton.js +109 -0
  175. package/dist/NavigationMenu/AxosBank/Menu.d.ts +37 -0
  176. package/dist/NavigationMenu/AxosBank/Menu.js +119 -0
  177. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileMenu.d.ts +12 -1
  178. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileMenu.js +187 -272
  179. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileMenu.module.js +27 -27
  180. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileNavData.d.ts +35 -282
  181. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileNavData.js +53 -523
  182. package/dist/NavigationMenu/AxosBank/MobileMenu/mobileReducer.d.ts +36 -0
  183. package/dist/NavigationMenu/AxosBank/MobileMenu/mobileReducer.js +105 -0
  184. package/dist/NavigationMenu/AxosBank/NavBar.css.js +1 -1
  185. package/dist/NavigationMenu/AxosBank/NavBar.module.js +42 -39
  186. package/dist/NavigationMenu/AxosBank/SubNavBar.d.ts +6 -1
  187. package/dist/NavigationMenu/AxosBank/SubNavBar.js +117 -3191
  188. package/dist/NavigationMenu/AxosBank/SubNavItem.d.ts +1 -0
  189. package/dist/NavigationMenu/AxosBank/SubNavItem.js +185 -0
  190. package/dist/NavigationMenu/AxosBank/SubNavbar.css.js +1 -1
  191. package/dist/NavigationMenu/AxosBank/index.d.ts +5 -3
  192. package/dist/NavigationMenu/AxosBank/index.js +131 -497
  193. package/dist/NavigationMenu/AxosClearing/NavBar.css.js +1 -1
  194. package/dist/NavigationMenu/AxosClearing/NavBar.module.js +37 -37
  195. package/dist/NavigationMenu/AxosFiduciary/NavBar.module.js +41 -41
  196. package/dist/NavigationMenu/LaVictoire/NavBar.css.js +1 -1
  197. package/dist/NavigationMenu/LaVictoire/NavBar.module.js +37 -37
  198. package/dist/NavigationMenu/LaVictoire/index.js +5 -118
  199. package/dist/NavigationMenu/Navbar.d.ts +4 -1
  200. package/dist/NavigationMenu/Navbar.js +10 -113
  201. package/dist/NavigationMenu/SignInNavButton.js +8 -121
  202. package/dist/NavigationMenu/utils.d.ts +465 -0
  203. package/dist/NavigationMenu/utils.js +112 -0
  204. package/dist/PageNavItem/PageNavItem.css.js +1 -1
  205. package/dist/PageNavItem/PageNavItem.js +1 -1
  206. package/dist/PageNavSet/PageNavSet.js +1 -1
  207. package/dist/PageNavSet/PageNavigationSet.css.js +1 -1
  208. package/dist/Pagination/Pagination.css.js +1 -1
  209. package/dist/Pagination/Pagination.js +2 -2
  210. package/dist/SecondaryFooter/SecondaryFooter.css.js +1 -1
  211. package/dist/SecondaryFooter/index.js +1 -1
  212. package/dist/SetContainer/SetContainer.css.js +1 -1
  213. package/dist/SetContainer/SetContainer.js +7 -108
  214. package/dist/SocialMediaBar/SocialMediaBar.css.js +1 -1
  215. package/dist/SocialMediaBar/iconsRepository.js +0 -124
  216. package/dist/StepItem/StepItem.css.js +1 -1
  217. package/dist/StepItem/StepItem.js +1 -1
  218. package/dist/StepItemSet/StepItemSet.css.js +1 -1
  219. package/dist/StepItemSet/StepItemSet.js +2 -2
  220. package/dist/Tab/Tab.css.js +1 -1
  221. package/dist/Table/Table.css.js +1 -1
  222. package/dist/Table/Table.js +2 -2
  223. package/dist/TextBlock/TextBlock.css.js +1 -1
  224. package/dist/TextBlock/TextBlock.js +1 -1
  225. package/dist/Topic/Topic.css.js +1 -1
  226. package/dist/Topic/Topic.js +1 -1
  227. package/dist/TopicalNavItem/TopicalNavItem.css.js +1 -1
  228. package/dist/TopicalNavSet/TopicalNavSet.css.js +1 -1
  229. package/dist/Typography/Typography.css.js +1 -1
  230. package/dist/VideoTile/VideoTile.css.js +1 -1
  231. package/dist/VideoTile/VideoTile.js +2 -106
  232. package/dist/VideoWrapper/VideoWrapper.css.js +1 -1
  233. package/dist/VideoWrapper/index.js +7 -110
  234. package/dist/WalnutIframe/wrapper.module.js +3 -3
  235. package/dist/assets/Avatar/Avatar.css +59 -59
  236. package/dist/assets/Blockquote/Blockquote.css +72 -72
  237. package/dist/assets/FdicCallout/FdicCallout.css +48 -48
  238. package/dist/assets/Interstitial/Interstitial.css +142 -142
  239. package/dist/assets/NavigationMenu/AxosALTS/NavBar.css +264 -264
  240. package/dist/assets/NavigationMenu/AxosAdvisor/NavBar.css +609 -609
  241. package/dist/assets/NavigationMenu/AxosAdvisorServices/NavBar.css +630 -630
  242. package/dist/assets/NavigationMenu/AxosBank/MobileMenu/MobileMenu.css +353 -353
  243. package/dist/assets/NavigationMenu/AxosBank/NavBar.css +483 -445
  244. package/dist/assets/NavigationMenu/AxosClearing/NavBar.css +484 -484
  245. package/dist/assets/NavigationMenu/AxosFiduciary/NavBar.css +427 -427
  246. package/dist/assets/NavigationMenu/LaVictoire/NavBar.css +429 -429
  247. package/dist/assets/WalnutIframe/wrapper.css +48 -48
  248. package/dist/assets/utils/optimizeImage/optimizeImage.css +47 -47
  249. package/dist/globals.css.js +1 -1
  250. package/dist/icons/ArrowIcon/ArrowIcon.css.js +1 -1
  251. package/dist/icons/CheckIcon/CheckIcon.css.js +1 -1
  252. package/dist/icons/DownloadIcon/DownloadIcon.css.js +1 -1
  253. package/dist/icons/FollowIcon/FollowIcon.css.js +1 -1
  254. package/dist/icons/Star/Star.css.js +1 -1
  255. package/dist/index.css.js +1 -1
  256. package/dist/themes/axos.css.js +1 -1
  257. package/dist/themes/premier.css.js +1 -1
  258. package/dist/themes/ufb.css.js +1 -1
  259. package/dist/themes/victorie.css.js +1 -1
  260. package/dist/utils/allowedAxosDomains.js +6 -2
  261. package/dist/utils/optimizeImage/optimizeImage.module.js +3 -3
  262. package/package.json +148 -148
@@ -1,133 +1,30 @@
1
1
  "use client";
2
2
  import { jsxs, Fragment, jsx } from "react/jsx-runtime";
3
- import { useState, useRef, useMemo, useEffect } from "react";
4
- import { AnimatePresence, motion } from "framer-motion";
5
- import { usePathname } from "next/navigation.js";
6
- import Link from "next/link.js";
7
- import { getMenuData, getLoginGroups, getQuickLinks } from "./MobileNavData.js";
8
- import styles from "./MobileMenu.module.js";
9
- import "../../../Chevron/Chevron.css.js";
10
- import "../../../Accordion/Accordion.js";
11
- import "../../../Accordion/Accordion.css.js";
3
+ import "../../../IconBillboard/IconBillboard.css.js";
12
4
  import "../../../icons/ArrowIcon/ArrowIcon.css.js";
13
5
  import "../../../icons/CheckIcon/CheckIcon.css.js";
14
- import '../../../assets/Modal/Modal.css';import '../../../assets/VideoWrapper/VideoWrapper.css';import '../../../assets/TopicalNavSet/TopicalNavSet.css';import '../../../assets/TopicalNavItem/TopicalNavItem.css';import '../../../assets/Topic/Topic.css';import '../../../assets/TextBlock/TextBlock.css';import '../../../assets/SocialMediaBar/SocialMediaBar.css';import '../../../assets/SecondaryFooter/SecondaryFooter.css';import '../../../assets/Pagination/Pagination.css';import '../../../assets/PageNavSet/PageNavigationSet.css';import '../../../assets/NavigationMenu/LaVictoire/NavBar2.css';import '../../../assets/NavigationMenu/AxosALTS/NavBar2.css';import '../../../assets/NavigationMenu/AxosClearing/NavBar2.css';import '../../../assets/NavigationMenu/AxosBank/SubNavbar.css';import '../../../assets/NavigationMenu/AxosBank/NavBar2.css';import '../../../assets/NavigationMenu/AxosAdvisorServices/SubNavbar.css';import '../../../assets/NavigationMenu/AxosAdvisorServices/NavBar2.css';import '../../../assets/NavigationMenu/AxosAdvisor/SubNavbar.css';import '../../../assets/NavigationMenu/AxosAdvisor/NavBar2.css';import '../../../assets/Insight/Featured/Header.css';import '../../../assets/Insight/Featured/CategorySelector.css';import '../../../assets/Insight/Featured/Featured.css';import '../../../assets/ImageLink/ImageLink.css';import '../../../assets/VideoTile/VideoTile.css';import '../../../assets/HelpArticle/HelpArticle.css';import '../../../assets/FooterSiteMap/AxosBank/FooterSiteMap.css';import '../../../assets/FooterDisclosure/LVF/LaVictorieFooter.css';import '../../../assets/DownloadTile/DownloadTile.css';import '../../../assets/CollectInformationAlert/CollectInformationAlert.css';import '../../../assets/Chatbot/ChatWindow.css';import '../../../assets/Chatbot/Bubble.css';import '../../../assets/Chatbot/Chatbot.css';import '../../../assets/Chatbot/AnimatedGradientBorder.css';import '../../../assets/CallToActionBar/CallToActionBar.css';import '../../../assets/Insight/Insight.css';import '../../../assets/AwardsItem/AwardsItem.css';import '../../../assets/AwardsBanner/AwardsBanner.css';import '../../../assets/Auth/SignIn.css';import '../../../assets/Auth/ErrorAlert.css';import '../../../assets/Calculators/MarginTradingCalculator/MarginTradingCalculator.css';import '../../../assets/Forms/QuickPricer/UserInformation.css';import '../../../assets/Forms/QuickPricer/QuickPricerResults.css';import '../../../assets/BulletItem/BulletItem.css';import '../../../assets/Typography/Typography.css';import '../../../assets/icons/FollowIcon/FollowIcon.css';import '../../../assets/icons/DownloadIcon/DownloadIcon.css';import '../../../assets/themes/victorie.css';import '../../../assets/themes/ufb.css';import '../../../assets/themes/premier.css';import '../../../assets/themes/axos.css';/* empty css */
6
+ /* empty css */
15
7
  /* empty css */
16
8
  /* empty css */
17
9
  /* empty css */
18
10
  /* empty css */
19
11
  /* empty css */
12
+ import { useRef, useState, useReducer, useEffect } from "react";
20
13
  import "clsx";
21
- import "../../../AlertBanner/AlertBanner.css.js";
22
- import "../../../Article/Article.css.js";
23
- import "../../../IconBillboard/IconBillboard.css.js";
24
14
  /* empty css */
25
15
  /* empty css */
16
+ import "../../../Chevron/Chevron.css.js";
26
17
  import "../../../Interstitial/Interstitial-variants.css.js";
27
18
  import "../../../Button/Button.css.js";
28
- import "react-use";
29
- import "../../../ArticlesSet/ArticlesSet.css.js";
30
- import "../../../Calculators/calculator.css.js";
31
- import "../../../Calculators/AnnualFeeCalculator/AnnualFeeCalculator.css.js";
32
- import { useGlobalContext } from "../../../Modal/contextApi/store.js";
33
- import "../../../Calculators/ApyCalculator/ApyCalculator.css.js";
34
- import "../../../Table/Table.css.js";
35
- import "../../../Calculators/AxosOneCalculator/BalanceAPYCalculator.css.js";
36
- import "../../../Calculators/BalanceAPYCalculator/BalanceAPYCalculator.css.js";
37
- import "@hookform/resolvers/zod";
38
- import "../../../Input/Checkbox.js";
39
- import "../../../Input/CurrencyInput.js";
40
- import "../../../Input/Dropdown.js";
41
- import "../../../Input/Dropdown.css.js";
42
- import "../../../Input/Input.js";
43
- import "../../../Input/Input.css.js";
44
- import "../../../Input/InputAmount.js";
45
- import "../../../Input/InputPhone.js";
46
- import "../../../Input/InputTextArea.js";
47
- import "../../../Input/DownPaymentInput.js";
48
- import "../../../Input/RadioButton.js";
49
- import "../../../Input/PercentageInput.js";
50
- import "react-hook-form";
51
- import "../../../Calculators/BuyDownCalculator/BuyDownCalculator.css.js";
52
- import "../../../Forms/Forms.css.js";
53
- import "../../../Forms/HoneyPot/index.js";
54
- import "../../../Forms/SalesforceFieldsForm.js";
55
- import "../../../Input/RadioButton.css.js";
56
- import "../../../Input/Checkbox.css.js";
57
- import "../../../LoadingIndicator/LoadingIndicator.css.js";
58
- import "../../../Inputs/Input.css.js";
59
- /* empty css */
60
- import "../../../Hyperlink/Hyperlink.css.js";
61
- /* empty css */
62
- import "iframe-resizer";
63
- /* empty css */
64
- import "../../../Calculators/MonthlyPaymentCalculator/MonthlyPaymentCalculator.css.js";
65
- import "../../../Calculators/MonthlyPaymentLVFCalculator/MonthlyPaymentCalculator.css.js";
66
- import "../../../Calculators/SummitApyCalculator/BalanceAPYCalculator.css.js";
67
- /* empty css */
68
- import "react-dom";
69
- /* empty css */
70
- import "../../../Auth/SignInPassword.js";
71
- /* empty css */
72
- /* empty css */
73
- /* empty css */
74
- /* empty css */
75
- import "../../../Carousel/index.js";
76
- /* empty css */
77
- /* empty css */
78
- /* empty css */
79
- import "../../../Chatbot/store/chat.js";
80
- import "../../../Chatbot/Chatbot.js";
81
- /* empty css */
82
- import "../../../Chatbot/store/messages.js";
83
- /* empty css */
84
- import "../../../Comparison/Comparison.css.js";
85
- import "next/image.js";
86
- import "../../../HeroBanner/LargeBanner.css.js";
87
- import "../../../HeroBanner/HeroBanner.css.js";
88
- import "../../../HeroBanner/SelectionBanner.css.js";
89
- import "../../../SetContainer/SetContainer.css.js";
90
- import "../../../Tab/Tab.css.js";
91
- import "../../../icons/Star/Star.css.js";
92
- import "../../../ContentBanner/ContentBanner.css.js";
93
- /* empty css */
94
- import "../../../ExecutiveBio/ExecutiveBio.css.js";
95
- import "../../../FaqAccordion/index.js";
96
- import "../../../FooterDisclosure/FooterDisclosure.css.js";
97
- /* empty css */
98
- /* empty css */
99
- /* empty css */
100
- import "../../../ImageBillboard/ImageBillboard.css.js";
101
- import "next/script.js";
102
- /* empty css */
103
- /* empty css */
104
- /* empty css */
105
- /* empty css */
106
- /* empty css */
107
- import "../../../LandingPageHeader/LandingPageHeader.css.js";
108
- /* empty css */
109
- /* empty css */
110
- /* empty css */
111
- /* empty css */
112
- /* empty css */
113
- /* empty css */
114
- /* empty css */
115
- /* empty css */
116
- /* empty css */
117
- import "../../../PageNavItem/PageNavItem.css.js";
118
- import "react-slick";
119
- /* empty css */
120
- /* empty css */
121
- /* empty css */
122
- /* empty css */
123
- import "../../../StepItem/StepItem.css.js";
124
- import "../../../StepItemSet/StepItemSet.css.js";
125
- /* empty css */
126
- /* empty css */
127
- /* empty css */
128
- /* empty css */
129
- /* empty css */
19
+ import { useLocation, useClickAway } from "react-use";
130
20
  /* empty css */
21
+ import { useGlobalContext } from "../../../Modal/contextApi/store.js";
22
+ import { AnimatePresence, motion } from "framer-motion";
23
+ import Link from "next/link.js";
24
+ import { usePathname } from "next/navigation.js";
25
+ import styles from "./MobileMenu.module.js";
26
+ import { mobileData } from "./MobileNavData.js";
27
+ import { MenuActions, reducer } from "./mobileReducer.js";
131
28
  const slideVariants = {
132
29
  enter: (direction) => ({
133
30
  x: direction === "forward" ? "100%" : "-100%",
@@ -146,104 +43,79 @@ const slideVariants = {
146
43
  position: "absolute"
147
44
  })
148
45
  };
149
- const MobileDrawerMenu = () => {
46
+ const initialState = {
47
+ direction: "forward",
48
+ isMobileMenuOpen: false,
49
+ hasOpenedOnce: false,
50
+ prevLevel: [],
51
+ currentMenuData: null,
52
+ stack: [],
53
+ loginDrawer: false,
54
+ loginData: {}
55
+ };
56
+ const MobileDrawerMenu = ({ menu }) => {
150
57
  const pathname = usePathname();
58
+ const { search } = useLocation();
151
59
  const { resolveUrl } = useGlobalContext();
152
- const menuData = getMenuData(resolveUrl);
153
- const [queryString, setQueryString] = useState("");
154
- const [open, setOpen] = useState(false);
155
- const [stack, setStack] = useState([
156
- { title: "Main Menu", items: menuData }
157
- ]);
158
- const [hasOpenedOnce, setHasOpenedOnce] = useState(false);
159
- const [direction, setDirection] = useState("forward");
160
- const [quickLinks, setQuickLinks] = useState([]);
161
- const [loginDrawerOpen, setLoginDrawerOpen] = useState(false);
162
60
  const drawerRef = useRef(null);
163
- const loginDrawerRef = useRef(null);
164
- const loginGroups = useMemo(() => getLoginGroups(resolveUrl), [resolveUrl]);
165
- const currentLevel = stack[stack.length - 1];
166
- const prevLevel = stack[stack.length - 2];
61
+ const loginRef = useRef(null);
62
+ useClickAway(drawerRef, () => {
63
+ dispatch({ type: MenuActions.SET_MOBILE_MENU_CLOSED, payload: {} });
64
+ });
65
+ useClickAway(loginRef, () => {
66
+ dispatch({ type: MenuActions.SET_LOGIN_MENU_CLOSED, payload: {} });
67
+ });
68
+ const [queryString, setQueryString] = useState("");
69
+ const [stack, dispatch] = useReducer(reducer, initialState);
70
+ useEffect(() => {
71
+ const menuProcessed = mobileData(menu);
72
+ dispatch({
73
+ type: MenuActions.INIT,
74
+ payload: {
75
+ currentMenuData: menuProcessed,
76
+ stack: [{ title: "Menu", items: menuProcessed }],
77
+ quickLinks: menu?.quickLinks
78
+ }
79
+ });
80
+ }, [menu]);
167
81
  useEffect(() => {
168
82
  if (!pathname) return;
169
- const pathnameParts = "/" + pathname.split("/")[1];
170
- const links = getQuickLinks(pathnameParts, resolveUrl);
171
- setQuickLinks(links);
172
- }, [pathname, resolveUrl]);
83
+ }, [pathname]);
173
84
  useEffect(() => {
174
- if (typeof window !== "undefined") {
175
- const search = window.location.search;
85
+ if (typeof search !== "undefined") {
176
86
  if (search.startsWith("?")) {
177
87
  setQueryString(search.slice(1));
178
88
  }
179
89
  }
180
- }, []);
90
+ }, [search]);
181
91
  const handleClick = (key) => {
182
- const item = currentLevel.items[key];
183
- if (typeof item === "object") {
184
- setDirection("forward");
185
- setStack((prev) => [...prev, { title: key, items: item }]);
186
- }
92
+ dispatch({ type: MenuActions.ADD_TO_STACK, payload: key });
187
93
  };
188
94
  const handleBack = () => {
189
- if (stack.length > 1) {
190
- setDirection("backward");
191
- setStack((prev) => prev.slice(0, -1));
95
+ if (stack.stack.length > 1) {
96
+ dispatch({ type: MenuActions.REMOVE_FROM_STACK, payload: {} });
192
97
  }
193
98
  };
194
99
  const handleToggle = () => {
195
- setOpen((prev) => {
196
- const isOpening = !prev;
197
- if (isOpening && !hasOpenedOnce) {
198
- setHasOpenedOnce(true);
199
- setStack([{ title: "Menu", items: menuData }]);
200
- }
201
- return isOpening;
202
- });
100
+ dispatch({ type: MenuActions.SET_HAS_OPENED_ONCE, payload: {} });
101
+ dispatch({ type: MenuActions.SET_MOBILE_MENU_OPEN, payload: {} });
203
102
  };
204
- const handleLoginDrawerOpen = () => setLoginDrawerOpen(true);
205
- const handleLoginDrawerClose = () => setLoginDrawerOpen(false);
206
- const handleLoginDrawerOutsideClick = (e) => {
207
- if (loginDrawerRef.current && !loginDrawerRef.current.contains(e.target)) {
208
- setLoginDrawerOpen(false);
209
- }
103
+ const handleLoginDrawerOpen = () => {
104
+ dispatch({ type: MenuActions.SET_LOGIN_MENU_OPEN, payload: {} });
210
105
  };
211
- const handleOutsideClick = (e) => {
212
- if (drawerRef.current && !drawerRef.current.contains(e.target)) {
213
- setOpen(false);
214
- }
106
+ const handleLoginDrawerClose = () => {
107
+ dispatch({ type: MenuActions.SET_LOGIN_MENU_CLOSED, payload: {} });
215
108
  };
216
- useEffect(() => {
217
- if (open) {
218
- document.addEventListener("mousedown", handleOutsideClick);
219
- } else {
220
- document.removeEventListener("mousedown", handleOutsideClick);
221
- }
222
- return () => document.removeEventListener("mousedown", handleOutsideClick);
223
- }, [open]);
224
109
  useEffect(() => {
225
110
  const onEsc = (e) => {
226
- if (e.key === "Escape") setOpen(false);
111
+ if (e.key === "Escape")
112
+ dispatch({ type: MenuActions.SET_MOBILE_MENU_CLOSED, payload: {} });
227
113
  };
228
- if (open) {
114
+ if (stack.isMobileMenuOpen) {
229
115
  document.addEventListener("keydown", onEsc);
230
116
  }
231
117
  return () => document.removeEventListener("keydown", onEsc);
232
- }, [open]);
233
- useEffect(() => {
234
- if (!loginDrawerOpen) return;
235
- document.addEventListener("mousedown", handleLoginDrawerOutsideClick);
236
- return () => document.removeEventListener("mousedown", handleLoginDrawerOutsideClick);
237
- }, [loginDrawerOpen]);
238
- useEffect(() => {
239
- const onEsc = (e) => {
240
- if (e.key === "Escape") setLoginDrawerOpen(false);
241
- };
242
- if (loginDrawerOpen) {
243
- document.addEventListener("keydown", onEsc);
244
- }
245
- return () => document.removeEventListener("keydown", onEsc);
246
- }, [loginDrawerOpen]);
118
+ }, [stack.isMobileMenuOpen]);
247
119
  return /* @__PURE__ */ jsxs(Fragment, { children: [
248
120
  /* @__PURE__ */ jsxs("div", { className: styles.mobileNavRow, children: [
249
121
  /* @__PURE__ */ jsx(
@@ -285,7 +157,7 @@ const MobileDrawerMenu = () => {
285
157
  }
286
158
  )
287
159
  ] }),
288
- /* @__PURE__ */ jsx(AnimatePresence, { children: open && /* @__PURE__ */ jsx(
160
+ /* @__PURE__ */ jsx(AnimatePresence, { children: stack.isMobileMenuOpen && /* @__PURE__ */ jsx(
289
161
  motion.div,
290
162
  {
291
163
  className: styles.overlay,
@@ -308,7 +180,7 @@ const MobileDrawerMenu = () => {
308
180
  children: [
309
181
  /* @__PURE__ */ jsx("p", { id: "menu-description", className: styles.sr_only, children: "Use tab to navigate this menu. Press Escape to close." }),
310
182
  /* @__PURE__ */ jsxs("div", { className: styles.header, children: [
311
- stack.length > 1 ? /* @__PURE__ */ jsxs(
183
+ stack.stack?.length > 1 ? /* @__PURE__ */ jsxs(
312
184
  "button",
313
185
  {
314
186
  onClick: handleBack,
@@ -333,13 +205,13 @@ const MobileDrawerMenu = () => {
333
205
  )
334
206
  }
335
207
  ),
336
- /* @__PURE__ */ jsx("span", { className: styles.prevlevel, children: prevLevel.title })
208
+ /* @__PURE__ */ jsx("span", { className: styles.prevlevel, children: stack.prevLevel?.title })
337
209
  ]
338
210
  }
339
211
  ) : /* @__PURE__ */ jsx(
340
212
  "a",
341
213
  {
342
- href: window.location.href.split("/")[3] === "invest" ? "/invest" : "/",
214
+ href: pathname.includes("/invest") ? "/invest" : "/",
343
215
  "aria-label": "return to home page",
344
216
  children: /* @__PURE__ */ jsx(
345
217
  "img",
@@ -386,7 +258,7 @@ const MobileDrawerMenu = () => {
386
258
  className: `${styles.level} flex middle`,
387
259
  "aria-label": "current menu level",
388
260
  children: [
389
- /* @__PURE__ */ jsx("h2", { className: styles.levelTitle, id: "menu-level", children: currentLevel.title }),
261
+ /* @__PURE__ */ jsx("h2", { className: styles.levelTitle, id: "menu-level", children: stack.currentMenuData?.title }),
390
262
  /* @__PURE__ */ jsx(
391
263
  "svg",
392
264
  {
@@ -411,75 +283,81 @@ const MobileDrawerMenu = () => {
411
283
  /* @__PURE__ */ jsx("nav", { "aria-label": "main navigation menu", children: /* @__PURE__ */ jsx(
412
284
  AnimatePresence,
413
285
  {
414
- custom: direction,
286
+ custom: stack.direction,
415
287
  mode: "sync",
416
288
  initial: false,
417
- children: /* @__PURE__ */ jsx(
289
+ children: /* @__PURE__ */ jsxs(
418
290
  motion.ul,
419
291
  {
420
292
  className: styles.menu,
421
- custom: direction,
293
+ custom: stack.direction,
422
294
  variants: slideVariants,
423
295
  initial: "enter",
424
296
  animate: "center",
425
297
  exit: "exit",
426
298
  transition: { duration: 0.3, ease: "linear" },
427
- children: Object.entries(
428
- stack.length === 1 ? Object.fromEntries(
429
- Object.entries(currentLevel.items).filter(
430
- ([k]) => k !== "Log in"
431
- )
432
- ) : currentLevel.items
433
- ).map(([key, value]) => {
434
- const hasChildren = typeof value === "object";
435
- return /* @__PURE__ */ jsx("li", { children: hasChildren ? /* @__PURE__ */ jsxs(
436
- "button",
437
- {
438
- className: styles.menuItem,
439
- onClick: () => handleClick(key),
440
- "aria-label": `open submenu for ${key}`,
441
- children: [
442
- /* @__PURE__ */ jsx("span", { children: key }),
443
- /* @__PURE__ */ jsx("span", { className: styles.chevron, children: /* @__PURE__ */ jsx(
444
- "svg",
445
- {
446
- className: styles.chevronIcon,
447
- width: 12,
448
- height: 20,
449
- viewBox: "0 0 12 20",
450
- fill: "none",
451
- xmlns: "http://www.w3.org/2000/svg",
452
- children: /* @__PURE__ */ jsx(
453
- "path",
454
- {
455
- d: "M1.76378 0.46875L11.2941 9.99908L1.76378 19.5294L0.703125 18.4687L9.17295 9.99908L0.703125 1.52941L1.76378 0.46875Z",
456
- fill: "#4A5560"
457
- }
458
- )
459
- }
460
- ) })
461
- ]
462
- }
463
- ) : /* @__PURE__ */ jsx(
299
+ children: [
300
+ stack.stack.length > 1 && !stack.currentMenuData?.dropdown && /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
464
301
  Link,
465
302
  {
466
- href: `${value}${queryString && !value.includes("?") ? `?${queryString}` : ""}`,
303
+ href: resolveUrl(stack.currentMenuData.url) + (queryString && !stack.currentMenuData.url.includes("?") ? `?${queryString}` : ""),
467
304
  className: styles.menuItem,
468
- children: /* @__PURE__ */ jsx("span", { children: key })
305
+ children: /* @__PURE__ */ jsxs("span", { children: [
306
+ stack.currentMenuData.title,
307
+ " Home"
308
+ ] })
469
309
  }
470
- ) }, key);
471
- })
310
+ ) }),
311
+ stack?.currentMenuData?.items?.map((item) => {
312
+ const hasChildren = item.items && item.items.length > 0;
313
+ return hasChildren ? /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsxs(
314
+ "button",
315
+ {
316
+ className: styles.menuItem,
317
+ onClick: () => handleClick(item),
318
+ children: [
319
+ /* @__PURE__ */ jsx("span", { children: item.label }),
320
+ /* @__PURE__ */ jsx("span", { className: styles.chevron, children: /* @__PURE__ */ jsx(
321
+ "svg",
322
+ {
323
+ className: styles.chevronIcon,
324
+ width: 12,
325
+ height: 20,
326
+ viewBox: "0 0 12 20",
327
+ fill: "none",
328
+ xmlns: "http://www.w3.org/2000/svg",
329
+ children: /* @__PURE__ */ jsx(
330
+ "path",
331
+ {
332
+ d: "M1.76378 0.46875L11.2941 9.99908L1.76378 19.5294L0.703125 18.4687L9.17295 9.99908L0.703125 1.52941L1.76378 0.46875Z",
333
+ fill: "#4A5560"
334
+ }
335
+ )
336
+ }
337
+ ) })
338
+ ]
339
+ }
340
+ ) }, item.id + "1") : /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
341
+ Link,
342
+ {
343
+ href: resolveUrl(item?.url) + (queryString && !item?.url?.includes("?") ? `?${queryString}` : ""),
344
+ className: styles.menuItem,
345
+ children: /* @__PURE__ */ jsx("span", { children: item.label })
346
+ }
347
+ ) }, item.id);
348
+ })
349
+ ]
472
350
  },
473
- currentLevel.title
351
+ stack.currentMenuData?.title
474
352
  )
475
353
  }
476
354
  ) }),
477
- /* @__PURE__ */ jsx("div", { className: `${styles.quickLinks} flex middle between`, children: quickLinks.map((link) => /* @__PURE__ */ jsxs(
355
+ /* @__PURE__ */ jsx("div", { className: `${styles.quickLinks} flex middle between`, children: stack.quickLinks?.map((link) => /* @__PURE__ */ jsxs(
478
356
  "a",
479
357
  {
480
- href: link.url + (queryString && !link.url.includes("?") ? `?${queryString}` : ""),
358
+ href: resolveUrl(link.url) + (queryString && !link.url.includes("?") ? `?${queryString}` : ""),
481
359
  className: `${styles.quickLink} flex_col middle`,
482
- "aria-label": `Visit ${link.title} page`,
360
+ "aria-label": link.ariaLabel,
483
361
  children: [
484
362
  /* @__PURE__ */ jsx(
485
363
  "img",
@@ -491,10 +369,10 @@ const MobileDrawerMenu = () => {
491
369
  loading: "lazy"
492
370
  }
493
371
  ),
494
- /* @__PURE__ */ jsx("span", { children: link.title })
372
+ /* @__PURE__ */ jsx("span", { children: link.label })
495
373
  ]
496
374
  },
497
- link.title
375
+ link.id
498
376
  )) })
499
377
  ] }) })
500
378
  ]
@@ -502,7 +380,7 @@ const MobileDrawerMenu = () => {
502
380
  )
503
381
  }
504
382
  ) }),
505
- /* @__PURE__ */ jsx(AnimatePresence, { children: loginDrawerOpen && /* @__PURE__ */ jsx(
383
+ /* @__PURE__ */ jsx(AnimatePresence, { children: stack.loginDrawer && /* @__PURE__ */ jsx(
506
384
  motion.div,
507
385
  {
508
386
  className: styles.overlay,
@@ -513,7 +391,7 @@ const MobileDrawerMenu = () => {
513
391
  motion.div,
514
392
  {
515
393
  className: `${styles.drawer} flex_col`,
516
- ref: loginDrawerRef,
394
+ ref: loginRef,
517
395
  initial: { x: "100%" },
518
396
  animate: { x: 0 },
519
397
  exit: { x: "100%" },
@@ -526,7 +404,7 @@ const MobileDrawerMenu = () => {
526
404
  /* @__PURE__ */ jsx(
527
405
  "a",
528
406
  {
529
- href: window.location.href.split("/")[3] === "invest" ? "/invest" : "/",
407
+ href: pathname.includes("/invest") ? "/invest" : "/",
530
408
  "aria-label": "return to home page",
531
409
  children: /* @__PURE__ */ jsx(
532
410
  "img",
@@ -568,37 +446,74 @@ const MobileDrawerMenu = () => {
568
446
  }
569
447
  )
570
448
  ] }),
571
- /* @__PURE__ */ jsx("div", { className: styles.loginDrawerContent, children: /* @__PURE__ */ jsx("div", { className: styles.loginAccordion, children: /* @__PURE__ */ jsx(
449
+ /* @__PURE__ */ jsx("div", { className: styles.loginDrawerContent, children: /* @__PURE__ */ jsx("div", { className: styles.loginAccordion, children: /* @__PURE__ */ jsxs(
572
450
  "ul",
573
451
  {
574
452
  className: styles.loginAccordionList,
575
453
  "aria-label": "Login options",
576
- children: loginGroups.map((group) => /* @__PURE__ */ jsxs(
577
- "li",
578
- {
579
- className: styles.loginAccordionGroup,
580
- "aria-label": `${group.heading} login options`,
581
- children: [
582
- /* @__PURE__ */ jsx("span", { className: styles.loginAccordionHeading, children: group.heading }),
583
- /* @__PURE__ */ jsx("ul", { className: styles.loginAccordionGroupList, children: group.items.map((item) => /* @__PURE__ */ jsx(
584
- "li",
585
- {
586
- "aria-label": `access ${item.title}`,
587
- children: /* @__PURE__ */ jsx(
588
- Link,
454
+ children: [
455
+ stack.loginData?.items?.filter((item) => item.items)?.map((group) => {
456
+ return /* @__PURE__ */ jsxs(
457
+ "li",
458
+ {
459
+ className: styles.loginAccordionGroup,
460
+ "aria-label": `${group?.label} login options`,
461
+ children: [
462
+ /* @__PURE__ */ jsx("span", { className: styles.loginAccordionHeading, children: group.label }),
463
+ /* @__PURE__ */ jsx("ul", { className: styles.loginAccordionGroupList, children: group.items?.map((item) => /* @__PURE__ */ jsx(
464
+ "li",
589
465
  {
590
- href: item.url + (queryString && !item.url.includes("?") ? `?${queryString}` : ""),
591
- className: styles.menuItem,
592
- children: /* @__PURE__ */ jsx("span", { children: item.title })
593
- }
594
- )
595
- },
596
- item.title
597
- )) })
598
- ]
599
- },
600
- group.heading
601
- ))
466
+ "aria-label": `access ${item.label}`,
467
+ children: /* @__PURE__ */ jsx(
468
+ "a",
469
+ {
470
+ href: item.url + (queryString && !item.url.includes("?") ? `?${queryString}` : ""),
471
+ className: styles.menuItem,
472
+ children: /* @__PURE__ */ jsx("span", { children: item.label })
473
+ }
474
+ )
475
+ },
476
+ item.id
477
+ )) })
478
+ ]
479
+ },
480
+ group?.id
481
+ );
482
+ }),
483
+ /* @__PURE__ */ jsxs(
484
+ "li",
485
+ {
486
+ className: styles.loginAccordionGroup,
487
+ children: [
488
+ /* @__PURE__ */ jsx("span", { className: styles.loginAccordionHeading }),
489
+ stack.loginData?.items.filter((item) => !item.items).map((group) => {
490
+ return /* @__PURE__ */ jsx(
491
+ "ul",
492
+ {
493
+ className: styles.loginAccordionGroupList,
494
+ children: /* @__PURE__ */ jsx(
495
+ "li",
496
+ {
497
+ "aria-label": `access ${group.label}`,
498
+ children: /* @__PURE__ */ jsx(
499
+ "a",
500
+ {
501
+ href: group.url + (queryString && !group.url.includes("?") ? `?${queryString}` : ""),
502
+ className: styles.menuItem,
503
+ children: /* @__PURE__ */ jsx("span", { children: group.label })
504
+ }
505
+ )
506
+ },
507
+ group.id
508
+ )
509
+ },
510
+ group.id
511
+ );
512
+ })
513
+ ]
514
+ }
515
+ )
516
+ ]
602
517
  }
603
518
  ) }) })
604
519
  ]