@planningcenter/chat-react-native 3.30.0-rc.2 → 3.30.0-rc.4

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 (320) hide show
  1. package/build/components/conversation/attachments/attachment_card.js +3 -3
  2. package/build/components/conversation/attachments/attachment_deleting_overlay.js +2 -2
  3. package/build/components/conversation/attachments/audio_attachment.d.ts +1 -1
  4. package/build/components/conversation/attachments/audio_attachment.js +3 -3
  5. package/build/components/conversation/attachments/expanded_link.d.ts +1 -1
  6. package/build/components/conversation/attachments/expanded_link.js +3 -3
  7. package/build/components/conversation/attachments/generic_file_attachment.d.ts +1 -1
  8. package/build/components/conversation/attachments/generic_file_attachment.js +4 -4
  9. package/build/components/conversation/attachments/giphy_attachment.d.ts +1 -1
  10. package/build/components/conversation/attachments/giphy_attachment.js +4 -4
  11. package/build/components/conversation/attachments/image_attachment.d.ts +1 -1
  12. package/build/components/conversation/attachments/image_attachment.js +5 -5
  13. package/build/components/conversation/attachments/video_attachment.d.ts +1 -1
  14. package/build/components/conversation/attachments/video_attachment.js +4 -4
  15. package/build/components/conversation/empty_conversation_blank_state.js +1 -1
  16. package/build/components/conversation/jump_to_bottom_button.js +3 -3
  17. package/build/components/conversation/message.d.ts +1 -1
  18. package/build/components/conversation/message.js +12 -12
  19. package/build/components/conversation/message_attachments.d.ts +1 -1
  20. package/build/components/conversation/message_attachments.js +1 -1
  21. package/build/components/conversation/message_form/message_form_attachment_image.d.ts +1 -1
  22. package/build/components/conversation/message_form/message_form_attachment_image.js +1 -1
  23. package/build/components/conversation/message_form/message_form_attachment_video.d.ts +1 -1
  24. package/build/components/conversation/message_form/message_form_attachment_video.js +1 -1
  25. package/build/components/conversation/message_form.d.ts +1 -1
  26. package/build/components/conversation/message_form.js +12 -12
  27. package/build/components/conversation/message_markdown.js +3 -3
  28. package/build/components/conversation/message_reaction.d.ts +2 -2
  29. package/build/components/conversation/message_reaction.js +6 -6
  30. package/build/components/conversation/message_read_receipts.d.ts +1 -1
  31. package/build/components/conversation/message_read_receipts.js +2 -2
  32. package/build/components/conversation/messages_disabled_banners.js +2 -2
  33. package/build/components/conversation/reply_connectors.d.ts +1 -1
  34. package/build/components/conversation/reply_connectors.js +2 -2
  35. package/build/components/conversation/reply_shadow_message.d.ts +1 -1
  36. package/build/components/conversation/reply_shadow_message.js +6 -6
  37. package/build/components/conversation/typing_indicator.js +3 -3
  38. package/build/components/conversations/conversation_actions.d.ts +1 -1
  39. package/build/components/conversations/conversation_actions.js +5 -5
  40. package/build/components/conversations/conversation_preview.d.ts +1 -1
  41. package/build/components/conversations/conversation_preview.js +3 -3
  42. package/build/components/conversations/conversations.js +5 -5
  43. package/build/components/conversations/mute_indicator.js +3 -3
  44. package/build/components/conversations/swipeable_toggle_button.d.ts +1 -1
  45. package/build/components/conversations/swipeable_toggle_button.js +5 -5
  46. package/build/components/conversations/unread_count_badge.js +3 -3
  47. package/build/components/display/action_button.js +2 -2
  48. package/build/components/display/avatar.d.ts +1 -1
  49. package/build/components/display/avatar.js +1 -1
  50. package/build/components/display/avatar_group.d.ts +1 -1
  51. package/build/components/display/avatar_group.js +1 -1
  52. package/build/components/display/badge.js +3 -3
  53. package/build/components/display/banner.d.ts +1 -1
  54. package/build/components/display/banner.js +1 -1
  55. package/build/components/display/banner_collapsible.js +1 -1
  56. package/build/components/display/button.js +3 -3
  57. package/build/components/display/child_notice.d.ts +1 -1
  58. package/build/components/display/child_notice.js +2 -2
  59. package/build/components/display/heading.js +3 -3
  60. package/build/components/display/icon.js +1 -1
  61. package/build/components/display/icon_button.js +2 -2
  62. package/build/components/display/image.js +1 -1
  63. package/build/components/display/image_attachment_preview.js +2 -2
  64. package/build/components/display/keyboard_view.js +1 -1
  65. package/build/components/display/person.d.ts +1 -1
  66. package/build/components/display/person.js +1 -1
  67. package/build/components/display/platform_modal_header_buttons.js +1 -1
  68. package/build/components/display/pressable_row.js +1 -1
  69. package/build/components/display/spinner.js +1 -1
  70. package/build/components/display/switch.js +1 -1
  71. package/build/components/display/tabs.js +1 -1
  72. package/build/components/display/text.js +2 -2
  73. package/build/components/display/text_button.js +2 -2
  74. package/build/components/display/text_inline_button.js +2 -2
  75. package/build/components/display/toggle_button.js +4 -4
  76. package/build/components/display/utils/button_colors.js +1 -1
  77. package/build/components/display/utils/status_colors.js +1 -1
  78. package/build/components/display/video_attachment_preview.js +3 -3
  79. package/build/components/group_conversation_list.d.ts +1 -1
  80. package/build/components/group_conversation_list.js +2 -2
  81. package/build/components/page/error_boundary.d.ts +1 -1
  82. package/build/components/page/error_boundary.js +2 -2
  83. package/build/components/page/loading.js +1 -1
  84. package/build/components/primitive/avatar_primitive.d.ts +2 -2
  85. package/build/components/primitive/avatar_primitive.js +5 -5
  86. package/build/components/primitive/banner_primitive.d.ts +2 -2
  87. package/build/components/primitive/banner_primitive.js +8 -8
  88. package/build/components/primitive/blank_state_primitive.d.ts +1 -1
  89. package/build/components/primitive/blank_state_primitive.js +2 -2
  90. package/build/components/primitive/form_sheet.d.ts +2 -2
  91. package/build/components/primitive/form_sheet.js +3 -3
  92. package/build/components/safe_area_modal.js +1 -1
  93. package/build/contexts/api_provider.js +4 -4
  94. package/build/contexts/chat_context.d.ts +6 -6
  95. package/build/contexts/chat_context.js +2 -2
  96. package/build/contexts/conversations_context.d.ts +2 -2
  97. package/build/contexts/conversations_context.js +1 -1
  98. package/build/contexts/session_context.d.ts +3 -3
  99. package/build/contexts/session_context.js +6 -6
  100. package/build/hooks/groups/use_group_members_for_new_conversation.d.ts +6 -6
  101. package/build/hooks/groups/use_group_members_for_new_conversation.js +2 -2
  102. package/build/hooks/groups/use_groups_conversation_create.d.ts +1 -1
  103. package/build/hooks/groups/use_groups_conversation_create.js +2 -2
  104. package/build/hooks/services/use_find_or_create_services_conversation.d.ts +2 -2
  105. package/build/hooks/services/use_find_or_create_services_conversation.js +2 -2
  106. package/build/hooks/services/use_services_team.d.ts +1 -1
  107. package/build/hooks/services/use_services_team.js +1 -1
  108. package/build/hooks/services/use_team_members_for_new_conversation.d.ts +21 -21
  109. package/build/hooks/services/use_team_members_for_new_conversation.js +1 -1
  110. package/build/hooks/services/use_team_plans.d.ts +1 -1
  111. package/build/hooks/services/use_team_plans.js +1 -1
  112. package/build/hooks/use_api.d.ts +2 -2
  113. package/build/hooks/use_api_client.d.ts +1 -1
  114. package/build/hooks/use_api_client.js +3 -3
  115. package/build/hooks/use_async_storage.js +1 -1
  116. package/build/hooks/use_attachment_uploader.d.ts +1 -1
  117. package/build/hooks/use_broadcast_typing_status.js +1 -1
  118. package/build/hooks/use_chat_permissions.d.ts +21 -21
  119. package/build/hooks/use_conversation.d.ts +4 -4
  120. package/build/hooks/use_conversation.js +3 -3
  121. package/build/hooks/use_conversation_jolt_events.js +1 -1
  122. package/build/hooks/use_conversation_membership.d.ts +1 -1
  123. package/build/hooks/use_conversation_membership.js +2 -2
  124. package/build/hooks/use_conversation_message.d.ts +1 -1
  125. package/build/hooks/use_conversation_message.js +1 -1
  126. package/build/hooks/use_conversation_messages.d.ts +3 -3
  127. package/build/hooks/use_conversation_messages.js +1 -1
  128. package/build/hooks/use_conversation_messages_jolt_events.js +6 -6
  129. package/build/hooks/use_conversations.d.ts +2 -2
  130. package/build/hooks/use_conversations.js +1 -1
  131. package/build/hooks/use_conversations_actions.d.ts +19 -19
  132. package/build/hooks/use_conversations_actions.js +1 -1
  133. package/build/hooks/use_conversations_cache.d.ts +2 -2
  134. package/build/hooks/use_conversations_cache.js +2 -2
  135. package/build/hooks/use_conversations_jolt_events.js +2 -2
  136. package/build/hooks/use_current_person.d.ts +1 -1
  137. package/build/hooks/use_features.d.ts +1 -1
  138. package/build/hooks/use_features.js +1 -1
  139. package/build/hooks/use_giphy.d.ts +1 -1
  140. package/build/hooks/use_giphy.js +1 -1
  141. package/build/hooks/use_groups.d.ts +2 -2
  142. package/build/hooks/use_groups_groups.d.ts +33 -33
  143. package/build/hooks/use_jolt.js +2 -2
  144. package/build/hooks/use_live_relative_time.d.ts +1 -1
  145. package/build/hooks/use_live_relative_time.js +2 -2
  146. package/build/hooks/use_mark_latest_message_read.d.ts +1 -1
  147. package/build/hooks/use_message_create_or_update.d.ts +2 -2
  148. package/build/hooks/use_message_create_or_update.js +7 -7
  149. package/build/hooks/use_message_draft.d.ts +1 -1
  150. package/build/hooks/use_message_draft.js +1 -1
  151. package/build/hooks/use_message_reaction_toggle.d.ts +2 -2
  152. package/build/hooks/use_message_reaction_toggle.js +2 -2
  153. package/build/hooks/use_organization.d.ts +4 -4
  154. package/build/hooks/use_people_person.d.ts +1 -1
  155. package/build/hooks/use_product_analytics.d.ts +1 -1
  156. package/build/hooks/use_product_analytics.js +3 -3
  157. package/build/hooks/use_qualified_by_age.js +1 -1
  158. package/build/hooks/use_read_receipts.d.ts +1 -1
  159. package/build/hooks/use_report_message.d.ts +1 -1
  160. package/build/hooks/use_report_message.js +1 -1
  161. package/build/hooks/use_storage.d.ts +1 -1
  162. package/build/hooks/use_submit_age_check.d.ts +1 -1
  163. package/build/hooks/use_submit_age_check.js +1 -1
  164. package/build/hooks/use_suspense_api.d.ts +3 -3
  165. package/build/hooks/use_suspense_api.js +2 -2
  166. package/build/hooks/use_teams.d.ts +1 -1
  167. package/build/hooks/use_theme.d.ts +1 -1
  168. package/build/hooks/use_theme.js +1 -1
  169. package/build/hooks/use_typing_indicators.js +1 -1
  170. package/build/hooks/use_typing_status_cache.d.ts +1 -1
  171. package/build/hooks/use_upload_client.d.ts +1 -1
  172. package/build/hooks/use_upload_client.js +3 -3
  173. package/build/icons/font_awesome.d.ts +2 -0
  174. package/build/icons/font_awesome.d.ts.map +1 -0
  175. package/build/icons/font_awesome.js +16 -0
  176. package/build/icons/font_awesome.js.map +1 -0
  177. package/build/index.d.ts +1 -0
  178. package/build/index.d.ts.map +1 -1
  179. package/build/index.js +1 -0
  180. package/build/index.js.map +1 -1
  181. package/build/navigation/chat_access_gate.js +7 -7
  182. package/build/navigation/index.d.ts +25 -25
  183. package/build/navigation/index.js +28 -28
  184. package/build/navigation/screenLayout.js +2 -2
  185. package/build/polyfills/events/Event.js +1 -1
  186. package/build/polyfills/events/EventTarget.js +1 -1
  187. package/build/polyfills/events/internals/EventInternals.d.ts +2 -2
  188. package/build/polyfills/events/internals/EventTargetInternals.d.ts +2 -2
  189. package/build/screens/age_check/age_check_required_screen.js +8 -8
  190. package/build/screens/age_check/age_check_underage_screen.js +3 -3
  191. package/build/screens/age_check/components/age_check_select_birthdate_modal.js +3 -3
  192. package/build/screens/attachment_actions/attachment_actions_screen.js +1 -1
  193. package/build/screens/attachment_actions/hooks/useDeleteAttachment.js +3 -3
  194. package/build/screens/bug_report_screen.js +11 -11
  195. package/build/screens/conversation/message_read_receipts_screen.js +4 -4
  196. package/build/screens/conversation_details_screen.js +8 -8
  197. package/build/screens/conversation_filter_recipients/components/checkbox_row.d.ts +1 -1
  198. package/build/screens/conversation_filter_recipients/components/checkbox_row.js +3 -3
  199. package/build/screens/conversation_filter_recipients/components/header_row.d.ts +1 -1
  200. package/build/screens/conversation_filter_recipients/components/header_row.js +4 -4
  201. package/build/screens/conversation_filter_recipients/conversation_filter_recipients_screen.js +6 -6
  202. package/build/screens/conversation_filter_recipients/hooks/use_flattened_array_of_service_types_with_teams.d.ts +1 -1
  203. package/build/screens/conversation_filter_recipients/hooks/use_flattened_array_of_service_types_with_teams.js +1 -1
  204. package/build/screens/conversation_filter_recipients/hooks/use_service_types_with_teams.d.ts +22 -22
  205. package/build/screens/conversation_filter_recipients/hooks/use_service_types_with_teams.js +2 -2
  206. package/build/screens/conversation_filter_recipients/types.d.ts +1 -1
  207. package/build/screens/conversation_filters/components/conversation_filters.js +5 -5
  208. package/build/screens/conversation_filters/components/rows.d.ts +4 -4
  209. package/build/screens/conversation_filters/components/rows.js +5 -5
  210. package/build/screens/conversation_filters/context/conversation_filter_context.d.ts +1 -1
  211. package/build/screens/conversation_filters/group_filters.js +1 -1
  212. package/build/screens/conversation_filters/hooks/filters.d.ts +54 -54
  213. package/build/screens/conversation_filters/hooks/filters.js +3 -3
  214. package/build/screens/conversation_filters/screen_props.d.ts +1 -1
  215. package/build/screens/conversation_filters/team_filters.js +1 -1
  216. package/build/screens/conversation_filters_screen.js +1 -1
  217. package/build/screens/conversation_new/components/filter_by_plan.js +7 -7
  218. package/build/screens/conversation_new/components/form_list.d.ts +1 -1
  219. package/build/screens/conversation_new/components/form_list.js +2 -2
  220. package/build/screens/conversation_new/components/gender_filter_toggle.js +3 -3
  221. package/build/screens/conversation_new/components/groups_form.d.ts +1 -1
  222. package/build/screens/conversation_new/components/groups_form.js +10 -10
  223. package/build/screens/conversation_new/components/services_form.d.ts +1 -1
  224. package/build/screens/conversation_new/components/services_form.js +8 -8
  225. package/build/screens/conversation_new/components/source_app_error_card.js +1 -1
  226. package/build/screens/conversation_new/conversation_new_screen.d.ts +3 -3
  227. package/build/screens/conversation_notification_level_select_screen.js +5 -5
  228. package/build/screens/conversation_screen.d.ts +3 -3
  229. package/build/screens/conversation_screen.js +21 -21
  230. package/build/screens/conversation_select_recipients/components/groups_recipient_row.d.ts +1 -1
  231. package/build/screens/conversation_select_recipients/components/groups_recipient_row.js +1 -1
  232. package/build/screens/conversation_select_recipients/components/recipient_link_row.js +3 -3
  233. package/build/screens/conversation_select_recipients/components/restricted_group_row.d.ts +1 -1
  234. package/build/screens/conversation_select_recipients/components/restricted_group_row.js +3 -3
  235. package/build/screens/conversation_select_recipients/components/team_recipient_row.d.ts +1 -1
  236. package/build/screens/conversation_select_recipients/components/team_recipient_row.js +1 -1
  237. package/build/screens/conversation_select_recipients/components/view_more_link_row.js +1 -1
  238. package/build/screens/conversation_select_recipients/conversation_new_entry_screen.js +4 -4
  239. package/build/screens/conversation_select_recipients/conversation_select_group_recipients_screen.js +2 -2
  240. package/build/screens/conversation_select_recipients/conversation_select_teams_i_lead_recipients_screen.js +4 -4
  241. package/build/screens/conversation_select_recipients/types/screen_props.d.ts +2 -2
  242. package/build/screens/conversation_select_type_screen.d.ts +2 -2
  243. package/build/screens/conversation_select_type_screen.js +2 -2
  244. package/build/screens/conversations/components/chat_group_badge.js +2 -2
  245. package/build/screens/conversations/components/list_header_action_button.d.ts +1 -1
  246. package/build/screens/conversations/components/list_header_action_button.js +4 -4
  247. package/build/screens/conversations/components/list_header_component.js +9 -9
  248. package/build/screens/conversations/conversations_screen.d.ts +2 -2
  249. package/build/screens/conversations/conversations_screen.js +3 -3
  250. package/build/screens/design_system_screen.d.ts.map +1 -1
  251. package/build/screens/design_system_screen.js +98 -6
  252. package/build/screens/design_system_screen.js.map +1 -1
  253. package/build/screens/get_help_screen.js +4 -4
  254. package/build/screens/group_notification_level_select_screen.js +3 -3
  255. package/build/screens/group_notification_settings_screen.js +3 -3
  256. package/build/screens/message_actions_screen.js +10 -10
  257. package/build/screens/message_report/components/message_preview.d.ts +1 -1
  258. package/build/screens/message_report/components/message_preview.js +2 -2
  259. package/build/screens/message_report/components/report_reason_list.d.ts +1 -1
  260. package/build/screens/message_report/components/report_reason_list.js +4 -4
  261. package/build/screens/message_report_screen.js +7 -7
  262. package/build/screens/notification_settings/hooks/groups.d.ts +5 -5
  263. package/build/screens/notification_settings/hooks/groups.js +4 -4
  264. package/build/screens/notification_settings_screen.js +4 -4
  265. package/build/screens/preferred_app/hooks/use_chat_types.d.ts +4 -4
  266. package/build/screens/preferred_app/hooks/use_chat_types.js +1 -1
  267. package/build/screens/preferred_app_selection_screen.js +7 -7
  268. package/build/screens/preferred_app_selection_screen.js.map +1 -1
  269. package/build/screens/reactions_screen.js +7 -7
  270. package/build/screens/send_giphy_screen.js +8 -8
  271. package/build/screens/team_conversation_screen.js +3 -3
  272. package/build/types/jolt_events/message_events.d.ts +1 -1
  273. package/build/types/jolt_events/reaction_events.d.ts +1 -1
  274. package/build/types/resources/app_grant.d.ts +1 -1
  275. package/build/types/resources/conversation_membership.d.ts +1 -1
  276. package/build/types/resources/group_membership.d.ts +1 -1
  277. package/build/types/resources/groups/groups_group_resource.d.ts +1 -1
  278. package/build/types/resources/organization.d.ts +1 -1
  279. package/build/types/resources/person.d.ts +1 -1
  280. package/build/types/resources/services/chat_resource.d.ts +1 -1
  281. package/build/types/resources/services/team_resource.d.ts +1 -1
  282. package/build/utils/cache/messages_cache.d.ts +3 -3
  283. package/build/utils/cache/messages_cache.js +3 -3
  284. package/build/utils/cache/optimistically_create_message.d.ts +2 -2
  285. package/build/utils/cache/optimistically_create_message.js +4 -4
  286. package/build/utils/cache/optimistically_update_message.d.ts +1 -1
  287. package/build/utils/cache/optimistically_update_message.js +2 -2
  288. package/build/utils/cache/page_mutations.d.ts +5 -5
  289. package/build/utils/client/client.d.ts +1 -1
  290. package/build/utils/convert_attachments_for_create.d.ts +2 -2
  291. package/build/utils/destructure_chat_group_graph_id.d.ts +2 -2
  292. package/build/utils/jolt/transform_message_event_data_to_message_resource.d.ts +2 -2
  293. package/build/utils/jolt/transform_message_event_data_to_message_resource.js +1 -1
  294. package/build/utils/jolt/transform_reaction_event_data_to_reaction_count_resource.d.ts +3 -3
  295. package/build/utils/performance_tracking.d.ts +1 -1
  296. package/build/utils/reaction_constants.d.ts +1 -1
  297. package/build/utils/request/conversation.d.ts +2 -2
  298. package/build/utils/request/get_features.d.ts +1 -1
  299. package/build/utils/request/get_features.js +1 -1
  300. package/build/utils/request/get_message.d.ts +1 -1
  301. package/build/utils/request/get_message.js +1 -1
  302. package/build/utils/request/get_messages.d.ts +1 -1
  303. package/build/utils/request/get_messages.js +1 -1
  304. package/build/utils/response_error.d.ts +1 -1
  305. package/build/utils/session.d.ts +1 -1
  306. package/build/utils/session_manager.d.ts +1 -1
  307. package/build/utils/styles.js +1 -1
  308. package/build/utils/theme.d.ts +1 -1
  309. package/build/utils/theme.js +2 -2
  310. package/build/utils/upload_uri.d.ts +1 -1
  311. package/build/vendor/font_awesome_pro_solid_icons.d.ts +48 -0
  312. package/build/vendor/font_awesome_pro_solid_icons.d.ts.map +1 -0
  313. package/build/vendor/font_awesome_pro_solid_icons.js +513 -0
  314. package/build/vendor/font_awesome_pro_solid_icons.js.map +1 -0
  315. package/package.json +10 -4
  316. package/src/icons/font_awesome.ts +104 -0
  317. package/src/index.tsx +2 -0
  318. package/src/screens/design_system_screen.tsx +107 -0
  319. package/src/screens/preferred_app_selection_screen.tsx +3 -3
  320. package/src/vendor/font_awesome_pro_solid_icons.ts +560 -0
@@ -4,27 +4,27 @@ import { CommonActions, useNavigation, useTheme as useNavigationTheme, useRoute,
4
4
  import React, { useCallback, useEffect, useRef, useState } from 'react';
5
5
  import { FlatList, Platform, StyleSheet, View } from 'react-native';
6
6
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
7
- import { Badge, Icon, Text } from '@/components';
8
- import { EmptyConversationBlankState } from '@/components/conversation/empty_conversation_blank_state';
9
- import { JumpToBottomButton } from '@/components/conversation/jump_to_bottom_button';
10
- import { Message } from '@/components/conversation/message';
11
- import { MessageForm } from '@/components/conversation/message_form';
12
- import { LeaderMessagesDisabledBanner, MemberMessagesDisabledBanner, } from '@/components/conversation/messages_disabled_banners';
13
- import { ReplyShadowMessage } from '@/components/conversation/reply_shadow_message';
14
- import { TypingIndicator } from '@/components/conversation/typing_indicator';
15
- import { KeyboardView } from '@/components/display/keyboard_view';
16
- import BlankState from '@/components/primitive/blank_state_primitive';
17
- import { ConversationContextProvider } from '@/contexts/conversation_context';
18
- import { useTheme } from '@/hooks';
19
- import { useConversation } from '@/hooks/use_conversation';
20
- import { useConversationJoltEvents } from '@/hooks/use_conversation_jolt_events';
21
- import { useConversationMessages } from '@/hooks/use_conversation_messages';
22
- import { useConversationMessagesJoltEvents } from '@/hooks/use_conversation_messages_jolt_events';
23
- import { useMarkLatestMessageRead } from '@/hooks/use_mark_latest_message_read';
24
- import { normalizeAnalyticsMetadata, usePublishProductAnalyticsEvent, } from '@/hooks/use_product_analytics';
25
- import { getRelativeDateStatus } from '@/utils/date';
26
- import dayjs from '@/utils/dayjs';
27
- import { CONVERSATION_MESSAGE_LIST_PADDING_HORIZONTAL } from '@/utils/styles';
7
+ import { Badge, Icon, Text } from '../components';
8
+ import { EmptyConversationBlankState } from '../components/conversation/empty_conversation_blank_state';
9
+ import { JumpToBottomButton } from '../components/conversation/jump_to_bottom_button';
10
+ import { Message } from '../components/conversation/message';
11
+ import { MessageForm } from '../components/conversation/message_form';
12
+ import { LeaderMessagesDisabledBanner, MemberMessagesDisabledBanner, } from '../components/conversation/messages_disabled_banners';
13
+ import { ReplyShadowMessage } from '../components/conversation/reply_shadow_message';
14
+ import { TypingIndicator } from '../components/conversation/typing_indicator';
15
+ import { KeyboardView } from '../components/display/keyboard_view';
16
+ import BlankState from '../components/primitive/blank_state_primitive';
17
+ import { ConversationContextProvider } from '../contexts/conversation_context';
18
+ import { useTheme } from '../hooks';
19
+ import { useConversation } from '../hooks/use_conversation';
20
+ import { useConversationJoltEvents } from '../hooks/use_conversation_jolt_events';
21
+ import { useConversationMessages } from '../hooks/use_conversation_messages';
22
+ import { useConversationMessagesJoltEvents } from '../hooks/use_conversation_messages_jolt_events';
23
+ import { useMarkLatestMessageRead } from '../hooks/use_mark_latest_message_read';
24
+ import { normalizeAnalyticsMetadata, usePublishProductAnalyticsEvent, } from '../hooks/use_product_analytics';
25
+ import { getRelativeDateStatus } from '../utils/date';
26
+ import dayjs from '../utils/dayjs';
27
+ import { CONVERSATION_MESSAGE_LIST_PADDING_HORIZONTAL } from '../utils/styles';
28
28
  export function ConversationScreen({ route }) {
29
29
  const { conversation_id, reply_root_id } = route.params;
30
30
  const { data: conversation } = useConversation({ conversation_id });
@@ -1,4 +1,4 @@
1
- import { GroupsGroupResource } from '@/types';
1
+ import { GroupsGroupResource } from '../../../types';
2
2
  interface GroupsRecipientRowProps {
3
3
  group: GroupsGroupResource;
4
4
  onPress: (group: GroupsGroupResource) => void;
@@ -1,5 +1,5 @@
1
1
  import { RecipientLinkRow } from './recipient_link_row';
2
- import { pluralize } from '@/utils';
2
+ import { pluralize } from '../../../utils';
3
3
  export const GroupsRecipientRow = ({ group, onPress }) => {
4
4
  const groupAccessibilityLabel = `Select ${group.name} with ${pluralize(group.membershipsCount, 'member')}`;
5
5
  return (<RecipientLinkRow imageUri={group.headerImage?.thumbnail} title={group.name} subtitle={`${group.membershipsCount} members`} onPress={() => onPress(group)} accessibilityLabel={groupAccessibilityLabel} accessibilityHint={`Selects group as recipient and navigates to the final screen to finish creating the conversation`}/>);
@@ -1,9 +1,9 @@
1
1
  import { PlatformPressable } from '@react-navigation/elements';
2
2
  import React from 'react';
3
3
  import { Platform, StyleSheet, View } from 'react-native';
4
- import { Icon, Image, Text } from '@/components';
5
- import { useTheme } from '@/hooks';
6
- import { platformFontWeightMedium } from '@/utils';
4
+ import { Icon, Image, Text } from '../../../components';
5
+ import { useTheme } from '../../../hooks';
6
+ import { platformFontWeightMedium } from '../../../utils';
7
7
  export const RecipientLinkRow = ({ onPress, accessibilityLabel, accessibilityHint, imageUri, title, subtitle, }) => {
8
8
  const styles = useStyles();
9
9
  return (<PlatformPressable style={styles.row} onPress={onPress} accessibilityRole="link" accessibilityLabel={accessibilityLabel} accessibilityHint={accessibilityHint}>
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { GroupsGroupResource } from '@/types';
2
+ import { GroupsGroupResource } from '../../../types';
3
3
  interface RestrictedGroupRowProps {
4
4
  group: GroupsGroupResource;
5
5
  }
@@ -1,8 +1,8 @@
1
1
  import React from 'react';
2
2
  import { StyleSheet, View } from 'react-native';
3
- import { Image, Text } from '@/components';
4
- import { useTheme } from '@/hooks';
5
- import { platformFontWeightMedium } from '@/utils';
3
+ import { Image, Text } from '../../../components';
4
+ import { useTheme } from '../../../hooks';
5
+ import { platformFontWeightMedium } from '../../../utils';
6
6
  const DEFAULT_REASON = 'Chat is not enabled for this group';
7
7
  const REASON_DISPLAY_TEXT = {
8
8
  leaders_only: 'Only leaders can start conversations',
@@ -1,4 +1,4 @@
1
- import { ServiceTypeWithTeams } from '@/screens/conversation_filter_recipients/types';
1
+ import { ServiceTypeWithTeams } from '../../../screens/conversation_filter_recipients/types';
2
2
  interface TeamRecipientRowProps {
3
3
  serviceType: ServiceTypeWithTeams;
4
4
  onPress: (teams: ServiceTypeWithTeams['teams']) => void;
@@ -1,5 +1,5 @@
1
1
  import { RecipientLinkRow } from './recipient_link_row';
2
- import { pluralize } from '@/utils';
2
+ import { pluralize } from '../../../utils';
3
3
  export const TeamRecipientRow = ({ serviceType, onPress }) => {
4
4
  const serviceTypeAccessibilityLabel = `Select ${pluralize(serviceType.teams.length, 'team')} for ${serviceType.name}`;
5
5
  const teamNames = serviceType.teams.map(team => team.name).join(', ');
@@ -1,5 +1,5 @@
1
1
  import { StyleSheet, View } from 'react-native';
2
- import { TextButton } from '@/components';
2
+ import { TextButton } from '../../../components';
3
3
  export const ViewMoreLinkRow = ({ accessibilityHint, onPress }) => {
4
4
  const styles = useRowStyles();
5
5
  return (<View style={[styles.row]}>
@@ -2,10 +2,10 @@ import { useNavigation } from '@react-navigation/native';
2
2
  import React, { useEffect } from 'react';
3
3
  import { ScrollView, StyleSheet, View } from 'react-native';
4
4
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
5
- import { Button, Heading } from '@/components';
6
- import { DefaultLoading } from '@/components/page/loading';
7
- import { useNewConversationEntry } from '@/hooks/use_new_conversation_entry';
8
- import { Haptic } from '@/utils/native_adapters';
5
+ import { Button, Heading } from '../../components';
6
+ import { DefaultLoading } from '../../components/page/loading';
7
+ import { useNewConversationEntry } from '../../hooks/use_new_conversation_entry';
8
+ import { Haptic } from '../../utils/native_adapters';
9
9
  export const ConversationNewEntryScreen = ({ route }) => {
10
10
  const styles = useStyles();
11
11
  const navigation = useNavigation();
@@ -5,8 +5,8 @@ import { SectionList, StyleSheet, View } from 'react-native';
5
5
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
6
6
  import { GroupsRecipientRow } from './components/groups_recipient_row';
7
7
  import { RestrictedGroupRow } from './components/restricted_group_row';
8
- import { Heading, Text } from '@/components';
9
- import { useGroupsGroups } from '@/hooks/use_groups_groups';
8
+ import { Heading, Text } from '../../components';
9
+ import { useGroupsGroups } from '../../hooks/use_groups_groups';
10
10
  const SectionKey = {
11
11
  my: 'my',
12
12
  more: 'more',
@@ -3,10 +3,10 @@ import React from 'react';
3
3
  import { FlatList, StyleSheet, View } from 'react-native';
4
4
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
5
5
  import { TeamRecipientRow } from './components/team_recipient_row';
6
- import { Button, Heading } from '@/components';
7
- import { useServiceTypesWithTeams } from '@/screens/conversation_filter_recipients/hooks/use_service_types_with_teams';
8
- import { TeamFilterTypes, } from '@/screens/conversation_filter_recipients/types';
9
- import { Haptic } from '@/utils/native_adapters';
6
+ import { Button, Heading } from '../../components';
7
+ import { useServiceTypesWithTeams } from '../../screens/conversation_filter_recipients/hooks/use_service_types_with_teams';
8
+ import { TeamFilterTypes, } from '../../screens/conversation_filter_recipients/types';
9
+ import { Haptic } from '../../utils/native_adapters';
10
10
  export const ConversationSelectTeamsILeadRecipientsScreen = ({ route, }) => {
11
11
  const styles = useStyles();
12
12
  const navigation = useNavigation();
@@ -1,6 +1,6 @@
1
1
  import { StaticScreenProps } from '@react-navigation/native';
2
- import { AppName } from '@/types/resources/app_name';
3
- import { GraphId } from '@/types/resources/group_resource';
2
+ import { AppName } from '../../../types/resources/app_name';
3
+ import { GraphId } from '../../../types/resources/group_resource';
4
4
  export type ConversationSelectRecipientsParams = {
5
5
  chat_group_graph_id?: GraphId;
6
6
  group_source_app_name?: AppName;
@@ -1,7 +1,7 @@
1
1
  import { StaticScreenProps } from '@react-navigation/native';
2
2
  import React from 'react';
3
- import { AppName } from '@/types/resources/app_name';
4
- import { GraphId } from '@/types/resources/group_resource';
3
+ import { AppName } from '../types/resources/app_name';
4
+ import { GraphId } from '../types/resources/group_resource';
5
5
  export declare const ConversationSelectTypeScreenOptions: import("@react-navigation/native-stack").NativeStackNavigationOptions;
6
6
  export type ConversationSelectTypeScreenProps = StaticScreenProps<{
7
7
  chat_group_graph_id?: GraphId;
@@ -1,7 +1,7 @@
1
1
  import { useNavigation } from '@react-navigation/native';
2
2
  import React from 'react';
3
- import FormSheet, { getFormSheetScreenOptions } from '@/components/primitive/form_sheet';
4
- import { Haptic } from '@/utils/native_adapters';
3
+ import FormSheet, { getFormSheetScreenOptions } from '../components/primitive/form_sheet';
4
+ import { Haptic } from '../utils/native_adapters';
5
5
  export const ConversationSelectTypeScreenOptions = getFormSheetScreenOptions({
6
6
  headerTitle: 'New conversation',
7
7
  });
@@ -1,8 +1,8 @@
1
1
  import { useNavigation, useRoute } from '@react-navigation/native';
2
2
  import React, { useCallback } from 'react';
3
3
  import { StyleSheet, View } from 'react-native';
4
- import { Badge } from '@/components';
5
- import { useApiGet } from '@/hooks/use_api';
4
+ import { Badge } from '../../../components';
5
+ import { useApiGet } from '../../../hooks/use_api';
6
6
  export const ChatGroupBadge = ({ rowPaddingHorizontal }) => {
7
7
  const styles = useStyles({ rowPaddingHorizontal });
8
8
  const navigation = useNavigation();
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import type { PressableProps } from 'react-native';
3
- import { type IconString } from '@/components/display/icon';
3
+ import { type IconString } from '../../../components/display/icon';
4
4
  interface ListHeaderActionButtonProps extends PressableProps {
5
5
  /**
6
6
  * Provides context to screen readers about what the button does.
@@ -1,9 +1,9 @@
1
1
  import React from 'react';
2
2
  import { Pressable, StyleSheet } from 'react-native';
3
- import { Icon } from '@/components/display/icon';
4
- import { useTheme, useFontScale, useCreateAndroidRippleColor } from '@/hooks';
5
- import { platformPressedOpacityStyle } from '@/utils';
6
- import { tokens } from '@/vendor/tapestry/tokens';
3
+ import { Icon } from '../../../components/display/icon';
4
+ import { useTheme, useFontScale, useCreateAndroidRippleColor } from '../../../hooks';
5
+ import { platformPressedOpacityStyle } from '../../../utils';
6
+ import { tokens } from '../../../vendor/tapestry/tokens';
7
7
  export function ListHeaderActionButton({ accessibilityLabel, maxFontSizeMultiplier, name, ...props }) {
8
8
  const styles = useStyles({ maxFontSizeMultiplier });
9
9
  const { colors } = useTheme();
@@ -3,15 +3,15 @@ import React, { useCallback, useMemo } from 'react';
3
3
  import { Alert, ScrollView, StyleSheet, View } from 'react-native';
4
4
  import { ChatGroupBadge } from './chat_group_badge';
5
5
  import { ListHeaderActionButton } from './list_header_action_button';
6
- import { Heading, TextButton, ToggleButton } from '@/components';
7
- import { useAtFontScaleBreakpoint, useCurrentPersonCache, useTheme } from '@/hooks';
8
- import { useCanCreateConversations } from '@/hooks';
9
- import { useAppName } from '@/hooks/use_app_name';
10
- import { useMarkAllRead } from '@/hooks/use_conversations_actions';
11
- import { useCanDisplayGroups } from '@/hooks/use_groups';
12
- import { useNewConversationEntry } from '@/hooks/use_new_conversation_entry';
13
- import { MAX_FONT_SIZE_MULTIPLIER_LANDMARK } from '@/utils';
14
- import { Haptic } from '@/utils/native_adapters';
6
+ import { Heading, TextButton, ToggleButton } from '../../../components';
7
+ import { useAtFontScaleBreakpoint, useCurrentPersonCache, useTheme } from '../../../hooks';
8
+ import { useCanCreateConversations } from '../../../hooks';
9
+ import { useAppName } from '../../../hooks/use_app_name';
10
+ import { useMarkAllRead } from '../../../hooks/use_conversations_actions';
11
+ import { useCanDisplayGroups } from '../../../hooks/use_groups';
12
+ import { useNewConversationEntry } from '../../../hooks/use_new_conversation_entry';
13
+ import { MAX_FONT_SIZE_MULTIPLIER_LANDMARK } from '../../../utils';
14
+ import { Haptic } from '../../../utils/native_adapters';
15
15
  const ROW_PADDING_HORIZONTAL = 16;
16
16
  var FilterTypes;
17
17
  (function (FilterTypes) {
@@ -1,7 +1,7 @@
1
1
  import { StaticScreenProps } from '@react-navigation/native';
2
2
  import React from 'react';
3
- import { AppName } from '@/types/resources/app_name';
4
- import { GraphId } from '@/types/resources/group_resource';
3
+ import { AppName } from '../../types/resources/app_name';
4
+ import { GraphId } from '../../types/resources/group_resource';
5
5
  export type ConversationsScreenProps = StaticScreenProps<{
6
6
  title?: string;
7
7
  chat_group_graph_id?: GraphId;
@@ -1,9 +1,9 @@
1
1
  import React from 'react';
2
2
  import { StyleSheet, View } from 'react-native';
3
3
  import { ListHeaderComponent } from './components/list_header_component';
4
- import { Conversations } from '@/components';
5
- import { ConversationsContextProvider } from '@/contexts/conversations_context';
6
- import { usePublishProductAnalyticsEvent } from '@/hooks';
4
+ import { Conversations } from '../../components';
5
+ import { ConversationsContextProvider } from '../../contexts/conversations_context';
6
+ import { usePublishProductAnalyticsEvent } from '../../hooks';
7
7
  export function ConversationsScreen({ route }) {
8
8
  const styles = useStyles();
9
9
  usePublishProductAnalyticsEvent('chat.mobile.conversations.index.opened');
@@ -1 +1 @@
1
- {"version":3,"file":"design_system_screen.d.ts","sourceRoot":"","sources":["../../src/screens/design_system_screen.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAiFvC,wBAAgB,kBAAkB,sBAkBjC"}
1
+ {"version":3,"file":"design_system_screen.d.ts","sourceRoot":"","sources":["../../src/screens/design_system_screen.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAiFvC,wBAAgB,kBAAkB,sBAmBjC"}
@@ -1,11 +1,12 @@
1
+ import { FontAwesomeIcon } from '@fortawesome/react-native-fontawesome';
1
2
  import React, { useState } from 'react';
2
3
  import { Alert, Pressable, ScrollView, StyleSheet, View } from 'react-native';
3
- import { Avatar, AvatarGroup, Badge, Banner, BannerCollapsible, Button, ToggleButton, Heading, Icon, IconButton, Image, Person, Spinner, Switch, Text, TextButton, TextInlineButton, ImageAttachmentPreview, } from '@/components/display';
4
- import { VideoAttachmentPreview } from '@/components/display/video_attachment_preview';
5
- import BannerPrimitive from '@/components/primitive/banner_primitive';
6
- import BlankState from '@/components/primitive/blank_state_primitive';
7
- import { useInteractionGhostBackgroundColor, useTheme } from '@/hooks';
8
- import { MAX_FONT_SIZE_MULTIPLIER, platformPressedOpacityStyle, platformFontWeightMedium, Haptic, } from '@/utils';
4
+ import { Avatar, AvatarGroup, Badge, Banner, BannerCollapsible, Button, ToggleButton, Heading, Icon, IconButton, Image, Person, Spinner, Switch, Text, TextButton, TextInlineButton, ImageAttachmentPreview, } from '../components/display';
5
+ import { VideoAttachmentPreview } from '../components/display/video_attachment_preview';
6
+ import BannerPrimitive from '../components/primitive/banner_primitive';
7
+ import BlankState from '../components/primitive/blank_state_primitive';
8
+ import { useInteractionGhostBackgroundColor, useTheme } from '../hooks';
9
+ import { MAX_FONT_SIZE_MULTIPLIER, platformPressedOpacityStyle, platformFontWeightMedium, Haptic, } from '../utils';
9
10
  // =================================
10
11
  // ====== Docs Utils ===============
11
12
  // =================================
@@ -60,6 +61,7 @@ export function DesignSystemScreen() {
60
61
  <ImageIconsSection />
61
62
  <FormControlsSection />
62
63
  <StatusComponentsSection />
64
+ <FontAwesomeIconsSection />
63
65
  <MiscComponentsSection isLast/>
64
66
  </ScrollView>);
65
67
  }
@@ -572,6 +574,96 @@ function StatusComponentsSection({ isLast }) {
572
574
  </Group>
573
575
  </CollapsableSection>);
574
576
  }
577
+ const FA_ICONS = [
578
+ {
579
+ category: 'Church',
580
+ icons: [
581
+ 'book-bible',
582
+ 'church',
583
+ 'cross',
584
+ 'dove',
585
+ 'hands-heart',
586
+ 'person-rays',
587
+ 'praying-hands',
588
+ 'podium',
589
+ 'droplet',
590
+ 'person-drowning',
591
+ 'lighthouse',
592
+ ],
593
+ },
594
+ {
595
+ category: 'Services',
596
+ icons: [
597
+ 'guitar',
598
+ 'guitar-electric',
599
+ 'violin',
600
+ 'calendar-heart',
601
+ 'hand-heart',
602
+ 'hand-wave',
603
+ 'baby',
604
+ 'children',
605
+ 'mug-hot',
606
+ 'video-camera',
607
+ 'music',
608
+ 'piano-keyboard',
609
+ 'drum',
610
+ 'user-graduate',
611
+ 'comments-question',
612
+ 'presentation',
613
+ 'microphone-stand',
614
+ 'id-badge',
615
+ 'book-user',
616
+ 'hand-holding-heart',
617
+ 'guitars',
618
+ 'amp-guitar',
619
+ 'school-flag',
620
+ 'shield-check',
621
+ 'projector',
622
+ ],
623
+ },
624
+ {
625
+ category: 'Groups',
626
+ icons: [
627
+ 'people',
628
+ 'people-group',
629
+ 'person-dress',
630
+ 'person',
631
+ 'seedling',
632
+ 'comments-alt',
633
+ 'globe',
634
+ 'book-open-reader',
635
+ 'running',
636
+ 'leaf',
637
+ ],
638
+ },
639
+ ];
640
+ function FontAwesomeIconsSection({ isLast }) {
641
+ const { colors } = useTheme();
642
+ return (<CollapsableSection title="FontAwesome Pro Icons" isLast={isLast}>
643
+ {FA_ICONS.map(({ category, icons }) => (<Group key={category} title={category}>
644
+ <View style={faStyles.grid}>
645
+ {icons.map(name => (<View key={name} style={faStyles.cell}>
646
+ <FontAwesomeIcon icon={['fas', name]} size={20} color={colors.iconColorDefaultSecondary}/>
647
+ <Text variant="footnote" numberOfLines={1}>
648
+ {name}
649
+ </Text>
650
+ </View>))}
651
+ </View>
652
+ </Group>))}
653
+ </CollapsableSection>);
654
+ }
655
+ const faStyles = StyleSheet.create({
656
+ grid: {
657
+ flexDirection: 'row',
658
+ flexWrap: 'wrap',
659
+ },
660
+ cell: {
661
+ width: '25%',
662
+ alignItems: 'center',
663
+ gap: 4,
664
+ paddingVertical: 12,
665
+ },
666
+ });
575
667
  function MiscComponentsSection({ isLast }) {
576
668
  return (<CollapsableSection title="Misc components" isLast={isLast}>
577
669
  <Group title="Person" description="Takes a person object (`MemberResource` type) and displays an avatar, name, and badges. If person is a child we show a special badge and faded styles. Implomentation is based on a similar Chat Web component.">