@axos-web-dev/shared-components 2.0.0-dev.1 → 2.0.0-dev.2-nav-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 (192) hide show
  1. package/dist/ATMLocator/ATMLocator.js +5 -9
  2. package/dist/Accordion/Accordion.js +3 -3
  3. package/dist/AlertBanner/index.js +1 -1
  4. package/dist/Article/Article.d.ts +2 -2
  5. package/dist/Article/Article.js +14 -3
  6. package/dist/Auth/ErrorAlert.js +6 -10
  7. package/dist/Auth/SignInPassword.js +0 -1
  8. package/dist/BulletItem/BulletItem.js +0 -1
  9. package/dist/Button/Button.js +5 -10
  10. package/dist/Calculators/AnnualFeeCalculator/index.js +1 -2
  11. package/dist/Calculators/ApyCalculator/index.js +4 -2
  12. package/dist/Calculators/AxosOneCalculator/index.js +16 -9
  13. package/dist/Calculators/BalanceAPYCalculator/index.js +0 -1
  14. package/dist/Calculators/BuyDownCalculator/index.js +1 -2
  15. package/dist/Calculators/Calculator.js +2 -6
  16. package/dist/Calculators/MarginTradingCalculator/index.js +121 -3
  17. package/dist/Calculators/MarineLoanMonthlyPaymentCalculator/index.js +1 -2
  18. package/dist/Calculators/MaxLoanCalculator/index.js +1 -2
  19. package/dist/Calculators/MonthlyPaymentCalculator/index.js +1 -2
  20. package/dist/Calculators/MonthlyPaymentLVFCalculator/index.js +1 -2
  21. package/dist/Calculators/SummitApyCalculator/index.js +3 -2
  22. package/dist/Carousel/index.js +6 -10
  23. package/dist/Chatbot/Bubble.js +1 -1
  24. package/dist/Chatbot/Chat.js +0 -7
  25. package/dist/Chatbot/ChatWindow.d.ts +2 -0
  26. package/dist/Chatbot/ChatWindow.js +27 -14
  27. package/dist/Chatbot/Chatbot.d.ts +1 -1
  28. package/dist/Chatbot/Chatbot.js +118 -13
  29. package/dist/Chatbot/ChatbotMessage.d.ts +1 -0
  30. package/dist/Chatbot/ChatbotMessage.js +42 -22
  31. package/dist/Chatbot/store/chat.d.ts +6 -0
  32. package/dist/Chatbot/store/chat.js +14 -2
  33. package/dist/Chatbot/store/messages.d.ts +1 -0
  34. package/dist/Chatbot/store/messages.js +5 -2
  35. package/dist/Chevron/index.js +4 -9
  36. package/dist/Comparison/Comparison.js +5 -9
  37. package/dist/ContentBanner/index.js +1 -1
  38. package/dist/ExecutiveBio/ExecutiveBio.css.d.ts +51 -1
  39. package/dist/ExecutiveBio/ExecutiveBio.css.js +48 -46
  40. package/dist/ExecutiveBio/ExecutiveBio.d.ts +1 -1
  41. package/dist/ExecutiveBio/ExecutiveBio.interface.d.ts +3 -1
  42. package/dist/ExecutiveBio/ExecutiveBio.js +144 -152
  43. package/dist/ExecutiveBio/ExecutiveBioSet.d.ts +1 -2
  44. package/dist/ExecutiveBio/ExecutiveBioSet.js +30 -17
  45. package/dist/ExecutiveBio/index.js +2 -1
  46. package/dist/FaqAccordion/index.js +6 -10
  47. package/dist/FooterDisclosure/FooterDisclosure.js +1 -1
  48. package/dist/FooterSiteMap/AxosBank/FooterSiteMap.js +85 -185
  49. package/dist/Forms/ApplicationStart.js +0 -1
  50. package/dist/Forms/ApplyNow.js +3 -7
  51. package/dist/Forms/BoatMooringLocation.js +0 -1
  52. package/dist/Forms/ClearingForm.js +0 -1
  53. package/dist/Forms/CommercialDeposits.js +0 -1
  54. package/dist/Forms/CommercialDepositsNoLendingOption.js +0 -1
  55. package/dist/Forms/CommercialLending.js +0 -1
  56. package/dist/Forms/CommercialPremiumFinance.js +0 -1
  57. package/dist/Forms/ConstructionLendingDynamic.d.ts +12 -0
  58. package/dist/Forms/ConstructionLendingDynamic.js +324 -0
  59. package/dist/Forms/ContactCompany.js +0 -1
  60. package/dist/Forms/ContactCompanyTitle.js +0 -1
  61. package/dist/Forms/ContactUs.js +0 -1
  62. package/dist/Forms/ContactUsAAS.js +0 -1
  63. package/dist/Forms/ContactUsBusiness.js +5 -9
  64. package/dist/Forms/ContactUsBusinessNameEmail.js +5 -9
  65. package/dist/Forms/ContactUsLVF.js +0 -1
  66. package/dist/Forms/ContactUsNMLSId.js +5 -9
  67. package/dist/Forms/CpraRequest.js +101 -3
  68. package/dist/Forms/CraPublicFile.js +5 -9
  69. package/dist/Forms/DealerServices.js +0 -1
  70. package/dist/Forms/EmailOnly.js +12 -11
  71. package/dist/Forms/EmailUs.js +0 -1
  72. package/dist/Forms/FormEnums.js +1 -3
  73. package/dist/Forms/Forms.css.d.ts +1 -1
  74. package/dist/Forms/Forms.css.js +3 -3
  75. package/dist/Forms/HoneyPot/index.js +0 -1
  76. package/dist/Forms/MortgageRate/MortgageRateForm.js +7 -11
  77. package/dist/Forms/MortgageRate/MortgageRateWatch.js +5 -9
  78. package/dist/Forms/MortgageWarehouseLending.js +5 -9
  79. package/dist/Forms/QuickPricer/QuickPricerForm.js +0 -1
  80. package/dist/Forms/ScheduleCall.js +0 -1
  81. package/dist/Forms/ScheduleCallPremier.js +0 -1
  82. package/dist/Forms/SuccesForm.js +5 -9
  83. package/dist/Forms/VendorQuestionnaire.js +0 -1
  84. package/dist/Forms/index.d.ts +1 -0
  85. package/dist/Forms/index.js +2 -1
  86. package/dist/HeroBanner/HeroBanner.js +2 -2
  87. package/dist/Hyperlink/index.js +8 -11
  88. package/dist/IconBillboard/IconBillboard.css.d.ts +1 -0
  89. package/dist/IconBillboard/IconBillboard.css.js +11 -9
  90. package/dist/IconBillboard/IconBillboardSet.js +1 -1
  91. package/dist/IconBillboard/index.js +2 -1
  92. package/dist/ImageBillboard/ImageBillboard.js +1 -1
  93. package/dist/ImageBillboard/ImageBillboardSet.js +14 -8
  94. package/dist/ImageLink/ImageLink.js +5 -9
  95. package/dist/ImageLink/ImageLinkSet.js +5 -9
  96. package/dist/ImageLink/index.js +3 -7
  97. package/dist/Input/Checkbox.js +2 -2
  98. package/dist/Input/DownPaymentInput.js +1 -1
  99. package/dist/Input/Dropdown.js +1 -1
  100. package/dist/Input/Input.js +1 -1
  101. package/dist/Input/InputTextArea.js +1 -1
  102. package/dist/Insight/Featured/CategorySelector.js +3 -7
  103. package/dist/Insight/Featured/Featured.js +7 -11
  104. package/dist/Insight/Featured/Header.js +5 -9
  105. package/dist/LandingPageHeader/LandingPageHeader.css.d.ts +19 -1
  106. package/dist/LandingPageHeader/LandingPageHeader.css.js +6 -6
  107. package/dist/LandingPageHeader/LandingPageHeader.d.ts +3 -1
  108. package/dist/LandingPageHeader/LandingPageHeader.js +42 -16
  109. package/dist/LoadingIndicator/index.js +0 -1
  110. package/dist/Modal/Modal.js +3 -7
  111. package/dist/Modal/contextApi/store.d.ts +16 -2
  112. package/dist/Modal/contextApi/store.js +37 -6
  113. package/dist/NavigationMenu/AxosALTS/NavData.d.ts +7 -1
  114. package/dist/NavigationMenu/AxosALTS/NavData.js +6 -137
  115. package/dist/NavigationMenu/AxosALTS/index.js +12 -13
  116. package/dist/NavigationMenu/AxosAdvisor/SubNavBar.js +0 -1
  117. package/dist/NavigationMenu/AxosAdvisor/index.js +0 -1
  118. package/dist/NavigationMenu/AxosAdvisorServices/SubNavBar.js +0 -1
  119. package/dist/NavigationMenu/AxosAdvisorServices/index.js +0 -1
  120. package/dist/NavigationMenu/AxosBank/DropwdownButton.d.ts +7 -0
  121. package/dist/NavigationMenu/AxosBank/DropwdownButton.js +239 -0
  122. package/dist/NavigationMenu/AxosBank/Menu.d.ts +37 -0
  123. package/dist/NavigationMenu/AxosBank/Menu.js +254 -0
  124. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileMenu.d.ts +12 -1
  125. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileMenu.js +389 -101
  126. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileMenu.module.js +50 -17
  127. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileNavData.d.ts +44 -261
  128. package/dist/NavigationMenu/AxosBank/MobileMenu/MobileNavData.js +61 -636
  129. package/dist/NavigationMenu/AxosBank/MobileMenu/mobileReducer.d.ts +36 -0
  130. package/dist/NavigationMenu/AxosBank/MobileMenu/mobileReducer.js +105 -0
  131. package/dist/NavigationMenu/AxosBank/NavBar.module.js +42 -39
  132. package/dist/NavigationMenu/AxosBank/NavData.d.ts +39 -2
  133. package/dist/NavigationMenu/AxosBank/NavData.js +34 -166
  134. package/dist/NavigationMenu/AxosBank/SubNavBar.d.ts +6 -1
  135. package/dist/NavigationMenu/AxosBank/SubNavBar.js +117 -3102
  136. package/dist/NavigationMenu/AxosBank/SubNavItem.d.ts +1 -0
  137. package/dist/NavigationMenu/AxosBank/SubNavItem.js +313 -0
  138. package/dist/NavigationMenu/AxosBank/index.d.ts +6 -4
  139. package/dist/NavigationMenu/AxosBank/index.js +87 -392
  140. package/dist/NavigationMenu/AxosClearing/index.js +0 -1
  141. package/dist/NavigationMenu/LaVictoire/NavData.d.ts +13 -2
  142. package/dist/NavigationMenu/LaVictoire/NavData.js +14 -146
  143. package/dist/NavigationMenu/LaVictoire/SubNavBar.js +4 -1
  144. package/dist/NavigationMenu/LaVictoire/index.js +18 -42
  145. package/dist/NavigationMenu/Navbar.d.ts +4 -1
  146. package/dist/NavigationMenu/Navbar.js +11 -11
  147. package/dist/NavigationMenu/SignInNavButton.js +18 -25
  148. package/dist/NavigationMenu/utils.d.ts +465 -0
  149. package/dist/NavigationMenu/utils.js +112 -0
  150. package/dist/PageNavItem/PageNavItem.js +1 -1
  151. package/dist/SetContainer/SetContainer.js +7 -11
  152. package/dist/SocialMediaBar/iconsRepository.d.ts +44 -14
  153. package/dist/SocialMediaBar/iconsRepository.js +30 -38
  154. package/dist/SocialMediaBar/index.js +3 -1
  155. package/dist/StepItem/StepItem.js +1 -1
  156. package/dist/StepItemSet/StepItemSet.js +1 -1
  157. package/dist/Tab/Tab.js +0 -1
  158. package/dist/Table/Table.js +1 -2
  159. package/dist/Topic/Topic.js +1 -1
  160. package/dist/VideoTile/VideoTile.js +2 -6
  161. package/dist/VideoWrapper/index.js +2 -6
  162. package/dist/assets/Calculators/ApyCalculator/ApyCalculator.css +1 -1
  163. package/dist/assets/Calculators/MarginTradingCalculator/MarginTradingCalculator.css +2 -2
  164. package/dist/assets/Calculators/SummitApyCalculator/BalanceAPYCalculator.css +1 -1
  165. package/dist/assets/Carousel/Carousel.css +1 -1
  166. package/dist/assets/Chatbot/AnimatedGradientBorder.css +2 -1
  167. package/dist/assets/Chatbot/ChatWindow.css +16 -8
  168. package/dist/assets/DownloadTile/DownloadTile.css +2 -2
  169. package/dist/assets/ExecutiveBio/ExecutiveBio.css +281 -171
  170. package/dist/assets/Forms/Forms.css +29 -25
  171. package/dist/assets/HelpArticle/HelpArticle.css +2 -2
  172. package/dist/assets/IconBillboard/IconBillboard.css +35 -28
  173. package/dist/assets/Inputs/Input.css +1 -1
  174. package/dist/assets/Insight/Featured/CategorySelector.css +1 -1
  175. package/dist/assets/Insight/Insight.css +4 -4
  176. package/dist/assets/LandingPageHeader/LandingPageHeader.css +28 -15
  177. package/dist/assets/NavigationMenu/AxosBank/MobileMenu/MobileMenu.css +191 -30
  178. package/dist/assets/NavigationMenu/AxosBank/NavBar.css +125 -87
  179. package/dist/assets/Topic/Topic.css +1 -1
  180. package/dist/assets/Typography/Typography.css +1 -1
  181. package/dist/assets/VideoTile/VideoTile.css +1 -1
  182. package/dist/assets/globals.css +24 -14
  183. package/dist/main.js +8 -3
  184. package/dist/utils/allowedAxosDomains.d.ts +5 -2
  185. package/dist/utils/allowedAxosDomains.js +50 -47
  186. package/dist/utils/appendQueryParams.js +36 -5
  187. package/dist/utils/index.js +2 -1
  188. package/dist/utils/validateExternalLinks.d.ts +1 -1
  189. package/dist/utils/validateExternalLinks.js +4 -6
  190. package/package.json +1 -1
  191. package/dist/NavigationMenu/NavDataJson.d.ts +0 -2
  192. package/dist/NavigationMenu/NavDataJson.js +0 -317
@@ -1,11 +1,135 @@
1
1
  "use client";
2
2
  import { jsxs, Fragment, jsx } from "react/jsx-runtime";
3
- import { useState, useRef, useEffect } from "react";
3
+ import "../../../Chevron/Chevron.css.js";
4
+ import "../../../Accordion/Accordion.js";
5
+ import "../../../Accordion/Accordion.css.js";
6
+ import "../../../icons/ArrowIcon/ArrowIcon.css.js";
7
+ import "../../../icons/CheckIcon/CheckIcon.css.js";
8
+ 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/Chatbot.css';import '../../../assets/Chatbot/Bubble.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 */
9
+ /* empty css */
10
+ /* empty css */
11
+ /* empty css */
12
+ /* empty css */
13
+ /* empty css */
14
+ import "clsx";
15
+ import { useRef, useReducer, useState, useEffect } from "react";
16
+ import "../../../AlertBanner/AlertBanner.css.js";
17
+ import "../../../Article/Article.css.js";
18
+ import "../../../IconBillboard/IconBillboard.css.js";
19
+ /* empty css */
20
+ /* empty css */
21
+ import "../../../Interstitial/Interstitial-variants.css.js";
22
+ import "../../../Button/Button.css.js";
23
+ import { useClickAway } from "react-use";
24
+ import "../../../ArticlesSet/ArticlesSet.css.js";
25
+ import "../../../Calculators/calculator.css.js";
26
+ import "../../../Calculators/AnnualFeeCalculator/AnnualFeeCalculator.css.js";
27
+ import { useGlobalContext } from "../../../Modal/contextApi/store.js";
28
+ import "../../../Calculators/ApyCalculator/ApyCalculator.css.js";
29
+ import "../../../Table/Table.css.js";
30
+ import "../../../Calculators/AxosOneCalculator/BalanceAPYCalculator.css.js";
31
+ import "../../../Calculators/BalanceAPYCalculator/BalanceAPYCalculator.css.js";
32
+ import "@hookform/resolvers/zod";
33
+ import "../../../Input/Checkbox.js";
34
+ import "../../../Input/CurrencyInput.js";
35
+ import "../../../Input/Dropdown.js";
36
+ import "../../../Input/Dropdown.css.js";
37
+ import "../../../Input/Input.js";
38
+ import "../../../Input/Input.css.js";
39
+ import "../../../Input/InputAmount.js";
40
+ import "../../../Input/InputPhone.js";
41
+ import "../../../Input/InputTextArea.js";
42
+ import "../../../Input/DownPaymentInput.js";
43
+ import "../../../Input/RadioButton.js";
44
+ import "../../../Input/PercentageInput.js";
45
+ import "react-hook-form";
46
+ import "../../../Calculators/BuyDownCalculator/BuyDownCalculator.css.js";
47
+ import "../../../Forms/Forms.css.js";
48
+ import "../../../Forms/HoneyPot/index.js";
49
+ import "../../../Forms/SalesforceFieldsForm.js";
50
+ import "../../../Input/RadioButton.css.js";
51
+ import "../../../Input/Checkbox.css.js";
52
+ import "../../../LoadingIndicator/LoadingIndicator.css.js";
53
+ import "../../../Inputs/Input.css.js";
54
+ /* empty css */
55
+ import "../../../Hyperlink/Hyperlink.css.js";
56
+ /* empty css */
57
+ import "iframe-resizer";
58
+ /* empty css */
59
+ import "../../../Calculators/MonthlyPaymentCalculator/MonthlyPaymentCalculator.css.js";
60
+ import "../../../Calculators/MonthlyPaymentLVFCalculator/MonthlyPaymentCalculator.css.js";
61
+ import "../../../Calculators/SummitApyCalculator/BalanceAPYCalculator.css.js";
62
+ /* empty css */
63
+ import "react-dom";
64
+ /* empty css */
65
+ import "../../../Auth/SignInPassword.js";
66
+ /* empty css */
67
+ /* empty css */
68
+ /* empty css */
69
+ /* empty css */
70
+ import "../../../Carousel/index.js";
4
71
  import { AnimatePresence, motion } from "framer-motion";
72
+ /* empty css */
73
+ /* empty css */
74
+ import "../../../Chatbot/store/chat.js";
75
+ import "../../../Chatbot/authenticate.js";
76
+ /* empty css */
77
+ /* empty css */
78
+ import "../../../Chatbot/store/messages.js";
79
+ /* empty css */
80
+ import "../../../Comparison/Comparison.css.js";
81
+ import "next/image.js";
82
+ import "../../../HeroBanner/HeroBanner.css.js";
83
+ import "../../../HeroBanner/LargeBanner.css.js";
84
+ import "../../../HeroBanner/SelectionBanner.css.js";
85
+ import "../../../SetContainer/SetContainer.css.js";
86
+ import "../../../Tab/Tab.css.js";
87
+ import "../../../icons/Star/Star.css.js";
88
+ import "../../../ContentBanner/ContentBanner.css.js";
89
+ /* empty css */
90
+ import "../../../ExecutiveBio/ExecutiveBio.css.js";
91
+ import "../../../FaqAccordion/index.js";
92
+ import "../../../FooterDisclosure/FooterDisclosure.css.js";
93
+ /* empty css */
94
+ /* empty css */
95
+ /* empty css */
96
+ import "../../../ImageBillboard/ImageBillboard.css.js";
97
+ import "next/script.js";
98
+ /* empty css */
99
+ /* empty css */
100
+ /* empty css */
101
+ /* empty css */
102
+ /* empty css */
103
+ import "../../../LandingPageHeader/LandingPageHeader.css.js";
104
+ /* empty css */
5
105
  import { usePathname } from "next/navigation.js";
106
+ /* empty css */
107
+ /* empty css */
108
+ /* empty css */
109
+ /* empty css */
110
+ import "../Menu.js";
111
+ /* empty css */
112
+ /* empty css */
113
+ /* empty css */
114
+ /* empty css */
6
115
  import Link from "next/link.js";
7
- import { menuData, getQuickLinks } from "./MobileNavData.js";
116
+ import "../../../PageNavItem/PageNavItem.css.js";
117
+ import "react-slick";
118
+ /* empty css */
119
+ /* empty css */
120
+ /* empty css */
121
+ /* empty css */
122
+ import "../../../StepItem/StepItem.css.js";
123
+ import "../../../StepItemSet/StepItemSet.css.js";
124
+ /* empty css */
125
+ /* empty css */
126
+ /* empty css */
127
+ /* empty css */
128
+ /* empty css */
129
+ /* empty css */
8
130
  import styles from "./MobileMenu.module.js";
131
+ import { mobileData } from "./MobileNavData.js";
132
+ import { MenuActions, reducer } from "./mobileReducer.js";
9
133
  const slideVariants = {
10
134
  enter: (direction) => ({
11
135
  x: direction === "forward" ? "100%" : "-100%",
@@ -24,24 +148,42 @@ const slideVariants = {
24
148
  position: "absolute"
25
149
  })
26
150
  };
27
- const MobileDrawerMenu = () => {
151
+ const initialState = {
152
+ direction: "forward",
153
+ isMobileMenuOpen: false,
154
+ hasOpenedOnce: false,
155
+ prevLevel: [],
156
+ currentMenuData: null,
157
+ stack: [],
158
+ loginDrawer: false,
159
+ loginData: {}
160
+ };
161
+ const MobileDrawerMenu = ({ menu }) => {
162
+ const { resolveUrl } = useGlobalContext();
28
163
  const pathname = usePathname();
29
- const [queryString, setQueryString] = useState("");
30
- const [open, setOpen] = useState(false);
31
- const [stack, setStack] = useState([
32
- { title: "Main Menu", items: menuData }
33
- ]);
34
- const [hasOpenedOnce, setHasOpenedOnce] = useState(false);
35
- const [direction, setDirection] = useState("forward");
36
- const [quickLinks, setQuickLinks] = useState([]);
37
164
  const drawerRef = useRef(null);
38
- const currentLevel = stack[stack.length - 1];
39
- const prevLevel = stack[stack.length - 2];
165
+ const loginRef = useRef(null);
166
+ useClickAway(drawerRef, () => {
167
+ dispatch({ type: MenuActions.SET_MOBILE_MENU_CLOSED, payload: {} });
168
+ });
169
+ useClickAway(loginRef, () => {
170
+ dispatch({ type: MenuActions.SET_LOGIN_MENU_CLOSED, payload: {} });
171
+ });
172
+ const [queryString, setQueryString] = useState("");
173
+ const [stack, dispatch] = useReducer(reducer, initialState);
174
+ useEffect(() => {
175
+ const menuProcessed = mobileData(menu);
176
+ dispatch({
177
+ type: MenuActions.INIT,
178
+ payload: {
179
+ currentMenuData: menuProcessed,
180
+ stack: [{ title: "Menu", items: menuProcessed }],
181
+ quickLinks: menu?.quickLinks
182
+ }
183
+ });
184
+ }, [menu]);
40
185
  useEffect(() => {
41
186
  if (!pathname) return;
42
- const pathnameParts = "/" + pathname.split("/")[1];
43
- const links = getQuickLinks(pathnameParts);
44
- setQuickLinks(links);
45
187
  }, [pathname]);
46
188
  useEffect(() => {
47
189
  if (typeof window !== "undefined") {
@@ -52,80 +194,75 @@ const MobileDrawerMenu = () => {
52
194
  }
53
195
  }, []);
54
196
  const handleClick = (key) => {
55
- const item = currentLevel.items[key];
56
- if (typeof item === "object") {
57
- setDirection("forward");
58
- setStack((prev) => [...prev, { title: key, items: item }]);
59
- }
197
+ dispatch({ type: MenuActions.ADD_TO_STACK, payload: key });
60
198
  };
61
199
  const handleBack = () => {
62
- if (stack.length > 1) {
63
- setDirection("backward");
64
- setStack((prev) => prev.slice(0, -1));
200
+ if (stack.stack.length > 1) {
201
+ dispatch({ type: MenuActions.REMOVE_FROM_STACK, payload: {} });
65
202
  }
66
203
  };
67
204
  const handleToggle = () => {
68
- setOpen((prev) => {
69
- const isOpening = !prev;
70
- if (isOpening && !hasOpenedOnce) {
71
- setHasOpenedOnce(true);
72
- setStack([{ title: "Menu", items: menuData }]);
73
- }
74
- return isOpening;
75
- });
205
+ dispatch({ type: MenuActions.SET_HAS_OPENED_ONCE, payload: {} });
206
+ dispatch({ type: MenuActions.SET_MOBILE_MENU_OPEN, payload: {} });
76
207
  };
77
- const handleOutsideClick = (e) => {
78
- if (drawerRef.current && !drawerRef.current.contains(e.target)) {
79
- setOpen(false);
80
- }
208
+ const handleLoginDrawerOpen = () => {
209
+ dispatch({ type: MenuActions.SET_LOGIN_MENU_OPEN, payload: {} });
210
+ };
211
+ const handleLoginDrawerClose = () => {
212
+ dispatch({ type: MenuActions.SET_LOGIN_MENU_CLOSED, payload: {} });
81
213
  };
82
- useEffect(() => {
83
- if (open) {
84
- document.addEventListener("mousedown", handleOutsideClick);
85
- } else {
86
- document.removeEventListener("mousedown", handleOutsideClick);
87
- }
88
- return () => document.removeEventListener("mousedown", handleOutsideClick);
89
- }, [open]);
90
214
  useEffect(() => {
91
215
  const onEsc = (e) => {
92
- if (e.key === "Escape") setOpen(false);
216
+ if (e.key === "Escape")
217
+ dispatch({ type: MenuActions.SET_MOBILE_MENU_CLOSED, payload: {} });
93
218
  };
94
- if (open) {
219
+ if (stack.isMobileMenuOpen) {
95
220
  document.addEventListener("keydown", onEsc);
96
221
  }
97
222
  return () => document.removeEventListener("keydown", onEsc);
98
- }, [open]);
223
+ }, [stack.isMobileMenuOpen]);
99
224
  return /* @__PURE__ */ jsxs(Fragment, { children: [
100
- /* @__PURE__ */ jsx(
101
- "button",
102
- {
103
- onClick: handleToggle,
104
- className: `${styles.hamburger} flex_col`,
105
- "aria-label": "open navigation menu",
106
- children: /* @__PURE__ */ jsx(
107
- "svg",
108
- {
109
- width: 24,
110
- height: 24,
111
- viewBox: "0 0 24 24",
112
- fill: "none",
113
- xmlns: "http://www.w3.org/2000/svg",
114
- "aria-hidden": "true",
115
- children: /* @__PURE__ */ jsx(
116
- "path",
117
- {
118
- fillRule: "evenodd",
119
- clipRule: "evenodd",
120
- d: "M22.5 15.75V17.25H1.5V15.75H22.5ZM22.5 11.25V12.75H1.5V11.25H22.5ZM22.5 6.75V8.25H1.5V6.75H22.5Z",
121
- fill: "#14263D"
122
- }
123
- )
124
- }
125
- )
126
- }
127
- ),
128
- /* @__PURE__ */ jsx(AnimatePresence, { children: open && /* @__PURE__ */ jsx(
225
+ /* @__PURE__ */ jsxs("div", { className: styles.mobileNavRow, children: [
226
+ /* @__PURE__ */ jsx(
227
+ "button",
228
+ {
229
+ type: "button",
230
+ onClick: handleLoginDrawerOpen,
231
+ className: styles.loginTrigger,
232
+ "aria-label": "Open login options",
233
+ children: "Log in"
234
+ }
235
+ ),
236
+ /* @__PURE__ */ jsx(
237
+ "button",
238
+ {
239
+ onClick: handleToggle,
240
+ className: `${styles.hamburger} flex_col`,
241
+ "aria-label": "open navigation menu",
242
+ children: /* @__PURE__ */ jsx(
243
+ "svg",
244
+ {
245
+ width: 24,
246
+ height: 24,
247
+ viewBox: "0 0 24 24",
248
+ fill: "none",
249
+ xmlns: "http://www.w3.org/2000/svg",
250
+ "aria-hidden": "true",
251
+ children: /* @__PURE__ */ jsx(
252
+ "path",
253
+ {
254
+ fillRule: "evenodd",
255
+ clipRule: "evenodd",
256
+ d: "M22.5 15.75V17.25H1.5V15.75H22.5ZM22.5 11.25V12.75H1.5V11.25H22.5ZM22.5 6.75V8.25H1.5V6.75H22.5Z",
257
+ fill: "#14263D"
258
+ }
259
+ )
260
+ }
261
+ )
262
+ }
263
+ )
264
+ ] }),
265
+ /* @__PURE__ */ jsx(AnimatePresence, { children: stack.isMobileMenuOpen && /* @__PURE__ */ jsx(
129
266
  motion.div,
130
267
  {
131
268
  className: styles.overlay,
@@ -148,7 +285,7 @@ const MobileDrawerMenu = () => {
148
285
  children: [
149
286
  /* @__PURE__ */ jsx("p", { id: "menu-description", className: styles.sr_only, children: "Use tab to navigate this menu. Press Escape to close." }),
150
287
  /* @__PURE__ */ jsxs("div", { className: styles.header, children: [
151
- stack.length > 1 ? /* @__PURE__ */ jsxs(
288
+ stack.stack?.length > 1 ? /* @__PURE__ */ jsxs(
152
289
  "button",
153
290
  {
154
291
  onClick: handleBack,
@@ -173,7 +310,7 @@ const MobileDrawerMenu = () => {
173
310
  )
174
311
  }
175
312
  ),
176
- /* @__PURE__ */ jsx("span", { className: styles.prevlevel, children: prevLevel.title })
313
+ /* @__PURE__ */ jsx("span", { className: styles.prevlevel, children: stack.prevLevel?.title })
177
314
  ]
178
315
  }
179
316
  ) : /* @__PURE__ */ jsx(
@@ -226,7 +363,7 @@ const MobileDrawerMenu = () => {
226
363
  className: `${styles.level} flex middle`,
227
364
  "aria-label": "current menu level",
228
365
  children: [
229
- /* @__PURE__ */ jsx("h2", { className: styles.levelTitle, id: "menu-level", children: currentLevel.title }),
366
+ /* @__PURE__ */ jsx("h2", { className: styles.levelTitle, id: "menu-level", children: stack.currentMenuData?.title }),
230
367
  /* @__PURE__ */ jsx(
231
368
  "svg",
232
369
  {
@@ -251,30 +388,40 @@ const MobileDrawerMenu = () => {
251
388
  /* @__PURE__ */ jsx("nav", { "aria-label": "main navigation menu", children: /* @__PURE__ */ jsx(
252
389
  AnimatePresence,
253
390
  {
254
- custom: direction,
391
+ custom: stack.direction,
255
392
  mode: "sync",
256
393
  initial: false,
257
- children: /* @__PURE__ */ jsx(
394
+ children: /* @__PURE__ */ jsxs(
258
395
  motion.ul,
259
396
  {
260
397
  className: styles.menu,
261
- custom: direction,
398
+ custom: stack.direction,
262
399
  variants: slideVariants,
263
400
  initial: "enter",
264
401
  animate: "center",
265
402
  exit: "exit",
266
403
  transition: { duration: 0.3, ease: "linear" },
267
- children: Object.entries(currentLevel.items).map(
268
- ([key, value]) => {
269
- const hasChildren = typeof value === "object";
270
- return /* @__PURE__ */ jsx("li", { children: hasChildren ? /* @__PURE__ */ jsxs(
404
+ children: [
405
+ stack.stack.length > 1 && !stack.currentMenuData?.dropdown && /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
406
+ Link,
407
+ {
408
+ href: stack.currentMenuData.url + (queryString && !stack.currentMenuData.url.includes("?") ? `?${queryString}` : ""),
409
+ className: styles.menuItem,
410
+ children: /* @__PURE__ */ jsxs("span", { children: [
411
+ stack.currentMenuData.title,
412
+ " Home"
413
+ ] })
414
+ }
415
+ ) }),
416
+ stack?.currentMenuData?.items?.map((item) => {
417
+ const hasChildren = item.items && item.items.length > 0;
418
+ return hasChildren ? /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsxs(
271
419
  "button",
272
420
  {
273
421
  className: styles.menuItem,
274
- onClick: () => handleClick(key),
275
- "aria-label": `open submenu for ${key}`,
422
+ onClick: () => handleClick(item),
276
423
  children: [
277
- /* @__PURE__ */ jsx("span", { children: key }),
424
+ /* @__PURE__ */ jsx("span", { children: item.label }),
278
425
  /* @__PURE__ */ jsx("span", { className: styles.chevron, children: /* @__PURE__ */ jsx(
279
426
  "svg",
280
427
  {
@@ -295,27 +442,27 @@ const MobileDrawerMenu = () => {
295
442
  ) })
296
443
  ]
297
444
  }
298
- ) : /* @__PURE__ */ jsx(
445
+ ) }, item.id + "1") : /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
299
446
  Link,
300
447
  {
301
- href: value + (queryString && !value.includes("?") ? `?${queryString}` : ""),
448
+ href: item?.url + (queryString && !item?.url?.includes("?") ? `?${queryString}` : ""),
302
449
  className: styles.menuItem,
303
- children: /* @__PURE__ */ jsx("span", { children: key })
450
+ children: /* @__PURE__ */ jsx("span", { children: item.label })
304
451
  }
305
- ) }, key);
306
- }
307
- )
452
+ ) }, item.id);
453
+ })
454
+ ]
308
455
  },
309
- currentLevel.title
456
+ stack.currentMenuData?.title
310
457
  )
311
458
  }
312
459
  ) }),
313
- /* @__PURE__ */ jsx("div", { className: `${styles.quickLinks} flex middle between`, children: quickLinks.map((link) => /* @__PURE__ */ jsxs(
460
+ /* @__PURE__ */ jsx("div", { className: `${styles.quickLinks} flex middle between`, children: stack.quickLinks?.map((link) => /* @__PURE__ */ jsxs(
314
461
  "a",
315
462
  {
316
- href: link.url + (queryString && !link.url.includes("?") ? `?${queryString}` : ""),
463
+ href: resolveUrl(link.url) + (queryString && !link.url.includes("?") ? `?${queryString}` : ""),
317
464
  className: `${styles.quickLink} flex_col middle`,
318
- "aria-label": `Visit ${link.title} page`,
465
+ "aria-label": link.ariaLabel,
319
466
  children: [
320
467
  /* @__PURE__ */ jsx(
321
468
  "img",
@@ -327,16 +474,157 @@ const MobileDrawerMenu = () => {
327
474
  loading: "lazy"
328
475
  }
329
476
  ),
330
- /* @__PURE__ */ jsx("span", { children: link.title })
477
+ /* @__PURE__ */ jsx("span", { children: link.label })
331
478
  ]
332
479
  },
333
- link.title
480
+ link.id
334
481
  )) })
335
482
  ] }) })
336
483
  ]
337
484
  }
338
485
  )
339
486
  }
487
+ ) }),
488
+ /* @__PURE__ */ jsx(AnimatePresence, { children: stack.loginDrawer && /* @__PURE__ */ jsx(
489
+ motion.div,
490
+ {
491
+ className: styles.overlay,
492
+ initial: { opacity: 0 },
493
+ animate: { opacity: 1 },
494
+ exit: { opacity: 0 },
495
+ children: /* @__PURE__ */ jsxs(
496
+ motion.div,
497
+ {
498
+ className: `${styles.drawer} flex_col`,
499
+ ref: loginRef,
500
+ initial: { x: "100%" },
501
+ animate: { x: 0 },
502
+ exit: { x: "100%" },
503
+ transition: { type: "tween", duration: 0.3 },
504
+ role: "dialog",
505
+ "aria-modal": "true",
506
+ "aria-label": "Login options",
507
+ children: [
508
+ /* @__PURE__ */ jsxs("div", { className: styles.header, children: [
509
+ /* @__PURE__ */ jsx(
510
+ "a",
511
+ {
512
+ href: window.location.href.split("/")[3] === "invest" ? "/invest" : "/",
513
+ "aria-label": "return to home page",
514
+ children: /* @__PURE__ */ jsx(
515
+ "img",
516
+ {
517
+ src: "https://www.axos.com/images/1sBwCIn5mqOg5DK2uXDJPc/axb_mobile_logo.png",
518
+ alt: "",
519
+ width: 86,
520
+ height: 19
521
+ }
522
+ )
523
+ }
524
+ ),
525
+ /* @__PURE__ */ jsx("span", { className: styles.loginDrawerTitle, children: "Log in" }),
526
+ /* @__PURE__ */ jsx(
527
+ "button",
528
+ {
529
+ type: "button",
530
+ className: `${styles.close} flex_col`,
531
+ "aria-label": "Close login options",
532
+ onClick: handleLoginDrawerClose,
533
+ children: /* @__PURE__ */ jsx(
534
+ "svg",
535
+ {
536
+ xmlns: "http://www.w3.org/2000/svg",
537
+ width: "24",
538
+ height: "24",
539
+ viewBox: "0 0 24 24",
540
+ fill: "none",
541
+ "aria-hidden": "true",
542
+ children: /* @__PURE__ */ jsx(
543
+ "path",
544
+ {
545
+ d: "M20.2812 2.65625L21.3419 3.71691L13.0602 11.9982L21.3419 20.2812L20.2812 21.3419L11.9982 13.0602L3.71691 21.3419L2.65625 20.2812L10.9377 11.9982L2.65625 3.71691L3.71691 2.65625L11.9982 10.9377L20.2812 2.65625Z",
546
+ fill: "#14263D"
547
+ }
548
+ )
549
+ }
550
+ )
551
+ }
552
+ )
553
+ ] }),
554
+ /* @__PURE__ */ jsx("div", { className: styles.loginDrawerContent, children: /* @__PURE__ */ jsx("div", { className: styles.loginAccordion, children: /* @__PURE__ */ jsxs(
555
+ "ul",
556
+ {
557
+ className: styles.loginAccordionList,
558
+ "aria-label": "Login options",
559
+ children: [
560
+ stack.loginData?.items?.filter((item) => item.items)?.map((group) => {
561
+ return /* @__PURE__ */ jsxs(
562
+ "li",
563
+ {
564
+ className: styles.loginAccordionGroup,
565
+ "aria-label": `${group?.label} login options`,
566
+ children: [
567
+ /* @__PURE__ */ jsx("span", { className: styles.loginAccordionHeading, children: group.label }),
568
+ /* @__PURE__ */ jsx("ul", { className: styles.loginAccordionGroupList, children: group.items?.map((item) => /* @__PURE__ */ jsx(
569
+ "li",
570
+ {
571
+ "aria-label": `access ${item.label}`,
572
+ children: /* @__PURE__ */ jsx(
573
+ "a",
574
+ {
575
+ href: item.url + (queryString && !item.url.includes("?") ? `?${queryString}` : ""),
576
+ className: styles.menuItem,
577
+ children: /* @__PURE__ */ jsx("span", { children: item.label })
578
+ }
579
+ )
580
+ },
581
+ item.id
582
+ )) })
583
+ ]
584
+ },
585
+ group?.id
586
+ );
587
+ }),
588
+ /* @__PURE__ */ jsxs(
589
+ "li",
590
+ {
591
+ className: styles.loginAccordionGroup,
592
+ children: [
593
+ /* @__PURE__ */ jsx("span", { className: styles.loginAccordionHeading }),
594
+ stack.loginData?.items.filter((item) => !item.items).map((group) => {
595
+ return /* @__PURE__ */ jsx(
596
+ "ul",
597
+ {
598
+ className: styles.loginAccordionGroupList,
599
+ children: /* @__PURE__ */ jsx(
600
+ "li",
601
+ {
602
+ "aria-label": `access ${group.label}`,
603
+ children: /* @__PURE__ */ jsx(
604
+ "a",
605
+ {
606
+ href: group.url + (queryString && !group.url.includes("?") ? `?${queryString}` : ""),
607
+ className: styles.menuItem,
608
+ children: /* @__PURE__ */ jsx("span", { children: group.label })
609
+ }
610
+ )
611
+ },
612
+ group.id
613
+ )
614
+ },
615
+ group.id
616
+ );
617
+ })
618
+ ]
619
+ }
620
+ )
621
+ ]
622
+ }
623
+ ) }) })
624
+ ]
625
+ }
626
+ )
627
+ }
340
628
  ) })
341
629
  ] });
342
630
  };