@churchapps/apphelper 0.0.14 → 0.1.1

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 (292) hide show
  1. package/.eslintignore +3 -3
  2. package/.eslintrc.json +22 -22
  3. package/LICENSE +21 -21
  4. package/README.md +22 -16
  5. package/dist/components/FormSubmissionEdit.d.ts.map +1 -1
  6. package/dist/components/FormSubmissionEdit.js +9 -2
  7. package/dist/components/FormSubmissionEdit.js.map +1 -1
  8. package/dist/components/QuestionEdit.d.ts.map +1 -1
  9. package/dist/components/QuestionEdit.js +2 -1
  10. package/dist/components/QuestionEdit.js.map +1 -1
  11. package/dist/components/iconPicker/IconNamesList.d.ts.map +1 -0
  12. package/dist/components/iconPicker/IconNamesList.js.map +1 -0
  13. package/dist/components/iconPicker/IconPicker.d.ts.map +1 -0
  14. package/dist/components/iconPicker/IconPicker.js.map +1 -0
  15. package/dist/components/index.d.ts +2 -1
  16. package/dist/components/index.d.ts.map +1 -1
  17. package/dist/components/index.js +4 -2
  18. package/dist/components/index.js.map +1 -1
  19. package/dist/components/markdownEditor/editor.css +787 -787
  20. package/dist/components/markdownEditor/images/icons/arrow-clockwise.svg +3 -3
  21. package/dist/components/markdownEditor/images/icons/arrow-counterclockwise.svg +3 -3
  22. package/dist/components/markdownEditor/images/icons/chat-square-quote.svg +3 -3
  23. package/dist/components/markdownEditor/images/icons/chevron-down.svg +2 -2
  24. package/dist/components/markdownEditor/images/icons/code.svg +2 -2
  25. package/dist/components/markdownEditor/images/icons/journal-code.svg +4 -4
  26. package/dist/components/markdownEditor/images/icons/journal-text.svg +4 -4
  27. package/dist/components/markdownEditor/images/icons/justify.svg +2 -2
  28. package/dist/components/markdownEditor/images/icons/link.svg +3 -3
  29. package/dist/components/markdownEditor/images/icons/list-ol.svg +3 -3
  30. package/dist/components/markdownEditor/images/icons/list-ul.svg +2 -2
  31. package/dist/components/markdownEditor/images/icons/pencil-fill.svg +2 -2
  32. package/dist/components/markdownEditor/images/icons/text-center.svg +2 -2
  33. package/dist/components/markdownEditor/images/icons/text-left.svg +2 -2
  34. package/dist/components/markdownEditor/images/icons/text-paragraph.svg +2 -2
  35. package/dist/components/markdownEditor/images/icons/text-right.svg +2 -2
  36. package/dist/components/markdownEditor/images/icons/type-bold.svg +2 -2
  37. package/dist/components/markdownEditor/images/icons/type-h1.svg +2 -2
  38. package/dist/components/markdownEditor/images/icons/type-h2.svg +2 -2
  39. package/dist/components/markdownEditor/images/icons/type-h3.svg +2 -2
  40. package/dist/components/markdownEditor/images/icons/type-h4.svg +12 -12
  41. package/dist/components/markdownEditor/images/icons/type-italic.svg +2 -2
  42. package/dist/components/markdownEditor/images/icons/type-strikethrough.svg +2 -2
  43. package/dist/components/markdownEditor/images/icons/type-underline.svg +2 -2
  44. package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.js +1 -1
  45. package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.js.map +1 -1
  46. package/dist/components/markdownEditor/plugins/emoji/EmojiNodeTransform.js +1 -1
  47. package/dist/components/markdownEditor/plugins/emoji/EmojiNodeTransform.js.map +1 -1
  48. package/dist/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.js +1 -1
  49. package/dist/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.js.map +1 -1
  50. package/dist/components/markdownEditor/plugins/emoji/EmojisPlugin.js +1 -1
  51. package/dist/components/markdownEditor/plugins/emoji/EmojisPlugin.js.map +1 -1
  52. package/dist/components/notes/Notes.d.ts +1 -0
  53. package/dist/components/notes/Notes.d.ts.map +1 -1
  54. package/dist/components/notes/Notes.js +18 -1
  55. package/dist/components/notes/Notes.js.map +1 -1
  56. package/dist/components/wrapper/AppList.d.ts.map +1 -0
  57. package/dist/components/wrapper/AppList.js.map +1 -0
  58. package/dist/components/wrapper/ChurchList.d.ts.map +1 -0
  59. package/dist/components/wrapper/ChurchList.js.map +1 -0
  60. package/dist/components/wrapper/Drawers.d.ts +22 -0
  61. package/dist/components/wrapper/Drawers.d.ts.map +1 -0
  62. package/dist/components/wrapper/Drawers.js +51 -0
  63. package/dist/components/wrapper/Drawers.js.map +1 -0
  64. package/dist/components/wrapper/NavItem.d.ts.map +1 -0
  65. package/dist/components/wrapper/NavItem.js.map +1 -0
  66. package/dist/components/wrapper/NewPrivateMessage.d.ts.map +1 -0
  67. package/dist/components/wrapper/NewPrivateMessage.js.map +1 -0
  68. package/dist/components/wrapper/NotificationMenu.d.ts +14 -0
  69. package/dist/components/wrapper/NotificationMenu.d.ts.map +1 -0
  70. package/dist/components/wrapper/NotificationMenu.js +60 -0
  71. package/dist/components/wrapper/NotificationMenu.js.map +1 -0
  72. package/dist/components/wrapper/Notifications.d.ts +8 -0
  73. package/dist/components/wrapper/Notifications.d.ts.map +1 -0
  74. package/dist/components/wrapper/Notifications.js +67 -0
  75. package/dist/components/wrapper/Notifications.js.map +1 -0
  76. package/dist/components/wrapper/PrivateMessageDetails.d.ts.map +1 -0
  77. package/dist/components/{material → wrapper}/PrivateMessageDetails.js +1 -1
  78. package/dist/components/wrapper/PrivateMessageDetails.js.map +1 -0
  79. package/dist/components/wrapper/PrivateMessages.d.ts.map +1 -0
  80. package/dist/components/{material → wrapper}/PrivateMessages.js +1 -1
  81. package/dist/components/wrapper/PrivateMessages.js.map +1 -0
  82. package/dist/components/wrapper/SiteWrapper.d.ts.map +1 -0
  83. package/dist/components/{material → wrapper}/SiteWrapper.js +13 -49
  84. package/dist/components/wrapper/SiteWrapper.js.map +1 -0
  85. package/dist/components/wrapper/TabPanel.d.ts +9 -0
  86. package/dist/components/wrapper/TabPanel.d.ts.map +1 -0
  87. package/dist/components/wrapper/TabPanel.js +24 -0
  88. package/dist/components/wrapper/TabPanel.js.map +1 -0
  89. package/dist/components/wrapper/UserMenu.d.ts.map +1 -0
  90. package/dist/components/{material → wrapper}/UserMenu.js +14 -31
  91. package/dist/components/wrapper/UserMenu.js.map +1 -0
  92. package/dist/components/{material → wrapper}/index.d.ts +0 -1
  93. package/dist/components/wrapper/index.d.ts.map +1 -0
  94. package/dist/components/{material → wrapper}/index.js +1 -3
  95. package/dist/components/wrapper/index.js.map +1 -0
  96. package/dist/interfaces/Messaging.d.ts +10 -0
  97. package/dist/interfaces/Messaging.d.ts.map +1 -1
  98. package/package.json +85 -84
  99. package/src/components/CreatePerson.tsx +80 -80
  100. package/src/components/DisplayBox.tsx +68 -68
  101. package/src/components/ErrorMessages.tsx +26 -26
  102. package/src/components/ExportLink.tsx +67 -67
  103. package/src/components/FloatingSupport.tsx +16 -16
  104. package/src/components/FormSubmissionEdit.tsx +129 -120
  105. package/src/components/HelpIcon.tsx +10 -10
  106. package/src/components/ImageEditor.tsx +126 -126
  107. package/src/components/InputBox.tsx +73 -73
  108. package/src/components/Loading.tsx +29 -29
  109. package/src/components/PersonAdd.tsx +75 -75
  110. package/src/components/QuestionEdit.tsx +63 -62
  111. package/src/components/SmallButton.tsx +39 -39
  112. package/src/components/SupportModal.tsx +26 -26
  113. package/src/components/TabPanel.tsx +34 -34
  114. package/src/components/gallery/GalleryModal.tsx +102 -102
  115. package/src/components/gallery/StockPhotos.tsx +74 -74
  116. package/src/components/gallery/index.ts +1 -1
  117. package/src/components/{material/iconPicker → iconPicker}/IconNamesList.ts +2240 -2240
  118. package/src/components/{material/iconPicker → iconPicker}/IconPicker.tsx +153 -153
  119. package/src/components/index.tsx +24 -23
  120. package/src/components/markdownEditor/Editor.tsx +132 -132
  121. package/src/components/markdownEditor/MarkdownEditor.tsx +16 -16
  122. package/src/components/markdownEditor/MarkdownModal.tsx +46 -46
  123. package/src/components/markdownEditor/MarkdownPreview.tsx +14 -14
  124. package/src/components/markdownEditor/editor.css +787 -787
  125. package/src/components/markdownEditor/images/icons/arrow-clockwise.svg +3 -3
  126. package/src/components/markdownEditor/images/icons/arrow-counterclockwise.svg +3 -3
  127. package/src/components/markdownEditor/images/icons/chat-square-quote.svg +3 -3
  128. package/src/components/markdownEditor/images/icons/chevron-down.svg +2 -2
  129. package/src/components/markdownEditor/images/icons/code.svg +2 -2
  130. package/src/components/markdownEditor/images/icons/journal-code.svg +4 -4
  131. package/src/components/markdownEditor/images/icons/journal-text.svg +4 -4
  132. package/src/components/markdownEditor/images/icons/justify.svg +2 -2
  133. package/src/components/markdownEditor/images/icons/link.svg +3 -3
  134. package/src/components/markdownEditor/images/icons/list-ol.svg +3 -3
  135. package/src/components/markdownEditor/images/icons/list-ul.svg +2 -2
  136. package/src/components/markdownEditor/images/icons/pencil-fill.svg +2 -2
  137. package/src/components/markdownEditor/images/icons/text-center.svg +2 -2
  138. package/src/components/markdownEditor/images/icons/text-left.svg +2 -2
  139. package/src/components/markdownEditor/images/icons/text-paragraph.svg +2 -2
  140. package/src/components/markdownEditor/images/icons/text-right.svg +2 -2
  141. package/src/components/markdownEditor/images/icons/type-bold.svg +2 -2
  142. package/src/components/markdownEditor/images/icons/type-h1.svg +2 -2
  143. package/src/components/markdownEditor/images/icons/type-h2.svg +2 -2
  144. package/src/components/markdownEditor/images/icons/type-h3.svg +2 -2
  145. package/src/components/markdownEditor/images/icons/type-h4.svg +12 -12
  146. package/src/components/markdownEditor/images/icons/type-italic.svg +2 -2
  147. package/src/components/markdownEditor/images/icons/type-strikethrough.svg +2 -2
  148. package/src/components/markdownEditor/images/icons/type-underline.svg +2 -2
  149. package/src/components/markdownEditor/index.ts +2 -2
  150. package/src/components/markdownEditor/plugins/AutoLinkPlugin.tsx +35 -35
  151. package/src/components/markdownEditor/plugins/ControlledEditorPlugin.tsx +24 -24
  152. package/src/components/markdownEditor/plugins/ListMaxIndentLevelPlugin.tsx +68 -68
  153. package/src/components/markdownEditor/plugins/MarkdownTransformers.ts +106 -106
  154. package/src/components/markdownEditor/plugins/ReadOnlyPlugin.tsx +15 -15
  155. package/src/components/markdownEditor/plugins/ToolbarPlugin.tsx +401 -401
  156. package/src/components/markdownEditor/plugins/customLink/CustomLinkNode.tsx +224 -224
  157. package/src/components/markdownEditor/plugins/customLink/CustomLinkNodePlugin.tsx +32 -32
  158. package/src/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.tsx +102 -102
  159. package/src/components/markdownEditor/plugins/customLink/FloatingLinkEditor.tsx +243 -243
  160. package/src/components/markdownEditor/plugins/customLink/FloatingLinkEditor.types.ts +11 -11
  161. package/src/components/markdownEditor/plugins/emoji/EmojiNode.tsx +95 -95
  162. package/src/components/markdownEditor/plugins/emoji/EmojiNodeTransform.ts +41 -41
  163. package/src/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.tsx +152 -152
  164. package/src/components/markdownEditor/plugins/emoji/EmojisPlugin.tsx +65 -65
  165. package/src/components/markdownEditor/plugins/index.ts +6 -6
  166. package/src/components/markdownEditor/theme.ts +65 -65
  167. package/src/components/notes/AddNote.tsx +90 -90
  168. package/src/components/notes/Conversation.tsx +82 -82
  169. package/src/components/notes/Conversations.tsx +58 -58
  170. package/src/components/notes/NewConversation.tsx +78 -78
  171. package/src/components/notes/Note.tsx +44 -44
  172. package/src/components/notes/Notes.tsx +68 -52
  173. package/src/components/notes/index.ts +5 -5
  174. package/src/components/reporting/ChartReport.tsx +98 -98
  175. package/src/components/reporting/ReportFilter.tsx +54 -54
  176. package/src/components/reporting/ReportFilterField.tsx +160 -160
  177. package/src/components/reporting/ReportOutput.tsx +79 -79
  178. package/src/components/reporting/ReportWithFilter.tsx +70 -70
  179. package/src/components/reporting/TableReport.tsx +57 -57
  180. package/src/components/reporting/TreeReport.tsx +111 -111
  181. package/src/components/reporting/index.ts +4 -4
  182. package/src/components/{material → wrapper}/AppList.tsx +20 -20
  183. package/src/components/{material → wrapper}/ChurchList.tsx +22 -22
  184. package/src/components/wrapper/Drawers.tsx +60 -0
  185. package/src/components/{material → wrapper}/NavItem.tsx +41 -41
  186. package/src/components/{material → wrapper}/NewPrivateMessage.tsx +103 -103
  187. package/src/components/wrapper/NotificationMenu.tsx +85 -0
  188. package/src/components/wrapper/Notifications.tsx +50 -0
  189. package/src/components/{material → wrapper}/PrivateMessageDetails.tsx +23 -23
  190. package/src/components/{material → wrapper}/PrivateMessages.tsx +87 -87
  191. package/src/components/{material → wrapper}/SiteWrapper.tsx +96 -145
  192. package/src/components/wrapper/TabPanel.tsx +30 -0
  193. package/src/components/{material → wrapper}/UserMenu.tsx +106 -141
  194. package/src/components/{material → wrapper}/index.tsx +5 -6
  195. package/src/donationComponents/DonationPage.tsx +136 -136
  196. package/src/donationComponents/components/BankForm.tsx +159 -159
  197. package/src/donationComponents/components/CardForm.tsx +104 -104
  198. package/src/donationComponents/components/DonationForm.tsx +235 -235
  199. package/src/donationComponents/components/FundDonation.tsx +49 -49
  200. package/src/donationComponents/components/FundDonations.tsx +39 -39
  201. package/src/donationComponents/components/NonAuthDonation.tsx +31 -31
  202. package/src/donationComponents/components/NonAuthDonationInner.tsx +259 -259
  203. package/src/donationComponents/components/PaymentMethods.tsx +135 -135
  204. package/src/donationComponents/components/RecurringDonations.tsx +121 -121
  205. package/src/donationComponents/components/RecurringDonationsEdit.tsx +93 -93
  206. package/src/donationComponents/components/index.tsx +9 -9
  207. package/src/donationComponents/index.ts +3 -3
  208. package/src/donationComponents/modals/DonationPreviewModal.tsx +66 -66
  209. package/src/helpers/AnalyticsHelper.ts +33 -33
  210. package/src/helpers/ApiHelper.ts +125 -125
  211. package/src/helpers/AppearanceHelper.ts +69 -69
  212. package/src/helpers/ArrayHelper.ts +81 -81
  213. package/src/helpers/CommonEnvironmentHelper.ts +80 -80
  214. package/src/helpers/CurrencyHelper.ts +10 -10
  215. package/src/helpers/DateHelper.ts +108 -108
  216. package/src/helpers/DonationHelper.ts +26 -26
  217. package/src/helpers/ErrorHelper.ts +36 -36
  218. package/src/helpers/EventHelper.ts +52 -52
  219. package/src/helpers/FileHelper.ts +31 -31
  220. package/src/helpers/PersonHelper.ts +60 -60
  221. package/src/helpers/SocketHelper.ts +76 -76
  222. package/src/helpers/Themes.ts +14 -14
  223. package/src/helpers/UniqueIdHelper.ts +36 -36
  224. package/src/helpers/UserHelper.ts +59 -59
  225. package/src/helpers/createEmotionCache.ts +17 -17
  226. package/src/helpers/index.ts +18 -18
  227. package/src/hooks/index.ts +1 -1
  228. package/src/hooks/useMountedState.ts +16 -16
  229. package/src/index.ts +6 -6
  230. package/src/interfaces/Access.ts +24 -24
  231. package/src/interfaces/Attendance.ts +8 -8
  232. package/src/interfaces/Content.ts +10 -10
  233. package/src/interfaces/Doing.ts +24 -24
  234. package/src/interfaces/Donation.ts +45 -45
  235. package/src/interfaces/Error.ts +17 -17
  236. package/src/interfaces/Membership.ts +51 -51
  237. package/src/interfaces/Messaging.ts +21 -20
  238. package/src/interfaces/Permissions.ts +68 -68
  239. package/src/interfaces/Reporting.ts +7 -7
  240. package/src/interfaces/UserContextInterface.ts +13 -13
  241. package/src/interfaces/index.ts +13 -13
  242. package/src/pageComponents/LoginPage.tsx +244 -244
  243. package/src/pageComponents/LogoutPage.tsx +28 -28
  244. package/src/pageComponents/components/Forgot.tsx +79 -79
  245. package/src/pageComponents/components/Login.tsx +54 -54
  246. package/src/pageComponents/components/LoginSetPassword.tsx +63 -63
  247. package/src/pageComponents/components/Register.tsx +107 -107
  248. package/src/pageComponents/components/SelectChurchModal.tsx +41 -41
  249. package/src/pageComponents/components/SelectChurchRegister.tsx +88 -88
  250. package/src/pageComponents/components/SelectChurchSearch.tsx +69 -69
  251. package/src/pageComponents/components/SelectableChurch.tsx +38 -38
  252. package/src/pageComponents/index.ts +3 -3
  253. package/tsconfig.json +34 -34
  254. package/tslint.json +14 -14
  255. package/dist/components/material/AppList.d.ts.map +0 -1
  256. package/dist/components/material/AppList.js.map +0 -1
  257. package/dist/components/material/ChurchList.d.ts.map +0 -1
  258. package/dist/components/material/ChurchList.js.map +0 -1
  259. package/dist/components/material/NavItem.d.ts.map +0 -1
  260. package/dist/components/material/NavItem.js.map +0 -1
  261. package/dist/components/material/NewPrivateMessage.d.ts.map +0 -1
  262. package/dist/components/material/NewPrivateMessage.js.map +0 -1
  263. package/dist/components/material/PrivateMessageDetails.d.ts.map +0 -1
  264. package/dist/components/material/PrivateMessageDetails.js.map +0 -1
  265. package/dist/components/material/PrivateMessages.d.ts.map +0 -1
  266. package/dist/components/material/PrivateMessages.js.map +0 -1
  267. package/dist/components/material/SiteWrapper.d.ts.map +0 -1
  268. package/dist/components/material/SiteWrapper.js.map +0 -1
  269. package/dist/components/material/UserMenu.d.ts.map +0 -1
  270. package/dist/components/material/UserMenu.js.map +0 -1
  271. package/dist/components/material/iconPicker/IconNamesList.d.ts.map +0 -1
  272. package/dist/components/material/iconPicker/IconNamesList.js.map +0 -1
  273. package/dist/components/material/iconPicker/IconPicker.d.ts.map +0 -1
  274. package/dist/components/material/iconPicker/IconPicker.js.map +0 -1
  275. package/dist/components/material/index.d.ts.map +0 -1
  276. package/dist/components/material/index.js.map +0 -1
  277. /package/dist/components/{material/iconPicker → iconPicker}/IconNamesList.d.ts +0 -0
  278. /package/dist/components/{material/iconPicker → iconPicker}/IconNamesList.js +0 -0
  279. /package/dist/components/{material/iconPicker → iconPicker}/IconPicker.d.ts +0 -0
  280. /package/dist/components/{material/iconPicker → iconPicker}/IconPicker.js +0 -0
  281. /package/dist/components/{material → wrapper}/AppList.d.ts +0 -0
  282. /package/dist/components/{material → wrapper}/AppList.js +0 -0
  283. /package/dist/components/{material → wrapper}/ChurchList.d.ts +0 -0
  284. /package/dist/components/{material → wrapper}/ChurchList.js +0 -0
  285. /package/dist/components/{material → wrapper}/NavItem.d.ts +0 -0
  286. /package/dist/components/{material → wrapper}/NavItem.js +0 -0
  287. /package/dist/components/{material → wrapper}/NewPrivateMessage.d.ts +0 -0
  288. /package/dist/components/{material → wrapper}/NewPrivateMessage.js +0 -0
  289. /package/dist/components/{material → wrapper}/PrivateMessageDetails.d.ts +0 -0
  290. /package/dist/components/{material → wrapper}/PrivateMessages.d.ts +0 -0
  291. /package/dist/components/{material → wrapper}/SiteWrapper.d.ts +0 -0
  292. /package/dist/components/{material → wrapper}/UserMenu.d.ts +0 -0
@@ -1,87 +1,87 @@
1
- import React, { useState } from "react";
2
- import { ApiHelper } from "../../helpers/ApiHelper";
3
- import { Box, Stack } from "@mui/material";
4
- import { SmallButton } from "../SmallButton";
5
- import { PrivateMessageInterface, UserContextInterface } from "../../interfaces";
6
- import { ArrayHelper, DateHelper, PersonHelper } from "../../helpers";
7
- import { PrivateMessageDetails } from "./PrivateMessageDetails";
8
- import { NewPrivateMessage } from "./NewPrivateMessage";
9
-
10
- interface Props {
11
- context: UserContextInterface;
12
- }
13
-
14
- export const PrivateMessages: React.FC<Props> = (props) => {
15
-
16
- const [privateMessages, setPrivateMessages] = useState<PrivateMessageInterface[]>([]);
17
- const [selectedMessage, setSelectedMessage] = useState<PrivateMessageInterface>(null);
18
- const [inAddMode, setInAddMode] = useState(false);
19
-
20
- const loadData = async () => {
21
- const pms: PrivateMessageInterface[] = await ApiHelper.get("/privateMessages", "MessagingApi");
22
- const peopleIds: string[] = [];
23
- pms.forEach(pm => {
24
- const personId = (pm.fromPersonId === props.context.person.id) ? pm.toPersonId : pm.fromPersonId;
25
- if (peopleIds.indexOf(personId) === -1) peopleIds.push(personId);
26
- });
27
- if (peopleIds.length > 0) {
28
- const people = await ApiHelper.get("/people/ids?ids=" + peopleIds.join(","), "MembershipApi");
29
- pms.forEach(pm => {
30
- const personId = (pm.fromPersonId === props.context.person.id) ? pm.toPersonId : pm.fromPersonId;
31
- pm.person = ArrayHelper.getOne(people, "id", personId);
32
- })
33
- }
34
- setPrivateMessages(pms);
35
- }
36
-
37
- React.useEffect(() => { loadData(); }, []); //eslint-disable-line
38
-
39
- const getMainLinks = () => {
40
- let result: JSX.Element[] = [];
41
- privateMessages.forEach(pm => {
42
-
43
- const person = pm.person;
44
- const message = pm.conversation.messages[0];
45
- const photoUrl = PersonHelper.getPhotoUrl(person);
46
-
47
- let datePosted = new Date(message.timeUpdated || message.timeSent);
48
- const displayDuration = DateHelper.getDisplayDuration(datePosted);
49
- const contents = message.content?.split("\n")[0];
50
- const privateMessage = pm;
51
- result.push(
52
- <div className="note" style={{ cursor: "pointer" }} onClick={(e) => { e.preventDefault(); setSelectedMessage(privateMessage) }}>
53
- <div className="postedBy">
54
- <img src={photoUrl} alt="avatar" />
55
- </div>
56
- <Box sx={{ width: "100%" }} className="note-contents">
57
- <Stack direction="row" justifyContent="space-between">
58
- <div>
59
- <b>{person.name?.display}</b> · <span className="text-grey">{displayDuration}</span>
60
- <p style={{ maxHeight: 20, overflowY: "hidden" }}>{contents}</p>
61
- </div>
62
- </Stack>
63
- </Box>
64
- </div>
65
- );
66
- })
67
- return result;
68
- }
69
-
70
- const handleBack = () => {
71
- setInAddMode(false);
72
- setSelectedMessage(null);
73
- loadData();
74
- }
75
-
76
- if (inAddMode) return <NewPrivateMessage context={props.context} onSelectMessage={(pm: PrivateMessageInterface) => { setSelectedMessage(pm); setInAddMode(false); }} onBack={handleBack} />
77
- if (selectedMessage) return <PrivateMessageDetails privateMessage={selectedMessage} context={props.context} onBack={handleBack} />
78
- else return (
79
- <>
80
- <span style={{ float: "right" }}>
81
- <SmallButton icon="add" onClick={() => { setInAddMode(true) }} />
82
- </span>
83
-
84
- {getMainLinks()}
85
- </>
86
- );
87
- };
1
+ import React, { useState } from "react";
2
+ import { ApiHelper } from "../../helpers/ApiHelper";
3
+ import { Box, Stack } from "@mui/material";
4
+ import { SmallButton } from "../SmallButton";
5
+ import { PrivateMessageInterface, UserContextInterface } from "../../interfaces";
6
+ import { ArrayHelper, DateHelper, PersonHelper } from "../../helpers";
7
+ import { PrivateMessageDetails } from "./PrivateMessageDetails";
8
+ import { NewPrivateMessage } from "./NewPrivateMessage";
9
+
10
+ interface Props {
11
+ context: UserContextInterface;
12
+ }
13
+
14
+ export const PrivateMessages: React.FC<Props> = (props) => {
15
+
16
+ const [privateMessages, setPrivateMessages] = useState<PrivateMessageInterface[]>([]);
17
+ const [selectedMessage, setSelectedMessage] = useState<PrivateMessageInterface>(null);
18
+ const [inAddMode, setInAddMode] = useState(false);
19
+
20
+ const loadData = async () => {
21
+ const pms: PrivateMessageInterface[] = await ApiHelper.get("/privateMessages", "MessagingApi");
22
+ const peopleIds: string[] = [];
23
+ pms.forEach(pm => {
24
+ const personId = (pm.fromPersonId === props.context.person.id) ? pm.toPersonId : pm.fromPersonId;
25
+ if (peopleIds.indexOf(personId) === -1) peopleIds.push(personId);
26
+ });
27
+ if (peopleIds.length > 0) {
28
+ const people = await ApiHelper.get("/people/ids?ids=" + peopleIds.join(","), "MembershipApi");
29
+ pms.forEach(pm => {
30
+ const personId = (pm.fromPersonId === props.context.person.id) ? pm.toPersonId : pm.fromPersonId;
31
+ pm.person = ArrayHelper.getOne(people, "id", personId);
32
+ })
33
+ }
34
+ setPrivateMessages(pms);
35
+ }
36
+
37
+ React.useEffect(() => { loadData(); }, []); //eslint-disable-line
38
+
39
+ const getMainLinks = () => {
40
+ let result: JSX.Element[] = [];
41
+ privateMessages.forEach(pm => {
42
+
43
+ const person = pm.person;
44
+ const message = pm.conversation.messages[0];
45
+ const photoUrl = PersonHelper.getPhotoUrl(person);
46
+
47
+ let datePosted = new Date(message.timeUpdated || message.timeSent);
48
+ const displayDuration = DateHelper.getDisplayDuration(datePosted);
49
+ const contents = message.content?.split("\n")[0];
50
+ const privateMessage = pm;
51
+ result.push(
52
+ <div className="note" style={{ cursor: "pointer" }} onClick={(e) => { e.preventDefault(); setSelectedMessage(privateMessage) }}>
53
+ <div className="postedBy">
54
+ <img src={photoUrl} alt="avatar" />
55
+ </div>
56
+ <Box sx={{ width: "100%" }} className="note-contents">
57
+ <Stack direction="row" justifyContent="space-between">
58
+ <div>
59
+ <b>{person.name?.display}</b> · <span className="text-grey">{displayDuration}</span>
60
+ <p style={{ maxHeight: 20, overflowY: "hidden" }}>{contents}</p>
61
+ </div>
62
+ </Stack>
63
+ </Box>
64
+ </div>
65
+ );
66
+ })
67
+ return result;
68
+ }
69
+
70
+ const handleBack = () => {
71
+ setInAddMode(false);
72
+ setSelectedMessage(null);
73
+ loadData();
74
+ }
75
+
76
+ if (inAddMode) return <NewPrivateMessage context={props.context} onSelectMessage={(pm: PrivateMessageInterface) => { setSelectedMessage(pm); setInAddMode(false); }} onBack={handleBack} />
77
+ if (selectedMessage) return <PrivateMessageDetails privateMessage={selectedMessage} context={props.context} onBack={handleBack} />
78
+ else return (
79
+ <>
80
+ <span style={{ float: "right" }}>
81
+ <SmallButton icon="edit_square" onClick={() => { setInAddMode(true) }} />
82
+ </span>
83
+
84
+ {getMainLinks()}
85
+ </>
86
+ );
87
+ };
@@ -1,145 +1,96 @@
1
- import React from "react";
2
- import { AppBar, Drawer, IconButton, styled, Toolbar, Icon, Typography, Box, Container, Link } from "@mui/material";
3
- import { UserHelper, AppearanceHelper, PersonHelper, AppearanceInterface, ApiHelper } from "../../helpers";
4
- import { UserMenu } from "./UserMenu";
5
- import { UserContextInterface } from "../../interfaces";
6
- import { useMountedState } from "../../hooks/useMountedState";
7
- import { SocketHelper } from "../../helpers/SocketHelper";
8
-
9
-
10
- interface Props {
11
- navContent: JSX.Element,
12
- context: UserContextInterface,
13
- children: React.ReactNode,
14
- appName: string,
15
- router?: any,
16
- appearance?: AppearanceInterface
17
- }
18
-
19
- const OpenDrawer = styled(Drawer)(
20
- ({ theme }) => ({
21
- "& .MuiDrawer-paper": {
22
- position: "relative",
23
- backgroundColor: theme.palette.primary.main,
24
- color: "#FFFFFF",
25
- whiteSpace: "nowrap",
26
- width: "100vw",
27
- zIndex: 9999,
28
- [theme.breakpoints.up("md")]: { width: 220 },
29
- transition: theme.transitions.create("width", {
30
- easing: theme.transitions.easing.sharp,
31
- duration: theme.transitions.duration.enteringScreen
32
- }),
33
- boxSizing: "border-box"
34
- },
35
- "& .MuiListItemButton-root, & .MuiListItemIcon-root": { color: "#FFFFFF" }
36
- })
37
- );
38
-
39
- const ClosedDrawer = styled(OpenDrawer)(
40
- ({ theme }) => ({
41
- overflowX: "hidden",
42
- transition: theme.transitions.create("width", {
43
- easing: theme.transitions.easing.sharp,
44
- duration: theme.transitions.duration.leavingScreen
45
- }),
46
- zIndex: 1,
47
- width: theme.spacing(7),
48
- [theme.breakpoints.up("sm")]: { width: theme.spacing(7) },
49
- "& .MuiListSubheader-root": {
50
- opacity: 0
51
- }
52
- })
53
- );
54
-
55
- const ClosedDrawerAppBar = styled(AppBar)(
56
- ({ theme }) => ({
57
- zIndex: theme.zIndex.drawer + 1,
58
- transition: theme.transitions.create(["width", "margin"], {
59
- easing: theme.transitions.easing.sharp,
60
- duration: theme.transitions.duration.leavingScreen
61
- }),
62
- "& .MuiIcon-root": { color: "#FFFFFF" }
63
- })
64
- );
65
-
66
- const OpenDrawerAppBar = styled(ClosedDrawerAppBar)(
67
- ({ theme }) => ({
68
- marginLeft: 220,
69
- width: `calc(100% - ${220}px)`,
70
- transition: theme.transitions.create(["width", "margin"], {
71
- easing: theme.transitions.easing.sharp,
72
- duration: theme.transitions.duration.enteringScreen
73
- })
74
- })
75
- );
76
-
77
- export const SiteWrapper: React.FC<Props> = props => {
78
- const [churchLogo, setChurchLogo] = React.useState<string>();
79
- const [open, setOpen] = React.useState(false);
80
- const toggleDrawer = () => { setOpen(!open); };
81
- const isMounted = useMountedState();
82
-
83
- const CustomDrawer = (open) ? OpenDrawer : ClosedDrawer;
84
- const CustomAppBar = (open) ? OpenDrawerAppBar : ClosedDrawerAppBar;
85
-
86
- const handleNotification = () => {
87
- alert("Notification received. Make GET to fetch bell count and toast message.")
88
- }
89
-
90
-
91
-
92
- React.useEffect(() => {
93
- const getChurchLogo = async () => {
94
- if (UserHelper.currentUserChurch) {
95
- setChurchLogo(AppearanceHelper.getLogoDark(props.appearance, "/images/logo-wrapper.png"));
96
- }
97
- }
98
-
99
- if (!isMounted()) {
100
- getChurchLogo();
101
- }
102
- }, [isMounted, props.appearance]);
103
-
104
-
105
- React.useEffect(() => {
106
- if (!props.context.userChurch) SocketHelper.setPersonChurch({personId:null, churchId:null});
107
- else SocketHelper.setPersonChurch({personId:props.context.userChurch?.person?.id, churchId:props.context.userChurch?.church?.id});
108
- }, [props.context.userChurch]);
109
-
110
- React.useEffect(() => {
111
- SocketHelper.addHandler("notification", "notificationBell", handleNotification);
112
- SocketHelper.init();
113
- }, []);
114
-
115
-
116
-
117
- return <>
118
- <CustomAppBar position="absolute">
119
- <Toolbar sx={{ pr: "24px" }}>
120
- <IconButton edge="start" color="inherit" aria-label="open drawer" onClick={toggleDrawer} sx={{ marginRight: "36px", ...(open && { display: "none" }) }}>
121
- <Icon>menu</Icon>
122
- </IconButton>
123
- <Typography variant="h6" noWrap>{UserHelper.currentUserChurch?.church?.name || ""}</Typography>
124
- <div style={{ flex: 1 }}></div>
125
- {UserHelper.user && <UserMenu profilePicture={PersonHelper.getPhotoUrl(props.context?.person)} userName={`${UserHelper.user?.firstName} ${UserHelper.user?.lastName}`} userChurches={UserHelper.userChurches} currentUserChurch={UserHelper.currentUserChurch} context={props.context} appName={props.appName} router={props.router} />}
126
- {!UserHelper.user && <Link href="/login" color="inherit" style={{ textDecoration: "none" }}>Login</Link>}
127
- </Toolbar>
128
- </CustomAppBar>
129
-
130
- <CustomDrawer variant="permanent" open={open}>
131
- <Toolbar sx={{ display: "flex", alignItems: "center", width: "100%", px: [1] }}>
132
- <img src={churchLogo || "/images/logo-wrapper.png"} alt="logo" style={{ maxWidth: 170 }} />
133
- <div style={{ justifyContent: "flex-end", flex: 1, display: "flex" }}>
134
- <IconButton onClick={toggleDrawer}><Icon style={{ color: "#FFFFFF" }}>chevron_left</Icon></IconButton>
135
- </div>
136
- </Toolbar>
137
- {props.navContent}
138
- </CustomDrawer>
139
- <Box component="main" sx={{ flexGrow: 1, overflow: "auto", marginTop: 8, minHeight: "90vh" }}>
140
- <Container maxWidth={false} sx={{ mt: 4, mb: 4 }}>
141
- {props.children}
142
- </Container>
143
- </Box>
144
- </>
145
- };
1
+ import React from "react";
2
+ import { IconButton, Toolbar, Icon, Typography, Box, Container, Link } from "@mui/material";
3
+ import { UserHelper, AppearanceHelper, PersonHelper, AppearanceInterface, ApiHelper } from "../../helpers";
4
+ import { UserMenu } from "./UserMenu";
5
+ import { UserContextInterface } from "../../interfaces";
6
+ import { useMountedState } from "../../hooks/useMountedState";
7
+ import { SocketHelper } from "../../helpers/SocketHelper";
8
+ import { NotificationMenu } from "./NotificationMenu";
9
+ import { ClosedDrawer, ClosedDrawerAppBar, OpenDrawer, OpenDrawerAppBar } from "./Drawers";
10
+
11
+ interface Props {
12
+ navContent: JSX.Element,
13
+ context: UserContextInterface,
14
+ children: React.ReactNode,
15
+ appName: string,
16
+ router?: any,
17
+ appearance?: AppearanceInterface
18
+ }
19
+
20
+ export const SiteWrapper: React.FC<Props> = props => {
21
+ const [churchLogo, setChurchLogo] = React.useState<string>();
22
+ const [open, setOpen] = React.useState(false);
23
+ const [notificationCounts, setNotificationCounts] = React.useState({notificationCount:0, pmCount:0});
24
+ const toggleDrawer = () => { setOpen(!open); };
25
+ const isMounted = useMountedState();
26
+
27
+ const CustomDrawer = (open) ? OpenDrawer : ClosedDrawer;
28
+ const CustomAppBar = (open) ? OpenDrawerAppBar : ClosedDrawerAppBar;
29
+
30
+ const loadCounts = () => {
31
+ ApiHelper.get("/notifications/unreadCount", "MessagingApi").then(data => { setNotificationCounts(data); });
32
+ }
33
+ const handleNotification = () => {
34
+ //alert("Notification received. Make GET to fetch bell count and toast message.")
35
+ console.log("Notification received. Make GET to fetch bell count and toast message.");
36
+ loadCounts();
37
+ }
38
+
39
+
40
+
41
+ React.useEffect(() => {
42
+ const getChurchLogo = async () => {
43
+ if (UserHelper.currentUserChurch) {
44
+ setChurchLogo(AppearanceHelper.getLogoDark(props.appearance, "/images/logo-wrapper.png"));
45
+ }
46
+ }
47
+
48
+ if (!isMounted()) {
49
+ getChurchLogo();
50
+ }
51
+ }, [isMounted, props.appearance]);
52
+
53
+
54
+ React.useEffect(() => {
55
+ if (!props.context.userChurch) SocketHelper.setPersonChurch({personId:null, churchId:null});
56
+ else SocketHelper.setPersonChurch({personId:props.context.userChurch?.person?.id, churchId:props.context.userChurch?.church?.id});
57
+ }, [props.context.userChurch]);
58
+
59
+ React.useEffect(() => {
60
+ SocketHelper.addHandler("notification", "notificationBell", handleNotification);
61
+ SocketHelper.init();
62
+ loadCounts();
63
+ }, []);
64
+
65
+
66
+
67
+ return <>
68
+ <CustomAppBar position="absolute">
69
+ <Toolbar sx={{ pr: "24px" }}>
70
+ <IconButton edge="start" color="inherit" aria-label="open drawer" onClick={toggleDrawer} sx={{ marginRight: "36px", ...(open && { display: "none" }) }}>
71
+ <Icon>menu</Icon>
72
+ </IconButton>
73
+ <Typography variant="h6" noWrap>{UserHelper.currentUserChurch?.church?.name || ""}</Typography>
74
+ <div style={{ flex: 1 }}></div>
75
+ {UserHelper.user && <NotificationMenu onUpdate={loadCounts} counts={notificationCounts} context={props.context} router={props.router} />}
76
+ {UserHelper.user && <UserMenu profilePicture={PersonHelper.getPhotoUrl(props.context?.person)} userName={`${UserHelper.user?.firstName} ${UserHelper.user?.lastName}`} userChurches={UserHelper.userChurches} currentUserChurch={UserHelper.currentUserChurch} context={props.context} appName={props.appName} router={props.router} />}
77
+ {!UserHelper.user && <Link href="/login" color="inherit" style={{ textDecoration: "none" }}>Login</Link>}
78
+ </Toolbar>
79
+ </CustomAppBar>
80
+
81
+ <CustomDrawer variant="permanent" open={open}>
82
+ <Toolbar sx={{ display: "flex", alignItems: "center", width: "100%", px: [1] }}>
83
+ <img src={churchLogo || "/images/logo-wrapper.png"} alt="logo" style={{ maxWidth: 170 }} />
84
+ <div style={{ justifyContent: "flex-end", flex: 1, display: "flex" }}>
85
+ <IconButton onClick={toggleDrawer}><Icon style={{ color: "#FFFFFF" }}>chevron_left</Icon></IconButton>
86
+ </div>
87
+ </Toolbar>
88
+ {props.navContent}
89
+ </CustomDrawer>
90
+ <Box component="main" sx={{ flexGrow: 1, overflow: "auto", marginTop: 8, minHeight: "90vh" }}>
91
+ <Container maxWidth={false} sx={{ mt: 4, mb: 4 }}>
92
+ {props.children}
93
+ </Container>
94
+ </Box>
95
+ </>
96
+ };
@@ -0,0 +1,30 @@
1
+ import React from "react";
2
+ import { Box, styled } from "@mui/material";
3
+
4
+ interface TabPanelProps { children?: React.ReactNode; index: number; value: number; }
5
+
6
+ const StyledMenuBox = styled(Box)(
7
+ ({ theme }) => ({
8
+ paddingTop: 10,
9
+ "& .MuiListItemButton-root": { paddingLeft: 30 },
10
+ "& .MuiListItemIcon-root": {
11
+ color: theme.palette.primary.main
12
+ },
13
+ "& .MuiListItemText-root": { color: theme.palette.text.primary },
14
+ "& .selected .MuiListItemText-root span": { fontWeight: "bold" }
15
+ })
16
+ );
17
+
18
+ export function TabPanel(props: TabPanelProps) {
19
+ const { children, value, index } = props;
20
+
21
+ return (
22
+ <div role="tabpanel" hidden={value !== index} id={`userMenuPanel-${index}`}>
23
+ {value === index && (
24
+ <StyledMenuBox>
25
+ <Box>{children}</Box>
26
+ </StyledMenuBox>
27
+ )}
28
+ </div>
29
+ );
30
+ }