@knocklabs/react 0.7.16-canary.2 → 0.7.17

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 (338) hide show
  1. package/CHANGELOG.md +687 -0
  2. package/dist/cjs/index.css +1 -0
  3. package/dist/cjs/index.js +2 -0
  4. package/dist/cjs/index.js.map +1 -0
  5. package/dist/cjs/modules/core/components/Button/Button.js +2 -0
  6. package/dist/cjs/modules/core/components/Button/Button.js.map +1 -0
  7. package/dist/cjs/modules/core/components/Button/ButtonGroup.js +2 -0
  8. package/dist/cjs/modules/core/components/Button/ButtonGroup.js.map +1 -0
  9. package/dist/cjs/modules/core/components/Button/ButtonSpinner.js +2 -0
  10. package/dist/cjs/modules/core/components/Button/ButtonSpinner.js.map +1 -0
  11. package/dist/cjs/modules/core/components/Icons/Bell.js +2 -0
  12. package/dist/cjs/modules/core/components/Icons/Bell.js.map +1 -0
  13. package/dist/cjs/modules/core/components/Icons/CheckmarkCircle.js +2 -0
  14. package/dist/cjs/modules/core/components/Icons/CheckmarkCircle.js.map +1 -0
  15. package/dist/cjs/modules/core/components/Icons/ChevronDown.js +2 -0
  16. package/dist/cjs/modules/core/components/Icons/ChevronDown.js.map +1 -0
  17. package/dist/cjs/modules/core/components/Icons/CloseCircle.js +2 -0
  18. package/dist/cjs/modules/core/components/Icons/CloseCircle.js.map +1 -0
  19. package/dist/cjs/modules/core/components/Spinner/Spinner.js +13 -0
  20. package/dist/cjs/modules/core/components/Spinner/Spinner.js.map +1 -0
  21. package/dist/cjs/modules/core/hooks/useComponentVisible.js +2 -0
  22. package/dist/cjs/modules/core/hooks/useComponentVisible.js.map +1 -0
  23. package/dist/cjs/modules/core/hooks/useOnBottomScroll.js +2 -0
  24. package/dist/cjs/modules/core/hooks/useOnBottomScroll.js.map +1 -0
  25. package/dist/cjs/modules/core/utils.js +2 -0
  26. package/dist/cjs/modules/core/utils.js.map +1 -0
  27. package/dist/cjs/modules/feed/components/EmptyFeed/EmptyFeed.js +2 -0
  28. package/dist/cjs/modules/feed/components/EmptyFeed/EmptyFeed.js.map +1 -0
  29. package/dist/cjs/modules/feed/components/NotificationCell/ArchiveButton.js +2 -0
  30. package/dist/cjs/modules/feed/components/NotificationCell/ArchiveButton.js.map +1 -0
  31. package/dist/cjs/modules/feed/components/NotificationCell/Avatar.js +2 -0
  32. package/dist/cjs/modules/feed/components/NotificationCell/Avatar.js.map +1 -0
  33. package/dist/cjs/modules/feed/components/NotificationCell/NotificationCell.js +2 -0
  34. package/dist/cjs/modules/feed/components/NotificationCell/NotificationCell.js.map +1 -0
  35. package/dist/cjs/modules/feed/components/NotificationFeed/Dropdown.js +2 -0
  36. package/dist/cjs/modules/feed/components/NotificationFeed/Dropdown.js.map +1 -0
  37. package/dist/cjs/modules/feed/components/NotificationFeed/MarkAsRead.js +2 -0
  38. package/dist/cjs/modules/feed/components/NotificationFeed/MarkAsRead.js.map +1 -0
  39. package/dist/cjs/modules/feed/components/NotificationFeed/NotificationFeed.js +2 -0
  40. package/dist/cjs/modules/feed/components/NotificationFeed/NotificationFeed.js.map +1 -0
  41. package/dist/cjs/modules/feed/components/NotificationFeed/NotificationFeedHeader.js +2 -0
  42. package/dist/cjs/modules/feed/components/NotificationFeed/NotificationFeedHeader.js.map +1 -0
  43. package/dist/cjs/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.js +2 -0
  44. package/dist/cjs/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.js.map +1 -0
  45. package/dist/cjs/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.js +2 -0
  46. package/dist/cjs/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.js.map +1 -0
  47. package/dist/cjs/modules/feed/components/NotificationIconButton/NotificationIconButton.js +2 -0
  48. package/dist/cjs/modules/feed/components/NotificationIconButton/NotificationIconButton.js.map +1 -0
  49. package/dist/cjs/modules/feed/components/UnseenBadge/UnseenBadge.js +2 -0
  50. package/dist/cjs/modules/feed/components/UnseenBadge/UnseenBadge.js.map +1 -0
  51. package/dist/cjs/modules/guide/components/Banner/Banner.js +2 -0
  52. package/dist/cjs/modules/guide/components/Banner/Banner.js.map +1 -0
  53. package/dist/cjs/modules/guide/components/Card/Card.js +2 -0
  54. package/dist/cjs/modules/guide/components/Card/Card.js.map +1 -0
  55. package/dist/cjs/modules/guide/components/Modal/Modal.js +2 -0
  56. package/dist/cjs/modules/guide/components/Modal/Modal.js.map +1 -0
  57. package/dist/cjs/modules/guide/components/helpers.js +2 -0
  58. package/dist/cjs/modules/guide/components/helpers.js.map +1 -0
  59. package/dist/cjs/modules/ms-teams/components/MsTeamsAuthButton/MsTeamsAuthButton.js +2 -0
  60. package/dist/cjs/modules/ms-teams/components/MsTeamsAuthButton/MsTeamsAuthButton.js.map +1 -0
  61. package/dist/cjs/modules/ms-teams/components/MsTeamsAuthContainer/MsTeamsAuthContainer.js +2 -0
  62. package/dist/cjs/modules/ms-teams/components/MsTeamsAuthContainer/MsTeamsAuthContainer.js.map +1 -0
  63. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelCombobox.js +2 -0
  64. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelCombobox.js.map +1 -0
  65. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelInTeamCombobox.js +2 -0
  66. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelInTeamCombobox.js.map +1 -0
  67. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsConnectionError.js +2 -0
  68. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsConnectionError.js.map +1 -0
  69. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsErrorMessage.js +2 -0
  70. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsErrorMessage.js.map +1 -0
  71. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsTeamCombobox.js +2 -0
  72. package/dist/cjs/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsTeamCombobox.js.map +1 -0
  73. package/dist/cjs/modules/ms-teams/components/MsTeamsIcon/MsTeamsIcon.js +2 -0
  74. package/dist/cjs/modules/ms-teams/components/MsTeamsIcon/MsTeamsIcon.js.map +1 -0
  75. package/dist/cjs/modules/ms-teams/utils.js +2 -0
  76. package/dist/cjs/modules/ms-teams/utils.js.map +1 -0
  77. package/dist/cjs/modules/slack/components/SlackAddChannelInput/SlackAddChannelInput.js +2 -0
  78. package/dist/cjs/modules/slack/components/SlackAddChannelInput/SlackAddChannelInput.js.map +1 -0
  79. package/dist/cjs/modules/slack/components/SlackAuthButton/SlackAuthButton.js +2 -0
  80. package/dist/cjs/modules/slack/components/SlackAuthButton/SlackAuthButton.js.map +1 -0
  81. package/dist/cjs/modules/slack/components/SlackAuthContainer/SlackAuthContainer.js +2 -0
  82. package/dist/cjs/modules/slack/components/SlackAuthContainer/SlackAuthContainer.js.map +1 -0
  83. package/dist/cjs/modules/slack/components/SlackChannelCombobox/SlackChannelCombobox.js +2 -0
  84. package/dist/cjs/modules/slack/components/SlackChannelCombobox/SlackChannelCombobox.js.map +1 -0
  85. package/dist/cjs/modules/slack/components/SlackChannelCombobox/SlackConnectionError.js +2 -0
  86. package/dist/cjs/modules/slack/components/SlackChannelCombobox/SlackConnectionError.js.map +1 -0
  87. package/dist/cjs/modules/slack/components/SlackChannelCombobox/SlackErrorMessage.js +2 -0
  88. package/dist/cjs/modules/slack/components/SlackChannelCombobox/SlackErrorMessage.js.map +1 -0
  89. package/dist/cjs/modules/slack/components/SlackIcon/SlackIcon.js +2 -0
  90. package/dist/cjs/modules/slack/components/SlackIcon/SlackIcon.js.map +1 -0
  91. package/dist/cjs/modules/slack/utils.js +2 -0
  92. package/dist/cjs/modules/slack/utils.js.map +1 -0
  93. package/dist/esm/index.mjs +101 -0
  94. package/dist/esm/index.mjs.map +1 -0
  95. package/dist/esm/modules/core/components/Button/Button.mjs +22 -0
  96. package/dist/esm/modules/core/components/Button/Button.mjs.map +1 -0
  97. package/dist/esm/modules/core/components/Button/ButtonGroup.mjs +9 -0
  98. package/dist/esm/modules/core/components/Button/ButtonGroup.mjs.map +1 -0
  99. package/dist/esm/modules/core/components/Button/ButtonSpinner.mjs +10 -0
  100. package/dist/esm/modules/core/components/Button/ButtonSpinner.mjs.map +1 -0
  101. package/dist/esm/modules/core/components/Icons/Bell.mjs +10 -0
  102. package/dist/esm/modules/core/components/Icons/Bell.mjs.map +1 -0
  103. package/dist/esm/modules/core/components/Icons/CheckmarkCircle.mjs +10 -0
  104. package/dist/esm/modules/core/components/Icons/CheckmarkCircle.mjs.map +1 -0
  105. package/dist/esm/modules/core/components/Icons/ChevronDown.mjs +10 -0
  106. package/dist/esm/modules/core/components/Icons/ChevronDown.mjs.map +1 -0
  107. package/dist/esm/modules/core/components/Icons/CloseCircle.mjs +10 -0
  108. package/dist/esm/modules/core/components/Icons/CloseCircle.mjs.map +1 -0
  109. package/dist/esm/modules/core/components/Spinner/Spinner.mjs +31 -0
  110. package/dist/esm/modules/core/components/Spinner/Spinner.mjs.map +1 -0
  111. package/dist/esm/modules/core/hooks/useComponentVisible.mjs +20 -0
  112. package/dist/esm/modules/core/hooks/useComponentVisible.mjs.map +1 -0
  113. package/dist/esm/modules/core/hooks/useOnBottomScroll.mjs +22 -0
  114. package/dist/esm/modules/core/hooks/useOnBottomScroll.mjs.map +1 -0
  115. package/dist/esm/modules/core/utils.mjs +8 -0
  116. package/dist/esm/modules/core/utils.mjs.map +1 -0
  117. package/dist/esm/modules/feed/components/EmptyFeed/EmptyFeed.mjs +15 -0
  118. package/dist/esm/modules/feed/components/EmptyFeed/EmptyFeed.mjs.map +1 -0
  119. package/dist/esm/modules/feed/components/NotificationCell/ArchiveButton.mjs +41 -0
  120. package/dist/esm/modules/feed/components/NotificationCell/ArchiveButton.mjs.map +1 -0
  121. package/dist/esm/modules/feed/components/NotificationCell/Avatar.mjs +16 -0
  122. package/dist/esm/modules/feed/components/NotificationCell/Avatar.mjs.map +1 -0
  123. package/dist/esm/modules/feed/components/NotificationCell/NotificationCell.mjs +67 -0
  124. package/dist/esm/modules/feed/components/NotificationCell/NotificationCell.mjs.map +1 -0
  125. package/dist/esm/modules/feed/components/NotificationFeed/Dropdown.mjs +18 -0
  126. package/dist/esm/modules/feed/components/NotificationFeed/Dropdown.mjs.map +1 -0
  127. package/dist/esm/modules/feed/components/NotificationFeed/MarkAsRead.mjs +22 -0
  128. package/dist/esm/modules/feed/components/NotificationFeed/MarkAsRead.mjs.map +1 -0
  129. package/dist/esm/modules/feed/components/NotificationFeed/NotificationFeed.mjs +63 -0
  130. package/dist/esm/modules/feed/components/NotificationFeed/NotificationFeed.mjs.map +1 -0
  131. package/dist/esm/modules/feed/components/NotificationFeed/NotificationFeedHeader.mjs +18 -0
  132. package/dist/esm/modules/feed/components/NotificationFeed/NotificationFeedHeader.mjs.map +1 -0
  133. package/dist/esm/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.mjs +9 -0
  134. package/dist/esm/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.mjs.map +1 -0
  135. package/dist/esm/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.mjs +63 -0
  136. package/dist/esm/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.mjs.map +1 -0
  137. package/dist/esm/modules/feed/components/NotificationIconButton/NotificationIconButton.mjs +18 -0
  138. package/dist/esm/modules/feed/components/NotificationIconButton/NotificationIconButton.mjs.map +1 -0
  139. package/dist/esm/modules/feed/components/UnseenBadge/UnseenBadge.mjs +25 -0
  140. package/dist/esm/modules/feed/components/UnseenBadge/UnseenBadge.mjs.map +1 -0
  141. package/dist/esm/modules/guide/components/Banner/Banner.mjs +133 -0
  142. package/dist/esm/modules/guide/components/Banner/Banner.mjs.map +1 -0
  143. package/dist/esm/modules/guide/components/Card/Card.mjs +170 -0
  144. package/dist/esm/modules/guide/components/Card/Card.mjs.map +1 -0
  145. package/dist/esm/modules/guide/components/Modal/Modal.mjs +172 -0
  146. package/dist/esm/modules/guide/components/Modal/Modal.mjs.map +1 -0
  147. package/dist/esm/modules/guide/components/helpers.mjs +16 -0
  148. package/dist/esm/modules/guide/components/helpers.mjs.map +1 -0
  149. package/dist/esm/modules/ms-teams/components/MsTeamsAuthButton/MsTeamsAuthButton.mjs +43 -0
  150. package/dist/esm/modules/ms-teams/components/MsTeamsAuthButton/MsTeamsAuthButton.mjs.map +1 -0
  151. package/dist/esm/modules/ms-teams/components/MsTeamsAuthContainer/MsTeamsAuthContainer.mjs +17 -0
  152. package/dist/esm/modules/ms-teams/components/MsTeamsAuthContainer/MsTeamsAuthContainer.mjs.map +1 -0
  153. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelCombobox.mjs +28 -0
  154. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelCombobox.mjs.map +1 -0
  155. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelInTeamCombobox.mjs +40 -0
  156. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelInTeamCombobox.mjs.map +1 -0
  157. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsConnectionError.mjs +15 -0
  158. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsConnectionError.mjs.map +1 -0
  159. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsErrorMessage.mjs +10 -0
  160. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsErrorMessage.mjs.map +1 -0
  161. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsTeamCombobox.mjs +34 -0
  162. package/dist/esm/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsTeamCombobox.mjs.map +1 -0
  163. package/dist/esm/modules/ms-teams/components/MsTeamsIcon/MsTeamsIcon.mjs +15 -0
  164. package/dist/esm/modules/ms-teams/components/MsTeamsIcon/MsTeamsIcon.mjs.map +1 -0
  165. package/dist/esm/modules/ms-teams/utils.mjs +5 -0
  166. package/dist/esm/modules/ms-teams/utils.mjs.map +1 -0
  167. package/dist/esm/modules/slack/components/SlackAddChannelInput/SlackAddChannelInput.mjs +34 -0
  168. package/dist/esm/modules/slack/components/SlackAddChannelInput/SlackAddChannelInput.mjs.map +1 -0
  169. package/dist/esm/modules/slack/components/SlackAuthButton/SlackAuthButton.mjs +48 -0
  170. package/dist/esm/modules/slack/components/SlackAuthButton/SlackAuthButton.mjs.map +1 -0
  171. package/dist/esm/modules/slack/components/SlackAuthContainer/SlackAuthContainer.mjs +17 -0
  172. package/dist/esm/modules/slack/components/SlackAuthContainer/SlackAuthContainer.mjs.map +1 -0
  173. package/dist/esm/modules/slack/components/SlackChannelCombobox/SlackChannelCombobox.mjs +67 -0
  174. package/dist/esm/modules/slack/components/SlackChannelCombobox/SlackChannelCombobox.mjs.map +1 -0
  175. package/dist/esm/modules/slack/components/SlackChannelCombobox/SlackConnectionError.mjs +15 -0
  176. package/dist/esm/modules/slack/components/SlackChannelCombobox/SlackConnectionError.mjs.map +1 -0
  177. package/dist/esm/modules/slack/components/SlackChannelCombobox/SlackErrorMessage.mjs +10 -0
  178. package/dist/esm/modules/slack/components/SlackChannelCombobox/SlackErrorMessage.mjs.map +1 -0
  179. package/dist/esm/modules/slack/components/SlackIcon/SlackIcon.mjs +12 -0
  180. package/dist/esm/modules/slack/components/SlackIcon/SlackIcon.mjs.map +1 -0
  181. package/dist/esm/modules/slack/utils.mjs +5 -0
  182. package/dist/esm/modules/slack/utils.mjs.map +1 -0
  183. package/dist/index.css +1 -0
  184. package/dist/types/App.d.ts +4 -0
  185. package/dist/types/App.d.ts.map +1 -0
  186. package/dist/types/index.d.ts +7 -0
  187. package/dist/types/index.d.ts.map +1 -0
  188. package/dist/types/main.d.ts +1 -0
  189. package/dist/types/main.d.ts.map +1 -0
  190. package/dist/types/modules/core/components/Button/Button.d.ts +11 -0
  191. package/dist/types/modules/core/components/Button/Button.d.ts.map +1 -0
  192. package/dist/types/modules/core/components/Button/ButtonGroup.d.ts +5 -0
  193. package/dist/types/modules/core/components/Button/ButtonGroup.d.ts.map +1 -0
  194. package/dist/types/modules/core/components/Button/ButtonSpinner.d.ts +7 -0
  195. package/dist/types/modules/core/components/Button/ButtonSpinner.d.ts.map +1 -0
  196. package/dist/types/modules/core/components/Button/index.d.ts +3 -0
  197. package/dist/types/modules/core/components/Button/index.d.ts.map +1 -0
  198. package/dist/types/modules/core/components/Icons/Bell.d.ts +9 -0
  199. package/dist/types/modules/core/components/Icons/Bell.d.ts.map +1 -0
  200. package/dist/types/modules/core/components/Icons/CheckmarkCircle.d.ts +9 -0
  201. package/dist/types/modules/core/components/Icons/CheckmarkCircle.d.ts.map +1 -0
  202. package/dist/types/modules/core/components/Icons/ChevronDown.d.ts +9 -0
  203. package/dist/types/modules/core/components/Icons/ChevronDown.d.ts.map +1 -0
  204. package/dist/types/modules/core/components/Icons/CloseCircle.d.ts +9 -0
  205. package/dist/types/modules/core/components/Icons/CloseCircle.d.ts.map +1 -0
  206. package/dist/types/modules/core/components/Icons/index.d.ts +5 -0
  207. package/dist/types/modules/core/components/Icons/index.d.ts.map +1 -0
  208. package/dist/types/modules/core/components/Spinner/Spinner.d.ts +12 -0
  209. package/dist/types/modules/core/components/Spinner/Spinner.d.ts.map +1 -0
  210. package/dist/types/modules/core/components/Spinner/index.d.ts +2 -0
  211. package/dist/types/modules/core/components/Spinner/index.d.ts.map +1 -0
  212. package/dist/types/modules/core/hooks/index.d.ts +2 -0
  213. package/dist/types/modules/core/hooks/index.d.ts.map +1 -0
  214. package/dist/types/modules/core/hooks/useComponentVisible.d.ts +8 -0
  215. package/dist/types/modules/core/hooks/useComponentVisible.d.ts.map +1 -0
  216. package/dist/types/modules/core/hooks/useOnBottomScroll.d.ts +9 -0
  217. package/dist/types/modules/core/hooks/useOnBottomScroll.d.ts.map +1 -0
  218. package/dist/types/modules/core/index.d.ts +5 -0
  219. package/dist/types/modules/core/index.d.ts.map +1 -0
  220. package/dist/types/modules/core/utils.d.ts +2 -0
  221. package/dist/types/modules/core/utils.d.ts.map +1 -0
  222. package/dist/types/modules/feed/components/EmptyFeed/EmptyFeed.d.ts +3 -0
  223. package/dist/types/modules/feed/components/EmptyFeed/EmptyFeed.d.ts.map +1 -0
  224. package/dist/types/modules/feed/components/EmptyFeed/index.d.ts +2 -0
  225. package/dist/types/modules/feed/components/EmptyFeed/index.d.ts.map +1 -0
  226. package/dist/types/modules/feed/components/NotificationCell/ArchiveButton.d.ts +7 -0
  227. package/dist/types/modules/feed/components/NotificationCell/ArchiveButton.d.ts.map +1 -0
  228. package/dist/types/modules/feed/components/NotificationCell/Avatar.d.ts +7 -0
  229. package/dist/types/modules/feed/components/NotificationCell/Avatar.d.ts.map +1 -0
  230. package/dist/types/modules/feed/components/NotificationCell/NotificationCell.d.ts +12 -0
  231. package/dist/types/modules/feed/components/NotificationCell/NotificationCell.d.ts.map +1 -0
  232. package/dist/types/modules/feed/components/NotificationCell/index.d.ts +3 -0
  233. package/dist/types/modules/feed/components/NotificationCell/index.d.ts.map +1 -0
  234. package/dist/types/modules/feed/components/NotificationFeed/Dropdown.d.ts +7 -0
  235. package/dist/types/modules/feed/components/NotificationFeed/Dropdown.d.ts.map +1 -0
  236. package/dist/types/modules/feed/components/NotificationFeed/MarkAsRead.d.ts +7 -0
  237. package/dist/types/modules/feed/components/NotificationFeed/MarkAsRead.d.ts.map +1 -0
  238. package/dist/types/modules/feed/components/NotificationFeed/NotificationFeed.d.ts +27 -0
  239. package/dist/types/modules/feed/components/NotificationFeed/NotificationFeed.d.ts.map +1 -0
  240. package/dist/types/modules/feed/components/NotificationFeed/NotificationFeedHeader.d.ts +10 -0
  241. package/dist/types/modules/feed/components/NotificationFeed/NotificationFeedHeader.d.ts.map +1 -0
  242. package/dist/types/modules/feed/components/NotificationFeed/index.d.ts +4 -0
  243. package/dist/types/modules/feed/components/NotificationFeed/index.d.ts.map +1 -0
  244. package/dist/types/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.d.ts +5 -0
  245. package/dist/types/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.d.ts.map +1 -0
  246. package/dist/types/modules/feed/components/NotificationFeedContainer/index.d.ts +2 -0
  247. package/dist/types/modules/feed/components/NotificationFeedContainer/index.d.ts.map +1 -0
  248. package/dist/types/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.d.ts +19 -0
  249. package/dist/types/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.d.ts.map +1 -0
  250. package/dist/types/modules/feed/components/NotificationFeedPopover/index.d.ts +2 -0
  251. package/dist/types/modules/feed/components/NotificationFeedPopover/index.d.ts.map +1 -0
  252. package/dist/types/modules/feed/components/NotificationIconButton/NotificationIconButton.d.ts +8 -0
  253. package/dist/types/modules/feed/components/NotificationIconButton/NotificationIconButton.d.ts.map +1 -0
  254. package/dist/types/modules/feed/components/NotificationIconButton/index.d.ts +2 -0
  255. package/dist/types/modules/feed/components/NotificationIconButton/index.d.ts.map +1 -0
  256. package/dist/types/modules/feed/components/UnseenBadge/UnseenBadge.d.ts +7 -0
  257. package/dist/types/modules/feed/components/UnseenBadge/UnseenBadge.d.ts.map +1 -0
  258. package/dist/types/modules/feed/components/UnseenBadge/index.d.ts +2 -0
  259. package/dist/types/modules/feed/components/UnseenBadge/index.d.ts.map +1 -0
  260. package/dist/types/modules/feed/index.d.ts +8 -0
  261. package/dist/types/modules/feed/index.d.ts.map +1 -0
  262. package/dist/types/modules/guide/components/Banner/Banner.d.ts +46 -0
  263. package/dist/types/modules/guide/components/Banner/Banner.d.ts.map +1 -0
  264. package/dist/types/modules/guide/components/Banner/index.d.ts +2 -0
  265. package/dist/types/modules/guide/components/Banner/index.d.ts.map +1 -0
  266. package/dist/types/modules/guide/components/Card/Card.d.ts +56 -0
  267. package/dist/types/modules/guide/components/Card/Card.d.ts.map +1 -0
  268. package/dist/types/modules/guide/components/Card/index.d.ts +2 -0
  269. package/dist/types/modules/guide/components/Card/index.d.ts.map +1 -0
  270. package/dist/types/modules/guide/components/Modal/Modal.d.ts +69 -0
  271. package/dist/types/modules/guide/components/Modal/Modal.d.ts.map +1 -0
  272. package/dist/types/modules/guide/components/Modal/index.d.ts +2 -0
  273. package/dist/types/modules/guide/components/Modal/index.d.ts.map +1 -0
  274. package/dist/types/modules/guide/components/helpers.d.ts +3 -0
  275. package/dist/types/modules/guide/components/helpers.d.ts.map +1 -0
  276. package/dist/types/modules/guide/components/index.d.ts +4 -0
  277. package/dist/types/modules/guide/components/index.d.ts.map +1 -0
  278. package/dist/types/modules/guide/components/types.d.ts +25 -0
  279. package/dist/types/modules/guide/components/types.d.ts.map +1 -0
  280. package/dist/types/modules/guide/index.d.ts +2 -0
  281. package/dist/types/modules/guide/index.d.ts.map +1 -0
  282. package/dist/types/modules/ms-teams/components/MsTeamsAuthButton/MsTeamsAuthButton.d.ts +8 -0
  283. package/dist/types/modules/ms-teams/components/MsTeamsAuthButton/MsTeamsAuthButton.d.ts.map +1 -0
  284. package/dist/types/modules/ms-teams/components/MsTeamsAuthButton/index.d.ts +2 -0
  285. package/dist/types/modules/ms-teams/components/MsTeamsAuthButton/index.d.ts.map +1 -0
  286. package/dist/types/modules/ms-teams/components/MsTeamsAuthContainer/MsTeamsAuthContainer.d.ts +6 -0
  287. package/dist/types/modules/ms-teams/components/MsTeamsAuthContainer/MsTeamsAuthContainer.d.ts.map +1 -0
  288. package/dist/types/modules/ms-teams/components/MsTeamsAuthContainer/index.d.ts +2 -0
  289. package/dist/types/modules/ms-teams/components/MsTeamsAuthContainer/index.d.ts.map +1 -0
  290. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelCombobox.d.ts +10 -0
  291. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelCombobox.d.ts.map +1 -0
  292. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelInTeamCombobox.d.ts +10 -0
  293. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsChannelInTeamCombobox.d.ts.map +1 -0
  294. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsConnectionError.d.ts +4 -0
  295. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsConnectionError.d.ts.map +1 -0
  296. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsErrorMessage.d.ts +7 -0
  297. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsErrorMessage.d.ts.map +1 -0
  298. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsTeamCombobox.d.ts +12 -0
  299. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/MsTeamsTeamCombobox.d.ts.map +1 -0
  300. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/index.d.ts +2 -0
  301. package/dist/types/modules/ms-teams/components/MsTeamsChannelCombobox/index.d.ts.map +1 -0
  302. package/dist/types/modules/ms-teams/components/MsTeamsIcon/MsTeamsIcon.d.ts +7 -0
  303. package/dist/types/modules/ms-teams/components/MsTeamsIcon/MsTeamsIcon.d.ts.map +1 -0
  304. package/dist/types/modules/ms-teams/components/MsTeamsIcon/index.d.ts +2 -0
  305. package/dist/types/modules/ms-teams/components/MsTeamsIcon/index.d.ts.map +1 -0
  306. package/dist/types/modules/ms-teams/index.d.ts +4 -0
  307. package/dist/types/modules/ms-teams/index.d.ts.map +1 -0
  308. package/dist/types/modules/ms-teams/utils.d.ts +4 -0
  309. package/dist/types/modules/ms-teams/utils.d.ts.map +1 -0
  310. package/dist/types/modules/slack/components/SlackAddChannelInput/SlackAddChannelInput.d.ts +12 -0
  311. package/dist/types/modules/slack/components/SlackAddChannelInput/SlackAddChannelInput.d.ts.map +1 -0
  312. package/dist/types/modules/slack/components/SlackAddChannelInput/index.d.ts +2 -0
  313. package/dist/types/modules/slack/components/SlackAddChannelInput/index.d.ts.map +1 -0
  314. package/dist/types/modules/slack/components/SlackAuthButton/SlackAuthButton.d.ts +10 -0
  315. package/dist/types/modules/slack/components/SlackAuthButton/SlackAuthButton.d.ts.map +1 -0
  316. package/dist/types/modules/slack/components/SlackAuthButton/index.d.ts +2 -0
  317. package/dist/types/modules/slack/components/SlackAuthButton/index.d.ts.map +1 -0
  318. package/dist/types/modules/slack/components/SlackAuthContainer/SlackAuthContainer.d.ts +6 -0
  319. package/dist/types/modules/slack/components/SlackAuthContainer/SlackAuthContainer.d.ts.map +1 -0
  320. package/dist/types/modules/slack/components/SlackAuthContainer/index.d.ts +2 -0
  321. package/dist/types/modules/slack/components/SlackAuthContainer/index.d.ts.map +1 -0
  322. package/dist/types/modules/slack/components/SlackChannelCombobox/SlackChannelCombobox.d.ts +15 -0
  323. package/dist/types/modules/slack/components/SlackChannelCombobox/SlackChannelCombobox.d.ts.map +1 -0
  324. package/dist/types/modules/slack/components/SlackChannelCombobox/SlackConnectionError.d.ts +4 -0
  325. package/dist/types/modules/slack/components/SlackChannelCombobox/SlackConnectionError.d.ts.map +1 -0
  326. package/dist/types/modules/slack/components/SlackChannelCombobox/SlackErrorMessage.d.ts +7 -0
  327. package/dist/types/modules/slack/components/SlackChannelCombobox/SlackErrorMessage.d.ts.map +1 -0
  328. package/dist/types/modules/slack/components/SlackChannelCombobox/index.d.ts +2 -0
  329. package/dist/types/modules/slack/components/SlackChannelCombobox/index.d.ts.map +1 -0
  330. package/dist/types/modules/slack/components/SlackIcon/SlackIcon.d.ts +7 -0
  331. package/dist/types/modules/slack/components/SlackIcon/SlackIcon.d.ts.map +1 -0
  332. package/dist/types/modules/slack/components/SlackIcon/index.d.ts +2 -0
  333. package/dist/types/modules/slack/components/SlackIcon/index.d.ts.map +1 -0
  334. package/dist/types/modules/slack/index.d.ts +4 -0
  335. package/dist/types/modules/slack/index.d.ts.map +1 -0
  336. package/dist/types/modules/slack/utils.d.ts +3 -0
  337. package/dist/types/modules/slack/utils.d.ts.map +1 -0
  338. package/package.json +4 -4
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkAsRead.mjs","sources":["../../../../../../src/modules/feed/components/NotificationFeed/MarkAsRead.tsx"],"sourcesContent":["import { FeedItem } from \"@knocklabs/client\";\nimport { useKnockFeed, useTranslations } from \"@knocklabs/react-core\";\nimport * as React from \"react\";\n\nimport { CheckmarkCircle } from \"../../../core/components/Icons\";\n\nimport \"./styles.css\";\n\nexport type MarkAsReadProps = {\n onClick?: (e: React.MouseEvent, unreadItems: FeedItem[]) => void;\n};\n\nexport const MarkAsRead: React.FC<MarkAsReadProps> = ({ onClick }) => {\n const { useFeedStore, feedClient, colorMode } = useKnockFeed();\n const { t } = useTranslations();\n\n const unreadItems = useFeedStore((state) =>\n state.items.filter((item) => !item.read_at),\n );\n\n const unreadCount = useFeedStore((state) => state.metadata.unread_count);\n\n const onClickHandler = React.useCallback(\n (e: React.MouseEvent) => {\n feedClient.markAllAsRead();\n if (onClick) onClick(e, unreadItems);\n },\n [feedClient, unreadItems, onClick],\n );\n\n return (\n <button\n className={`rnf-mark-all-as-read rnf-mark-all-as-read--${colorMode}`}\n disabled={unreadCount === 0}\n onClick={onClickHandler}\n type=\"button\"\n >\n {t(\"markAllAsRead\")}\n <CheckmarkCircle aria-hidden />\n </button>\n );\n};\n"],"names":["MarkAsRead","onClick","useFeedStore","feedClient","colorMode","useKnockFeed","t","useTranslations","unreadItems","state","items","filter","item","read_at","unreadCount","metadata","unread_count","onClickHandler","React","useCallback","e","markAllAsRead","CheckmarkCircle"],"mappings":";;;;AAYO,MAAMA,IAAwCA,CAAC;AAAA,EAAEC,SAAAA;AAAQ,MAAM;AAC9D,QAAA;AAAA,IAAEC,cAAAA;AAAAA,IAAcC,YAAAA;AAAAA,IAAYC,WAAAA;AAAAA,MAAcC,EAAa,GACvD;AAAA,IAAEC,GAAAA;AAAAA,MAAMC,EAAgB,GAExBC,IAAcN,EAAcO,CAAAA,MAChCA,EAAMC,MAAMC,OAAQC,CAASA,MAAA,CAACA,EAAKC,OAAO,CAC5C,GAEMC,IAAcZ,EAAcO,CAAUA,MAAAA,EAAMM,SAASC,YAAY,GAEjEC,IAAiBC,EAAMC,YAC3B,CAACC,MAAwB;AACvBjB,IAAAA,EAAWkB,cAAc,GACrBpB,KAAiBmB,EAAAA,GAAGZ,CAAW;AAAA,EAErC,GAAA,CAACL,GAAYK,GAAaP,CAAO,CACnC;AAGE,SAAA,gBAAAiB,EAAA,cAAC,YACC,WAAW,8CAA8Cd,CAAS,IAClE,UAAUU,MAAgB,GAC1B,SAASG,GACT,MAAK,YAEJX,EAAE,eAAe,mCACjBgB,GAAgB,EAAA,eAAW,GAAA,CAAA,CAC9B;AAEJ;"}
@@ -0,0 +1,63 @@
1
+ import { isRequestInFlight as C, NetworkStatus as f } from "@knocklabs/client";
2
+ import { FilterStatus as I, useKnockFeed as R, useFeedSettings as B, useTranslations as q } from "@knocklabs/react-core";
3
+ import e, { useState as x, useRef as K, useEffect as p, useCallback as H } from "react";
4
+ import { Spinner as M } from "../../../core/components/Spinner/Spinner.mjs";
5
+ import P from "../../../core/hooks/useOnBottomScroll.mjs";
6
+ import { EmptyFeed as z } from "../EmptyFeed/EmptyFeed.mjs";
7
+ import { NotificationCell as A } from "../NotificationCell/NotificationCell.mjs";
8
+ /* empty css */
9
+ import { NotificationFeedHeader as L } from "./NotificationFeedHeader.mjs";
10
+ /* empty css */
11
+ const O = (t) => /* @__PURE__ */ e.createElement(A, { key: t.item.id, ...t }), T = (t) => /* @__PURE__ */ e.createElement(L, { ...t }), k = ({
12
+ colorMode: t
13
+ }) => /* @__PURE__ */ e.createElement("div", { className: "rnf-notification-feed__spinner-container" }, /* @__PURE__ */ e.createElement(M, { thickness: 3, size: "16px", color: t === "dark" ? "rgba(255, 255, 255, 0.65)" : void 0 })), U = "https://knock.app?utm_source=powered-by-knock&utm_medium=referral&utm_campaign=knock-branding-feed", Z = ({
14
+ EmptyComponent: t = /* @__PURE__ */ e.createElement(z, null),
15
+ renderItem: _ = O,
16
+ onNotificationClick: g,
17
+ onNotificationButtonClick: E,
18
+ onMarkAllAsReadClick: b,
19
+ initialFilterStatus: r = I.All,
20
+ header: N,
21
+ renderHeader: S = T
22
+ }) => {
23
+ const [a, m] = x(r), {
24
+ feedClient: n,
25
+ useFeedStore: h,
26
+ colorMode: c
27
+ } = R(), {
28
+ settings: i
29
+ } = B(n), {
30
+ t: F
31
+ } = q(), {
32
+ pageInfo: l,
33
+ items: d,
34
+ networkStatus: o
35
+ } = h(), u = K(null);
36
+ p(() => {
37
+ m(r);
38
+ }, [r]), p(() => {
39
+ n.fetch({
40
+ status: a
41
+ });
42
+ }, [n, a]);
43
+ const v = d.length === 0, s = C(o), w = H(() => {
44
+ !s && l.after && n.fetchNextPage();
45
+ }, [s, l, n]);
46
+ return P({
47
+ ref: u,
48
+ callback: w,
49
+ offset: 70
50
+ }), /* @__PURE__ */ e.createElement("div", { className: `rnf-notification-feed rnf-notification-feed--${c}` }, N || S({
51
+ setFilterStatus: m,
52
+ filterStatus: a,
53
+ onMarkAllAsReadClick: b
54
+ }), /* @__PURE__ */ e.createElement("div", { className: "rnf-notification-feed__container", ref: u }, o === f.loading && /* @__PURE__ */ e.createElement(k, { colorMode: c }), /* @__PURE__ */ e.createElement("div", { className: "rnf-notification-feed__feed-items-container" }, o !== f.loading && d.map((y) => _({
55
+ item: y,
56
+ onItemClick: g,
57
+ onButtonClick: E
58
+ }))), o === f.fetchMore && /* @__PURE__ */ e.createElement(k, { colorMode: c }), !s && v && t), (i == null ? void 0 : i.features.branding_required) && /* @__PURE__ */ e.createElement("div", { className: "rnf-notification-feed__knock-branding" }, /* @__PURE__ */ e.createElement("a", { href: U, target: "_blank" }, F("poweredBy") || "Powered by Knock")));
59
+ };
60
+ export {
61
+ Z as NotificationFeed
62
+ };
63
+ //# sourceMappingURL=NotificationFeed.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationFeed.mjs","sources":["../../../../../../src/modules/feed/components/NotificationFeed/NotificationFeed.tsx"],"sourcesContent":["import { FeedItem, NetworkStatus, isRequestInFlight } from \"@knocklabs/client\";\nimport {\n ColorMode,\n FilterStatus,\n useFeedSettings,\n useKnockFeed,\n useTranslations,\n} from \"@knocklabs/react-core\";\nimport { GenericData } from \"@knocklabs/types\";\nimport React, {\n ReactNode,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from \"react\";\n\nimport { Spinner } from \"../../../core/components/Spinner\";\nimport useOnBottomScroll from \"../../../core/hooks/useOnBottomScroll\";\nimport { EmptyFeed } from \"../EmptyFeed\";\nimport { NotificationCell, NotificationCellProps } from \"../NotificationCell\";\n\nimport {\n NotificationFeedHeader,\n NotificationFeedHeaderProps,\n} from \"./NotificationFeedHeader\";\nimport \"./styles.css\";\n\nexport type RenderItemProps<T = GenericData> = {\n item: FeedItem<T>;\n onItemClick?: NotificationCellProps[\"onItemClick\"];\n onButtonClick?: NotificationCellProps[\"onButtonClick\"];\n};\n\nexport type RenderItem = (props: RenderItemProps) => ReactNode;\n\nexport interface NotificationFeedProps {\n EmptyComponent?: ReactNode;\n /**\n * @deprecated Use `renderHeader` instead to accept `NotificationFeedHeaderProps`\n */\n header?: ReactNode;\n renderItem?: RenderItem;\n renderHeader?: (props: NotificationFeedHeaderProps) => ReactNode;\n onNotificationClick?: NotificationCellProps[\"onItemClick\"];\n onNotificationButtonClick?: NotificationCellProps[\"onButtonClick\"];\n onMarkAllAsReadClick?: (e: React.MouseEvent, unreadItems: FeedItem[]) => void;\n initialFilterStatus?: FilterStatus;\n}\n\nconst defaultRenderItem = (props: RenderItemProps) => (\n <NotificationCell key={props.item.id} {...props} />\n);\n\nconst defaultRenderHeader = (props: NotificationFeedHeaderProps) => (\n <NotificationFeedHeader {...props} />\n);\n\nconst LoadingSpinner = ({ colorMode }: { colorMode: ColorMode }) => (\n <div className=\"rnf-notification-feed__spinner-container\">\n <Spinner\n thickness={3}\n size=\"16px\"\n color={colorMode === \"dark\" ? \"rgba(255, 255, 255, 0.65)\" : undefined}\n />\n </div>\n);\n\nconst poweredByKnockUrl =\n \"https://knock.app?utm_source=powered-by-knock&utm_medium=referral&utm_campaign=knock-branding-feed\";\n\nexport const NotificationFeed: React.FC<NotificationFeedProps> = ({\n EmptyComponent = <EmptyFeed />,\n renderItem = defaultRenderItem,\n onNotificationClick,\n onNotificationButtonClick,\n onMarkAllAsReadClick,\n initialFilterStatus = FilterStatus.All,\n header,\n renderHeader = defaultRenderHeader,\n}) => {\n const [status, setStatus] = useState(initialFilterStatus);\n const { feedClient, useFeedStore, colorMode } = useKnockFeed();\n const { settings } = useFeedSettings(feedClient);\n const { t } = useTranslations();\n\n const { pageInfo, items, networkStatus } = useFeedStore();\n const containerRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n setStatus(initialFilterStatus);\n }, [initialFilterStatus]);\n\n useEffect(() => {\n // When the feed client changes, or the status changes issue a re-fetch\n feedClient.fetch({ status });\n }, [feedClient, status]);\n\n const noItems = items.length === 0;\n const requestInFlight = isRequestInFlight(networkStatus);\n\n // Handle fetching more once we reach the bottom of the list\n const onBottomCallback = useCallback(() => {\n if (!requestInFlight && pageInfo.after) {\n feedClient.fetchNextPage();\n }\n }, [requestInFlight, pageInfo, feedClient]);\n\n // Once we scroll to the bottom of the view we want to automatically fetch\n // more items for the feed and bring them into the list\n useOnBottomScroll({\n ref: containerRef,\n callback: onBottomCallback,\n offset: 70,\n });\n\n return (\n <div\n className={`rnf-notification-feed rnf-notification-feed--${colorMode}`}\n >\n {header ||\n renderHeader({\n setFilterStatus: setStatus,\n filterStatus: status,\n onMarkAllAsReadClick,\n })}\n\n <div className=\"rnf-notification-feed__container\" ref={containerRef}>\n {networkStatus === NetworkStatus.loading && (\n <LoadingSpinner colorMode={colorMode} />\n )}\n\n <div className=\"rnf-notification-feed__feed-items-container\">\n {networkStatus !== NetworkStatus.loading &&\n items.map((item: FeedItem) =>\n renderItem({\n item,\n onItemClick: onNotificationClick,\n onButtonClick: onNotificationButtonClick,\n }),\n )}\n </div>\n\n {networkStatus === NetworkStatus.fetchMore && (\n <LoadingSpinner colorMode={colorMode} />\n )}\n\n {!requestInFlight && noItems && EmptyComponent}\n </div>\n\n {settings?.features.branding_required && (\n <div className=\"rnf-notification-feed__knock-branding\">\n <a href={poweredByKnockUrl} target=\"_blank\">\n {t(\"poweredBy\") || \"Powered by Knock\"}\n </a>\n </div>\n )}\n </div>\n );\n};\n"],"names":["defaultRenderItem","props","React","NotificationCell","item","id","defaultRenderHeader","NotificationFeedHeader","LoadingSpinner","colorMode","Spinner","undefined","poweredByKnockUrl","NotificationFeed","EmptyComponent","EmptyFeed","renderItem","onNotificationClick","onNotificationButtonClick","onMarkAllAsReadClick","initialFilterStatus","FilterStatus","All","header","renderHeader","status","setStatus","useState","feedClient","useFeedStore","useKnockFeed","settings","useFeedSettings","t","useTranslations","pageInfo","items","networkStatus","containerRef","useRef","useEffect","fetch","noItems","length","requestInFlight","isRequestInFlight","onBottomCallback","useCallback","after","fetchNextPage","useOnBottomScroll","ref","callback","offset","setFilterStatus","filterStatus","NetworkStatus","loading","map","onItemClick","onButtonClick","fetchMore","features","branding_required"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { FilterStatus as a, useTranslations as c } from "@knocklabs/react-core";
2
+ import e from "react";
3
+ import { Dropdown as l } from "./Dropdown.mjs";
4
+ import { MarkAsRead as m } from "./MarkAsRead.mjs";
5
+ const s = [a.All, a.Unread, a.Read], u = ({
6
+ onMarkAllAsReadClick: r,
7
+ filterStatus: o,
8
+ setFilterStatus: i
9
+ }) => {
10
+ const {
11
+ t: n
12
+ } = c();
13
+ return /* @__PURE__ */ e.createElement("header", { className: "rnf-notification-feed__header" }, /* @__PURE__ */ e.createElement("div", { className: "rnf-notification-feed__selector" }, /* @__PURE__ */ e.createElement("span", { className: "rnf-notification-feed__type" }, n("notifications")), /* @__PURE__ */ e.createElement(l, { value: o, onChange: (t) => i(t.target.value) }, s.map((t) => /* @__PURE__ */ e.createElement("option", { key: t, value: t }, n(t))))), /* @__PURE__ */ e.createElement(m, { onClick: r }));
14
+ };
15
+ export {
16
+ u as NotificationFeedHeader
17
+ };
18
+ //# sourceMappingURL=NotificationFeedHeader.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationFeedHeader.mjs","sources":["../../../../../../src/modules/feed/components/NotificationFeed/NotificationFeedHeader.tsx"],"sourcesContent":["import { FeedItem } from \"@knocklabs/client\";\nimport { FilterStatus, useTranslations } from \"@knocklabs/react-core\";\nimport React, { SetStateAction } from \"react\";\n\nimport { Dropdown } from \"./Dropdown\";\nimport { MarkAsRead } from \"./MarkAsRead\";\n\nexport type NotificationFeedHeaderProps = {\n filterStatus: FilterStatus;\n setFilterStatus: React.Dispatch<SetStateAction<FilterStatus>>;\n onMarkAllAsReadClick?: (e: React.MouseEvent, unreadItems: FeedItem[]) => void;\n};\n\nconst OrderedFilterStatuses = [\n FilterStatus.All,\n FilterStatus.Unread,\n FilterStatus.Read,\n];\n\nexport const NotificationFeedHeader: React.FC<NotificationFeedHeaderProps> = ({\n onMarkAllAsReadClick,\n filterStatus,\n setFilterStatus,\n}) => {\n const { t } = useTranslations();\n\n return (\n <header className=\"rnf-notification-feed__header\">\n <div className=\"rnf-notification-feed__selector\">\n <span className=\"rnf-notification-feed__type\">\n {t(\"notifications\")}\n </span>\n <Dropdown\n value={filterStatus}\n onChange={(e) => setFilterStatus(e.target.value as FilterStatus)}\n >\n {OrderedFilterStatuses.map((filterStatus) => (\n <option key={filterStatus} value={filterStatus}>\n {t(filterStatus)}\n </option>\n ))}\n </Dropdown>\n </div>\n <MarkAsRead onClick={onMarkAllAsReadClick} />\n </header>\n );\n};\n"],"names":["OrderedFilterStatuses","FilterStatus","All","Unread","Read","NotificationFeedHeader","onMarkAllAsReadClick","filterStatus","setFilterStatus","t","useTranslations","React","Dropdown","e","target","value","map","MarkAsRead"],"mappings":";;;;AAaA,MAAMA,IAAwB,CAC5BC,EAAaC,KACbD,EAAaE,QACbF,EAAaG,IAAI,GAGNC,IAAgEA,CAAC;AAAA,EAC5EC,sBAAAA;AAAAA,EACAC,cAAAA;AAAAA,EACAC,iBAAAA;AACF,MAAM;AACE,QAAA;AAAA,IAAEC,GAAAA;AAAAA,MAAMC,EAAgB;AAG5B,SAAAC,gBAAAA,EAAA,cAAC,YAAO,WAAU,gCAAA,mCACf,OAAI,EAAA,WAAU,kCACb,GAAAA,gBAAAA,EAAA,cAAC,QAAK,EAAA,WAAU,iCACbF,EAAE,eAAe,CACpB,GACAE,gBAAAA,EAAA,cAACC,KACC,OAAOL,GACP,UAAWM,CAAAA,MAAML,EAAgBK,EAAEC,OAAOC,KAAqB,EAAA,GAE9Df,EAAsBgB,IAAKT,CAAAA,MACzBI,gBAAAA,EAAA,cAAA,UAAA,EAAO,KAAKJ,GAAc,OAAOA,EAAAA,GAC/BE,EAAEF,CAAY,CACjB,CACD,CACH,CACF,GACCI,gBAAAA,EAAA,cAAAM,GAAA,EAAW,SAASX,EAAqB,CAAA,CAC5C;AAEJ;"}
@@ -0,0 +1,9 @@
1
+ import t from "react";
2
+ /* empty css */
3
+ const i = ({
4
+ children: e
5
+ }) => /* @__PURE__ */ t.createElement("div", { className: "rnf-feed-provider" }, e);
6
+ export {
7
+ i as NotificationFeedContainer
8
+ };
9
+ //# sourceMappingURL=NotificationFeedContainer.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationFeedContainer.mjs","sources":["../../../../../../src/modules/feed/components/NotificationFeedContainer/NotificationFeedContainer.tsx"],"sourcesContent":["import { FunctionComponent, ReactNode } from \"react\";\n\nimport \"./styles.css\";\n\nexport const NotificationFeedContainer: FunctionComponent<{\n children?: ReactNode | undefined;\n}> = ({ children }) => <div className=\"rnf-feed-provider\">{children}</div>;\n"],"names":["NotificationFeedContainer","children","React"],"mappings":";;AAIO,MAAMA,IAERA,CAAC;AAAA,EAAEC,UAAAA;AAAS,MAAOC,gBAAAA,EAAA,cAAA,OAAA,EAAI,WAAU,oBAAA,GAAqBD,CAAS;"}
@@ -0,0 +1,63 @@
1
+ import { useTranslations as y, useKnockFeed as _ } from "@knocklabs/react-core";
2
+ import { createPopper as E } from "@popperjs/core";
3
+ import n, { useEffect as c } from "react";
4
+ import F from "../../../core/hooks/useComponentVisible.mjs";
5
+ import { NotificationFeed as N } from "../NotificationFeed/NotificationFeed.mjs";
6
+ import "../NotificationFeed/NotificationFeedHeader.mjs";
7
+ /* empty css */
8
+ /* empty css */
9
+ const x = ({
10
+ store: e,
11
+ feedClient: t
12
+ }) => {
13
+ e.metadata.unseen_count > 0 && t.markAllAsSeen();
14
+ }, K = ({
15
+ isVisible: e,
16
+ onOpen: t = x,
17
+ onClose: p,
18
+ buttonRef: r,
19
+ closeOnClickOutside: s = !0,
20
+ placement: i = "bottom-end",
21
+ ...m
22
+ }) => {
23
+ const {
24
+ t: d
25
+ } = y(), {
26
+ colorMode: l,
27
+ feedClient: f,
28
+ useFeedStore: u
29
+ } = _(), a = u(), {
30
+ ref: o
31
+ } = F(e, p, {
32
+ closeOnClickOutside: s
33
+ });
34
+ return c(() => {
35
+ e && t && t({
36
+ store: a,
37
+ feedClient: f
38
+ });
39
+ }, [e, t, a, f]), c(() => {
40
+ if (r.current && o.current) {
41
+ const v = E(r.current, o.current, {
42
+ strategy: "fixed",
43
+ placement: i,
44
+ modifiers: [{
45
+ name: "offset",
46
+ options: {
47
+ offset: [0, 8]
48
+ }
49
+ }]
50
+ });
51
+ return () => {
52
+ v.destroy();
53
+ };
54
+ }
55
+ }, [r, o, i]), /* @__PURE__ */ n.createElement("div", { className: `rnf-notification-feed-popover rnf-notification-feed-popover--${l}`, style: {
56
+ visibility: e ? "visible" : "hidden",
57
+ opacity: e ? 1 : 0
58
+ }, ref: o, role: "dialog", "aria-label": d("notifications"), tabIndex: -1 }, /* @__PURE__ */ n.createElement("div", { className: "rnf-notification-feed-popover__inner" }, /* @__PURE__ */ n.createElement(N, { ...m })));
59
+ };
60
+ export {
61
+ K as NotificationFeedPopover
62
+ };
63
+ //# sourceMappingURL=NotificationFeedPopover.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationFeedPopover.mjs","sources":["../../../../../../src/modules/feed/components/NotificationFeedPopover/NotificationFeedPopover.tsx"],"sourcesContent":["import { Feed, FeedStoreState } from \"@knocklabs/client\";\nimport { useKnockFeed, useTranslations } from \"@knocklabs/react-core\";\nimport { Placement, createPopper } from \"@popperjs/core\";\nimport React, { RefObject, useEffect } from \"react\";\n\nimport useComponentVisible from \"../../../core/hooks/useComponentVisible\";\nimport { NotificationFeed, NotificationFeedProps } from \"../NotificationFeed\";\n\nimport \"./styles.css\";\n\ntype OnOpenOptions = {\n store: FeedStoreState;\n feedClient: Feed;\n};\n\nconst defaultOnOpen = ({ store, feedClient }: OnOpenOptions) => {\n if (store.metadata.unseen_count > 0) {\n feedClient.markAllAsSeen();\n }\n};\n\nexport interface NotificationFeedPopoverProps extends NotificationFeedProps {\n isVisible: boolean;\n onOpen?: (arg: OnOpenOptions) => void;\n onClose: (e: Event) => void;\n buttonRef: RefObject<HTMLElement | null>;\n closeOnClickOutside?: boolean;\n placement?: Placement;\n}\n\nexport const NotificationFeedPopover: React.FC<\n NotificationFeedPopoverProps\n> = ({\n isVisible,\n onOpen = defaultOnOpen,\n onClose,\n buttonRef,\n closeOnClickOutside = true,\n placement = \"bottom-end\",\n ...feedProps\n}) => {\n const { t } = useTranslations();\n const { colorMode, feedClient, useFeedStore } = useKnockFeed();\n const store = useFeedStore();\n\n const { ref: popperRef } = useComponentVisible(isVisible, onClose, {\n closeOnClickOutside,\n });\n\n useEffect(() => {\n // Whenever the feed is opened, we want to invoke the `onOpen` callback\n // function to handle any side effects.\n if (isVisible && onOpen) {\n onOpen({ store, feedClient });\n }\n }, [isVisible, onOpen, store, feedClient]);\n\n useEffect(() => {\n if (buttonRef.current && popperRef.current) {\n const popperInstance = createPopper(\n buttonRef.current,\n popperRef.current,\n {\n strategy: \"fixed\",\n placement,\n modifiers: [\n {\n name: \"offset\",\n options: {\n offset: [0, 8],\n },\n },\n ],\n },\n );\n\n // Cleanup\n return () => {\n popperInstance.destroy();\n };\n }\n }, [buttonRef, popperRef, placement]);\n\n return (\n <div\n className={`rnf-notification-feed-popover rnf-notification-feed-popover--${colorMode}`}\n style={{\n visibility: isVisible ? \"visible\" : \"hidden\",\n opacity: isVisible ? 1 : 0,\n }}\n ref={popperRef}\n role=\"dialog\"\n aria-label={t(\"notifications\")}\n tabIndex={-1}\n >\n <div className=\"rnf-notification-feed-popover__inner\">\n <NotificationFeed {...feedProps} />\n </div>\n </div>\n );\n};\n"],"names":["defaultOnOpen","store","feedClient","metadata","unseen_count","markAllAsSeen","NotificationFeedPopover","isVisible","onOpen","onClose","buttonRef","closeOnClickOutside","placement","feedProps","t","useTranslations","colorMode","useFeedStore","useKnockFeed","ref","popperRef","useComponentVisible","useEffect","current","popperInstance","createPopper","strategy","modifiers","name","options","offset","destroy","visibility","opacity","React","NotificationFeed"],"mappings":";;;;;;;;AAeA,MAAMA,IAAgBA,CAAC;AAAA,EAAEC,OAAAA;AAAAA,EAAOC,YAAAA;AAA0B,MAAM;AAC1DD,EAAAA,EAAME,SAASC,eAAe,KAChCF,EAAWG,cAAc;AAE7B,GAWaC,IAETA,CAAC;AAAA,EACHC,WAAAA;AAAAA,EACAC,QAAAA,IAASR;AAAAA,EACTS,SAAAA;AAAAA,EACAC,WAAAA;AAAAA,EACAC,qBAAAA,IAAsB;AAAA,EACtBC,WAAAA,IAAY;AAAA,EACZ,GAAGC;AACL,MAAM;AACE,QAAA;AAAA,IAAEC,GAAAA;AAAAA,MAAMC,EAAgB,GACxB;AAAA,IAAEC,WAAAA;AAAAA,IAAWd,YAAAA;AAAAA,IAAYe,cAAAA;AAAAA,MAAiBC,EAAa,GACvDjB,IAAQgB,EAAa,GAErB;AAAA,IAAEE,KAAKC;AAAAA,EAAAA,IAAcC,EAAoBd,GAAWE,GAAS;AAAA,IACjEE,qBAAAA;AAAAA,EAAAA,CACD;AAEDW,SAAAA,EAAU,MAAM;AAGd,IAAIf,KAAaC,KACRA,EAAA;AAAA,MAAEP,OAAAA;AAAAA,MAAOC,YAAAA;AAAAA,IAAAA,CAAY;AAAA,KAE7B,CAACK,GAAWC,GAAQP,GAAOC,CAAU,CAAC,GAEzCoB,EAAU,MAAM;AACVZ,QAAAA,EAAUa,WAAWH,EAAUG,SAAS;AAC1C,YAAMC,IAAiBC,EACrBf,EAAUa,SACVH,EAAUG,SACV;AAAA,QACEG,UAAU;AAAA,QACVd,WAAAA;AAAAA,QACAe,WAAW,CACT;AAAA,UACEC,MAAM;AAAA,UACNC,SAAS;AAAA,YACPC,QAAQ,CAAC,GAAG,CAAC;AAAA,UAAA;AAAA,QAEhB,CAAA;AAAA,MAAA,CAGP;AAGA,aAAO,MAAM;AACXN,QAAAA,EAAeO,QAAQ;AAAA,MACzB;AAAA,IAAA;AAAA,EAED,GAAA,CAACrB,GAAWU,GAAWR,CAAS,CAAC,mCAGjC,OACC,EAAA,WAAW,gEAAgEI,CAAS,IACpF,OAAO;AAAA,IACLgB,YAAYzB,IAAY,YAAY;AAAA,IACpC0B,SAAS1B,IAAY,IAAI;AAAA,EAC3B,GACA,KAAKa,GACL,MAAK,UACL,cAAYN,EAAE,eAAe,GAC7B,UAAU,MAEToB,gBAAAA,EAAA,cAAA,OAAA,EAAI,WAAU,0CACbA,gBAAAA,EAAA,cAACC,KAAiB,GAAItB,EAAAA,CAAU,CAClC,CACF;AAEJ;"}
@@ -0,0 +1,18 @@
1
+ import { useKnockFeed as i } from "@knocklabs/react-core";
2
+ import t from "react";
3
+ import { BellIcon as a } from "../../../core/components/Icons/Bell.mjs";
4
+ import { UnseenBadge as c } from "../UnseenBadge/UnseenBadge.mjs";
5
+ /* empty css */
6
+ const p = t.forwardRef(({
7
+ onClick: o,
8
+ badgeCountType: e
9
+ }, n) => {
10
+ const {
11
+ colorMode: r
12
+ } = i();
13
+ return /* @__PURE__ */ t.createElement("button", { className: `rnf-notification-icon-button rnf-notification-icon-button--${r}`, "aria-label": "Open notification feed", ref: n, onClick: o }, /* @__PURE__ */ t.createElement(a, { "aria-hidden": !0 }), /* @__PURE__ */ t.createElement(c, { badgeCountType: e }));
14
+ });
15
+ export {
16
+ p as NotificationIconButton
17
+ };
18
+ //# sourceMappingURL=NotificationIconButton.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationIconButton.mjs","sources":["../../../../../../src/modules/feed/components/NotificationIconButton/NotificationIconButton.tsx"],"sourcesContent":["import { useKnockFeed } from \"@knocklabs/react-core\";\nimport React, { SyntheticEvent } from \"react\";\n\nimport { BellIcon } from \"../../../core/components/Icons\";\nimport { BadgeCountType, UnseenBadge } from \"../UnseenBadge\";\n\nimport \"./styles.css\";\n\nexport interface NotificationIconButtonProps {\n // What value should we use to drive the badge count?\n badgeCountType?: BadgeCountType;\n onClick: (e: SyntheticEvent) => void;\n}\n\nexport const NotificationIconButton = React.forwardRef<\n HTMLButtonElement,\n NotificationIconButtonProps\n>(({ onClick, badgeCountType }, ref) => {\n const { colorMode } = useKnockFeed();\n\n return (\n <button\n className={`rnf-notification-icon-button rnf-notification-icon-button--${colorMode}`}\n aria-label=\"Open notification feed\"\n ref={ref}\n onClick={onClick}\n >\n <BellIcon aria-hidden />\n <UnseenBadge badgeCountType={badgeCountType} />\n </button>\n );\n});\n"],"names":["NotificationIconButton","React","forwardRef","onClick","badgeCountType","ref","colorMode","useKnockFeed","BellIcon","UnseenBadge"],"mappings":";;;;;AAcaA,MAAAA,IAAyBC,EAAMC,WAG1C,CAAC;AAAA,EAAEC,SAAAA;AAAAA,EAASC,gBAAAA;AAAe,GAAGC,MAAQ;AAChC,QAAA;AAAA,IAAEC,WAAAA;AAAAA,MAAcC,EAAa;AAEnC,yCACG,UACC,EAAA,WAAW,8DAA8DD,CAAS,IAClF,cAAW,0BACX,KAAAD,GACA,SAAAF,KAEAF,gBAAAA,EAAA,cAACO,KAAS,eAAW,GAAA,CAAA,GACpBP,gBAAAA,EAAA,cAAAQ,GAAA,EAAY,gBAAAL,EAA+B,CAAA,CAC9C;AAEJ,CAAC;"}
@@ -0,0 +1,25 @@
1
+ import { useKnockFeed as a, formatBadgeCount as o } from "@knocklabs/react-core";
2
+ import u from "react";
3
+ /* empty css */
4
+ function s(n, e) {
5
+ switch (n) {
6
+ case "all":
7
+ return e.total_count;
8
+ case "unread":
9
+ return e.unread_count;
10
+ case "unseen":
11
+ return e.unseen_count;
12
+ }
13
+ }
14
+ const m = ({
15
+ badgeCountType: n = "unseen"
16
+ }) => {
17
+ const {
18
+ useFeedStore: e
19
+ } = a(), t = e((r) => s(n, r.metadata));
20
+ return t !== 0 ? /* @__PURE__ */ u.createElement("div", { className: "rnf-unseen-badge" }, /* @__PURE__ */ u.createElement("span", { className: "rnf-unseen-badge__count" }, o(t))) : null;
21
+ };
22
+ export {
23
+ m as UnseenBadge
24
+ };
25
+ //# sourceMappingURL=UnseenBadge.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UnseenBadge.mjs","sources":["../../../../../../src/modules/feed/components/UnseenBadge/UnseenBadge.tsx"],"sourcesContent":["import { FeedMetadata } from \"@knocklabs/client\";\nimport { formatBadgeCount, useKnockFeed } from \"@knocklabs/react-core\";\nimport React from \"react\";\n\nimport \"./styles.css\";\n\nexport type BadgeCountType = \"unseen\" | \"unread\" | \"all\";\n\nexport type UnseenBadgeProps = {\n badgeCountType?: BadgeCountType;\n};\n\nfunction selectBadgeCount(\n badgeCountType: BadgeCountType,\n metadata: FeedMetadata,\n) {\n switch (badgeCountType) {\n case \"all\":\n return metadata.total_count;\n case \"unread\":\n return metadata.unread_count;\n case \"unseen\":\n return metadata.unseen_count;\n }\n}\n\nexport const UnseenBadge: React.FC<UnseenBadgeProps> = ({\n badgeCountType = \"unseen\",\n}) => {\n const { useFeedStore } = useKnockFeed();\n const badgeCountValue = useFeedStore((state) =>\n selectBadgeCount(badgeCountType, state.metadata),\n );\n\n return badgeCountValue !== 0 ? (\n <div className=\"rnf-unseen-badge\">\n <span className=\"rnf-unseen-badge__count\">\n {formatBadgeCount(badgeCountValue)}\n </span>\n </div>\n ) : null;\n};\n"],"names":["selectBadgeCount","badgeCountType","metadata","total_count","unread_count","unseen_count","UnseenBadge","useFeedStore","useKnockFeed","badgeCountValue","state","React","formatBadgeCount"],"mappings":";;;AAYA,SAASA,EACPC,GACAC,GACA;AACA,UAAQD,GAAc;AAAA,IACpB,KAAK;AACH,aAAOC,EAASC;AAAAA,IAClB,KAAK;AACH,aAAOD,EAASE;AAAAA,IAClB,KAAK;AACH,aAAOF,EAASG;AAAAA,EAAAA;AAEtB;AAEO,MAAMC,IAA0CA,CAAC;AAAA,EACtDL,gBAAAA,IAAiB;AACnB,MAAM;AACE,QAAA;AAAA,IAAEM,cAAAA;AAAAA,MAAiBC,EAAa,GAChCC,IAAkBF,EAAcG,CAAAA,MACpCV,EAAiBC,GAAgBS,EAAMR,QAAQ,CACjD;AAEA,SAAOO,MAAoB,IACxBE,gBAAAA,EAAA,cAAA,OAAA,EAAI,WAAU,sBACbA,gBAAAA,EAAA,cAAC,QAAK,EAAA,WAAU,0BACbC,GAAAA,EAAiBH,CAAe,CACnC,CACF,IACE;AACN;"}
@@ -0,0 +1,133 @@
1
+ import { useGuide as g } from "@knocklabs/react-core";
2
+ import i from "clsx";
3
+ import t from "react";
4
+ import { maybeNavigateToUrlWithDelay as N } from "../helpers.mjs";
5
+ /* empty css */
6
+ const f = "banner", s = ({
7
+ children: e,
8
+ className: n,
9
+ ...a
10
+ }) => /* @__PURE__ */ t.createElement("div", { className: i("knock-guide-banner", n), ...a }, e);
11
+ s.displayName = "BannerView.Root";
12
+ const m = ({
13
+ children: e,
14
+ className: n,
15
+ ...a
16
+ }) => /* @__PURE__ */ t.createElement("div", { className: i("knock-guide-banner__message", n), ...a }, e);
17
+ m.displayName = "BannerView.Content";
18
+ const d = ({
19
+ title: e,
20
+ className: n,
21
+ ...a
22
+ }) => /* @__PURE__ */ t.createElement("div", { className: i("knock-guide-banner__title", n), ...a }, e);
23
+ d.displayName = "BannerView.Title";
24
+ const u = ({
25
+ body: e,
26
+ className: n,
27
+ ...a
28
+ }) => /* @__PURE__ */ t.createElement("div", { className: i("knock-guide-banner__body", n), dangerouslySetInnerHTML: {
29
+ __html: e
30
+ }, ...a });
31
+ u.displayName = "BannerView.Body";
32
+ const y = ({
33
+ children: e,
34
+ className: n,
35
+ ...a
36
+ }) => /* @__PURE__ */ t.createElement("div", { className: i("knock-guide-banner__actions", n), ...a }, e);
37
+ y.displayName = "BannerView.Actions";
38
+ const _ = ({
39
+ text: e,
40
+ action: n,
41
+ className: a,
42
+ ...r
43
+ }) => /* @__PURE__ */ t.createElement("button", { className: i("knock-guide-banner__action", a), ...r }, e);
44
+ _.displayName = "BannerView.PrimaryButton";
45
+ const b = ({
46
+ text: e,
47
+ action: n,
48
+ className: a,
49
+ ...r
50
+ }) => /* @__PURE__ */ t.createElement("button", { className: i("knock-guide-banner__action knock-guide-banner__action--secondary", a), ...r }, e);
51
+ b.displayName = "BannerView.SecondaryButton";
52
+ const p = ({
53
+ className: e,
54
+ ...n
55
+ }) => /* @__PURE__ */ t.createElement("button", { className: i("knock-guide-banner__close", e), ...n }, /* @__PURE__ */ t.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", width: "18", height: "18", fill: "none" }, /* @__PURE__ */ t.createElement("g", { fill: "#60646C", fillRule: "evenodd", clipRule: "evenodd" }, /* @__PURE__ */ t.createElement("path", { d: "M14.03 3.97a.75.75 0 0 1 0 1.06l-9 9a.75.75 0 0 1-1.06-1.06l9-9a.75.75 0 0 1 1.06 0Z" }), /* @__PURE__ */ t.createElement("path", { d: "M3.97 3.97a.75.75 0 0 1 1.06 0l9 9a.75.75 0 1 1-1.06 1.06l-9-9a.75.75 0 0 1 0-1.06Z" }))));
56
+ p.displayName = "BannerView.DismissButton";
57
+ const k = ({
58
+ content: e,
59
+ colorMode: n = "light",
60
+ onDismiss: a,
61
+ onButtonClick: r
62
+ }) => /* @__PURE__ */ t.createElement(s, { "data-knock-color-mode": n }, /* @__PURE__ */ t.createElement(m, null, /* @__PURE__ */ t.createElement(d, { title: e.title }), /* @__PURE__ */ t.createElement(u, { body: e.body })), /* @__PURE__ */ t.createElement(y, null, e.secondary_button && /* @__PURE__ */ t.createElement(b, { text: e.secondary_button.text, action: e.secondary_button.action, onClick: (c) => {
63
+ if (r) {
64
+ const {
65
+ text: l,
66
+ action: o
67
+ } = e.secondary_button;
68
+ r(c, {
69
+ name: "secondary_button",
70
+ text: l,
71
+ action: o
72
+ });
73
+ }
74
+ } }), e.primary_button && /* @__PURE__ */ t.createElement(_, { text: e.primary_button.text, action: e.primary_button.action, onClick: (c) => {
75
+ if (r) {
76
+ const {
77
+ text: l,
78
+ action: o
79
+ } = e.primary_button;
80
+ r(c, {
81
+ name: "primary_button",
82
+ text: l,
83
+ action: o
84
+ });
85
+ }
86
+ } }), e.dismissible && /* @__PURE__ */ t.createElement(p, { onClick: a })));
87
+ k.displayName = "BannerView.Default";
88
+ const B = ({
89
+ guideKey: e,
90
+ onButtonClick: n
91
+ }) => {
92
+ const {
93
+ guide: a,
94
+ step: r,
95
+ colorMode: c
96
+ } = g({
97
+ key: e,
98
+ type: f
99
+ });
100
+ return t.useEffect(() => {
101
+ r && r.markAsSeen();
102
+ }, [r]), !a || !r ? null : /* @__PURE__ */ t.createElement(k, { content: r.content, colorMode: c, onDismiss: () => r.markAsArchived(), onButtonClick: (l, o) => {
103
+ const E = {
104
+ ...o,
105
+ type: "button_click"
106
+ };
107
+ return r.markAsInteracted({
108
+ metadata: E
109
+ }), n ? n(l, {
110
+ button: o,
111
+ step: r,
112
+ guide: a
113
+ }) : N(o.action);
114
+ } });
115
+ };
116
+ B.displayName = "Banner";
117
+ const w = {};
118
+ Object.assign(w, {
119
+ Default: k,
120
+ Root: s,
121
+ Content: m,
122
+ Title: d,
123
+ Body: u,
124
+ Actions: y,
125
+ PrimaryButton: _,
126
+ SecondaryButton: b,
127
+ DismissButton: p
128
+ });
129
+ export {
130
+ B as Banner,
131
+ w as BannerView
132
+ };
133
+ //# sourceMappingURL=Banner.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Banner.mjs","sources":["../../../../../../src/modules/guide/components/Banner/Banner.tsx"],"sourcesContent":["import { ColorMode, useGuide } from \"@knocklabs/react-core\";\nimport clsx from \"clsx\";\nimport React from \"react\";\n\nimport { maybeNavigateToUrlWithDelay } from \"../helpers\";\nimport { ButtonContent, TargetButton, TargetButtonWithGuide } from \"../types\";\n\nimport \"./styles.css\";\n\nconst MESSAGE_TYPE = \"banner\";\n\nconst Root: React.FC<\n React.PropsWithChildren<React.ComponentPropsWithRef<\"div\">>\n> = ({ children, className, ...props }) => {\n return (\n <div className={clsx(\"knock-guide-banner\", className)} {...props}>\n {children}\n </div>\n );\n};\nRoot.displayName = \"BannerView.Root\";\n\nconst Content: React.FC<\n React.PropsWithChildren<React.ComponentPropsWithRef<\"div\">>\n> = ({ children, className, ...props }) => {\n return (\n <div className={clsx(\"knock-guide-banner__message\", className)} {...props}>\n {children}\n </div>\n );\n};\nContent.displayName = \"BannerView.Content\";\n\nconst Title: React.FC<\n { title: string } & React.ComponentPropsWithRef<\"div\">\n> = ({ title, className, ...props }) => {\n return (\n <div className={clsx(\"knock-guide-banner__title\", className)} {...props}>\n {title}\n </div>\n );\n};\nTitle.displayName = \"BannerView.Title\";\n\nconst Body: React.FC<{ body: string } & React.ComponentPropsWithRef<\"div\">> = ({\n body,\n className,\n ...props\n}) => {\n return (\n <div\n className={clsx(\"knock-guide-banner__body\", className)}\n dangerouslySetInnerHTML={{ __html: body }}\n {...props}\n />\n );\n};\nBody.displayName = \"BannerView.Body\";\n\nconst Actions: React.FC<\n React.PropsWithChildren<React.ComponentPropsWithRef<\"div\">>\n> = ({ children, className, ...props }) => {\n return (\n <div className={clsx(\"knock-guide-banner__actions\", className)} {...props}>\n {children}\n </div>\n );\n};\nActions.displayName = \"BannerView.Actions\";\n\nconst PrimaryButton: React.FC<\n ButtonContent & React.ComponentPropsWithRef<\"button\">\n> = ({ text, action, className, ...props }) => {\n return (\n <button\n className={clsx(\"knock-guide-banner__action\", className)}\n {...props}\n >\n {text}\n </button>\n );\n};\nPrimaryButton.displayName = \"BannerView.PrimaryButton\";\n\nconst SecondaryButton: React.FC<\n ButtonContent & React.ComponentPropsWithRef<\"button\">\n> = ({ text, action, className, ...props }) => {\n return (\n <button\n className={clsx(\n \"knock-guide-banner__action knock-guide-banner__action--secondary\",\n className,\n )}\n {...props}\n >\n {text}\n </button>\n );\n};\nSecondaryButton.displayName = \"BannerView.SecondaryButton\";\n\nconst DismissButton: React.FC<React.ComponentPropsWithRef<\"button\">> = ({\n className,\n ...props\n}) => {\n return (\n <button className={clsx(\"knock-guide-banner__close\", className)} {...props}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"18\"\n fill=\"none\"\n >\n <g fill=\"#60646C\" fillRule=\"evenodd\" clipRule=\"evenodd\">\n <path d=\"M14.03 3.97a.75.75 0 0 1 0 1.06l-9 9a.75.75 0 0 1-1.06-1.06l9-9a.75.75 0 0 1 1.06 0Z\" />\n <path d=\"M3.97 3.97a.75.75 0 0 1 1.06 0l9 9a.75.75 0 1 1-1.06 1.06l-9-9a.75.75 0 0 1 0-1.06Z\" />\n </g>\n </svg>\n </button>\n );\n};\nDismissButton.displayName = \"BannerView.DismissButton\";\n\ntype BannerContent = {\n title: string;\n body: string;\n primary_button?: ButtonContent;\n secondary_button?: ButtonContent;\n dismissible?: boolean;\n};\n\nconst DefaultView: React.FC<{\n content: BannerContent;\n colorMode?: ColorMode;\n onDismiss?: () => void;\n onButtonClick?: (e: React.MouseEvent, button: TargetButton) => void;\n}> = ({ content, colorMode = \"light\", onDismiss, onButtonClick }) => {\n return (\n <Root data-knock-color-mode={colorMode}>\n <Content>\n <Title title={content.title} />\n <Body body={content.body} />\n </Content>\n <Actions>\n {content.secondary_button && (\n <SecondaryButton\n text={content.secondary_button.text}\n action={content.secondary_button.action}\n onClick={(e) => {\n if (onButtonClick) {\n const { text, action } = content.secondary_button!;\n onButtonClick(e, { name: \"secondary_button\", text, action });\n }\n }}\n />\n )}\n\n {content.primary_button && (\n <PrimaryButton\n text={content.primary_button.text}\n action={content.primary_button.action}\n onClick={(e) => {\n if (onButtonClick) {\n const { text, action } = content.primary_button!;\n onButtonClick(e, { name: \"primary_button\", text, action });\n }\n }}\n />\n )}\n\n {content.dismissible && <DismissButton onClick={onDismiss} />}\n </Actions>\n </Root>\n );\n};\nDefaultView.displayName = \"BannerView.Default\";\n\ntype BannerProps = {\n guideKey?: string;\n onButtonClick?: (e: React.MouseEvent, target: TargetButtonWithGuide) => void;\n};\n\nexport const Banner: React.FC<BannerProps> = ({ guideKey, onButtonClick }) => {\n const { guide, step, colorMode } = useGuide({\n key: guideKey,\n type: MESSAGE_TYPE,\n });\n\n React.useEffect(() => {\n if (step) step.markAsSeen();\n }, [step]);\n\n if (!guide || !step) return null;\n\n return (\n <DefaultView\n content={step.content as BannerContent}\n colorMode={colorMode}\n onDismiss={() => step.markAsArchived()}\n onButtonClick={(e, button) => {\n const metadata = { ...button, type: \"button_click\" };\n step.markAsInteracted({ metadata });\n\n return onButtonClick\n ? onButtonClick(e, { button, step, guide })\n : maybeNavigateToUrlWithDelay(button.action);\n }}\n />\n );\n};\nBanner.displayName = \"Banner\";\n\nexport const BannerView = {} as {\n Default: typeof DefaultView;\n Root: typeof Root;\n Content: typeof Content;\n Title: typeof Title;\n Body: typeof Body;\n Actions: typeof Actions;\n PrimaryButton: typeof PrimaryButton;\n SecondaryButton: typeof SecondaryButton;\n DismissButton: typeof DismissButton;\n};\n\nObject.assign(BannerView, {\n Default: DefaultView,\n Root,\n Content,\n Title,\n Body,\n Actions,\n PrimaryButton,\n SecondaryButton,\n DismissButton,\n});\n"],"names":["MESSAGE_TYPE","Root","children","className","props","React","clsx","displayName","Content","Title","title","Body","body","__html","Actions","PrimaryButton","text","action","SecondaryButton","DismissButton","DefaultView","content","colorMode","onDismiss","onButtonClick","secondary_button","e","name","primary_button","dismissible","Banner","guideKey","guide","step","useGuide","key","type","useEffect","markAsSeen","markAsArchived","button","metadata","markAsInteracted","maybeNavigateToUrlWithDelay","BannerView","Object","assign","Default"],"mappings":"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"}
@@ -0,0 +1,170 @@
1
+ import { useGuide as C } from "@knocklabs/react-core";
2
+ import c from "clsx";
3
+ import a from "react";
4
+ import { isValidHttpUrl as h, maybeNavigateToUrlWithDelay as V } from "../helpers.mjs";
5
+ /* empty css */
6
+ const v = "card", o = ({
7
+ children: e,
8
+ className: t,
9
+ ...r
10
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card", t), ...r }, e);
11
+ o.displayName = "CardView.Root";
12
+ const u = ({
13
+ children: e,
14
+ className: t,
15
+ ...r
16
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card__message", t), ...r }, e);
17
+ u.displayName = "CardView.Content";
18
+ const f = ({
19
+ children: e,
20
+ className: t,
21
+ ...r
22
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card__header", t), ...r }, e);
23
+ f.displayName = "CardView.Header";
24
+ const w = ({
25
+ headline: e,
26
+ className: t,
27
+ ...r
28
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card__headline", t), ...r }, e);
29
+ w.displayName = "CardView.Headline";
30
+ const y = ({
31
+ title: e,
32
+ className: t,
33
+ ...r
34
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card__title", t), ...r }, e);
35
+ y.displayName = "CardView.Title";
36
+ const _ = ({
37
+ body: e,
38
+ className: t,
39
+ ...r
40
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card__body", t), dangerouslySetInnerHTML: {
41
+ __html: e
42
+ }, ...r });
43
+ _.displayName = "CardView.Body";
44
+ const k = ({
45
+ children: e,
46
+ className: t,
47
+ alt: r,
48
+ ...i
49
+ }) => /* @__PURE__ */ a.createElement("img", { className: c("knock-guide-card__img", t), alt: r || "", ...i }, e);
50
+ k.displayName = "CardView.Img";
51
+ const p = ({
52
+ children: e,
53
+ className: t,
54
+ ...r
55
+ }) => /* @__PURE__ */ a.createElement("div", { className: c("knock-guide-card__actions", t), ...r }, e);
56
+ p.displayName = "CardView.Actions";
57
+ const g = ({
58
+ text: e,
59
+ action: t,
60
+ className: r,
61
+ ...i
62
+ }) => /* @__PURE__ */ a.createElement("button", { className: c("knock-guide-card__action", r), ...i }, e);
63
+ g.displayName = "CardView.PrimaryButton";
64
+ const E = ({
65
+ text: e,
66
+ action: t,
67
+ className: r,
68
+ ...i
69
+ }) => /* @__PURE__ */ a.createElement("button", { className: c("knock-guide-card__action knock-guide-card__action--secondary", r), ...i }, e);
70
+ E.displayName = "CardView.SecondaryButton";
71
+ const N = ({
72
+ className: e,
73
+ ...t
74
+ }) => /* @__PURE__ */ a.createElement("button", { className: c("knock-guide-card__close", e), ...t }, /* @__PURE__ */ a.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", width: "18", height: "18", fill: "none" }, /* @__PURE__ */ a.createElement("g", { fill: "#60646C", fillRule: "evenodd", clipRule: "evenodd" }, /* @__PURE__ */ a.createElement("path", { d: "M14.03 3.97a.75.75 0 0 1 0 1.06l-9 9a.75.75 0 0 1-1.06-1.06l9-9a.75.75 0 0 1 1.06 0Z" }), /* @__PURE__ */ a.createElement("path", { d: "M3.97 3.97a.75.75 0 0 1 1.06 0l9 9a.75.75 0 1 1-1.06 1.06l-9-9a.75.75 0 0 1 0-1.06Z" }))));
75
+ N.displayName = "CardView.DismissButton";
76
+ const b = ({
77
+ content: e,
78
+ colorMode: t = "light",
79
+ onDismiss: r,
80
+ onButtonClick: i,
81
+ onImageClick: n
82
+ }) => /* @__PURE__ */ a.createElement(o, { "data-knock-color-mode": t }, /* @__PURE__ */ a.createElement(u, null, /* @__PURE__ */ a.createElement(f, null, /* @__PURE__ */ a.createElement(w, { headline: e.headline }), e.dismissible && /* @__PURE__ */ a.createElement(N, { onClick: r })), /* @__PURE__ */ a.createElement(y, { title: e.title }), /* @__PURE__ */ a.createElement(_, { body: e.body })), e.image && /* @__PURE__ */ a.createElement("a", { href: h(e.image.action) ? e.image.action : void 0, target: "_blank" }, /* @__PURE__ */ a.createElement(k, { src: e.image.url, alt: e.image.alt, onClick: (d) => {
83
+ n && n(d, e.image);
84
+ } })), (e.primary_button || e.secondary_button) && /* @__PURE__ */ a.createElement(p, null, e.primary_button && /* @__PURE__ */ a.createElement(g, { text: e.primary_button.text, action: e.primary_button.action, onClick: (d) => {
85
+ if (i) {
86
+ const {
87
+ text: s,
88
+ action: l
89
+ } = e.primary_button;
90
+ i(d, {
91
+ name: "primary_button",
92
+ text: s,
93
+ action: l
94
+ });
95
+ }
96
+ } }), e.secondary_button && /* @__PURE__ */ a.createElement(E, { text: e.secondary_button.text, action: e.secondary_button.action, onClick: (d) => {
97
+ if (i) {
98
+ const {
99
+ text: s,
100
+ action: l
101
+ } = e.secondary_button;
102
+ i(d, {
103
+ name: "secondary_button",
104
+ text: s,
105
+ action: l
106
+ });
107
+ }
108
+ } })));
109
+ b.displayName = "CardView.Default";
110
+ const x = ({
111
+ guideKey: e,
112
+ onButtonClick: t,
113
+ onImageClick: r
114
+ }) => {
115
+ const {
116
+ guide: i,
117
+ step: n,
118
+ colorMode: d
119
+ } = C({
120
+ key: e,
121
+ type: v
122
+ });
123
+ return a.useEffect(() => {
124
+ n && n.markAsSeen();
125
+ }, [n]), !i || !n ? null : /* @__PURE__ */ a.createElement(b, { content: n.content, colorMode: d, onDismiss: () => n.markAsArchived(), onButtonClick: (s, l) => {
126
+ const m = {
127
+ ...l,
128
+ type: "button_click"
129
+ };
130
+ return n.markAsInteracted({
131
+ metadata: m
132
+ }), t ? t(s, {
133
+ button: l,
134
+ step: n,
135
+ guide: i
136
+ }) : V(l.action);
137
+ }, onImageClick: (s, l) => {
138
+ const m = {
139
+ ...l,
140
+ type: "image_click"
141
+ };
142
+ if (n.markAsInteracted({
143
+ metadata: m
144
+ }), r)
145
+ return r(s, {
146
+ image: l,
147
+ step: n,
148
+ guide: i
149
+ });
150
+ } });
151
+ };
152
+ x.displayName = "Card";
153
+ const A = {};
154
+ Object.assign(A, {
155
+ Default: b,
156
+ Root: o,
157
+ Content: u,
158
+ Title: y,
159
+ Body: _,
160
+ Img: k,
161
+ Actions: p,
162
+ PrimaryButton: g,
163
+ SecondaryButton: E,
164
+ DismissButton: N
165
+ });
166
+ export {
167
+ x as Card,
168
+ A as CardView
169
+ };
170
+ //# sourceMappingURL=Card.mjs.map