qpp-style 0.0.9 → 0.0.10

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 (456) hide show
  1. package/.eslintrc.js +28 -28
  2. package/.husky/pre-commit +5 -0
  3. package/README.md +45 -0
  4. package/components/Accordion/index.jsx +35 -43
  5. package/components/Alert/index.js +53 -0
  6. package/components/Breadcrumb/index.js +4 -4
  7. package/components/Button/index.js +17 -6
  8. package/components/CalloutBox/index.js +109 -0
  9. package/components/Card/index.js +137 -0
  10. package/components/Details/DetailsIcons.js +50 -0
  11. package/components/Details/index.js +53 -0
  12. package/components/Dropdown/index.js +85 -0
  13. package/components/DropdownButton/Menu.js +25 -0
  14. package/components/DropdownButton/MenuButton.js +41 -0
  15. package/components/DropdownButton/MenuItem.js +25 -0
  16. package/components/DropdownButton/MenuItemLink.js +27 -0
  17. package/components/Error/Collapsible.jsx +2 -2
  18. package/components/Footer/FooterUI.jsx +175 -177
  19. package/components/Footer/footer.js +2 -12
  20. package/components/GovBanner/index.js +117 -0
  21. package/components/Header/HeaderAccountMenu.jsx +49 -75
  22. package/components/Header/HeaderContainer.jsx +46 -34
  23. package/components/Header/HeaderLogo.jsx +40 -17
  24. package/components/Header/HeaderMenuButton.js +38 -12
  25. package/components/Header/HeaderMenuItem.jsx +204 -64
  26. package/components/Header/HeaderMenuLink.js +46 -10
  27. package/components/Header/HeaderMenuSignOutButton.js +46 -10
  28. package/components/Header/HeaderMobileButton.js +15 -6
  29. package/components/Header/HeaderUI.jsx +118 -117
  30. package/components/Header/HelpIcon.jsx +7 -5
  31. package/components/Header/ImpersonatorBanner.jsx +81 -0
  32. package/components/Header/header.js +2 -0
  33. package/components/Header/hooks.js +53 -1
  34. package/components/Header/utag-helpers.js +9 -0
  35. package/components/Infotip/Infotip.jsx +6 -10
  36. package/components/Infotip/InfotipContent.jsx +46 -0
  37. package/components/Infotip/InfotipIcon.jsx +3 -3
  38. package/components/Link/index.js +61 -0
  39. package/components/Modal/Modal.jsx +53 -40
  40. package/components/Modal/index.jsx +11 -11
  41. package/components/NotificationBanner/CollapsedView.js +39 -0
  42. package/components/NotificationBanner/ExpandedView.js +45 -0
  43. package/components/NotificationBanner/index.js +219 -30
  44. package/components/Search/index.js +98 -0
  45. package/components/SessionDialog/sessionDialog.js +26 -0
  46. package/components/SessionDialogUI.jsx +34 -26
  47. package/components/SideNav/AnimationGroup/AnimationGroup.jsx +9 -2
  48. package/components/SideNav/Chart/ScoreChart.jsx +1 -1
  49. package/components/SideNav/Chart/__tests__/ScoreChart.test.js +3 -12
  50. package/components/SideNav/Chart/__tests__/__snapshots__/ScoreChart.test.js.snap +144 -35
  51. package/components/SideNav/Chart/index.js +1 -1
  52. package/components/SideNav/Content/LevelOneContent.jsx +145 -255
  53. package/components/SideNav/Content/LevelTwoContent.jsx +12 -10
  54. package/components/SideNav/Content/SelectRole/index.js +77 -0
  55. package/components/SideNav/Content/SelectRole/utils.js +140 -0
  56. package/components/SideNav/Details/PracticeDetails.jsx +4 -0
  57. package/components/SideNav/Links/CmsSwitchLink.jsx +1 -1
  58. package/components/SideNav/Links/NavLinkContainer.jsx +29 -34
  59. package/components/SideNav/Links/NavLinkDrawer.jsx +100 -17
  60. package/components/SideNav/Links/NavLinkInline.jsx +7 -2
  61. package/components/SideNav/SideNav.md +28 -27
  62. package/components/SideNav/UI/SideNavUI.jsx +122 -129
  63. package/components/SideNav/UI/default-content.json +117 -0
  64. package/components/SideNav/helpers.js +316 -4
  65. package/components/Tabs/TabPanel.js +5 -0
  66. package/components/Tabs/Tabs.js +73 -0
  67. package/components/TextInput/index.js +137 -0
  68. package/components/hooks/useGetConfig.js +75 -0
  69. package/components/index.js +103 -9
  70. package/coverage/clover.xml +1465 -41
  71. package/coverage/coverage-final.json +72 -1
  72. package/coverage/lcov-report/block-navigation.js +8 -0
  73. package/coverage/lcov-report/components/Accordion/index.html +26 -21
  74. package/coverage/lcov-report/components/Accordion/index.jsx.html +106 -131
  75. package/coverage/lcov-report/{SideNav/Chart → components/Button}/index.html +29 -24
  76. package/coverage/lcov-report/{Error/Collapsible.jsx.html → components/Button/index.js.html} +125 -114
  77. package/coverage/lcov-report/components/Error/Collapsible.jsx.html +92 -87
  78. package/coverage/lcov-report/components/Error/ErrorUI.jsx.html +32 -33
  79. package/coverage/lcov-report/components/Error/index.html +11 -6
  80. package/coverage/lcov-report/components/Footer/FooterUI.jsx.html +200 -189
  81. package/coverage/lcov-report/components/Footer/SocialLinks.jsx.html +24 -61
  82. package/coverage/lcov-report/components/Footer/Subscribe.jsx.html +18 -13
  83. package/coverage/lcov-report/components/Footer/index.html +35 -45
  84. package/coverage/lcov-report/components/{InfoModal → GovBanner}/index.html +27 -22
  85. package/coverage/lcov-report/components/{InfoModal/index.jsx.html → GovBanner/index.js.html} +157 -122
  86. package/coverage/lcov-report/components/Header/HeaderAccountMenu.jsx.html +93 -520
  87. package/coverage/lcov-report/components/Header/HeaderCancel.jsx.html +19 -23
  88. package/coverage/lcov-report/components/Header/HeaderContainer.jsx.html +280 -0
  89. package/coverage/lcov-report/components/{SideNav/Links/NavLinkContainer.jsx.html → Header/HeaderLogo.jsx.html} +78 -67
  90. package/coverage/lcov-report/components/{SideNav/Links/NavItemInline.jsx.html → Header/HeaderMenuButton.js.html} +71 -78
  91. package/coverage/lcov-report/components/{SideNav/Links/NavLinkDrawer.jsx.html → Header/HeaderMenuItem.jsx.html} +291 -268
  92. package/coverage/lcov-report/components/Header/HeaderMenuLink.js.html +253 -0
  93. package/coverage/lcov-report/components/Header/HeaderMenuSignOutButton.js.html +271 -0
  94. package/coverage/lcov-report/components/{SideNav/Links/NavLinkToggle.jsx.html → Header/HeaderMobileButton.js.html} +64 -47
  95. package/coverage/lcov-report/components/Header/HeaderUI.jsx.html +176 -756
  96. package/coverage/lcov-report/components/Header/HelpIcon.jsx.html +181 -0
  97. package/coverage/lcov-report/{Accordion/index.jsx.html → components/Header/ImpersonatorBanner.jsx.html} +109 -167
  98. package/coverage/lcov-report/components/Header/NavigationButtonIcon.jsx.html +24 -19
  99. package/coverage/lcov-report/components/Header/hooks.js.html +283 -0
  100. package/coverage/lcov-report/components/Header/index.html +203 -33
  101. package/coverage/lcov-report/components/{SideNav/Links/index.js.html → Header/utag-helpers.js.html} +35 -42
  102. package/coverage/lcov-report/components/Infotip/Infotip.jsx.html +53 -48
  103. package/coverage/lcov-report/components/Infotip/InfotipIcon.jsx.html +37 -32
  104. package/coverage/lcov-report/components/Infotip/index.html +8 -3
  105. package/coverage/lcov-report/components/Infotip/index.js.html +8 -3
  106. package/coverage/lcov-report/components/Modal/LegacyModal.jsx.html +301 -0
  107. package/coverage/lcov-report/{HeaderUI.jsx.html → components/Modal/Modal.jsx.html} +169 -257
  108. package/coverage/lcov-report/components/Modal/index.html +146 -0
  109. package/coverage/lcov-report/components/{SideNav/Details/IndividualDetails.jsx.html → Modal/index.jsx.html} +50 -42
  110. package/coverage/lcov-report/components/NotificationBanner/CollapsedView.js.html +202 -0
  111. package/coverage/lcov-report/components/NotificationBanner/ExpandedView.js.html +220 -0
  112. package/coverage/lcov-report/components/NotificationBanner/index.html +58 -23
  113. package/coverage/lcov-report/components/{SideNav/Content/LevelTwoContent.jsx.html → NotificationBanner/index.js.html} +292 -272
  114. package/coverage/lcov-report/components/SanitizedContent/index.html +8 -3
  115. package/coverage/lcov-report/components/SanitizedContent/index.jsx.html +475 -50
  116. package/coverage/lcov-report/components/SessionDialogUI.jsx.html +248 -255
  117. package/coverage/lcov-report/components/SideNav/Chart/ScoreChart.jsx.html +272 -408
  118. package/coverage/lcov-report/components/SideNav/Chart/index.html +28 -38
  119. package/coverage/lcov-report/components/SideNav/Content/SelectRole/index.html +116 -0
  120. package/coverage/lcov-report/components/SideNav/Content/SelectRole/utils.js.html +505 -0
  121. package/coverage/lcov-report/components/SideNav/helpers.js.html +987 -46
  122. package/coverage/lcov-report/components/SideNav/index.html +24 -19
  123. package/coverage/lcov-report/components/Tooltip/Tooltip.jsx.html +70 -65
  124. package/coverage/lcov-report/components/Tooltip/index.html +8 -3
  125. package/coverage/lcov-report/components/Tooltip/index.js.html +8 -3
  126. package/coverage/lcov-report/components/Tooltip/position.js.html +57 -64
  127. package/coverage/lcov-report/components/hooks/index.html +116 -0
  128. package/coverage/lcov-report/components/hooks/useGetConfig.js.html +310 -0
  129. package/coverage/lcov-report/components/index.html +10 -5
  130. package/coverage/lcov-report/index.html +401 -21
  131. package/coverage/lcov-report/{Error/ErrorUI.jsx.html → lib/Chevron.jsx.html} +44 -42
  132. package/coverage/lcov-report/lib/SvgComponents.jsx.html +1840 -0
  133. package/coverage/lcov-report/lib/index.html +34 -14
  134. package/coverage/lcov-report/react/components/Accordion/index.html +26 -21
  135. package/coverage/lcov-report/react/components/Accordion/index.jsx.html +67 -86
  136. package/coverage/lcov-report/react/components/{FlashNotification → Button}/index.html +23 -33
  137. package/coverage/lcov-report/{components/SideNav/Links/NavLinkInline.jsx.html → react/components/Button/index.js.html} +119 -120
  138. package/coverage/lcov-report/react/components/{Tabs → Dropdown}/index.html +23 -33
  139. package/coverage/lcov-report/react/components/{InfoModal/index.jsx.html → Dropdown/index.js.html} +102 -154
  140. package/coverage/lcov-report/react/components/Error/Collapsible.jsx.html +26 -21
  141. package/coverage/lcov-report/react/components/Error/ErrorUI.jsx.html +11 -6
  142. package/coverage/lcov-report/react/components/Error/error.js.html +8 -3
  143. package/coverage/lcov-report/react/components/Error/index.html +11 -6
  144. package/coverage/lcov-report/react/components/Footer/FooterUI.jsx.html +196 -194
  145. package/coverage/lcov-report/react/components/Footer/LegacyFooterUI.jsx.html +9 -4
  146. package/coverage/lcov-report/react/components/Footer/SocialLinks.jsx.html +18 -13
  147. package/coverage/lcov-report/react/components/Footer/Subscribe.jsx.html +18 -13
  148. package/coverage/lcov-report/react/components/Footer/footer.js.html +12 -37
  149. package/coverage/lcov-report/react/components/Footer/index.html +35 -45
  150. package/coverage/lcov-report/react/components/{InfoModal → GovBanner}/index.html +27 -22
  151. package/coverage/lcov-report/react/components/{Tabs/TabsUI.jsx.html → GovBanner/index.js.html} +146 -153
  152. package/coverage/lcov-report/react/components/Header/HeaderAccountMenu.jsx.html +81 -154
  153. package/coverage/lcov-report/react/components/Header/HeaderCancel.jsx.html +15 -10
  154. package/coverage/lcov-report/react/components/Header/HeaderContainer.jsx.html +91 -50
  155. package/coverage/lcov-report/react/components/Header/HeaderLogo.jsx.html +105 -31
  156. package/coverage/lcov-report/react/components/Header/HeaderMenuButton.js.html +109 -26
  157. package/coverage/lcov-report/react/components/Header/HeaderMenuItem.jsx.html +510 -85
  158. package/coverage/lcov-report/react/components/Header/HeaderMenuLink.js.html +137 -24
  159. package/coverage/lcov-report/react/components/Header/HeaderMenuSignOutButton.js.html +134 -21
  160. package/coverage/lcov-report/react/components/Header/HeaderMobileButton.js.html +56 -24
  161. package/coverage/lcov-report/react/components/Header/HeaderUI.jsx.html +172 -179
  162. package/coverage/lcov-report/react/components/Header/HelpIcon.jsx.html +30 -19
  163. package/coverage/lcov-report/react/components/Header/ImpersonatorBanner.jsx.html +331 -0
  164. package/coverage/lcov-report/react/components/Header/NavigationButtonIcon.jsx.html +9 -4
  165. package/coverage/lcov-report/react/components/Header/header.js.html +15 -4
  166. package/coverage/lcov-report/react/components/Header/hooks.js.html +187 -26
  167. package/coverage/lcov-report/react/components/Header/index.html +157 -122
  168. package/coverage/lcov-report/react/components/{Spinner/index.js.html → Header/utag-helpers.js.html} +26 -21
  169. package/coverage/lcov-report/react/components/Infotip/Infotip.jsx.html +12 -7
  170. package/coverage/lcov-report/react/components/{Tabs/tabs.js.html → Infotip/InfotipContent.jsx.html} +83 -48
  171. package/coverage/lcov-report/react/components/Infotip/InfotipIcon.jsx.html +12 -7
  172. package/coverage/lcov-report/react/components/Infotip/index.html +8 -3
  173. package/coverage/lcov-report/react/components/Infotip/index.js.html +8 -3
  174. package/coverage/lcov-report/react/components/{FlashNotification/FlashNotificationUI.jsx.html → Modal/LegacyModal.jsx.html} +89 -84
  175. package/coverage/lcov-report/react/components/Modal/Modal.jsx.html +505 -0
  176. package/coverage/lcov-report/react/components/Modal/index.html +52 -17
  177. package/coverage/lcov-report/react/components/Modal/index.jsx.html +38 -201
  178. package/coverage/lcov-report/{components/SideNav/Links/CmsSwitchLink.jsx.html → react/components/NotificationBanner/CollapsedView.js.html} +52 -50
  179. package/coverage/lcov-report/{components/SideNav/Details/PracticeDetails.jsx.html → react/components/NotificationBanner/ExpandedView.js.html} +74 -57
  180. package/coverage/lcov-report/react/components/NotificationBanner/index.html +56 -21
  181. package/coverage/lcov-report/react/components/NotificationBanner/index.js.html +615 -43
  182. package/coverage/lcov-report/react/components/SanitizedContent/index.html +8 -3
  183. package/coverage/lcov-report/react/components/SanitizedContent/index.jsx.html +12 -7
  184. package/coverage/lcov-report/react/components/{Spinner → SessionDialog}/index.html +11 -6
  185. package/coverage/lcov-report/react/components/{FlashNotification/index.js.html → SessionDialog/sessionDialog.js.html} +35 -42
  186. package/coverage/lcov-report/react/components/SessionDialogUI.jsx.html +80 -51
  187. package/coverage/lcov-report/react/components/SideNav/AnimationGroup/AnimationGroup.jsx.html +38 -12
  188. package/coverage/lcov-report/react/components/SideNav/AnimationGroup/index.html +18 -13
  189. package/coverage/lcov-report/react/components/SideNav/Chart/ScoreChart.jsx.html +67 -56
  190. package/coverage/lcov-report/react/components/SideNav/Chart/index.html +26 -21
  191. package/coverage/lcov-report/react/components/SideNav/Chart/index.js.html +9 -4
  192. package/coverage/lcov-report/react/components/SideNav/Content/LevelOneContent.jsx.html +189 -514
  193. package/coverage/lcov-report/react/components/SideNav/Content/LevelTwoContent.jsx.html +28 -17
  194. package/coverage/lcov-report/{components/SideNav/Details → react/components/SideNav/Content/SelectRole}/index.html +42 -52
  195. package/coverage/lcov-report/react/components/SideNav/Content/SelectRole/index.js.html +316 -0
  196. package/coverage/lcov-report/react/components/SideNav/Content/SelectRole/utils.js.html +505 -0
  197. package/coverage/lcov-report/react/components/SideNav/Content/index.html +32 -27
  198. package/coverage/lcov-report/react/components/SideNav/Content/index.js.html +8 -3
  199. package/coverage/lcov-report/react/components/SideNav/Details/IndividualDetails.jsx.html +10 -5
  200. package/coverage/lcov-report/react/components/SideNav/Details/PracticeDetails.jsx.html +26 -9
  201. package/coverage/lcov-report/react/components/SideNav/Details/index.html +23 -18
  202. package/coverage/lcov-report/react/components/SideNav/Details/index.js.html +8 -3
  203. package/coverage/lcov-report/react/components/SideNav/Links/CmsSwitchLink.jsx.html +9 -4
  204. package/coverage/lcov-report/react/components/SideNav/Links/NavItemInline.jsx.html +8 -3
  205. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkContainer.jsx.html +54 -64
  206. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkDrawer.jsx.html +281 -27
  207. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkInline.jsx.html +66 -46
  208. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkToggle.jsx.html +8 -3
  209. package/coverage/lcov-report/react/components/SideNav/Links/index.html +44 -39
  210. package/coverage/lcov-report/react/components/SideNav/Links/index.js.html +8 -3
  211. package/coverage/lcov-report/react/components/SideNav/UI/SideNavUI.jsx.html +165 -181
  212. package/coverage/lcov-report/react/components/SideNav/UI/index.html +28 -23
  213. package/coverage/lcov-report/react/components/SideNav/UI/index.js.html +8 -3
  214. package/coverage/lcov-report/react/components/SideNav/helpers.js.html +967 -26
  215. package/coverage/lcov-report/react/components/SideNav/index.html +27 -22
  216. package/coverage/lcov-report/react/components/SideNav/index.js.html +8 -3
  217. package/coverage/lcov-report/react/components/Tooltip/Tooltip.jsx.html +20 -15
  218. package/coverage/lcov-report/react/components/Tooltip/index.html +8 -3
  219. package/coverage/lcov-report/react/components/Tooltip/index.js.html +8 -3
  220. package/coverage/lcov-report/react/components/Tooltip/position.js.html +22 -17
  221. package/coverage/lcov-report/{components/SideNav/AnimationGroup → react/components/hooks}/index.html +29 -24
  222. package/coverage/lcov-report/react/components/hooks/useGetConfig.js.html +310 -0
  223. package/coverage/lcov-report/react/components/index.html +10 -5
  224. package/coverage/lcov-report/react/index.html +20 -15
  225. package/coverage/lcov-report/react/index.js.html +29 -9
  226. package/coverage/lcov-report/react/lib/Chevron.jsx.html +181 -0
  227. package/coverage/lcov-report/react/lib/SvgComponents.jsx.html +221 -132
  228. package/coverage/lcov-report/react/lib/index.html +32 -27
  229. package/coverage/lcov-report/react/lib/svg-definitions.svg.html +8 -3
  230. package/coverage/lcov-report/react/session/index.html +32 -27
  231. package/coverage/lcov-report/react/session/index.js.html +8 -3
  232. package/coverage/lcov-report/react/session/logout.js.html +122 -18
  233. package/coverage/lcov-report/react/session/refresh.js.html +12 -7
  234. package/coverage/lcov-report/react/session/ttl.js.html +9 -4
  235. package/coverage/lcov-report/session/index.html +50 -45
  236. package/coverage/lcov-report/session/index.js.html +8 -3
  237. package/coverage/lcov-report/session/logout.js.html +144 -49
  238. package/coverage/lcov-report/session/refresh.js.html +41 -36
  239. package/coverage/lcov-report/session/ttl.js.html +34 -29
  240. package/coverage/lcov-report/sorter.js +26 -0
  241. package/coverage/lcov.info +3189 -46
  242. package/dist/browser.js +1 -1
  243. package/dist/browser.js.LICENSE.txt +1 -7
  244. package/dist/browser.js.map +1 -1
  245. package/dist/index.js +1 -1
  246. package/dist/index.js.LICENSE.txt +1 -7
  247. package/dist/index.js.map +1 -1
  248. package/dist/react/index.js +1 -1
  249. package/dist/react/index.js.LICENSE.txt +16 -16
  250. package/dist/react/index.js.map +1 -1
  251. package/fonts/PublicSans-Black.ttf +0 -0
  252. package/fonts/PublicSans-BlackItalic.ttf +0 -0
  253. package/fonts/PublicSans-Bold.ttf +0 -0
  254. package/fonts/PublicSans-BoldItalic.ttf +0 -0
  255. package/fonts/PublicSans-ExtraBold.ttf +0 -0
  256. package/fonts/PublicSans-ExtraBoldItalic.ttf +0 -0
  257. package/fonts/PublicSans-ExtraLight.ttf +0 -0
  258. package/fonts/PublicSans-ExtraLightItalic.ttf +0 -0
  259. package/fonts/PublicSans-Italic.ttf +0 -0
  260. package/fonts/PublicSans-Light.ttf +0 -0
  261. package/fonts/PublicSans-LightItalic.ttf +0 -0
  262. package/fonts/PublicSans-Medium.ttf +0 -0
  263. package/fonts/PublicSans-MediumItalic.ttf +0 -0
  264. package/fonts/PublicSans-Regular.ttf +0 -0
  265. package/fonts/PublicSans-SemiBold.ttf +0 -0
  266. package/fonts/PublicSans-SemiBoldItalic.ttf +0 -0
  267. package/fonts/PublicSans-Thin.ttf +0 -0
  268. package/fonts/PublicSans-ThinItalic.ttf +0 -0
  269. package/images/icon-dot-gov.svg +1 -0
  270. package/images/icon-https.svg +1 -0
  271. package/images/icons/close-x.svg +6 -0
  272. package/images/icons/svg/arrow-down.svg +3 -0
  273. package/images/icons/svg/arrow-download.svg +1 -0
  274. package/images/icons/svg/arrow-right.svg +1 -0
  275. package/images/icons/svg/arrow-up.svg +3 -0
  276. package/images/icons/svg/block.svg +5 -0
  277. package/images/icons/svg/calendar.svg +1 -0
  278. package/images/icons/svg/check-circle.svg +5 -0
  279. package/images/icons/svg/checkmark.svg +7 -0
  280. package/images/icons/svg/chevron-down.svg +11 -0
  281. package/images/icons/svg/chevron-left.svg +12 -0
  282. package/images/icons/svg/chevron-right.svg +12 -0
  283. package/images/icons/svg/chevron-up.svg +12 -0
  284. package/images/icons/svg/clipboard.svg +1 -0
  285. package/images/icons/svg/close.svg +1 -0
  286. package/images/icons/svg/divide.svg +13 -0
  287. package/images/icons/svg/doctors-and-clinicians-preview.svg +10 -0
  288. package/images/icons/svg/download.svg +1 -0
  289. package/images/icons/svg/dropdown-arrow.svg +1 -0
  290. package/images/icons/svg/equals.svg +13 -0
  291. package/images/icons/svg/exclamation.svg +11 -0
  292. package/images/icons/svg/external.svg +1 -0
  293. package/images/icons/svg/file-download.svg +1 -0
  294. package/images/icons/svg/file-upload.svg +1 -0
  295. package/images/icons/svg/info.svg +20 -0
  296. package/images/icons/svg/manage-user-access.svg +8 -0
  297. package/images/icons/svg/multiply.svg +12 -0
  298. package/images/icons/svg/performance-feedback.svg +1 -0
  299. package/images/icons/svg/plus.svg +12 -0
  300. package/images/icons/svg/preview.svg +17 -0
  301. package/images/icons/svg/print.svg +1 -0
  302. package/images/icons/svg/registration.svg +8 -0
  303. package/images/icons/svg/reporting.svg +17 -0
  304. package/images/icons/svg/save-disk.svg +5 -0
  305. package/images/icons/svg/search.svg +1 -0
  306. package/images/icons/svg/subtract.svg +15 -0
  307. package/images/icons/svg/targeted-review.svg +15 -0
  308. package/images/icons/svg/tooltip-question.svg +1 -0
  309. package/images/icons/svg/trash.svg +1 -0
  310. package/images/icons/svg/upload.svg +1 -0
  311. package/images/us_flag_small.png +0 -0
  312. package/index.js +5 -0
  313. package/jest.config.js +139 -132
  314. package/lib/Chevron.jsx +32 -0
  315. package/lib/SvgComponents.jsx +197 -49
  316. package/package.json +60 -78
  317. package/session/logout.js +35 -2
  318. package/styles/_global.scss +63 -62
  319. package/styles/_main.scss +6 -0
  320. package/styles/_qpp-style.scss +0 -3
  321. package/styles/components/_accordion.scss +249 -246
  322. package/styles/components/_autocomplete.scss +0 -3
  323. package/styles/components/_spinner.scss +0 -2
  324. package/styles/components/_tables.scss +77 -67
  325. package/styles/components/_text.scss +102 -102
  326. package/styles/components/_variables.scss +12 -12
  327. package/styles/qppds/base/_backgrounds.scss +1 -6
  328. package/styles/qppds/base/_fonts.scss +24 -0
  329. package/styles/qppds/base/_icon.scss +31 -0
  330. package/styles/qppds/base/_layout.scss +5 -0
  331. package/styles/qppds/base/_typography.scss +77 -43
  332. package/styles/qppds/base/index.scss +3 -6
  333. package/styles/qppds/components/_alert.scss +101 -0
  334. package/styles/qppds/components/_breadcrumbs.scss +42 -10
  335. package/styles/qppds/components/_button.scss +38 -12
  336. package/styles/qppds/components/_card.scss +175 -0
  337. package/styles/qppds/components/_checkbox.scss +199 -0
  338. package/styles/qppds/components/_circular-loader.scss +47 -0
  339. package/styles/qppds/components/_details.scss +90 -0
  340. package/styles/qppds/components/_dropdown-menu.scss +125 -0
  341. package/styles/qppds/components/_dropdown.scss +5 -0
  342. package/styles/qppds/components/_footer.scss +606 -0
  343. package/styles/qppds/components/_gov-banner.scss +344 -0
  344. package/styles/{components → qppds/components}/_header.scss +460 -24
  345. package/styles/qppds/components/_link.scss +32 -9
  346. package/styles/qppds/components/_modal.scss +61 -21
  347. package/styles/qppds/components/_page-header.scss +65 -2
  348. package/styles/qppds/components/_pagination.scss +227 -0
  349. package/styles/qppds/components/_process-list.scss +104 -0
  350. package/styles/qppds/components/_radio-button.scss +184 -0
  351. package/styles/qppds/components/_search.scss +118 -0
  352. package/styles/{components → qppds/components}/_sidebar.scss +2 -0
  353. package/styles/qppds/components/_step-indicator.scss +190 -0
  354. package/styles/qppds/components/_table.scss +157 -0
  355. package/styles/qppds/components/_tabs.scss +197 -0
  356. package/styles/qppds/components/_text-input.scss +60 -0
  357. package/styles/qppds/components/index.scss +18 -0
  358. package/styles/{components → qppds/components}/sidebar/_links.scss +48 -1
  359. package/styles/qppds/components/sidebar/_select-role-dropdown.scss +21 -0
  360. package/styles/{components → qppds/components}/sidebar/_sidebar-animation.scss +4 -0
  361. package/styles/qppds/components/sidebar/_sidebar.scss +146 -0
  362. package/styles/qppds/settings/_functions.scss +3 -1
  363. package/styles/qppds/settings/mixins/_borders.scss +6 -0
  364. package/styles/qppds/settings/mixins/_focus.scss +7 -1
  365. package/styles/qppds/settings/mixins/_icons.scss +39 -4
  366. package/styles/qppds/settings/mixins/_index.scss +3 -0
  367. package/styles/qppds/settings/mixins/_layout.scss +46 -7
  368. package/styles/qppds/settings/mixins/_table.scss +91 -0
  369. package/styles/qppds/settings/mixins/_type.scss +89 -0
  370. package/styles/qppds/settings/variables/_color.scss +47 -1
  371. package/styles/qppds/settings/variables/_index.scss +2 -1
  372. package/styles/qppds/settings/variables/_layout.scss +34 -9
  373. package/styles/qppds/settings/variables/_type.scss +41 -0
  374. package/styles/qppds/settings/variables/_z-index.scss +8 -0
  375. package/styles/qppds/utilities/_background-color.scss +4 -0
  376. package/styles/qppds/utilities/_color.scss +24 -0
  377. package/styles/qppds/utilities/{_display-visability.scss → _display-visibility.scss} +8 -0
  378. package/styles/qppds/utilities/_flexbox.scss +113 -0
  379. package/styles/qppds/utilities/_font-family.scss +4 -0
  380. package/styles/qppds/utilities/_gap.scss +38 -0
  381. package/styles/qppds/utilities/_height.scss +79 -0
  382. package/styles/qppds/utilities/_list-style.scss +18 -0
  383. package/styles/qppds/utilities/_position.scss +24 -0
  384. package/styles/qppds/utilities/_text-align.scss +40 -0
  385. package/styles/qppds/utilities/_text-transform.scss +7 -0
  386. package/styles/qppds/utilities/_truncate.scss +5 -5
  387. package/styles/qppds/utilities/_vertical-align.scss +72 -0
  388. package/styles/qppds/utilities/_width.scss +38 -1
  389. package/styles/qppds/utilities/index.scss +8 -2
  390. package/svgo.config.js +14 -0
  391. package/test/components/Accordion.test.js +4 -13
  392. package/test/components/ErrorUI.test.js +10 -46
  393. package/test/components/FooterUI.test.js +0 -30
  394. package/test/components/HeaderUI.test.js +32 -40
  395. package/test/components/Infotip.test.js +18 -12
  396. package/test/components/SessionDialogUI.test.js +55 -70
  397. package/test-setup.js +0 -8
  398. package/webpack.config.js +29 -39
  399. package/webpack.config.react.js +7 -18
  400. package/.storybook/.babelrc +0 -4
  401. package/.storybook/main.js +0 -88
  402. package/.storybook/preview-head.html +0 -9
  403. package/.storybook/preview.js +0 -5
  404. package/Session.vim +0 -83
  405. package/components/Accordion/Accordion.stories.js +0 -20
  406. package/components/Breadcrumb/Breadcrumb.stories.js +0 -58
  407. package/components/Button/Button.stories.js +0 -125
  408. package/components/Footer/Footer.stories.js +0 -20
  409. package/components/Footer/LegacyFooterUI.jsx +0 -194
  410. package/components/Header/Header.stories.js +0 -32
  411. package/components/InfoModal/InfoModal.stories.js +0 -98
  412. package/components/InfoModal/index.jsx +0 -104
  413. package/components/Infotip/Infotip.stories.js +0 -50
  414. package/components/Modal/Modal.stories.js +0 -159
  415. package/components/NotificationBanner/NotificationBanner.stories.js +0 -22
  416. package/components/NotificationBanner/NotificationBannerUI.jsx +0 -282
  417. package/components/SideNav/SideNav.stories.js +0 -397
  418. package/components/Spinner/index.js +0 -9
  419. package/components/Tabs/TabsUI.jsx +0 -118
  420. package/components/Tabs/tabs.js +0 -36
  421. package/components/Tooltip/Tooltip.jsx +0 -88
  422. package/components/Tooltip/Tooltip.stories.js +0 -80
  423. package/components/Tooltip/index.js +0 -3
  424. package/components/Tooltip/position.js +0 -68
  425. package/components/UnwrappedSpinner/index.js +0 -8
  426. package/components/UnwrappedTabs/TabPanelUI.jsx +0 -16
  427. package/components/UnwrappedTabs/TabsUI.jsx +0 -82
  428. package/coverage/lcov-report/Accordion/index.html +0 -111
  429. package/coverage/lcov-report/Error/index.html +0 -126
  430. package/coverage/lcov-report/ScoreChart.jsx.html +0 -1025
  431. package/coverage/lcov-report/SideNav/Chart/ScoreChart.jsx.html +0 -1025
  432. package/coverage/lcov-report/components/Footer/LegacyFooterUI.jsx.html +0 -668
  433. package/coverage/lcov-report/components/NotificationBanner/NotificationBannerUI.jsx.html +0 -1010
  434. package/coverage/lcov-report/components/SideNav/AnimationGroup/AnimationGroup.jsx.html +0 -131
  435. package/coverage/lcov-report/components/SideNav/Chart/index.js.html +0 -89
  436. package/coverage/lcov-report/components/SideNav/Content/LevelOneContent.jsx.html +0 -1007
  437. package/coverage/lcov-report/components/SideNav/Content/index.html +0 -141
  438. package/coverage/lcov-report/components/SideNav/Content/index.js.html +0 -92
  439. package/coverage/lcov-report/components/SideNav/Details/index.js.html +0 -92
  440. package/coverage/lcov-report/components/SideNav/Links/index.html +0 -201
  441. package/coverage/lcov-report/components/SideNav/UI/SideNavUI.jsx.html +0 -1298
  442. package/coverage/lcov-report/components/SideNav/UI/index.html +0 -126
  443. package/coverage/lcov-report/components/SideNav/UI/index.js.html +0 -89
  444. package/coverage/lcov-report/lib/svg-definitions.svg.html +0 -1319
  445. package/coverage/lcov-report/react/components/NotificationBanner/NotificationBannerUI.jsx.html +0 -926
  446. package/styles/components/_footer.scss +0 -593
  447. package/styles/components/_header_backup.scss +0 -574
  448. package/styles/components/sidebar/_sidebar.scss +0 -141
  449. package/test/components/Tooltip.test.js +0 -147
  450. package/test/components/__snapshots__/Accordion.test.js.snap +0 -11439
  451. package/test/components/__snapshots__/HeaderUI.test.js.snap +0 -3
  452. /package/styles/{components → qppds/components}/sidebar/_animations.scss +0 -0
  453. /package/styles/{components → qppds/components}/sidebar/_cms.scss +0 -0
  454. /package/styles/{components → qppds/components}/sidebar/_details.scss +0 -0
  455. /package/styles/{components → qppds/components}/sidebar/_sidebar-tooltip.scss +0 -0
  456. /package/styles/{components → qppds/components}/sidebar/project-specific/_wi.scss +0 -0
@@ -1,99 +1,239 @@
1
- import React, { useRef, useEffect, useState } from 'react'
2
- import PropTypes from 'prop-types'
1
+ import React, { Fragment, useRef, useEffect, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
3
 
4
- import { useWindowWidth } from './hooks'
5
- import HeaderMenuLink from './HeaderMenuLink'
6
- import HeaderMenuButton from './HeaderMenuButton'
7
- import HeaderMenuSignOutButton from './HeaderMenuSignOutButton'
4
+ import { useWindowWidth, useHeaderState } from './hooks';
5
+ import HeaderMenuLink from './HeaderMenuLink';
6
+ import HeaderMenuButton from './HeaderMenuButton';
7
+ import HeaderMenuSignOutButton from './HeaderMenuSignOutButton';
8
+ import Accordion from '../Accordion';
9
+ import { Chevron } from '../../lib/Chevron.jsx';
8
10
 
9
11
  const menuSizes = {
10
- '1': 315,
11
- '2': 650,
12
- '3': 890,
13
- '4': 1200,
14
- }
12
+ 1: 315,
13
+ 2: 650,
14
+ 3: 890,
15
+ 4: 1200,
16
+ };
15
17
 
16
- const HeaderMenuItem = ({ columns, isOpen, handleToggleMenu, name, subtitle }) => {
18
+ const excludedClickOutClasses = [
19
+ 'menu-dropdown-toggle',
20
+ 'nav-link',
21
+ 'nav-link-li',
22
+ 'dropdown-description',
23
+ 'dropdown-title',
24
+ 'dropdown-title-chevron-container',
25
+ 'signout-button',
26
+ 'submenu-section',
27
+ 'accordion',
28
+ 'accordion-title',
29
+ 'accordion-left-title',
30
+ 'header-menu-btn',
31
+ 'btn-navigation-icon',
32
+ ];
33
+
34
+ const HeaderMenuItem = ({
35
+ handleClick,
36
+ isMobileMenuExpanded,
37
+ columns,
38
+ menuName,
39
+ rows,
40
+ name,
41
+ subtitle,
42
+ className,
43
+ }) => {
17
44
  const [isSubMenuFullWidth, setSubMenuFullWidth] = useState(false);
18
- const windowWidth = useWindowWidth()
19
- const menuToggle = useRef(null)
20
- const numColumns = (columns || []).length
45
+ const [openMobileSubMenu, setOpenMobileSubMenu] = useState('');
46
+
47
+ const windowWidth = useWindowWidth();
48
+ const menuButtonRef = useRef(null);
49
+ const menuRef = useRef(null);
50
+ const { RouterLink, handleToggleMenu, currentOpenMenu, closeMenus } =
51
+ useHeaderState();
52
+ const numColumns = (columns || []).length;
53
+
54
+ const menuIdentifier = menuName || name;
55
+ const isOpen = menuIdentifier === currentOpenMenu;
21
56
 
22
57
  useEffect(() => {
23
- const isMobile = windowWidth < 768
58
+ const isMobile = windowWidth < 768;
24
59
  if (isOpen) {
25
- const shouldSetFullWidth = isMobile || menuSizes[numColumns] > menuToggle.current.getBoundingClientRect().right
26
- setSubMenuFullWidth(shouldSetFullWidth)
60
+ const shouldSetFullWidth =
61
+ isMobile ||
62
+ menuSizes[numColumns] >
63
+ menuButtonRef.current.getBoundingClientRect().right;
64
+ setSubMenuFullWidth(shouldSetFullWidth);
65
+ }
66
+ }, [windowWidth, isOpen]);
67
+
68
+ useEffect(() => {
69
+ const listener = (event) => {
70
+ if (
71
+ !menuRef ||
72
+ !menuRef.current ||
73
+ menuRef.current.contains(event.target) ||
74
+ excludedClickOutClasses.some((className) =>
75
+ event?.target?.classList.contains(className)
76
+ )
77
+ ) {
78
+ return;
79
+ }
80
+ setOpenMobileSubMenu('');
81
+ closeMenus();
82
+ };
83
+ document.addEventListener('mousedown', listener);
84
+ return () => document.removeEventListener('mousedown', listener);
85
+ }, [menuRef]);
86
+
87
+ useEffect(() => {
88
+ if (!isMobileMenuExpanded || !isOpen) {
89
+ setOpenMobileSubMenu('');
27
90
  }
28
- }, [windowWidth, isOpen])
91
+ }, [isMobileMenuExpanded, isOpen]);
92
+
29
93
  return (
30
- <li key={`header-item-${name}`} className={`header-item-${name}${isSubMenuFullWidth ? ' full-width-menu': ''}`}>
94
+ <li
95
+ key={`header-item-${menuIdentifier}`}
96
+ className={`header-item-${menuIdentifier}${
97
+ isSubMenuFullWidth ? ' full-width-menu' : ''
98
+ }${className ? ` ${className}` : ''}`}
99
+ ref={menuRef}
100
+ >
31
101
  <button
32
- ref={menuToggle}
102
+ ref={menuButtonRef}
33
103
  className="menu-dropdown-toggle"
104
+ aria-label={`${name} navigation dropdown`}
34
105
  aria-expanded={isOpen}
35
- aria-controls={`nav-section-${name}`}
106
+ aria-controls={`nav-section-${menuIdentifier}`}
36
107
  data-toggle="dropdown"
37
- onClick={handleToggleMenu}
108
+ onClick={() => handleToggleMenu(menuIdentifier)}
38
109
  >
39
- <span className="dropdown-title">{name}</span>
40
- <span className="dropdown-description">
110
+ <div className="dropdown-title-chevron-container">
111
+ <span className="dropdown-title">{name}</span>
112
+ <div className="chevron-container">
113
+ <Chevron focusable="false" />
114
+ </div>
115
+ </div>
116
+
117
+ <span className={`dropdown-description ${isOpen ? 'active' : ''}`}>
41
118
  {subtitle}
42
119
  </span>
43
120
  </button>
44
- <div className={`nav-section${isOpen ? ' open': ''}`} id={`nav-section-${name}`} hidden={!isOpen} data-columns={numColumns} style={{ gridTemplateColumns: `repeat(${numColumns}, 1fr)` }}>
45
- {columns.map((columnContent, index) => {
121
+ <div
122
+ className={`nav-section${isOpen ? ' open' : ''}`}
123
+ id={`nav-section-${menuIdentifier}`}
124
+ hidden={!isOpen}
125
+ data-columns={numColumns}
126
+ >
127
+ {rows.map((columnContent, index) => {
46
128
  return (
47
- <ul key={`${name}-${index}`} className="nav-column">
129
+ <ul key={`${menuIdentifier}-${index}`} className="nav-column">
48
130
  {columnContent.map((c, cIndex) => {
49
131
  return (
50
- <li key={`${name}-${index}-${cIndex}`} className="submenu-section">
51
- {c.heading && (
52
- <h3 className="submenu-heading">{c.heading}</h3>
132
+ <Fragment key={`${menuIdentifier}-${index}-${cIndex}`}>
133
+ <li className="submenu-section">
134
+ {c.heading && (
135
+ <h3 className="submenu-heading">{c.heading}</h3>
136
+ )}
137
+ <ul>
138
+ {c.items.map((item) => {
139
+ const isSubLink = item.type === 'sublink';
140
+ const componentsByType = {
141
+ button: HeaderMenuButton,
142
+ signout: HeaderMenuSignOutButton,
143
+ link: HeaderMenuLink,
144
+ sublink: HeaderMenuLink,
145
+ };
146
+ const SubMenuComponent = componentsByType[item.type];
147
+ return (
148
+ <li
149
+ onClick={handleClick}
150
+ key={`item-link-${item.name}`}
151
+ className={
152
+ isSubLink
153
+ ? 'nav-link-li sublink'
154
+ : 'nav-link-li'
155
+ }
156
+ >
157
+ <SubMenuComponent
158
+ href={item.href}
159
+ name={item.name}
160
+ RouterLink={RouterLink}
161
+ />
162
+ </li>
163
+ );
164
+ })}
165
+ </ul>
166
+ </li>
167
+ {name === 'MIPS' && (
168
+ <li
169
+ key={`${menuIdentifier}-mobile-${index}-${cIndex}`}
170
+ className="submenu-section-mips-mobile"
171
+ onClick={() => {
172
+ setOpenMobileSubMenu(c.heading);
173
+ }}
174
+ >
175
+ <Accordion
176
+ title={c.heading}
177
+ isOpen={
178
+ isMobileMenuExpanded &&
179
+ openMobileSubMenu === c.heading
180
+ }
181
+ >
182
+ <ul>
183
+ {c.items.map((item) => {
184
+ const isSubLink = item.type === 'sublink';
185
+ const componentsByType = {
186
+ button: HeaderMenuButton,
187
+ signout: HeaderMenuSignOutButton,
188
+ link: HeaderMenuLink,
189
+ sublink: HeaderMenuLink,
190
+ };
191
+ const SubMenuComponent =
192
+ componentsByType[item.type];
193
+ return (
194
+ <li
195
+ onClick={handleClick}
196
+ key={`item-link-${item.name}`}
197
+ className={isSubLink ? 'sublink' : ''}
198
+ >
199
+ <SubMenuComponent
200
+ href={item.href}
201
+ name={item.name}
202
+ RouterLink={RouterLink}
203
+ />
204
+ </li>
205
+ );
206
+ })}
207
+ </ul>
208
+ </Accordion>
209
+ </li>
53
210
  )}
54
- <ul>
55
- {c.items.map(item => {
56
- const isSubLink = item.type === 'sublink'
57
- const componentsByType = {
58
- button: HeaderMenuButton,
59
- signout: HeaderMenuSignOutButton,
60
- link: HeaderMenuLink,
61
- sublink: HeaderMenuLink,
62
- }
63
- const SubMenuComponent = componentsByType[item.type]
64
- return (
65
- <li
66
- key={`item-link-${item.name}`}
67
- className={isSubLink ? 'sublink' : ''}
68
- >
69
- <SubMenuComponent href={item.href} name={item.name} />
70
- </li>
71
- )
72
- })}
73
- </ul>
74
- </li>
75
- )
211
+ </Fragment>
212
+ );
76
213
  })}
77
214
  </ul>
78
- )
215
+ );
79
216
  })}
80
217
  </div>
81
218
  </li>
82
- )
83
- }
84
-
219
+ );
220
+ };
85
221
 
86
222
  HeaderMenuItem.propTypes = {
87
223
  columns: PropTypes.array,
88
- handleToggleMenu: PropTypes.func,
89
- isOpen: PropTypes.bool,
224
+ menuName: PropTypes.string,
225
+ rows: PropTypes.array,
90
226
  name: PropTypes.string.isRequired,
91
227
  subtitle: PropTypes.string.isRequired,
92
- }
228
+ className: PropTypes.string,
229
+ handleClick: PropTypes.func.isRequired,
230
+ isMobileMenuExpanded: PropTypes.bool.isRequired,
231
+ };
93
232
  HeaderMenuItem.defaultProps = {
233
+ menuName: '',
94
234
  columns: [],
95
- handleToggleMenu: null,
96
- isOpen: false,
97
- }
235
+ rows: [],
236
+ className: null,
237
+ };
98
238
 
99
- export default HeaderMenuItem
239
+ export default HeaderMenuItem;
@@ -1,16 +1,52 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import { submissionsUrl } from '../SideNav/helpers';
4
+ import { useHeaderState } from './hooks';
5
+ import { setUtagLink } from './utag-helpers';
3
6
 
4
- const HeaderMenuLink = ({ href, name }) => (
5
- <a
6
- href={href}
7
- data-track-category="TopNav"
8
- data-track-action="click"
9
- data-track-label={name}
10
- >
11
- {name}
12
- </a>
13
- );
7
+ // exclude submissions urls
8
+ const isNotExcluded = (href) => !href.includes(submissionsUrl);
9
+
10
+ const HeaderMenuLink = ({ href, name }) => {
11
+ const { RouterLink, closeMenus } = useHeaderState();
12
+ if (RouterLink && isNotExcluded(href)) {
13
+ return (
14
+ <RouterLink
15
+ to={href}
16
+ onClick={() => {
17
+ closeMenus();
18
+ setUtagLink('main navbar', 'click', href);
19
+ }}
20
+ data-track-category="TopNav"
21
+ data-track-action="click"
22
+ data-track-label={name}
23
+ className="nav-link"
24
+ >
25
+ {name}
26
+ </RouterLink>
27
+ );
28
+ }
29
+ return (
30
+ <a
31
+ href={href}
32
+ className="nav-link"
33
+ data-track-category="TopNav"
34
+ data-track-action="click"
35
+ data-track-label={name}
36
+ onKeyDown={(e) => {
37
+ if (e.key === ' ' || e.code === 'Space') {
38
+ window.location.href = window.location.origin + href;
39
+ setUtagLink('main navbar', 'keydown', href);
40
+ }
41
+ }}
42
+ onClick={() => {
43
+ setUtagLink('main navbar', 'click', href);
44
+ }}
45
+ >
46
+ {name}
47
+ </a>
48
+ );
49
+ };
14
50
 
15
51
  HeaderMenuLink.propTypes = {
16
52
  href: PropTypes.string.isRequired,
@@ -1,21 +1,57 @@
1
- import React from 'react';
1
+ import React, { useState } from 'react';
2
2
  import PropTypes from 'prop-types';
3
+
3
4
  import { LogoutSession } from '../../session';
5
+ import { setUtagLink } from './utag-helpers';
6
+ import Modal from '../Modal/index';
7
+
8
+ const useModal = () => {
9
+ const [open, setOpen] = useState(false);
10
+ const openModal = () => setOpen(true);
11
+ const closeModal = () => setOpen(false);
12
+ return [open, openModal, closeModal];
13
+ };
4
14
 
5
15
  const HeaderMenuSignOutButton = ({ name }) => {
16
+ const [open, openModal, closeModal] = useModal();
6
17
  const showLogoutWarning = () => {
7
18
  LogoutSession(window);
8
19
  };
9
20
  return (
10
- <button
11
- className="signout-button"
12
- onClick={showLogoutWarning}
13
- data-track-category="TopNav"
14
- data-track-action="click"
15
- data-track-label={name}
16
- >
17
- {name}
18
- </button>
21
+ <>
22
+ <button
23
+ className="signout-button"
24
+ aria-label="Sign out"
25
+ onClick={openModal}
26
+ data-track-category="TopNav"
27
+ data-track-action="click"
28
+ data-track-label={name}
29
+ >
30
+ {name}
31
+ </button>
32
+ <Modal
33
+ useDesignSystem
34
+ isOpen={open}
35
+ title="Sign out"
36
+ onRequestClose={closeModal}
37
+ primary={{
38
+ title: 'Sign me out now',
39
+ onClick: () => {
40
+ showLogoutWarning();
41
+ setUtagLink('button', 'click', 'Sign me out now');
42
+ },
43
+ }}
44
+ secondary={{
45
+ title: 'Keep me signed in',
46
+ onClick: () => {
47
+ closeModal();
48
+ setUtagLink('button', 'click', 'Keep me signed in');
49
+ },
50
+ }}
51
+ >
52
+ <p>Are you sure you want to sign out?</p>
53
+ </Modal>
54
+ </>
19
55
  );
20
56
  };
21
57
 
@@ -1,21 +1,30 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import { CloseXIcon } from '../../lib/SvgComponents.jsx';
3
4
 
4
5
  const HeaderMobileButton = ({ isMobileMenuExpanded, handleClick }) => (
5
6
  <button
6
- className="mobile-menu-btn"
7
+ className="mobile-menu-btn-new"
7
8
  type="button"
8
9
  data-toggle="collapse"
9
10
  data-target="#nav-mobile"
11
+ aria-label="Navigation menu"
10
12
  aria-expanded={isMobileMenuExpanded ? 'true' : 'false'}
11
13
  aria-controls="nav-mobile"
12
14
  onClick={handleClick}
13
15
  >
14
- <div className="icon">
15
- <span className="icon-bar" />
16
- <span className="icon-bar" />
17
- <span className="icon-bar" />
18
- </div>
16
+ {!isMobileMenuExpanded && (
17
+ <div className="icon">
18
+ <span className="icon-bar" />
19
+ <span className="icon-bar" />
20
+ <span className="icon-bar" />
21
+ </div>
22
+ )}
23
+ {isMobileMenuExpanded && (
24
+ <svg className="close-icon" aria-hidden="true">
25
+ <CloseXIcon />
26
+ </svg>
27
+ )}
19
28
  <div className="toggle-text">Menu</div>
20
29
  </button>
21
30
  );