qpp-style 9.6.13 → 9.7.3

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 (328) hide show
  1. package/.storybook/main.js +19 -13
  2. package/components/Breadcrumb/Breadcrumb.stories.js +10 -6
  3. package/components/Button/Button.stories.js +0 -2
  4. package/components/CalloutBox/CalloutBox.stories.js +0 -2
  5. package/components/Card/Card.stories.js +0 -2
  6. package/components/Dropdown/Dropdown.stories.js +92 -0
  7. package/components/Dropdown/index.js +85 -0
  8. package/components/Footer/Footer.stories.js +7 -10
  9. package/components/Header/Header.stories.js +16 -20
  10. package/components/Infotip/Infotip.stories.js +5 -5
  11. package/components/Modal/Modal.stories.js +28 -30
  12. package/components/NotificationBanner/NotificationBanner.stories.js +10 -10
  13. package/components/Search/Search.stories.js +0 -2
  14. package/components/SideNav/AnimationGroup/AnimationGroup.jsx +7 -2
  15. package/components/SideNav/Links/NavLinkDrawer.jsx +38 -8
  16. package/components/SideNav/SideNav.stories.js +104 -185
  17. package/components/SideNav/UI/SideNavUI.jsx +9 -2
  18. package/components/Tabs/Tabs.stories.js +0 -2
  19. package/components/TextInput/TextInput.stories.js +0 -2
  20. package/components/index.js +2 -0
  21. package/coverage/clover.xml +1192 -0
  22. package/coverage/coverage-final.json +67 -0
  23. package/coverage/lcov-report/Header/HeaderUI.jsx.html +1418 -0
  24. package/coverage/lcov-report/Header/index.html +111 -0
  25. package/coverage/lcov-report/HeaderUI.jsx.html +578 -0
  26. package/coverage/lcov-report/SideNav/UI/index.html +111 -0
  27. package/coverage/lcov-report/SideNav/UI/index.js.html +89 -0
  28. package/coverage/lcov-report/base.css +224 -0
  29. package/coverage/lcov-report/block-navigation.js +79 -0
  30. package/coverage/lcov-report/components/Accordion/index.html +111 -0
  31. package/coverage/lcov-report/components/Accordion/index.jsx.html +359 -0
  32. package/coverage/lcov-report/components/Error/Collapsible.jsx.html +344 -0
  33. package/coverage/lcov-report/components/Error/ErrorUI.jsx.html +173 -0
  34. package/coverage/lcov-report/components/Error/index.html +126 -0
  35. package/coverage/lcov-report/components/Footer/FooterUI.jsx.html +845 -0
  36. package/coverage/lcov-report/components/Footer/LegacyFooterUI.jsx.html +662 -0
  37. package/coverage/lcov-report/components/Footer/SocialLinks.jsx.html +260 -0
  38. package/coverage/lcov-report/components/Footer/Subscribe.jsx.html +182 -0
  39. package/coverage/lcov-report/components/Footer/index.html +156 -0
  40. package/coverage/lcov-report/components/InfoModal/index.html +111 -0
  41. package/coverage/lcov-report/components/InfoModal/index.jsx.html +392 -0
  42. package/coverage/lcov-report/components/Infotip/Infotip.jsx.html +305 -0
  43. package/coverage/lcov-report/components/Infotip/InfotipIcon.jsx.html +203 -0
  44. package/coverage/lcov-report/components/Infotip/index.html +141 -0
  45. package/coverage/lcov-report/components/Infotip/index.js.html +89 -0
  46. package/coverage/lcov-report/components/SanitizedContent/index.html +111 -0
  47. package/coverage/lcov-report/components/SanitizedContent/index.jsx.html +680 -0
  48. package/coverage/lcov-report/components/SessionDialogUI.jsx.html +863 -0
  49. package/coverage/lcov-report/components/SideNav/AnimationGroup/AnimationGroup.jsx.html +140 -0
  50. package/coverage/lcov-report/components/SideNav/AnimationGroup/index.html +111 -0
  51. package/coverage/lcov-report/components/SideNav/Chart/ScoreChart.jsx.html +884 -0
  52. package/coverage/lcov-report/components/SideNav/Chart/index.html +126 -0
  53. package/coverage/lcov-report/components/SideNav/Chart/index.js.html +89 -0
  54. package/coverage/lcov-report/components/SideNav/Content/LevelOneContent.jsx.html +1007 -0
  55. package/coverage/lcov-report/components/SideNav/Content/LevelTwoContent.jsx.html +722 -0
  56. package/coverage/lcov-report/components/SideNav/Content/index.html +141 -0
  57. package/coverage/lcov-report/components/SideNav/Content/index.js.html +92 -0
  58. package/coverage/lcov-report/components/SideNav/Details/IndividualDetails.jsx.html +134 -0
  59. package/coverage/lcov-report/components/SideNav/Details/PracticeDetails.jsx.html +203 -0
  60. package/coverage/lcov-report/components/SideNav/Details/index.html +141 -0
  61. package/coverage/lcov-report/components/SideNav/Details/index.js.html +92 -0
  62. package/coverage/lcov-report/components/SideNav/Links/CmsSwitchLink.jsx.html +203 -0
  63. package/coverage/lcov-report/components/SideNav/Links/NavItemInline.jsx.html +242 -0
  64. package/coverage/lcov-report/components/SideNav/Links/NavLinkContainer.jsx.html +209 -0
  65. package/coverage/lcov-report/components/SideNav/Links/NavLinkDrawer.jsx.html +659 -0
  66. package/coverage/lcov-report/components/SideNav/Links/NavLinkInline.jsx.html +401 -0
  67. package/coverage/lcov-report/components/SideNav/Links/NavLinkToggle.jsx.html +182 -0
  68. package/coverage/lcov-report/components/SideNav/Links/index.html +201 -0
  69. package/coverage/lcov-report/components/SideNav/Links/index.js.html +119 -0
  70. package/coverage/lcov-report/components/SideNav/UI/SideNavUI.jsx.html +1103 -0
  71. package/coverage/lcov-report/components/SideNav/UI/index.html +126 -0
  72. package/coverage/lcov-report/components/SideNav/UI/index.js.html +89 -0
  73. package/coverage/lcov-report/components/SideNav/helpers.js.html +221 -0
  74. package/coverage/lcov-report/components/SideNav/index.html +111 -0
  75. package/coverage/lcov-report/components/Tooltip/Tooltip.jsx.html +344 -0
  76. package/coverage/lcov-report/components/Tooltip/index.html +141 -0
  77. package/coverage/lcov-report/components/Tooltip/index.js.html +89 -0
  78. package/coverage/lcov-report/components/Tooltip/position.js.html +284 -0
  79. package/coverage/lcov-report/components/index.html +111 -0
  80. package/coverage/lcov-report/favicon.png +0 -0
  81. package/coverage/lcov-report/index.html +426 -0
  82. package/coverage/lcov-report/lib/Chevron.jsx.html +161 -0
  83. package/coverage/lcov-report/lib/SvgComponents.jsx.html +1697 -0
  84. package/coverage/lcov-report/lib/index.html +141 -0
  85. package/coverage/lcov-report/lib/svg-definitions.svg.html +455 -0
  86. package/coverage/lcov-report/prettify.css +1 -0
  87. package/coverage/lcov-report/prettify.js +2 -0
  88. package/coverage/lcov-report/react/components/Accordion/index.html +111 -0
  89. package/coverage/lcov-report/react/components/Accordion/index.jsx.html +359 -0
  90. package/coverage/lcov-report/react/components/Error/Collapsible.jsx.html +344 -0
  91. package/coverage/lcov-report/react/components/Error/ErrorUI.jsx.html +173 -0
  92. package/coverage/lcov-report/react/components/Error/error.js.html +158 -0
  93. package/coverage/lcov-report/react/components/Error/index.html +141 -0
  94. package/coverage/lcov-report/react/components/Footer/FooterUI.jsx.html +845 -0
  95. package/coverage/lcov-report/react/components/Footer/LegacyFooterUI.jsx.html +662 -0
  96. package/coverage/lcov-report/react/components/Footer/SocialLinks.jsx.html +260 -0
  97. package/coverage/lcov-report/react/components/Footer/Subscribe.jsx.html +182 -0
  98. package/coverage/lcov-report/react/components/Footer/footer.js.html +170 -0
  99. package/coverage/lcov-report/react/components/Footer/index.html +171 -0
  100. package/coverage/lcov-report/react/components/Header/HeaderAccountMenu.jsx.html +587 -0
  101. package/coverage/lcov-report/react/components/Header/HeaderCancel.jsx.html +128 -0
  102. package/coverage/lcov-report/react/components/Header/HeaderContainer.jsx.html +260 -0
  103. package/coverage/lcov-report/react/components/Header/HeaderLogo.jsx.html +206 -0
  104. package/coverage/lcov-report/react/components/Header/HeaderMenuButton.js.html +230 -0
  105. package/coverage/lcov-report/react/components/Header/HeaderMenuItem.jsx.html +749 -0
  106. package/coverage/lcov-report/react/components/Header/HeaderMenuLink.js.html +230 -0
  107. package/coverage/lcov-report/react/components/Header/HeaderMenuSignOutButton.js.html +266 -0
  108. package/coverage/lcov-report/react/components/Header/HeaderMobileButton.js.html +191 -0
  109. package/coverage/lcov-report/react/components/Header/HeaderUI.jsx.html +557 -0
  110. package/coverage/lcov-report/react/components/Header/HelpIcon.jsx.html +176 -0
  111. package/coverage/lcov-report/react/components/Header/NavigationButtonIcon.jsx.html +161 -0
  112. package/coverage/lcov-report/react/components/Header/header.js.html +194 -0
  113. package/coverage/lcov-report/react/components/Header/hooks.js.html +236 -0
  114. package/coverage/lcov-report/react/components/Header/index.html +321 -0
  115. package/coverage/lcov-report/react/components/Header/utag-helpers.js.html +107 -0
  116. package/coverage/lcov-report/react/components/InfoModal/index.html +111 -0
  117. package/coverage/lcov-report/react/components/InfoModal/index.jsx.html +392 -0
  118. package/coverage/lcov-report/react/components/Infotip/Infotip.jsx.html +305 -0
  119. package/coverage/lcov-report/react/components/Infotip/InfotipIcon.jsx.html +203 -0
  120. package/coverage/lcov-report/react/components/Infotip/index.html +141 -0
  121. package/coverage/lcov-report/react/components/Infotip/index.js.html +89 -0
  122. package/coverage/lcov-report/react/components/Modal/LegacyModal.jsx.html +296 -0
  123. package/coverage/lcov-report/react/components/Modal/Modal.jsx.html +500 -0
  124. package/coverage/lcov-report/react/components/Modal/index.html +141 -0
  125. package/coverage/lcov-report/react/components/Modal/index.jsx.html +146 -0
  126. package/coverage/lcov-report/react/components/NotificationBanner/NotificationBannerUI.jsx.html +950 -0
  127. package/coverage/lcov-report/react/components/NotificationBanner/index.html +111 -0
  128. package/coverage/lcov-report/react/components/NotificationBanner/index.js.html +875 -0
  129. package/coverage/lcov-report/react/components/SanitizedContent/index.html +111 -0
  130. package/coverage/lcov-report/react/components/SanitizedContent/index.jsx.html +680 -0
  131. package/coverage/lcov-report/react/components/SessionDialog/index.html +111 -0
  132. package/coverage/lcov-report/react/components/SessionDialog/sessionDialog.js.html +158 -0
  133. package/coverage/lcov-report/react/components/SessionDialogUI.jsx.html +863 -0
  134. package/coverage/lcov-report/react/components/SideNav/AnimationGroup/AnimationGroup.jsx.html +146 -0
  135. package/coverage/lcov-report/react/components/SideNav/AnimationGroup/index.html +111 -0
  136. package/coverage/lcov-report/react/components/SideNav/Chart/ScoreChart.jsx.html +884 -0
  137. package/coverage/lcov-report/react/components/SideNav/Chart/index.html +126 -0
  138. package/coverage/lcov-report/react/components/SideNav/Chart/index.js.html +89 -0
  139. package/coverage/lcov-report/react/components/SideNav/Content/LevelOneContent.jsx.html +590 -0
  140. package/coverage/lcov-report/react/components/SideNav/Content/LevelTwoContent.jsx.html +728 -0
  141. package/coverage/lcov-report/react/components/SideNav/Content/index.html +141 -0
  142. package/coverage/lcov-report/react/components/SideNav/Content/index.js.html +92 -0
  143. package/coverage/lcov-report/react/components/SideNav/Details/IndividualDetails.jsx.html +134 -0
  144. package/coverage/lcov-report/react/components/SideNav/Details/PracticeDetails.jsx.html +215 -0
  145. package/coverage/lcov-report/react/components/SideNav/Details/index.html +141 -0
  146. package/coverage/lcov-report/react/components/SideNav/Details/index.js.html +92 -0
  147. package/coverage/lcov-report/react/components/SideNav/Links/CmsSwitchLink.jsx.html +203 -0
  148. package/coverage/lcov-report/react/components/SideNav/Links/NavItemInline.jsx.html +242 -0
  149. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkContainer.jsx.html +194 -0
  150. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkDrawer.jsx.html +695 -0
  151. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkInline.jsx.html +401 -0
  152. package/coverage/lcov-report/react/components/SideNav/Links/NavLinkToggle.jsx.html +182 -0
  153. package/coverage/lcov-report/react/components/SideNav/Links/index.html +201 -0
  154. package/coverage/lcov-report/react/components/SideNav/Links/index.js.html +119 -0
  155. package/coverage/lcov-report/react/components/SideNav/UI/SideNavUI.jsx.html +1052 -0
  156. package/coverage/lcov-report/react/components/SideNav/UI/index.html +126 -0
  157. package/coverage/lcov-report/react/components/SideNav/UI/index.js.html +89 -0
  158. package/coverage/lcov-report/react/components/SideNav/helpers.js.html +227 -0
  159. package/coverage/lcov-report/react/components/SideNav/index.html +126 -0
  160. package/coverage/lcov-report/react/components/SideNav/index.js.html +239 -0
  161. package/coverage/lcov-report/react/components/Tooltip/Tooltip.jsx.html +344 -0
  162. package/coverage/lcov-report/react/components/Tooltip/index.html +141 -0
  163. package/coverage/lcov-report/react/components/Tooltip/index.js.html +89 -0
  164. package/coverage/lcov-report/react/components/Tooltip/position.js.html +284 -0
  165. package/coverage/lcov-report/react/components/hooks/index.html +111 -0
  166. package/coverage/lcov-report/react/components/hooks/useGetConfig.js.html +302 -0
  167. package/coverage/lcov-report/react/components/index.html +111 -0
  168. package/coverage/lcov-report/react/index.html +111 -0
  169. package/coverage/lcov-report/react/index.js.html +173 -0
  170. package/coverage/lcov-report/react/lib/Chevron.jsx.html +176 -0
  171. package/coverage/lcov-report/react/lib/SvgComponents.jsx.html +1697 -0
  172. package/coverage/lcov-report/react/lib/index.html +141 -0
  173. package/coverage/lcov-report/react/lib/svg-definitions.svg.html +455 -0
  174. package/coverage/lcov-report/react/session/index.html +156 -0
  175. package/coverage/lcov-report/react/session/index.js.html +95 -0
  176. package/coverage/lcov-report/react/session/logout.js.html +203 -0
  177. package/coverage/lcov-report/react/session/refresh.js.html +227 -0
  178. package/coverage/lcov-report/react/session/ttl.js.html +191 -0
  179. package/coverage/lcov-report/session/index.html +126 -0
  180. package/coverage/lcov-report/session/index.js.html +95 -0
  181. package/coverage/lcov-report/session/logout.js.html +203 -0
  182. package/coverage/lcov-report/session/refresh.js.html +227 -0
  183. package/coverage/lcov-report/session/ttl.js.html +191 -0
  184. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  185. package/coverage/lcov-report/sorter.js +170 -0
  186. package/coverage/lcov.info +2673 -0
  187. package/dist/browser.js +1 -1
  188. package/dist/browser.js.map +1 -1
  189. package/dist/index.js +1 -1
  190. package/dist/index.js.map +1 -1
  191. package/dist/react/index.js +1 -1
  192. package/dist/react/index.js.map +1 -1
  193. package/images/icons/svg/tooltip-question.svg +6 -0
  194. package/package.json +28 -26
  195. package/storybook-static/0.284246fa7dd756530022.manager.bundle.js +1 -0
  196. package/storybook-static/0.e444ffe0.iframe.bundle.js +1 -0
  197. package/storybook-static/4.38e07a72.iframe.bundle.js +3 -0
  198. package/storybook-static/4.38e07a72.iframe.bundle.js.LICENSE.txt +8 -0
  199. package/storybook-static/4.38e07a72.iframe.bundle.js.map +1 -0
  200. package/storybook-static/4.5a2288a7314de45771fd.manager.bundle.js +2 -0
  201. package/storybook-static/4.5a2288a7314de45771fd.manager.bundle.js.LICENSE.txt +8 -0
  202. package/storybook-static/5.96d29e90.iframe.bundle.js +1 -0
  203. package/storybook-static/5.f669e5db79f970f4eeda.manager.bundle.js +2 -0
  204. package/storybook-static/5.f669e5db79f970f4eeda.manager.bundle.js.LICENSE.txt +12 -0
  205. package/storybook-static/6.fbe12c4b.iframe.bundle.js +3 -0
  206. package/storybook-static/6.fbe12c4b.iframe.bundle.js.LICENSE.txt +12 -0
  207. package/storybook-static/6.fbe12c4b.iframe.bundle.js.map +1 -0
  208. package/storybook-static/6.fc183cb0948fa18c4851.manager.bundle.js +1 -0
  209. package/storybook-static/7.6262147d7bfe4804e70d.manager.bundle.js +1 -0
  210. package/storybook-static/7.9e6103c8.iframe.bundle.js +1 -0
  211. package/storybook-static/8.88a822e73e773dbd9da6.manager.bundle.js +1 -0
  212. package/storybook-static/favicon.ico +0 -0
  213. package/storybook-static/fonts/FontAwesome.otf +0 -0
  214. package/storybook-static/fonts/OFL.txt +92 -0
  215. package/storybook-static/fonts/Rubik-Black.ttf +0 -0
  216. package/storybook-static/fonts/Rubik-BlackItalic.ttf +0 -0
  217. package/storybook-static/fonts/Rubik-Bold.ttf +0 -0
  218. package/storybook-static/fonts/Rubik-BoldItalic.ttf +0 -0
  219. package/storybook-static/fonts/Rubik-Italic.ttf +0 -0
  220. package/storybook-static/fonts/Rubik-Light.ttf +0 -0
  221. package/storybook-static/fonts/Rubik-LightItalic.ttf +0 -0
  222. package/storybook-static/fonts/Rubik-Medium.ttf +0 -0
  223. package/storybook-static/fonts/Rubik-MediumItalic.ttf +0 -0
  224. package/storybook-static/fonts/Rubik-Regular.ttf +0 -0
  225. package/storybook-static/fonts/fontawesome-webfont.eot +0 -0
  226. package/storybook-static/fonts/fontawesome-webfont.svg +2671 -0
  227. package/storybook-static/fonts/fontawesome-webfont.ttf +0 -0
  228. package/storybook-static/fonts/fontawesome-webfont.woff +0 -0
  229. package/storybook-static/fonts/fontawesome-webfont.woff2 +0 -0
  230. package/storybook-static/iframe.html +138 -0
  231. package/storybook-static/images/favicon/android-chrome-192x192.png +0 -0
  232. package/storybook-static/images/favicon/android-chrome-256x256.png +0 -0
  233. package/storybook-static/images/favicon/apple-touch-icon.png +0 -0
  234. package/storybook-static/images/favicon/browserconfig.xml +9 -0
  235. package/storybook-static/images/favicon/favicon-16x16.png +0 -0
  236. package/storybook-static/images/favicon/favicon-32x32.png +0 -0
  237. package/storybook-static/images/favicon/favicon.ico +0 -0
  238. package/storybook-static/images/favicon/manifest.json +18 -0
  239. package/storybook-static/images/favicon/mstile-150x150.png +0 -0
  240. package/storybook-static/images/favicon/safari-pinned-tab.svg +32 -0
  241. package/storybook-static/images/hhs-logo-black.svg +10 -0
  242. package/storybook-static/images/hhs-logo-white.svg +10 -0
  243. package/storybook-static/images/icons/close-x.svg +6 -0
  244. package/storybook-static/images/icons/help-headset.svg +21 -0
  245. package/storybook-static/images/icons/svg/arrow-down.svg +3 -0
  246. package/storybook-static/images/icons/svg/arrow-download.svg +5 -0
  247. package/storybook-static/images/icons/svg/arrow-right.svg +5 -0
  248. package/storybook-static/images/icons/svg/close.svg +3 -0
  249. package/storybook-static/images/icons/svg/download.svg +1 -0
  250. package/storybook-static/images/icons/svg/external.svg +4 -0
  251. package/storybook-static/images/icons/svg/file-upload.svg +1 -0
  252. package/storybook-static/images/icons/svg/print.svg +4 -0
  253. package/storybook-static/images/icons/svg/trash.svg +5 -0
  254. package/storybook-static/images/icons/svg/upload.svg +3 -0
  255. package/storybook-static/images/qpp_logo_reversed.png +0 -0
  256. package/storybook-static/images/qpp_logo_rgb_color.png +0 -0
  257. package/storybook-static/index.html +55 -0
  258. package/storybook-static/main.18ac9bfd601c66f4bee6.manager.bundle.js +1 -0
  259. package/storybook-static/main.9d42b744.iframe.bundle.js +1 -0
  260. package/storybook-static/runtime~main.d17fbed7a9ad1d2c431e.manager.bundle.js +1 -0
  261. package/storybook-static/runtime~main.ed6e2009.iframe.bundle.js +1 -0
  262. package/storybook-static/static/media/Bitter-Bold.091bd4b7.woff +0 -0
  263. package/storybook-static/static/media/Bitter-Bold.24bf01e4.woff2 +0 -0
  264. package/storybook-static/static/media/Bitter-Bold.46bc29e4.ttf +0 -0
  265. package/storybook-static/static/media/Bitter-Bold.790f4f2f.eot +0 -0
  266. package/storybook-static/static/media/Bitter-Italic.1fa5390c.eot +0 -0
  267. package/storybook-static/static/media/Bitter-Italic.25e5675f.woff +0 -0
  268. package/storybook-static/static/media/Bitter-Italic.2eb18f5a.ttf +0 -0
  269. package/storybook-static/static/media/Bitter-Italic.34644574.woff2 +0 -0
  270. package/storybook-static/static/media/Bitter-Regular.4b22b6e8.woff +0 -0
  271. package/storybook-static/static/media/Bitter-Regular.559e7075.eot +0 -0
  272. package/storybook-static/static/media/Bitter-Regular.8db0301b.ttf +0 -0
  273. package/storybook-static/static/media/Bitter-Regular.f4e2f1f1.woff2 +0 -0
  274. package/storybook-static/static/media/FontAwesome.91f80bba.otf +0 -0
  275. package/storybook-static/static/media/OpenSans-Bold-webfont.202d819d.eot +0 -0
  276. package/storybook-static/static/media/OpenSans-Bold-webfont.92e570c6.woff2 +0 -0
  277. package/storybook-static/static/media/OpenSans-Bold-webfont.da71e99a.ttf +0 -0
  278. package/storybook-static/static/media/OpenSans-Bold-webfont.e75949bb.woff +0 -0
  279. package/storybook-static/static/media/OpenSans-Italic-webfont.72daa33a.woff2 +0 -0
  280. package/storybook-static/static/media/OpenSans-Italic-webfont.74ead3a8.woff +0 -0
  281. package/storybook-static/static/media/OpenSans-Italic-webfont.ae19388f.eot +0 -0
  282. package/storybook-static/static/media/OpenSans-Italic-webfont.ec7a2746.ttf +0 -0
  283. package/storybook-static/static/media/OpenSans-Regular-webfont.63a5fa7d.woff +0 -0
  284. package/storybook-static/static/media/OpenSans-Regular-webfont.66451be4.ttf +0 -0
  285. package/storybook-static/static/media/OpenSans-Regular-webfont.7882d20f.eot +0 -0
  286. package/storybook-static/static/media/OpenSans-Regular-webfont.ca4dd835.woff2 +0 -0
  287. package/storybook-static/static/media/OpenSans-Semibold-webfont.17ded75f.woff2 +0 -0
  288. package/storybook-static/static/media/OpenSans-Semibold-webfont.2a5adf6c.woff +0 -0
  289. package/storybook-static/static/media/OpenSans-Semibold-webfont.6059fecb.ttf +0 -0
  290. package/storybook-static/static/media/OpenSans-Semibold-webfont.c9808185.eot +0 -0
  291. package/storybook-static/static/media/Rubik-Bold.31bbd4d2.ttf +0 -0
  292. package/storybook-static/static/media/Rubik-Light.c90e2014.ttf +0 -0
  293. package/storybook-static/static/media/Rubik-Medium.5daa89aa.ttf +0 -0
  294. package/storybook-static/static/media/Rubik-Regular.cdf97d58.ttf +0 -0
  295. package/storybook-static/static/media/fontawesome-webfont.1e59d233.ttf +0 -0
  296. package/storybook-static/static/media/fontawesome-webfont.20fd1704.woff2 +0 -0
  297. package/storybook-static/static/media/fontawesome-webfont.8b43027f.eot +0 -0
  298. package/storybook-static/static/media/fontawesome-webfont.f691f37e.woff +0 -0
  299. package/storybook-static/vendors~main.3604044d8484c1c4d1f7.manager.bundle.js +2 -0
  300. package/storybook-static/vendors~main.3604044d8484c1c4d1f7.manager.bundle.js.LICENSE.txt +88 -0
  301. package/storybook-static/vendors~main.7f923d15.iframe.bundle.js +3 -0
  302. package/storybook-static/vendors~main.7f923d15.iframe.bundle.js.LICENSE.txt +152 -0
  303. package/storybook-static/vendors~main.7f923d15.iframe.bundle.js.map +1 -0
  304. package/styles/_main.scss +1 -0
  305. package/styles/components/_footer.scss +593 -0
  306. package/styles/components/_header.scss +887 -0
  307. package/styles/components/_sidebar.scss +8 -0
  308. package/styles/components/sidebar/_animations.scss +38 -0
  309. package/styles/components/sidebar/_cms.scss +61 -0
  310. package/styles/components/sidebar/_details.scss +58 -0
  311. package/styles/components/sidebar/_links.scss +415 -0
  312. package/styles/components/sidebar/_sidebar-animation.scss +121 -0
  313. package/styles/components/sidebar/_sidebar-tooltip.scss +33 -0
  314. package/styles/components/sidebar/_sidebar.scss +141 -0
  315. package/styles/components/sidebar/project-specific/_wi.scss +42 -0
  316. package/styles/qppds/base/_icon.scss +21 -0
  317. package/styles/qppds/base/index.scss +1 -0
  318. package/styles/qppds/components/_button.scss +1 -1
  319. package/styles/qppds/components/_dropdown.scss +4 -0
  320. package/styles/qppds/components/_pagination.scss +227 -0
  321. package/styles/qppds/components/index.scss +1 -0
  322. package/styles/qppds/components/sidebar/_links.scss +24 -2
  323. package/styles/qppds/components/sidebar/_sidebar-animation.scss +4 -0
  324. package/styles/qppds/components/sidebar/_sidebar.scss +4 -0
  325. package/styles/qppds/settings/mixins/_icons.scss +29 -2
  326. package/styles/qppds/utilities/_display-visability.scss +83 -0
  327. package/webpack.config.js +20 -18
  328. package/webpack.config.react.js +0 -1
@@ -0,0 +1,950 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <title>Code coverage report for react/components/NotificationBanner/NotificationBannerUI.jsx</title>
7
+ <meta charset="utf-8" />
8
+ <link rel="stylesheet" href="../../../prettify.css" />
9
+ <link rel="stylesheet" href="../../../base.css" />
10
+ <link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
11
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
12
+ <style type='text/css'>
13
+ .coverage-summary .sorter {
14
+ background-image: url(../../../sort-arrow-sprite.png);
15
+ }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <div class='wrapper'>
21
+ <div class='pad1'>
22
+ <h1><a href="../../../index.html">All files</a> / <a href="index.html">react/components/NotificationBanner</a> NotificationBannerUI.jsx</h1>
23
+ <div class='clearfix'>
24
+
25
+ <div class='fl pad1y space-right2'>
26
+ <span class="strong">27.69% </span>
27
+ <span class="quiet">Statements</span>
28
+ <span class='fraction'>18/65</span>
29
+ </div>
30
+
31
+
32
+ <div class='fl pad1y space-right2'>
33
+ <span class="strong">8.33% </span>
34
+ <span class="quiet">Branches</span>
35
+ <span class='fraction'>4/48</span>
36
+ </div>
37
+
38
+
39
+ <div class='fl pad1y space-right2'>
40
+ <span class="strong">21.05% </span>
41
+ <span class="quiet">Functions</span>
42
+ <span class='fraction'>4/19</span>
43
+ </div>
44
+
45
+
46
+ <div class='fl pad1y space-right2'>
47
+ <span class="strong">27.69% </span>
48
+ <span class="quiet">Lines</span>
49
+ <span class='fraction'>18/65</span>
50
+ </div>
51
+
52
+
53
+ </div>
54
+ <p class="quiet">
55
+ Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
+ </p>
57
+ </div>
58
+ <div class='status-line low'></div>
59
+ <pre><table class="coverage">
60
+ <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
61
+ <a name='L2'></a><a href='#L2'>2</a>
62
+ <a name='L3'></a><a href='#L3'>3</a>
63
+ <a name='L4'></a><a href='#L4'>4</a>
64
+ <a name='L5'></a><a href='#L5'>5</a>
65
+ <a name='L6'></a><a href='#L6'>6</a>
66
+ <a name='L7'></a><a href='#L7'>7</a>
67
+ <a name='L8'></a><a href='#L8'>8</a>
68
+ <a name='L9'></a><a href='#L9'>9</a>
69
+ <a name='L10'></a><a href='#L10'>10</a>
70
+ <a name='L11'></a><a href='#L11'>11</a>
71
+ <a name='L12'></a><a href='#L12'>12</a>
72
+ <a name='L13'></a><a href='#L13'>13</a>
73
+ <a name='L14'></a><a href='#L14'>14</a>
74
+ <a name='L15'></a><a href='#L15'>15</a>
75
+ <a name='L16'></a><a href='#L16'>16</a>
76
+ <a name='L17'></a><a href='#L17'>17</a>
77
+ <a name='L18'></a><a href='#L18'>18</a>
78
+ <a name='L19'></a><a href='#L19'>19</a>
79
+ <a name='L20'></a><a href='#L20'>20</a>
80
+ <a name='L21'></a><a href='#L21'>21</a>
81
+ <a name='L22'></a><a href='#L22'>22</a>
82
+ <a name='L23'></a><a href='#L23'>23</a>
83
+ <a name='L24'></a><a href='#L24'>24</a>
84
+ <a name='L25'></a><a href='#L25'>25</a>
85
+ <a name='L26'></a><a href='#L26'>26</a>
86
+ <a name='L27'></a><a href='#L27'>27</a>
87
+ <a name='L28'></a><a href='#L28'>28</a>
88
+ <a name='L29'></a><a href='#L29'>29</a>
89
+ <a name='L30'></a><a href='#L30'>30</a>
90
+ <a name='L31'></a><a href='#L31'>31</a>
91
+ <a name='L32'></a><a href='#L32'>32</a>
92
+ <a name='L33'></a><a href='#L33'>33</a>
93
+ <a name='L34'></a><a href='#L34'>34</a>
94
+ <a name='L35'></a><a href='#L35'>35</a>
95
+ <a name='L36'></a><a href='#L36'>36</a>
96
+ <a name='L37'></a><a href='#L37'>37</a>
97
+ <a name='L38'></a><a href='#L38'>38</a>
98
+ <a name='L39'></a><a href='#L39'>39</a>
99
+ <a name='L40'></a><a href='#L40'>40</a>
100
+ <a name='L41'></a><a href='#L41'>41</a>
101
+ <a name='L42'></a><a href='#L42'>42</a>
102
+ <a name='L43'></a><a href='#L43'>43</a>
103
+ <a name='L44'></a><a href='#L44'>44</a>
104
+ <a name='L45'></a><a href='#L45'>45</a>
105
+ <a name='L46'></a><a href='#L46'>46</a>
106
+ <a name='L47'></a><a href='#L47'>47</a>
107
+ <a name='L48'></a><a href='#L48'>48</a>
108
+ <a name='L49'></a><a href='#L49'>49</a>
109
+ <a name='L50'></a><a href='#L50'>50</a>
110
+ <a name='L51'></a><a href='#L51'>51</a>
111
+ <a name='L52'></a><a href='#L52'>52</a>
112
+ <a name='L53'></a><a href='#L53'>53</a>
113
+ <a name='L54'></a><a href='#L54'>54</a>
114
+ <a name='L55'></a><a href='#L55'>55</a>
115
+ <a name='L56'></a><a href='#L56'>56</a>
116
+ <a name='L57'></a><a href='#L57'>57</a>
117
+ <a name='L58'></a><a href='#L58'>58</a>
118
+ <a name='L59'></a><a href='#L59'>59</a>
119
+ <a name='L60'></a><a href='#L60'>60</a>
120
+ <a name='L61'></a><a href='#L61'>61</a>
121
+ <a name='L62'></a><a href='#L62'>62</a>
122
+ <a name='L63'></a><a href='#L63'>63</a>
123
+ <a name='L64'></a><a href='#L64'>64</a>
124
+ <a name='L65'></a><a href='#L65'>65</a>
125
+ <a name='L66'></a><a href='#L66'>66</a>
126
+ <a name='L67'></a><a href='#L67'>67</a>
127
+ <a name='L68'></a><a href='#L68'>68</a>
128
+ <a name='L69'></a><a href='#L69'>69</a>
129
+ <a name='L70'></a><a href='#L70'>70</a>
130
+ <a name='L71'></a><a href='#L71'>71</a>
131
+ <a name='L72'></a><a href='#L72'>72</a>
132
+ <a name='L73'></a><a href='#L73'>73</a>
133
+ <a name='L74'></a><a href='#L74'>74</a>
134
+ <a name='L75'></a><a href='#L75'>75</a>
135
+ <a name='L76'></a><a href='#L76'>76</a>
136
+ <a name='L77'></a><a href='#L77'>77</a>
137
+ <a name='L78'></a><a href='#L78'>78</a>
138
+ <a name='L79'></a><a href='#L79'>79</a>
139
+ <a name='L80'></a><a href='#L80'>80</a>
140
+ <a name='L81'></a><a href='#L81'>81</a>
141
+ <a name='L82'></a><a href='#L82'>82</a>
142
+ <a name='L83'></a><a href='#L83'>83</a>
143
+ <a name='L84'></a><a href='#L84'>84</a>
144
+ <a name='L85'></a><a href='#L85'>85</a>
145
+ <a name='L86'></a><a href='#L86'>86</a>
146
+ <a name='L87'></a><a href='#L87'>87</a>
147
+ <a name='L88'></a><a href='#L88'>88</a>
148
+ <a name='L89'></a><a href='#L89'>89</a>
149
+ <a name='L90'></a><a href='#L90'>90</a>
150
+ <a name='L91'></a><a href='#L91'>91</a>
151
+ <a name='L92'></a><a href='#L92'>92</a>
152
+ <a name='L93'></a><a href='#L93'>93</a>
153
+ <a name='L94'></a><a href='#L94'>94</a>
154
+ <a name='L95'></a><a href='#L95'>95</a>
155
+ <a name='L96'></a><a href='#L96'>96</a>
156
+ <a name='L97'></a><a href='#L97'>97</a>
157
+ <a name='L98'></a><a href='#L98'>98</a>
158
+ <a name='L99'></a><a href='#L99'>99</a>
159
+ <a name='L100'></a><a href='#L100'>100</a>
160
+ <a name='L101'></a><a href='#L101'>101</a>
161
+ <a name='L102'></a><a href='#L102'>102</a>
162
+ <a name='L103'></a><a href='#L103'>103</a>
163
+ <a name='L104'></a><a href='#L104'>104</a>
164
+ <a name='L105'></a><a href='#L105'>105</a>
165
+ <a name='L106'></a><a href='#L106'>106</a>
166
+ <a name='L107'></a><a href='#L107'>107</a>
167
+ <a name='L108'></a><a href='#L108'>108</a>
168
+ <a name='L109'></a><a href='#L109'>109</a>
169
+ <a name='L110'></a><a href='#L110'>110</a>
170
+ <a name='L111'></a><a href='#L111'>111</a>
171
+ <a name='L112'></a><a href='#L112'>112</a>
172
+ <a name='L113'></a><a href='#L113'>113</a>
173
+ <a name='L114'></a><a href='#L114'>114</a>
174
+ <a name='L115'></a><a href='#L115'>115</a>
175
+ <a name='L116'></a><a href='#L116'>116</a>
176
+ <a name='L117'></a><a href='#L117'>117</a>
177
+ <a name='L118'></a><a href='#L118'>118</a>
178
+ <a name='L119'></a><a href='#L119'>119</a>
179
+ <a name='L120'></a><a href='#L120'>120</a>
180
+ <a name='L121'></a><a href='#L121'>121</a>
181
+ <a name='L122'></a><a href='#L122'>122</a>
182
+ <a name='L123'></a><a href='#L123'>123</a>
183
+ <a name='L124'></a><a href='#L124'>124</a>
184
+ <a name='L125'></a><a href='#L125'>125</a>
185
+ <a name='L126'></a><a href='#L126'>126</a>
186
+ <a name='L127'></a><a href='#L127'>127</a>
187
+ <a name='L128'></a><a href='#L128'>128</a>
188
+ <a name='L129'></a><a href='#L129'>129</a>
189
+ <a name='L130'></a><a href='#L130'>130</a>
190
+ <a name='L131'></a><a href='#L131'>131</a>
191
+ <a name='L132'></a><a href='#L132'>132</a>
192
+ <a name='L133'></a><a href='#L133'>133</a>
193
+ <a name='L134'></a><a href='#L134'>134</a>
194
+ <a name='L135'></a><a href='#L135'>135</a>
195
+ <a name='L136'></a><a href='#L136'>136</a>
196
+ <a name='L137'></a><a href='#L137'>137</a>
197
+ <a name='L138'></a><a href='#L138'>138</a>
198
+ <a name='L139'></a><a href='#L139'>139</a>
199
+ <a name='L140'></a><a href='#L140'>140</a>
200
+ <a name='L141'></a><a href='#L141'>141</a>
201
+ <a name='L142'></a><a href='#L142'>142</a>
202
+ <a name='L143'></a><a href='#L143'>143</a>
203
+ <a name='L144'></a><a href='#L144'>144</a>
204
+ <a name='L145'></a><a href='#L145'>145</a>
205
+ <a name='L146'></a><a href='#L146'>146</a>
206
+ <a name='L147'></a><a href='#L147'>147</a>
207
+ <a name='L148'></a><a href='#L148'>148</a>
208
+ <a name='L149'></a><a href='#L149'>149</a>
209
+ <a name='L150'></a><a href='#L150'>150</a>
210
+ <a name='L151'></a><a href='#L151'>151</a>
211
+ <a name='L152'></a><a href='#L152'>152</a>
212
+ <a name='L153'></a><a href='#L153'>153</a>
213
+ <a name='L154'></a><a href='#L154'>154</a>
214
+ <a name='L155'></a><a href='#L155'>155</a>
215
+ <a name='L156'></a><a href='#L156'>156</a>
216
+ <a name='L157'></a><a href='#L157'>157</a>
217
+ <a name='L158'></a><a href='#L158'>158</a>
218
+ <a name='L159'></a><a href='#L159'>159</a>
219
+ <a name='L160'></a><a href='#L160'>160</a>
220
+ <a name='L161'></a><a href='#L161'>161</a>
221
+ <a name='L162'></a><a href='#L162'>162</a>
222
+ <a name='L163'></a><a href='#L163'>163</a>
223
+ <a name='L164'></a><a href='#L164'>164</a>
224
+ <a name='L165'></a><a href='#L165'>165</a>
225
+ <a name='L166'></a><a href='#L166'>166</a>
226
+ <a name='L167'></a><a href='#L167'>167</a>
227
+ <a name='L168'></a><a href='#L168'>168</a>
228
+ <a name='L169'></a><a href='#L169'>169</a>
229
+ <a name='L170'></a><a href='#L170'>170</a>
230
+ <a name='L171'></a><a href='#L171'>171</a>
231
+ <a name='L172'></a><a href='#L172'>172</a>
232
+ <a name='L173'></a><a href='#L173'>173</a>
233
+ <a name='L174'></a><a href='#L174'>174</a>
234
+ <a name='L175'></a><a href='#L175'>175</a>
235
+ <a name='L176'></a><a href='#L176'>176</a>
236
+ <a name='L177'></a><a href='#L177'>177</a>
237
+ <a name='L178'></a><a href='#L178'>178</a>
238
+ <a name='L179'></a><a href='#L179'>179</a>
239
+ <a name='L180'></a><a href='#L180'>180</a>
240
+ <a name='L181'></a><a href='#L181'>181</a>
241
+ <a name='L182'></a><a href='#L182'>182</a>
242
+ <a name='L183'></a><a href='#L183'>183</a>
243
+ <a name='L184'></a><a href='#L184'>184</a>
244
+ <a name='L185'></a><a href='#L185'>185</a>
245
+ <a name='L186'></a><a href='#L186'>186</a>
246
+ <a name='L187'></a><a href='#L187'>187</a>
247
+ <a name='L188'></a><a href='#L188'>188</a>
248
+ <a name='L189'></a><a href='#L189'>189</a>
249
+ <a name='L190'></a><a href='#L190'>190</a>
250
+ <a name='L191'></a><a href='#L191'>191</a>
251
+ <a name='L192'></a><a href='#L192'>192</a>
252
+ <a name='L193'></a><a href='#L193'>193</a>
253
+ <a name='L194'></a><a href='#L194'>194</a>
254
+ <a name='L195'></a><a href='#L195'>195</a>
255
+ <a name='L196'></a><a href='#L196'>196</a>
256
+ <a name='L197'></a><a href='#L197'>197</a>
257
+ <a name='L198'></a><a href='#L198'>198</a>
258
+ <a name='L199'></a><a href='#L199'>199</a>
259
+ <a name='L200'></a><a href='#L200'>200</a>
260
+ <a name='L201'></a><a href='#L201'>201</a>
261
+ <a name='L202'></a><a href='#L202'>202</a>
262
+ <a name='L203'></a><a href='#L203'>203</a>
263
+ <a name='L204'></a><a href='#L204'>204</a>
264
+ <a name='L205'></a><a href='#L205'>205</a>
265
+ <a name='L206'></a><a href='#L206'>206</a>
266
+ <a name='L207'></a><a href='#L207'>207</a>
267
+ <a name='L208'></a><a href='#L208'>208</a>
268
+ <a name='L209'></a><a href='#L209'>209</a>
269
+ <a name='L210'></a><a href='#L210'>210</a>
270
+ <a name='L211'></a><a href='#L211'>211</a>
271
+ <a name='L212'></a><a href='#L212'>212</a>
272
+ <a name='L213'></a><a href='#L213'>213</a>
273
+ <a name='L214'></a><a href='#L214'>214</a>
274
+ <a name='L215'></a><a href='#L215'>215</a>
275
+ <a name='L216'></a><a href='#L216'>216</a>
276
+ <a name='L217'></a><a href='#L217'>217</a>
277
+ <a name='L218'></a><a href='#L218'>218</a>
278
+ <a name='L219'></a><a href='#L219'>219</a>
279
+ <a name='L220'></a><a href='#L220'>220</a>
280
+ <a name='L221'></a><a href='#L221'>221</a>
281
+ <a name='L222'></a><a href='#L222'>222</a>
282
+ <a name='L223'></a><a href='#L223'>223</a>
283
+ <a name='L224'></a><a href='#L224'>224</a>
284
+ <a name='L225'></a><a href='#L225'>225</a>
285
+ <a name='L226'></a><a href='#L226'>226</a>
286
+ <a name='L227'></a><a href='#L227'>227</a>
287
+ <a name='L228'></a><a href='#L228'>228</a>
288
+ <a name='L229'></a><a href='#L229'>229</a>
289
+ <a name='L230'></a><a href='#L230'>230</a>
290
+ <a name='L231'></a><a href='#L231'>231</a>
291
+ <a name='L232'></a><a href='#L232'>232</a>
292
+ <a name='L233'></a><a href='#L233'>233</a>
293
+ <a name='L234'></a><a href='#L234'>234</a>
294
+ <a name='L235'></a><a href='#L235'>235</a>
295
+ <a name='L236'></a><a href='#L236'>236</a>
296
+ <a name='L237'></a><a href='#L237'>237</a>
297
+ <a name='L238'></a><a href='#L238'>238</a>
298
+ <a name='L239'></a><a href='#L239'>239</a>
299
+ <a name='L240'></a><a href='#L240'>240</a>
300
+ <a name='L241'></a><a href='#L241'>241</a>
301
+ <a name='L242'></a><a href='#L242'>242</a>
302
+ <a name='L243'></a><a href='#L243'>243</a>
303
+ <a name='L244'></a><a href='#L244'>244</a>
304
+ <a name='L245'></a><a href='#L245'>245</a>
305
+ <a name='L246'></a><a href='#L246'>246</a>
306
+ <a name='L247'></a><a href='#L247'>247</a>
307
+ <a name='L248'></a><a href='#L248'>248</a>
308
+ <a name='L249'></a><a href='#L249'>249</a>
309
+ <a name='L250'></a><a href='#L250'>250</a>
310
+ <a name='L251'></a><a href='#L251'>251</a>
311
+ <a name='L252'></a><a href='#L252'>252</a>
312
+ <a name='L253'></a><a href='#L253'>253</a>
313
+ <a name='L254'></a><a href='#L254'>254</a>
314
+ <a name='L255'></a><a href='#L255'>255</a>
315
+ <a name='L256'></a><a href='#L256'>256</a>
316
+ <a name='L257'></a><a href='#L257'>257</a>
317
+ <a name='L258'></a><a href='#L258'>258</a>
318
+ <a name='L259'></a><a href='#L259'>259</a>
319
+ <a name='L260'></a><a href='#L260'>260</a>
320
+ <a name='L261'></a><a href='#L261'>261</a>
321
+ <a name='L262'></a><a href='#L262'>262</a>
322
+ <a name='L263'></a><a href='#L263'>263</a>
323
+ <a name='L264'></a><a href='#L264'>264</a>
324
+ <a name='L265'></a><a href='#L265'>265</a>
325
+ <a name='L266'></a><a href='#L266'>266</a>
326
+ <a name='L267'></a><a href='#L267'>267</a>
327
+ <a name='L268'></a><a href='#L268'>268</a>
328
+ <a name='L269'></a><a href='#L269'>269</a>
329
+ <a name='L270'></a><a href='#L270'>270</a>
330
+ <a name='L271'></a><a href='#L271'>271</a>
331
+ <a name='L272'></a><a href='#L272'>272</a>
332
+ <a name='L273'></a><a href='#L273'>273</a>
333
+ <a name='L274'></a><a href='#L274'>274</a>
334
+ <a name='L275'></a><a href='#L275'>275</a>
335
+ <a name='L276'></a><a href='#L276'>276</a>
336
+ <a name='L277'></a><a href='#L277'>277</a>
337
+ <a name='L278'></a><a href='#L278'>278</a>
338
+ <a name='L279'></a><a href='#L279'>279</a>
339
+ <a name='L280'></a><a href='#L280'>280</a>
340
+ <a name='L281'></a><a href='#L281'>281</a>
341
+ <a name='L282'></a><a href='#L282'>282</a>
342
+ <a name='L283'></a><a href='#L283'>283</a>
343
+ <a name='L284'></a><a href='#L284'>284</a>
344
+ <a name='L285'></a><a href='#L285'>285</a>
345
+ <a name='L286'></a><a href='#L286'>286</a>
346
+ <a name='L287'></a><a href='#L287'>287</a>
347
+ <a name='L288'></a><a href='#L288'>288</a>
348
+ <a name='L289'></a><a href='#L289'>289</a>
349
+ <a name='L290'></a><a href='#L290'>290</a>
350
+ <a name='L291'></a><a href='#L291'>291</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
351
+ <span class="cline-any cline-neutral">&nbsp;</span>
352
+ <span class="cline-any cline-neutral">&nbsp;</span>
353
+ <span class="cline-any cline-neutral">&nbsp;</span>
354
+ <span class="cline-any cline-neutral">&nbsp;</span>
355
+ <span class="cline-any cline-neutral">&nbsp;</span>
356
+ <span class="cline-any cline-neutral">&nbsp;</span>
357
+ <span class="cline-any cline-neutral">&nbsp;</span>
358
+ <span class="cline-any cline-neutral">&nbsp;</span>
359
+ <span class="cline-any cline-neutral">&nbsp;</span>
360
+ <span class="cline-any cline-neutral">&nbsp;</span>
361
+ <span class="cline-any cline-neutral">&nbsp;</span>
362
+ <span class="cline-any cline-neutral">&nbsp;</span>
363
+ <span class="cline-any cline-neutral">&nbsp;</span>
364
+ <span class="cline-any cline-neutral">&nbsp;</span>
365
+ <span class="cline-any cline-neutral">&nbsp;</span>
366
+ <span class="cline-any cline-neutral">&nbsp;</span>
367
+ <span class="cline-any cline-neutral">&nbsp;</span>
368
+ <span class="cline-any cline-yes">2x</span>
369
+ <span class="cline-any cline-neutral">&nbsp;</span>
370
+ <span class="cline-any cline-yes">2x</span>
371
+ <span class="cline-any cline-neutral">&nbsp;</span>
372
+ <span class="cline-any cline-neutral">&nbsp;</span>
373
+ <span class="cline-any cline-neutral">&nbsp;</span>
374
+ <span class="cline-any cline-neutral">&nbsp;</span>
375
+ <span class="cline-any cline-neutral">&nbsp;</span>
376
+ <span class="cline-any cline-yes">2x</span>
377
+ <span class="cline-any cline-yes">2x</span>
378
+ <span class="cline-any cline-yes">2x</span>
379
+ <span class="cline-any cline-yes">2x</span>
380
+ <span class="cline-any cline-neutral">&nbsp;</span>
381
+ <span class="cline-any cline-neutral">&nbsp;</span>
382
+ <span class="cline-any cline-neutral">&nbsp;</span>
383
+ <span class="cline-any cline-neutral">&nbsp;</span>
384
+ <span class="cline-any cline-neutral">&nbsp;</span>
385
+ <span class="cline-any cline-neutral">&nbsp;</span>
386
+ <span class="cline-any cline-neutral">&nbsp;</span>
387
+ <span class="cline-any cline-neutral">&nbsp;</span>
388
+ <span class="cline-any cline-yes">2x</span>
389
+ <span class="cline-any cline-yes">2x</span>
390
+ <span class="cline-any cline-neutral">&nbsp;</span>
391
+ <span class="cline-any cline-yes">2x</span>
392
+ <span class="cline-any cline-no">&nbsp;</span>
393
+ <span class="cline-any cline-neutral">&nbsp;</span>
394
+ <span class="cline-any cline-no">&nbsp;</span>
395
+ <span class="cline-any cline-no">&nbsp;</span>
396
+ <span class="cline-any cline-neutral">&nbsp;</span>
397
+ <span class="cline-any cline-neutral">&nbsp;</span>
398
+ <span class="cline-any cline-neutral">&nbsp;</span>
399
+ <span class="cline-any cline-neutral">&nbsp;</span>
400
+ <span class="cline-any cline-neutral">&nbsp;</span>
401
+ <span class="cline-any cline-neutral">&nbsp;</span>
402
+ <span class="cline-any cline-neutral">&nbsp;</span>
403
+ <span class="cline-any cline-neutral">&nbsp;</span>
404
+ <span class="cline-any cline-neutral">&nbsp;</span>
405
+ <span class="cline-any cline-neutral">&nbsp;</span>
406
+ <span class="cline-any cline-yes">2x</span>
407
+ <span class="cline-any cline-no">&nbsp;</span>
408
+ <span class="cline-any cline-neutral">&nbsp;</span>
409
+ <span class="cline-any cline-neutral">&nbsp;</span>
410
+ <span class="cline-any cline-neutral">&nbsp;</span>
411
+ <span class="cline-any cline-neutral">&nbsp;</span>
412
+ <span class="cline-any cline-yes">2x</span>
413
+ <span class="cline-any cline-yes">2x</span>
414
+ <span class="cline-any cline-neutral">&nbsp;</span>
415
+ <span class="cline-any cline-neutral">&nbsp;</span>
416
+ <span class="cline-any cline-neutral">&nbsp;</span>
417
+ <span class="cline-any cline-neutral">&nbsp;</span>
418
+ <span class="cline-any cline-neutral">&nbsp;</span>
419
+ <span class="cline-any cline-neutral">&nbsp;</span>
420
+ <span class="cline-any cline-neutral">&nbsp;</span>
421
+ <span class="cline-any cline-yes">2x</span>
422
+ <span class="cline-any cline-yes">2x</span>
423
+ <span class="cline-any cline-neutral">&nbsp;</span>
424
+ <span class="cline-any cline-no">&nbsp;</span>
425
+ <span class="cline-any cline-neutral">&nbsp;</span>
426
+ <span class="cline-any cline-neutral">&nbsp;</span>
427
+ <span class="cline-any cline-neutral">&nbsp;</span>
428
+ <span class="cline-any cline-neutral">&nbsp;</span>
429
+ <span class="cline-any cline-no">&nbsp;</span>
430
+ <span class="cline-any cline-no">&nbsp;</span>
431
+ <span class="cline-any cline-neutral">&nbsp;</span>
432
+ <span class="cline-any cline-no">&nbsp;</span>
433
+ <span class="cline-any cline-neutral">&nbsp;</span>
434
+ <span class="cline-any cline-neutral">&nbsp;</span>
435
+ <span class="cline-any cline-neutral">&nbsp;</span>
436
+ <span class="cline-any cline-no">&nbsp;</span>
437
+ <span class="cline-any cline-neutral">&nbsp;</span>
438
+ <span class="cline-any cline-neutral">&nbsp;</span>
439
+ <span class="cline-any cline-neutral">&nbsp;</span>
440
+ <span class="cline-any cline-neutral">&nbsp;</span>
441
+ <span class="cline-any cline-neutral">&nbsp;</span>
442
+ <span class="cline-any cline-neutral">&nbsp;</span>
443
+ <span class="cline-any cline-neutral">&nbsp;</span>
444
+ <span class="cline-any cline-neutral">&nbsp;</span>
445
+ <span class="cline-any cline-neutral">&nbsp;</span>
446
+ <span class="cline-any cline-neutral">&nbsp;</span>
447
+ <span class="cline-any cline-neutral">&nbsp;</span>
448
+ <span class="cline-any cline-neutral">&nbsp;</span>
449
+ <span class="cline-any cline-neutral">&nbsp;</span>
450
+ <span class="cline-any cline-neutral">&nbsp;</span>
451
+ <span class="cline-any cline-neutral">&nbsp;</span>
452
+ <span class="cline-any cline-neutral">&nbsp;</span>
453
+ <span class="cline-any cline-no">&nbsp;</span>
454
+ <span class="cline-any cline-no">&nbsp;</span>
455
+ <span class="cline-any cline-neutral">&nbsp;</span>
456
+ <span class="cline-any cline-no">&nbsp;</span>
457
+ <span class="cline-any cline-neutral">&nbsp;</span>
458
+ <span class="cline-any cline-neutral">&nbsp;</span>
459
+ <span class="cline-any cline-no">&nbsp;</span>
460
+ <span class="cline-any cline-neutral">&nbsp;</span>
461
+ <span class="cline-any cline-neutral">&nbsp;</span>
462
+ <span class="cline-any cline-neutral">&nbsp;</span>
463
+ <span class="cline-any cline-no">&nbsp;</span>
464
+ <span class="cline-any cline-no">&nbsp;</span>
465
+ <span class="cline-any cline-neutral">&nbsp;</span>
466
+ <span class="cline-any cline-no">&nbsp;</span>
467
+ <span class="cline-any cline-neutral">&nbsp;</span>
468
+ <span class="cline-any cline-neutral">&nbsp;</span>
469
+ <span class="cline-any cline-neutral">&nbsp;</span>
470
+ <span class="cline-any cline-neutral">&nbsp;</span>
471
+ <span class="cline-any cline-no">&nbsp;</span>
472
+ <span class="cline-any cline-neutral">&nbsp;</span>
473
+ <span class="cline-any cline-neutral">&nbsp;</span>
474
+ <span class="cline-any cline-neutral">&nbsp;</span>
475
+ <span class="cline-any cline-neutral">&nbsp;</span>
476
+ <span class="cline-any cline-neutral">&nbsp;</span>
477
+ <span class="cline-any cline-neutral">&nbsp;</span>
478
+ <span class="cline-any cline-neutral">&nbsp;</span>
479
+ <span class="cline-any cline-neutral">&nbsp;</span>
480
+ <span class="cline-any cline-neutral">&nbsp;</span>
481
+ <span class="cline-any cline-no">&nbsp;</span>
482
+ <span class="cline-any cline-neutral">&nbsp;</span>
483
+ <span class="cline-any cline-neutral">&nbsp;</span>
484
+ <span class="cline-any cline-neutral">&nbsp;</span>
485
+ <span class="cline-any cline-neutral">&nbsp;</span>
486
+ <span class="cline-any cline-neutral">&nbsp;</span>
487
+ <span class="cline-any cline-neutral">&nbsp;</span>
488
+ <span class="cline-any cline-neutral">&nbsp;</span>
489
+ <span class="cline-any cline-neutral">&nbsp;</span>
490
+ <span class="cline-any cline-no">&nbsp;</span>
491
+ <span class="cline-any cline-no">&nbsp;</span>
492
+ <span class="cline-any cline-no">&nbsp;</span>
493
+ <span class="cline-any cline-neutral">&nbsp;</span>
494
+ <span class="cline-any cline-no">&nbsp;</span>
495
+ <span class="cline-any cline-no">&nbsp;</span>
496
+ <span class="cline-any cline-no">&nbsp;</span>
497
+ <span class="cline-any cline-neutral">&nbsp;</span>
498
+ <span class="cline-any cline-neutral">&nbsp;</span>
499
+ <span class="cline-any cline-no">&nbsp;</span>
500
+ <span class="cline-any cline-neutral">&nbsp;</span>
501
+ <span class="cline-any cline-neutral">&nbsp;</span>
502
+ <span class="cline-any cline-neutral">&nbsp;</span>
503
+ <span class="cline-any cline-no">&nbsp;</span>
504
+ <span class="cline-any cline-no">&nbsp;</span>
505
+ <span class="cline-any cline-neutral">&nbsp;</span>
506
+ <span class="cline-any cline-neutral">&nbsp;</span>
507
+ <span class="cline-any cline-neutral">&nbsp;</span>
508
+ <span class="cline-any cline-neutral">&nbsp;</span>
509
+ <span class="cline-any cline-neutral">&nbsp;</span>
510
+ <span class="cline-any cline-neutral">&nbsp;</span>
511
+ <span class="cline-any cline-neutral">&nbsp;</span>
512
+ <span class="cline-any cline-no">&nbsp;</span>
513
+ <span class="cline-any cline-neutral">&nbsp;</span>
514
+ <span class="cline-any cline-neutral">&nbsp;</span>
515
+ <span class="cline-any cline-neutral">&nbsp;</span>
516
+ <span class="cline-any cline-neutral">&nbsp;</span>
517
+ <span class="cline-any cline-neutral">&nbsp;</span>
518
+ <span class="cline-any cline-neutral">&nbsp;</span>
519
+ <span class="cline-any cline-neutral">&nbsp;</span>
520
+ <span class="cline-any cline-neutral">&nbsp;</span>
521
+ <span class="cline-any cline-no">&nbsp;</span>
522
+ <span class="cline-any cline-no">&nbsp;</span>
523
+ <span class="cline-any cline-no">&nbsp;</span>
524
+ <span class="cline-any cline-no">&nbsp;</span>
525
+ <span class="cline-any cline-no">&nbsp;</span>
526
+ <span class="cline-any cline-neutral">&nbsp;</span>
527
+ <span class="cline-any cline-neutral">&nbsp;</span>
528
+ <span class="cline-any cline-neutral">&nbsp;</span>
529
+ <span class="cline-any cline-neutral">&nbsp;</span>
530
+ <span class="cline-any cline-neutral">&nbsp;</span>
531
+ <span class="cline-any cline-neutral">&nbsp;</span>
532
+ <span class="cline-any cline-no">&nbsp;</span>
533
+ <span class="cline-any cline-no">&nbsp;</span>
534
+ <span class="cline-any cline-no">&nbsp;</span>
535
+ <span class="cline-any cline-no">&nbsp;</span>
536
+ <span class="cline-any cline-neutral">&nbsp;</span>
537
+ <span class="cline-any cline-neutral">&nbsp;</span>
538
+ <span class="cline-any cline-neutral">&nbsp;</span>
539
+ <span class="cline-any cline-neutral">&nbsp;</span>
540
+ <span class="cline-any cline-neutral">&nbsp;</span>
541
+ <span class="cline-any cline-neutral">&nbsp;</span>
542
+ <span class="cline-any cline-neutral">&nbsp;</span>
543
+ <span class="cline-any cline-neutral">&nbsp;</span>
544
+ <span class="cline-any cline-neutral">&nbsp;</span>
545
+ <span class="cline-any cline-neutral">&nbsp;</span>
546
+ <span class="cline-any cline-neutral">&nbsp;</span>
547
+ <span class="cline-any cline-neutral">&nbsp;</span>
548
+ <span class="cline-any cline-no">&nbsp;</span>
549
+ <span class="cline-any cline-no">&nbsp;</span>
550
+ <span class="cline-any cline-neutral">&nbsp;</span>
551
+ <span class="cline-any cline-neutral">&nbsp;</span>
552
+ <span class="cline-any cline-neutral">&nbsp;</span>
553
+ <span class="cline-any cline-neutral">&nbsp;</span>
554
+ <span class="cline-any cline-neutral">&nbsp;</span>
555
+ <span class="cline-any cline-neutral">&nbsp;</span>
556
+ <span class="cline-any cline-neutral">&nbsp;</span>
557
+ <span class="cline-any cline-neutral">&nbsp;</span>
558
+ <span class="cline-any cline-neutral">&nbsp;</span>
559
+ <span class="cline-any cline-neutral">&nbsp;</span>
560
+ <span class="cline-any cline-neutral">&nbsp;</span>
561
+ <span class="cline-any cline-neutral">&nbsp;</span>
562
+ <span class="cline-any cline-no">&nbsp;</span>
563
+ <span class="cline-any cline-neutral">&nbsp;</span>
564
+ <span class="cline-any cline-neutral">&nbsp;</span>
565
+ <span class="cline-any cline-neutral">&nbsp;</span>
566
+ <span class="cline-any cline-neutral">&nbsp;</span>
567
+ <span class="cline-any cline-neutral">&nbsp;</span>
568
+ <span class="cline-any cline-neutral">&nbsp;</span>
569
+ <span class="cline-any cline-neutral">&nbsp;</span>
570
+ <span class="cline-any cline-neutral">&nbsp;</span>
571
+ <span class="cline-any cline-neutral">&nbsp;</span>
572
+ <span class="cline-any cline-yes">2x</span>
573
+ <span class="cline-any cline-yes">2x</span>
574
+ <span class="cline-any cline-neutral">&nbsp;</span>
575
+ <span class="cline-any cline-no">&nbsp;</span>
576
+ <span class="cline-any cline-no">&nbsp;</span>
577
+ <span class="cline-any cline-neutral">&nbsp;</span>
578
+ <span class="cline-any cline-no">&nbsp;</span>
579
+ <span class="cline-any cline-neutral">&nbsp;</span>
580
+ <span class="cline-any cline-neutral">&nbsp;</span>
581
+ <span class="cline-any cline-no">&nbsp;</span>
582
+ <span class="cline-any cline-neutral">&nbsp;</span>
583
+ <span class="cline-any cline-neutral">&nbsp;</span>
584
+ <span class="cline-any cline-neutral">&nbsp;</span>
585
+ <span class="cline-any cline-no">&nbsp;</span>
586
+ <span class="cline-any cline-neutral">&nbsp;</span>
587
+ <span class="cline-any cline-neutral">&nbsp;</span>
588
+ <span class="cline-any cline-neutral">&nbsp;</span>
589
+ <span class="cline-any cline-neutral">&nbsp;</span>
590
+ <span class="cline-any cline-neutral">&nbsp;</span>
591
+ <span class="cline-any cline-neutral">&nbsp;</span>
592
+ <span class="cline-any cline-neutral">&nbsp;</span>
593
+ <span class="cline-any cline-neutral">&nbsp;</span>
594
+ <span class="cline-any cline-neutral">&nbsp;</span>
595
+ <span class="cline-any cline-neutral">&nbsp;</span>
596
+ <span class="cline-any cline-neutral">&nbsp;</span>
597
+ <span class="cline-any cline-neutral">&nbsp;</span>
598
+ <span class="cline-any cline-neutral">&nbsp;</span>
599
+ <span class="cline-any cline-neutral">&nbsp;</span>
600
+ <span class="cline-any cline-neutral">&nbsp;</span>
601
+ <span class="cline-any cline-neutral">&nbsp;</span>
602
+ <span class="cline-any cline-no">&nbsp;</span>
603
+ <span class="cline-any cline-neutral">&nbsp;</span>
604
+ <span class="cline-any cline-neutral">&nbsp;</span>
605
+ <span class="cline-any cline-neutral">&nbsp;</span>
606
+ <span class="cline-any cline-neutral">&nbsp;</span>
607
+ <span class="cline-any cline-no">&nbsp;</span>
608
+ <span class="cline-any cline-neutral">&nbsp;</span>
609
+ <span class="cline-any cline-neutral">&nbsp;</span>
610
+ <span class="cline-any cline-neutral">&nbsp;</span>
611
+ <span class="cline-any cline-neutral">&nbsp;</span>
612
+ <span class="cline-any cline-neutral">&nbsp;</span>
613
+ <span class="cline-any cline-neutral">&nbsp;</span>
614
+ <span class="cline-any cline-neutral">&nbsp;</span>
615
+ <span class="cline-any cline-neutral">&nbsp;</span>
616
+ <span class="cline-any cline-neutral">&nbsp;</span>
617
+ <span class="cline-any cline-neutral">&nbsp;</span>
618
+ <span class="cline-any cline-neutral">&nbsp;</span>
619
+ <span class="cline-any cline-neutral">&nbsp;</span>
620
+ <span class="cline-any cline-neutral">&nbsp;</span>
621
+ <span class="cline-any cline-neutral">&nbsp;</span>
622
+ <span class="cline-any cline-neutral">&nbsp;</span>
623
+ <span class="cline-any cline-neutral">&nbsp;</span>
624
+ <span class="cline-any cline-yes">2x</span>
625
+ <span class="cline-any cline-neutral">&nbsp;</span>
626
+ <span class="cline-any cline-neutral">&nbsp;</span>
627
+ <span class="cline-any cline-neutral">&nbsp;</span>
628
+ <span class="cline-any cline-neutral">&nbsp;</span>
629
+ <span class="cline-any cline-neutral">&nbsp;</span>
630
+ <span class="cline-any cline-neutral">&nbsp;</span>
631
+ <span class="cline-any cline-neutral">&nbsp;</span>
632
+ <span class="cline-any cline-neutral">&nbsp;</span>
633
+ <span class="cline-any cline-yes">2x</span>
634
+ <span class="cline-any cline-neutral">&nbsp;</span>
635
+ <span class="cline-any cline-neutral">&nbsp;</span>
636
+ <span class="cline-any cline-neutral">&nbsp;</span>
637
+ <span class="cline-any cline-neutral">&nbsp;</span>
638
+ <span class="cline-any cline-neutral">&nbsp;</span>
639
+ <span class="cline-any cline-neutral">&nbsp;</span>
640
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import React, { Component } from 'react';
641
+ import PropTypes from 'prop-types';
642
+ import SanitizedContent from '../SanitizedContent';
643
+ import { CloseXIcon, BellOutline } from '../../lib/SvgComponents.jsx';
644
+ &nbsp;
645
+ /**
646
+ * Renders the QPP NotificationBanner content.
647
+ */
648
+ export default class NotificationBannerUI extends Component {
649
+ /**
650
+ * @param {Object} props - An object containing content and config data
651
+ * @param {Boolean} props.dismissable - Whether to render a close button
652
+ * @param {String} props.content - An HTML string of content
653
+ * @param {String} props.name - The unique name of this NotificationBanner
654
+ * @param {Boolean} props.fromStorage - Whether to load content from
655
+ * localStorage
656
+ */
657
+ constructor(props) {
658
+ super(props);
659
+ &nbsp;
660
+ this.state = {
661
+ content: props.content,
662
+ label: props.label,
663
+ color: props.color,
664
+ };
665
+ &nbsp;
666
+ this._renderCloseButton = this.renderCloseButton.bind(this);
667
+ this._collapseNotification = this.collapseNotification.bind(this);
668
+ this._expandNotification = this.expandNotification.bind(this);
669
+ this._setBannerHeight = this.setBannerHeight.bind(this);
670
+ }
671
+ &nbsp;
672
+ /**
673
+ * If any notifications are found in localStorage, filter to ones that match
674
+ * this instance's unique props.name. If the notification is active, set the
675
+ * content, otherwise empty it.
676
+ */
677
+ componentDidMount() {
678
+ const notifications = this.getNotificationsFromStorage() || [];
679
+ const now = new Date();
680
+ &nbsp;
681
+ notifications
682
+ .filter(<span class="fstat-no" title="function not covered" >(x</span>) =&gt; <span class="cstat-no" title="statement not covered" >x.name === this.props.name)</span>
683
+ .forEach(<span class="fstat-no" title="function not covered" >(x</span>) =&gt; {
684
+ <span class="cstat-no" title="statement not covered" > if (this.isNotificationCurrent(now, x)) {</span>
685
+ <span class="cstat-no" title="statement not covered" > this.setState({</span>
686
+ content: this.props.fromStorage ? x.content : this.props.content,
687
+ label:
688
+ this.props.fromStorage &amp;&amp; x.label ? x.label : this.props.label,
689
+ color:
690
+ this.props.fromStorage &amp;&amp; x.color ? x.color : this.props.color,
691
+ expanded: this.isNotificationExpanded(x),
692
+ });
693
+ }
694
+ });
695
+ &nbsp;
696
+ <span class="missing-if-branch" title="if path not taken" >I</span>if (window.innerWidth &lt;= 767) {
697
+ <span class="cstat-no" title="statement not covered" > this.setState({</span>
698
+ expanded: false,
699
+ });
700
+ }
701
+ &nbsp;
702
+ window.addEventListener('load', this._setBannerHeight);
703
+ window.addEventListener('resize', this._setBannerHeight);
704
+ }
705
+ &nbsp;
706
+ /**
707
+ * Attempt to read notifications from localStorage
708
+ * @return {Array} An array of notification objects
709
+ */
710
+ getNotificationsFromStorage() {
711
+ try {
712
+ return JSON.parse(window.localStorage.getItem('notifications'));
713
+ } catch (e) {
714
+ <span class="cstat-no" title="statement not covered" > return [];</span>
715
+ }
716
+ }
717
+ &nbsp;
718
+ <span class="fstat-no" title="function not covered" > se</span>tBannerHeight() {
719
+ <span class="cstat-no" title="statement not covered" > if (this.state.content) {</span>
720
+ <span class="cstat-no" title="statement not covered" > this.bannerContainer.style.transition = 'none';</span>
721
+ &nbsp;
722
+ <span class="cstat-no" title="statement not covered" > this.state.expanded</span>
723
+ ? this.collapsedBanner.setAttribute('tabIndex', '-1')
724
+ : this.collapsedBanner.setAttribute('tabIndex', ' ');
725
+ &nbsp;
726
+ <span class="cstat-no" title="statement not covered" > this.setState({</span>
727
+ height: this.state.expanded
728
+ ? '100%'
729
+ : this.collapsedWrapper.offsetHeight + 'px',
730
+ });
731
+ }
732
+ }
733
+ &nbsp;
734
+ /**
735
+ * Check the notification properties to determine whether it is still active
736
+ * based on the current date and time.
737
+ *
738
+ * @param {Date} now
739
+ * @param {Object} notification
740
+ * @return {Boolean}
741
+ */
742
+ <span class="fstat-no" title="function not covered" > is</span>NotificationCurrent(now, notification) {
743
+ const startDate = <span class="cstat-no" title="statement not covered" >new Date(notification.startDate);</span>
744
+ const endDate = <span class="cstat-no" title="statement not covered" >new Date(notification.endDate);</span>
745
+ const isActive =
746
+ <span class="cstat-no" title="statement not covered" > (!this.isDateValid(startDate) &amp;&amp; !this.isDateValid(endDate)) ||</span>
747
+ (startDate &lt;= now &amp;&amp; now &lt;= endDate);
748
+ &nbsp;
749
+ <span class="cstat-no" title="statement not covered" > return isActive;</span>
750
+ }
751
+ &nbsp;
752
+ <span class="fstat-no" title="function not covered" > is</span>NotificationExpanded(notification) {
753
+ const dateDismissed = <span class="cstat-no" title="statement not covered" >new Date(notification.dateDismissed);</span>
754
+ const dateUpdated = <span class="cstat-no" title="statement not covered" >new Date(notification.dateUpdated);</span>
755
+ const notDismissed =
756
+ <span class="cstat-no" title="statement not covered" > (this.isDateValid(dateUpdated) &amp;&amp;</span>
757
+ this.isDateValid(dateDismissed) &amp;&amp;
758
+ dateUpdated &gt;= dateDismissed) ||
759
+ !this.isDateValid(dateDismissed);
760
+ &nbsp;
761
+ <span class="cstat-no" title="statement not covered" > return notDismissed;</span>
762
+ }
763
+ &nbsp;
764
+ /**
765
+ * Whether the date is valid, i.e. not null
766
+ *
767
+ * @param {Date} date
768
+ * @return {Boolean}
769
+ */
770
+ <span class="fstat-no" title="function not covered" > is</span>DateValid(date) {
771
+ <span class="cstat-no" title="statement not covered" > return !isNaN(Date.parse(date));</span>
772
+ }
773
+ &nbsp;
774
+ /**
775
+ * Try to find this NotificationBanner instance in localStorage, or else add
776
+ * a minimal version of it, and mark it with a dateDismissed, then update
777
+ * localStorage.
778
+ */
779
+ <span class="fstat-no" title="function not covered" > ma</span>rkNotificationClosed() {
780
+ let found = <span class="cstat-no" title="statement not covered" >false;</span>
781
+ const dateDismissed = <span class="cstat-no" title="statement not covered" >new Date().toISOString();</span>
782
+ let notifications = <span class="cstat-no" title="statement not covered" >(this.getNotificationsFromStorage() || []).map(</span>
783
+ <span class="fstat-no" title="function not covered" > (n</span>otification) =&gt; {
784
+ <span class="cstat-no" title="statement not covered" > if (notification.name === this.props.name) {</span>
785
+ <span class="cstat-no" title="statement not covered" > notification.dateDismissed = dateDismissed;</span>
786
+ <span class="cstat-no" title="statement not covered" > found = true;</span>
787
+ }
788
+ &nbsp;
789
+ <span class="cstat-no" title="statement not covered" > return notification;</span>
790
+ }
791
+ );
792
+ &nbsp;
793
+ <span class="cstat-no" title="statement not covered" > if (!found) {</span>
794
+ <span class="cstat-no" title="statement not covered" > notifications = notifications.concat([</span>
795
+ {
796
+ name: this.props.name,
797
+ dateDismissed,
798
+ },
799
+ ]);
800
+ }
801
+ &nbsp;
802
+ <span class="cstat-no" title="statement not covered" > window.localStorage.setItem('notifications', JSON.stringify(notifications));</span>
803
+ }
804
+ &nbsp;
805
+ /**
806
+ * Callback when the user dimisses a notification. Mark it as dismissed in
807
+ * localStorage, empty the contents, and dispatch a custom event to notify
808
+ * any observers that it has been dismissed.
809
+ */
810
+ <span class="fstat-no" title="function not covered" > co</span>llapseNotification(e) {
811
+ <span class="cstat-no" title="statement not covered" > e.stopPropagation();</span>
812
+ <span class="cstat-no" title="statement not covered" > this.markNotificationClosed();</span>
813
+ <span class="cstat-no" title="statement not covered" > this.collapsedBanner.setAttribute('tabIndex', ' ');</span>
814
+ <span class="cstat-no" title="statement not covered" > this.bannerContainer.style.transition = 'height .2s ease-out';</span>
815
+ <span class="cstat-no" title="statement not covered" > this.setState({</span>
816
+ expanded: false,
817
+ height: this.collapsedWrapper.offsetHeight + 'px',
818
+ });
819
+ }
820
+ &nbsp;
821
+ <span class="fstat-no" title="function not covered" > ex</span>pandNotification() {
822
+ <span class="cstat-no" title="statement not covered" > if (!this.state.expanded) {</span>
823
+ <span class="cstat-no" title="statement not covered" > this.collapsedBanner.setAttribute('tabIndex', '-1');</span>
824
+ <span class="cstat-no" title="statement not covered" > this.bannerContainer.style.transition = 'height .2s ease-out';</span>
825
+ <span class="cstat-no" title="statement not covered" > this.setState({</span>
826
+ expanded: true,
827
+ height: '100%',
828
+ });
829
+ }
830
+ }
831
+ &nbsp;
832
+ /**
833
+ * Renders the close button if the notification instance is dismissable.
834
+ *
835
+ * @return {String} HTML content
836
+ */
837
+ <span class="fstat-no" title="function not covered" > re</span>nderCloseButton() {
838
+ <span class="cstat-no" title="statement not covered" > if (this.props.dismissable) {</span>
839
+ <span class="cstat-no" title="statement not covered" > return (</span>
840
+ &lt;button
841
+ onClick={this._collapseNotification}
842
+ type="button"
843
+ className="notification-banner-close"
844
+ &gt;
845
+ &lt;svg className="close-icon" aria-hidden="true" focusable="false"&gt;
846
+ &lt;CloseXIcon /&gt;
847
+ &lt;/svg&gt;
848
+ &lt;span className="sr-only"&gt;Close&lt;/span&gt;
849
+ &lt;/button&gt;
850
+ );
851
+ } else {
852
+ <span class="cstat-no" title="statement not covered" > return '';</span>
853
+ }
854
+ }
855
+ &nbsp;
856
+ /**
857
+ * Render the notification if it has any contents.
858
+ *
859
+ * @return {String} HTML content
860
+ */
861
+ render() {
862
+ <span class="missing-if-branch" title="else path not taken" >E</span>if (this.state.content === '') {
863
+ return &lt;div id="notification-banner" /&gt;;
864
+ } else {
865
+ const notificationStatus = <span class="cstat-no" title="statement not covered" >this.state.expanded ? 'expanded' : 'collapsed';</span>
866
+ const className = <span class="cstat-no" title="statement not covered" >`notification-banner notification-banner-${this.state.color} ${notificationStatus}`;</span>
867
+ &nbsp;
868
+ <span class="cstat-no" title="statement not covered" > return (</span>
869
+ &lt;div
870
+ style={{ height: this.state.height }}
871
+ ref={<span class="fstat-no" title="function not covered" >(e</span>lem) =&gt; (<span class="cstat-no" title="statement not covered" >this.bannerContainer = elem)</span>}
872
+ className={className}
873
+ &gt;
874
+ &lt;div
875
+ ref={<span class="fstat-no" title="function not covered" >(e</span>lem) =&gt; (<span class="cstat-no" title="statement not covered" >this.expandedWrapper = elem)</span>}
876
+ className={`notification-banner-wrapper expanded-view`}
877
+ &gt;
878
+ &lt;div className="notification-banner-label"&gt;{this.state.label}&lt;/div&gt;
879
+ &lt;div className="notification-banner-content"&gt;
880
+ &lt;SanitizedContent
881
+ html={
882
+ this.state.expanded
883
+ ? this.state.content
884
+ : '&lt;p&gt;Nothing to see here&lt;/p&gt;'
885
+ }
886
+ /&gt;
887
+ &lt;/div&gt;
888
+ {this.state.expanded &amp;&amp; this._renderCloseButton()}
889
+ &lt;/div&gt;
890
+ &nbsp;
891
+ &lt;div
892
+ ref={<span class="fstat-no" title="function not covered" >(e</span>lem) =&gt; (<span class="cstat-no" title="statement not covered" >this.collapsedWrapper = elem)</span>}
893
+ className={`notification-banner-wrapper collapsed-view`}
894
+ onClick={this._expandNotification}
895
+ &gt;
896
+ &lt;button
897
+ ref={<span class="fstat-no" title="function not covered" >(e</span>lem) =&gt; (<span class="cstat-no" title="statement not covered" >this.collapsedBanner = elem)</span>}
898
+ className={`notification-banner-label`}
899
+ &gt;
900
+ {this.state.label}
901
+ &lt;span className="bell-icon"&gt;
902
+ &lt;svg aria-hidden="true" focusable="false"&gt;
903
+ &lt;BellOutline /&gt;
904
+ &lt;/svg&gt;
905
+ &lt;/span&gt;
906
+ &lt;/button&gt;
907
+ &lt;/div&gt;
908
+ &lt;/div&gt;
909
+ );
910
+ }
911
+ }
912
+ }
913
+ &nbsp;
914
+ NotificationBannerUI.propTypes = {
915
+ dismissable: PropTypes.bool,
916
+ content: PropTypes.string,
917
+ label: PropTypes.string,
918
+ name: PropTypes.string.isRequired,
919
+ fromStorage: PropTypes.bool,
920
+ color: PropTypes.string,
921
+ };
922
+ &nbsp;
923
+ NotificationBannerUI.defaultProps = {
924
+ dismissable: true,
925
+ content: '',
926
+ fromStorage: false,
927
+ label: 'Update',
928
+ color: 'blue',
929
+ };
930
+ &nbsp;</pre></td></tr></table></pre>
931
+
932
+ <div class='push'></div><!-- for sticky footer -->
933
+ </div><!-- /wrapper -->
934
+ <div class='footer quiet pad2 space-top1 center small'>
935
+ Code coverage generated by
936
+ <a href="https://istanbul.js.org/" target="_blank">istanbul</a>
937
+ at Tue Apr 20 2021 13:45:22 GMT-0700 (Pacific Daylight Time)
938
+ </div>
939
+ </div>
940
+ <script src="../../../prettify.js"></script>
941
+ <script>
942
+ window.onload = function () {
943
+ prettyPrint();
944
+ };
945
+ </script>
946
+ <script src="../../../sorter.js"></script>
947
+ <script src="../../../block-navigation.js"></script>
948
+ </body>
949
+ </html>
950
+