@churchapps/apphelper 0.0.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.
- package/.eslintignore +4 -0
- package/.eslintrc.json +22 -0
- package/LICENSE +21 -0
- package/README.md +16 -0
- package/dist/components/CreatePerson.d.ts +9 -0
- package/dist/components/CreatePerson.d.ts.map +1 -0
- package/dist/components/CreatePerson.js +80 -0
- package/dist/components/CreatePerson.js.map +1 -0
- package/dist/components/DisplayBox.d.ts +16 -0
- package/dist/components/DisplayBox.d.ts.map +1 -0
- package/dist/components/DisplayBox.js +48 -0
- package/dist/components/DisplayBox.js.map +1 -0
- package/dist/components/ErrorMessages.d.ts +7 -0
- package/dist/components/ErrorMessages.d.ts.map +1 -0
- package/dist/components/ErrorMessages.js +47 -0
- package/dist/components/ErrorMessages.js.map +1 -0
- package/dist/components/ExportLink.d.ts +10 -0
- package/dist/components/ExportLink.d.ts.map +1 -0
- package/dist/components/ExportLink.js +70 -0
- package/dist/components/ExportLink.js.map +1 -0
- package/dist/components/FloatingSupport.d.ts +7 -0
- package/dist/components/FloatingSupport.d.ts.map +1 -0
- package/dist/components/FloatingSupport.js +18 -0
- package/dist/components/FloatingSupport.js.map +1 -0
- package/dist/components/FormSubmissionEdit.d.ts +18 -0
- package/dist/components/FormSubmissionEdit.d.ts.map +1 -0
- package/dist/components/FormSubmissionEdit.js +125 -0
- package/dist/components/FormSubmissionEdit.js.map +1 -0
- package/dist/components/HelpIcon.d.ts +7 -0
- package/dist/components/HelpIcon.d.ts.map +1 -0
- package/dist/components/HelpIcon.js +12 -0
- package/dist/components/HelpIcon.js.map +1 -0
- package/dist/components/ImageEditor.d.ts +15 -0
- package/dist/components/ImageEditor.d.ts.map +1 -0
- package/dist/components/ImageEditor.js +109 -0
- package/dist/components/ImageEditor.js.map +1 -0
- package/dist/components/InputBox.d.ts +24 -0
- package/dist/components/InputBox.d.ts.map +1 -0
- package/dist/components/InputBox.js +59 -0
- package/dist/components/InputBox.js.map +1 -0
- package/dist/components/Loading.d.ts +10 -0
- package/dist/components/Loading.d.ts.map +1 -0
- package/dist/components/Loading.js +34 -0
- package/dist/components/Loading.js.map +1 -0
- package/dist/components/PersonAdd.d.ts +15 -0
- package/dist/components/PersonAdd.d.ts.map +1 -0
- package/dist/components/PersonAdd.js +84 -0
- package/dist/components/PersonAdd.js.map +1 -0
- package/dist/components/QuestionEdit.d.ts +11 -0
- package/dist/components/QuestionEdit.d.ts.map +1 -0
- package/dist/components/QuestionEdit.js +76 -0
- package/dist/components/QuestionEdit.js.map +1 -0
- package/dist/components/SmallButton.d.ts +14 -0
- package/dist/components/SmallButton.d.ts.map +1 -0
- package/dist/components/SmallButton.js +31 -0
- package/dist/components/SmallButton.js.map +1 -0
- package/dist/components/SupportModal.d.ts +8 -0
- package/dist/components/SupportModal.d.ts.map +1 -0
- package/dist/components/SupportModal.js +47 -0
- package/dist/components/SupportModal.js.map +1 -0
- package/dist/components/TabPanel.d.ts +9 -0
- package/dist/components/TabPanel.d.ts.map +1 -0
- package/dist/components/TabPanel.js +24 -0
- package/dist/components/TabPanel.js.map +1 -0
- package/dist/components/gallery/GalleryModal.d.ts +9 -0
- package/dist/components/gallery/GalleryModal.d.ts.map +1 -0
- package/dist/components/gallery/GalleryModal.js +108 -0
- package/dist/components/gallery/GalleryModal.js.map +1 -0
- package/dist/components/gallery/StockPhotos.d.ts +9 -0
- package/dist/components/gallery/StockPhotos.d.ts.map +1 -0
- package/dist/components/gallery/StockPhotos.js +82 -0
- package/dist/components/gallery/StockPhotos.js.map +1 -0
- package/dist/components/index.d.ts +18 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +51 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/markdownEditor/Editor.d.ts +12 -0
- package/dist/components/markdownEditor/Editor.d.ts.map +1 -0
- package/dist/components/markdownEditor/Editor.js +106 -0
- package/dist/components/markdownEditor/Editor.js.map +1 -0
- package/dist/components/markdownEditor/MarkdownEditor.d.ts +11 -0
- package/dist/components/markdownEditor/MarkdownEditor.d.ts.map +1 -0
- package/dist/components/markdownEditor/MarkdownEditor.js +39 -0
- package/dist/components/markdownEditor/MarkdownEditor.js.map +1 -0
- package/dist/components/markdownEditor/MarkdownModal.d.ts +9 -0
- package/dist/components/markdownEditor/MarkdownModal.d.ts.map +1 -0
- package/dist/components/markdownEditor/MarkdownModal.js +58 -0
- package/dist/components/markdownEditor/MarkdownModal.js.map +1 -0
- package/dist/components/markdownEditor/MarkdownPreview.d.ts +8 -0
- package/dist/components/markdownEditor/MarkdownPreview.d.ts.map +1 -0
- package/dist/components/markdownEditor/MarkdownPreview.js +35 -0
- package/dist/components/markdownEditor/MarkdownPreview.js.map +1 -0
- package/dist/components/markdownEditor/plugins/AutoLinkPlugin.d.ts +3 -0
- package/dist/components/markdownEditor/plugins/AutoLinkPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/AutoLinkPlugin.js +35 -0
- package/dist/components/markdownEditor/plugins/AutoLinkPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/ControlledEditorPlugin.d.ts +8 -0
- package/dist/components/markdownEditor/plugins/ControlledEditorPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/ControlledEditorPlugin.js +20 -0
- package/dist/components/markdownEditor/plugins/ControlledEditorPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/ListMaxIndentLevelPlugin.d.ts +2 -0
- package/dist/components/markdownEditor/plugins/ListMaxIndentLevelPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/ListMaxIndentLevelPlugin.js +46 -0
- package/dist/components/markdownEditor/plugins/ListMaxIndentLevelPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/MarkdownTransformers.d.ts +12 -0
- package/dist/components/markdownEditor/plugins/MarkdownTransformers.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/MarkdownTransformers.js +85 -0
- package/dist/components/markdownEditor/plugins/MarkdownTransformers.js.map +1 -0
- package/dist/components/markdownEditor/plugins/ReadOnlyPlugin.d.ts +6 -0
- package/dist/components/markdownEditor/plugins/ReadOnlyPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/ReadOnlyPlugin.js +13 -0
- package/dist/components/markdownEditor/plugins/ReadOnlyPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/ToolbarPlugin.d.ts +8 -0
- package/dist/components/markdownEditor/plugins/ToolbarPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/ToolbarPlugin.js +324 -0
- package/dist/components/markdownEditor/plugins/ToolbarPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNode.d.ts +27 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNode.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNode.js +158 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNode.js.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodePlugin.d.ts +4 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodePlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodePlugin.js +18 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodePlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.d.ts +3 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.js +67 -0
- package/dist/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.js.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.d.ts +5 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.js +212 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.js.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.types.d.ts +11 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.types.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.types.js +3 -0
- package/dist/components/markdownEditor/plugins/customLink/FloatingLinkEditor.types.js.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNode.d.ts +24 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNode.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNode.js +63 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNode.js.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNodeTransform.d.ts +4 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNodeTransform.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNodeTransform.js +35 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiNodeTransform.js.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.d.ts +10 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.js +99 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojisPlugin.d.ts +11 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojisPlugin.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojisPlugin.js +55 -0
- package/dist/components/markdownEditor/plugins/emoji/EmojisPlugin.js.map +1 -0
- package/dist/components/markdownEditor/plugins/index.d.ts +7 -0
- package/dist/components/markdownEditor/plugins/index.d.ts.map +1 -0
- package/dist/components/markdownEditor/plugins/index.js +16 -0
- package/dist/components/markdownEditor/plugins/index.js.map +1 -0
- package/dist/components/markdownEditor/theme.d.ts +66 -0
- package/dist/components/markdownEditor/theme.d.ts.map +1 -0
- package/dist/components/markdownEditor/theme.js +69 -0
- package/dist/components/markdownEditor/theme.js.map +1 -0
- package/dist/components/material/AppList.d.ts +9 -0
- package/dist/components/material/AppList.d.ts.map +1 -0
- package/dist/components/material/AppList.js +21 -0
- package/dist/components/material/AppList.js.map +1 -0
- package/dist/components/material/ChurchList.d.ts +9 -0
- package/dist/components/material/ChurchList.d.ts.map +1 -0
- package/dist/components/material/ChurchList.js +25 -0
- package/dist/components/material/ChurchList.js.map +1 -0
- package/dist/components/material/NavItem.d.ts +14 -0
- package/dist/components/material/NavItem.d.ts.map +1 -0
- package/dist/components/material/NavItem.js +36 -0
- package/dist/components/material/NavItem.js.map +1 -0
- package/dist/components/material/NewPrivateMessage.d.ts +10 -0
- package/dist/components/material/NewPrivateMessage.d.ts.map +1 -0
- package/dist/components/material/NewPrivateMessage.js +96 -0
- package/dist/components/material/NewPrivateMessage.js.map +1 -0
- package/dist/components/material/PrivateMessageDetails.d.ts +10 -0
- package/dist/components/material/PrivateMessageDetails.d.ts.map +1 -0
- package/dist/components/material/PrivateMessageDetails.js +18 -0
- package/dist/components/material/PrivateMessageDetails.js.map +1 -0
- package/dist/components/material/PrivateMessages.d.ts +8 -0
- package/dist/components/material/PrivateMessages.d.ts.map +1 -0
- package/dist/components/material/PrivateMessages.js +105 -0
- package/dist/components/material/PrivateMessages.js.map +1 -0
- package/dist/components/material/SiteWrapper.d.ts +14 -0
- package/dist/components/material/SiteWrapper.d.ts.map +1 -0
- package/dist/components/material/SiteWrapper.js +120 -0
- package/dist/components/material/SiteWrapper.js.map +1 -0
- package/dist/components/material/UserMenu.d.ts +14 -0
- package/dist/components/material/UserMenu.d.ts.map +1 -0
- package/dist/components/material/UserMenu.js +98 -0
- package/dist/components/material/UserMenu.js.map +1 -0
- package/dist/components/material/iconPicker/IconNamesList.d.ts +3 -0
- package/dist/components/material/iconPicker/IconNamesList.d.ts.map +1 -0
- package/dist/components/material/iconPicker/IconNamesList.js +2241 -0
- package/dist/components/material/iconPicker/IconNamesList.js.map +1 -0
- package/dist/components/material/iconPicker/IconPicker.d.ts +7 -0
- package/dist/components/material/iconPicker/IconPicker.d.ts.map +1 -0
- package/dist/components/material/iconPicker/IconPicker.js +136 -0
- package/dist/components/material/iconPicker/IconPicker.js.map +1 -0
- package/dist/components/material/index.d.ts +6 -0
- package/dist/components/material/index.d.ts.map +1 -0
- package/dist/components/material/index.js +14 -0
- package/dist/components/material/index.js.map +1 -0
- package/dist/components/notes/AddNote.d.ts +12 -0
- package/dist/components/notes/AddNote.d.ts.map +1 -0
- package/dist/components/notes/AddNote.js +123 -0
- package/dist/components/notes/AddNote.js.map +1 -0
- package/dist/components/notes/Conversation.d.ts +11 -0
- package/dist/components/notes/Conversation.d.ts.map +1 -0
- package/dist/components/notes/Conversation.js +85 -0
- package/dist/components/notes/Conversation.js.map +1 -0
- package/dist/components/notes/Conversations.d.ts +11 -0
- package/dist/components/notes/Conversations.d.ts.map +1 -0
- package/dist/components/notes/Conversations.js +64 -0
- package/dist/components/notes/Conversations.js.map +1 -0
- package/dist/components/notes/NewConversation.d.ts +13 -0
- package/dist/components/notes/NewConversation.d.ts.map +1 -0
- package/dist/components/notes/NewConversation.js +86 -0
- package/dist/components/notes/NewConversation.js.map +1 -0
- package/dist/components/notes/Note.d.ts +9 -0
- package/dist/components/notes/Note.d.ts.map +1 -0
- package/dist/components/notes/Note.js +58 -0
- package/dist/components/notes/Note.js.map +1 -0
- package/dist/components/notes/Notes.d.ts +11 -0
- package/dist/components/notes/Notes.d.ts.map +1 -0
- package/dist/components/notes/Notes.js +59 -0
- package/dist/components/notes/Notes.js.map +1 -0
- package/dist/components/reporting/ChartReport.d.ts +9 -0
- package/dist/components/reporting/ChartReport.d.ts.map +1 -0
- package/dist/components/reporting/ChartReport.js +93 -0
- package/dist/components/reporting/ChartReport.js.map +1 -0
- package/dist/components/reporting/ReportFilter.d.ts +10 -0
- package/dist/components/reporting/ReportFilter.d.ts.map +1 -0
- package/dist/components/reporting/ReportFilter.js +54 -0
- package/dist/components/reporting/ReportFilter.js.map +1 -0
- package/dist/components/reporting/ReportFilterField.d.ts +10 -0
- package/dist/components/reporting/ReportFilterField.d.ts.map +1 -0
- package/dist/components/reporting/ReportFilterField.js +167 -0
- package/dist/components/reporting/ReportFilterField.js.map +1 -0
- package/dist/components/reporting/ReportOutput.d.ts +8 -0
- package/dist/components/reporting/ReportOutput.d.ts.map +1 -0
- package/dist/components/reporting/ReportOutput.js +95 -0
- package/dist/components/reporting/ReportOutput.js.map +1 -0
- package/dist/components/reporting/ReportWithFilter.d.ts +8 -0
- package/dist/components/reporting/ReportWithFilter.d.ts.map +1 -0
- package/dist/components/reporting/ReportWithFilter.js +67 -0
- package/dist/components/reporting/ReportWithFilter.js.map +1 -0
- package/dist/components/reporting/TableReport.d.ts +9 -0
- package/dist/components/reporting/TableReport.d.ts.map +1 -0
- package/dist/components/reporting/TableReport.js +50 -0
- package/dist/components/reporting/TableReport.js.map +1 -0
- package/dist/components/reporting/TreeReport.d.ts +9 -0
- package/dist/components/reporting/TreeReport.d.ts.map +1 -0
- package/dist/components/reporting/TreeReport.js +104 -0
- package/dist/components/reporting/TreeReport.js.map +1 -0
- package/dist/components/reporting/index.d.ts +5 -0
- package/dist/components/reporting/index.d.ts.map +1 -0
- package/dist/components/reporting/index.js +12 -0
- package/dist/components/reporting/index.js.map +1 -0
- package/dist/donationComponents/DonationPage.d.ts +9 -0
- package/dist/donationComponents/DonationPage.d.ts.map +1 -0
- package/dist/donationComponents/DonationPage.js +128 -0
- package/dist/donationComponents/DonationPage.js.map +1 -0
- package/dist/donationComponents/components/BankForm.d.ts +14 -0
- package/dist/donationComponents/components/BankForm.d.ts.map +1 -0
- package/dist/donationComponents/components/BankForm.js +161 -0
- package/dist/donationComponents/components/BankForm.js.map +1 -0
- package/dist/donationComponents/components/CardForm.d.ts +13 -0
- package/dist/donationComponents/components/CardForm.d.ts.map +1 -0
- package/dist/donationComponents/components/CardForm.js +128 -0
- package/dist/donationComponents/components/CardForm.js.map +1 -0
- package/dist/donationComponents/components/DonationForm.d.ts +14 -0
- package/dist/donationComponents/components/DonationForm.d.ts.map +1 -0
- package/dist/donationComponents/components/DonationForm.js +227 -0
- package/dist/donationComponents/components/DonationForm.js.map +1 -0
- package/dist/donationComponents/components/FundDonation.d.ts +11 -0
- package/dist/donationComponents/components/FundDonation.d.ts.map +1 -0
- package/dist/donationComponents/components/FundDonation.js +37 -0
- package/dist/donationComponents/components/FundDonation.js.map +1 -0
- package/dist/donationComponents/components/FundDonations.d.ts +10 -0
- package/dist/donationComponents/components/FundDonations.d.ts.map +1 -0
- package/dist/donationComponents/components/FundDonations.js +35 -0
- package/dist/donationComponents/components/FundDonations.js.map +1 -0
- package/dist/donationComponents/components/NonAuthDonation.d.ts +11 -0
- package/dist/donationComponents/components/NonAuthDonation.d.ts.map +1 -0
- package/dist/donationComponents/components/NonAuthDonation.js +40 -0
- package/dist/donationComponents/components/NonAuthDonation.js.map +1 -0
- package/dist/donationComponents/components/NonAuthDonationInner.d.ts +11 -0
- package/dist/donationComponents/components/NonAuthDonationInner.d.ts.map +1 -0
- package/dist/donationComponents/components/NonAuthDonationInner.js +246 -0
- package/dist/donationComponents/components/NonAuthDonationInner.js.map +1 -0
- package/dist/donationComponents/components/PaymentMethods.d.ts +14 -0
- package/dist/donationComponents/components/PaymentMethods.d.ts.map +1 -0
- package/dist/donationComponents/components/PaymentMethods.js +113 -0
- package/dist/donationComponents/components/PaymentMethods.js.map +1 -0
- package/dist/donationComponents/components/RecurringDonations.d.ts +10 -0
- package/dist/donationComponents/components/RecurringDonations.d.ts.map +1 -0
- package/dist/donationComponents/components/RecurringDonations.js +118 -0
- package/dist/donationComponents/components/RecurringDonations.js.map +1 -0
- package/dist/donationComponents/components/RecurringDonationsEdit.d.ts +11 -0
- package/dist/donationComponents/components/RecurringDonationsEdit.d.ts.map +1 -0
- package/dist/donationComponents/components/RecurringDonationsEdit.js +81 -0
- package/dist/donationComponents/components/RecurringDonationsEdit.js.map +1 -0
- package/dist/donationComponents/components/index.d.ts +10 -0
- package/dist/donationComponents/components/index.d.ts.map +1 -0
- package/dist/donationComponents/components/index.js +22 -0
- package/dist/donationComponents/components/index.js.map +1 -0
- package/dist/donationComponents/modals/DonationPreviewModal.d.ts +15 -0
- package/dist/donationComponents/modals/DonationPreviewModal.d.ts.map +1 -0
- package/dist/donationComponents/modals/DonationPreviewModal.js +73 -0
- package/dist/donationComponents/modals/DonationPreviewModal.js.map +1 -0
- package/dist/helpers/AnalyticsHelper.d.ts +7 -0
- package/dist/helpers/AnalyticsHelper.d.ts.map +1 -0
- package/dist/helpers/AnalyticsHelper.js +39 -0
- package/dist/helpers/AnalyticsHelper.js.map +1 -0
- package/dist/helpers/ApiHelper.d.ts +18 -0
- package/dist/helpers/ApiHelper.d.ts.map +1 -0
- package/dist/helpers/ApiHelper.js +145 -0
- package/dist/helpers/ApiHelper.js.map +1 -0
- package/dist/helpers/AppearanceHelper.d.ts +19 -0
- package/dist/helpers/AppearanceHelper.d.ts.map +1 -0
- package/dist/helpers/AppearanceHelper.js +64 -0
- package/dist/helpers/AppearanceHelper.js.map +1 -0
- package/dist/helpers/ArrayHelper.d.ts +12 -0
- package/dist/helpers/ArrayHelper.d.ts.map +1 -0
- package/dist/helpers/ArrayHelper.js +88 -0
- package/dist/helpers/ArrayHelper.js.map +1 -0
- package/dist/helpers/CommonEnvironmentHelper.d.ts +20 -0
- package/dist/helpers/CommonEnvironmentHelper.d.ts.map +1 -0
- package/dist/helpers/CommonEnvironmentHelper.js +82 -0
- package/dist/helpers/CommonEnvironmentHelper.js.map +1 -0
- package/dist/helpers/CurrencyHelper.d.ts +4 -0
- package/dist/helpers/CurrencyHelper.d.ts.map +1 -0
- package/dist/helpers/CurrencyHelper.js +15 -0
- package/dist/helpers/CurrencyHelper.js.map +1 -0
- package/dist/helpers/DateHelper.d.ts +19 -0
- package/dist/helpers/DateHelper.d.ts.map +1 -0
- package/dist/helpers/DateHelper.js +108 -0
- package/dist/helpers/DateHelper.js.map +1 -0
- package/dist/helpers/DonationHelper.d.ts +8 -0
- package/dist/helpers/DonationHelper.d.ts.map +1 -0
- package/dist/helpers/DonationHelper.js +33 -0
- package/dist/helpers/DonationHelper.js.map +1 -0
- package/dist/helpers/ErrorHelper.d.ts +13 -0
- package/dist/helpers/ErrorHelper.d.ts.map +1 -0
- package/dist/helpers/ErrorHelper.js +34 -0
- package/dist/helpers/ErrorHelper.js.map +1 -0
- package/dist/helpers/EventHelper.d.ts +11 -0
- package/dist/helpers/EventHelper.d.ts.map +1 -0
- package/dist/helpers/EventHelper.js +47 -0
- package/dist/helpers/EventHelper.js.map +1 -0
- package/dist/helpers/FileHelper.d.ts +5 -0
- package/dist/helpers/FileHelper.d.ts.map +1 -0
- package/dist/helpers/FileHelper.js +34 -0
- package/dist/helpers/FileHelper.js.map +1 -0
- package/dist/helpers/PersonHelper.d.ts +11 -0
- package/dist/helpers/PersonHelper.d.ts.map +1 -0
- package/dist/helpers/PersonHelper.js +53 -0
- package/dist/helpers/PersonHelper.js.map +1 -0
- package/dist/helpers/SocketHelper.d.ts +16 -0
- package/dist/helpers/SocketHelper.d.ts.map +1 -0
- package/dist/helpers/SocketHelper.js +87 -0
- package/dist/helpers/SocketHelper.js.map +1 -0
- package/dist/helpers/Themes.d.ts +9 -0
- package/dist/helpers/Themes.d.ts.map +1 -0
- package/dist/helpers/Themes.js +16 -0
- package/dist/helpers/Themes.js.map +1 -0
- package/dist/helpers/UniqueIdHelper.d.ts +9 -0
- package/dist/helpers/UniqueIdHelper.d.ts.map +1 -0
- package/dist/helpers/UniqueIdHelper.js +37 -0
- package/dist/helpers/UniqueIdHelper.js.map +1 -0
- package/dist/helpers/UserHelper.d.ts +14 -0
- package/dist/helpers/UserHelper.d.ts.map +1 -0
- package/dist/helpers/UserHelper.js +68 -0
- package/dist/helpers/UserHelper.js.map +1 -0
- package/dist/helpers/createEmotionCache.d.ts +2 -0
- package/dist/helpers/createEmotionCache.d.ts.map +1 -0
- package/dist/helpers/createEmotionCache.js +21 -0
- package/dist/helpers/createEmotionCache.js.map +1 -0
- package/dist/helpers/index.d.ts +16 -0
- package/dist/helpers/index.d.ts.map +1 -0
- package/dist/helpers/index.js +47 -0
- package/dist/helpers/index.js.map +1 -0
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +6 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useMountedState.d.ts +2 -0
- package/dist/hooks/useMountedState.d.ts.map +1 -0
- package/dist/hooks/useMountedState.js +17 -0
- package/dist/hooks/useMountedState.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/Access.d.ts +131 -0
- package/dist/interfaces/Access.d.ts.map +1 -0
- package/dist/interfaces/Access.js +3 -0
- package/dist/interfaces/Access.js.map +1 -0
- package/dist/interfaces/Attendance.d.ts +45 -0
- package/dist/interfaces/Attendance.d.ts.map +1 -0
- package/dist/interfaces/Attendance.js +3 -0
- package/dist/interfaces/Attendance.js.map +1 -0
- package/dist/interfaces/Content.d.ts +86 -0
- package/dist/interfaces/Content.d.ts.map +1 -0
- package/dist/interfaces/Content.js +3 -0
- package/dist/interfaces/Content.js.map +1 -0
- package/dist/interfaces/Doing.d.ts +50 -0
- package/dist/interfaces/Doing.d.ts.map +1 -0
- package/dist/interfaces/Doing.js +3 -0
- package/dist/interfaces/Doing.js.map +1 -0
- package/dist/interfaces/Donation.d.ts +138 -0
- package/dist/interfaces/Donation.d.ts.map +1 -0
- package/dist/interfaces/Donation.js +24 -0
- package/dist/interfaces/Donation.js.map +1 -0
- package/dist/interfaces/Error.d.ts +17 -0
- package/dist/interfaces/Error.d.ts.map +1 -0
- package/dist/interfaces/Error.js +4 -0
- package/dist/interfaces/Error.js.map +1 -0
- package/dist/interfaces/Membership.d.ts +172 -0
- package/dist/interfaces/Membership.d.ts.map +1 -0
- package/dist/interfaces/Membership.js +3 -0
- package/dist/interfaces/Membership.js.map +1 -0
- package/dist/interfaces/Messaging.d.ts +59 -0
- package/dist/interfaces/Messaging.d.ts.map +1 -0
- package/dist/interfaces/Messaging.js +3 -0
- package/dist/interfaces/Messaging.js.map +1 -0
- package/dist/interfaces/Permissions.d.ts +159 -0
- package/dist/interfaces/Permissions.d.ts.map +1 -0
- package/dist/interfaces/Permissions.js +67 -0
- package/dist/interfaces/Permissions.js.map +1 -0
- package/dist/interfaces/Reporting.d.ts +45 -0
- package/dist/interfaces/Reporting.d.ts.map +1 -0
- package/dist/interfaces/Reporting.js +3 -0
- package/dist/interfaces/Reporting.js.map +1 -0
- package/dist/interfaces/UserContextInterface.d.ts +13 -0
- package/dist/interfaces/UserContextInterface.d.ts.map +1 -0
- package/dist/interfaces/UserContextInterface.js +3 -0
- package/dist/interfaces/UserContextInterface.js.map +1 -0
- package/dist/interfaces/index.d.ts +11 -0
- package/dist/interfaces/index.d.ts.map +1 -0
- package/dist/interfaces/index.js +28 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/pageComponents/LoginPage.d.ts +22 -0
- package/dist/pageComponents/LoginPage.d.ts.map +1 -0
- package/dist/pageComponents/LoginPage.js +287 -0
- package/dist/pageComponents/LoginPage.js.map +1 -0
- package/dist/pageComponents/LogoutPage.d.ts +8 -0
- package/dist/pageComponents/LogoutPage.d.ts.map +1 -0
- package/dist/pageComponents/LogoutPage.js +26 -0
- package/dist/pageComponents/LogoutPage.js.map +1 -0
- package/dist/pageComponents/components/Forgot.d.ts +8 -0
- package/dist/pageComponents/components/Forgot.d.ts.map +1 -0
- package/dist/pageComponents/components/Forgot.js +70 -0
- package/dist/pageComponents/components/Forgot.js.map +1 -0
- package/dist/pageComponents/components/Login.d.ts +13 -0
- package/dist/pageComponents/components/Login.d.ts.map +1 -0
- package/dist/pageComponents/components/Login.js +57 -0
- package/dist/pageComponents/components/Login.js.map +1 -0
- package/dist/pageComponents/components/LoginSetPassword.d.ts +13 -0
- package/dist/pageComponents/components/LoginSetPassword.d.ts.map +1 -0
- package/dist/pageComponents/components/LoginSetPassword.js +68 -0
- package/dist/pageComponents/components/LoginSetPassword.js.map +1 -0
- package/dist/pageComponents/components/Register.d.ts +12 -0
- package/dist/pageComponents/components/Register.d.ts.map +1 -0
- package/dist/pageComponents/components/Register.js +105 -0
- package/dist/pageComponents/components/Register.js.map +1 -0
- package/dist/pageComponents/components/SelectChurchModal.d.ts +13 -0
- package/dist/pageComponents/components/SelectChurchModal.d.ts.map +1 -0
- package/dist/pageComponents/components/SelectChurchModal.js +33 -0
- package/dist/pageComponents/components/SelectChurchModal.js.map +1 -0
- package/dist/pageComponents/components/SelectChurchRegister.d.ts +11 -0
- package/dist/pageComponents/components/SelectChurchRegister.d.ts.map +1 -0
- package/dist/pageComponents/components/SelectChurchRegister.js +114 -0
- package/dist/pageComponents/components/SelectChurchRegister.js.map +1 -0
- package/dist/pageComponents/components/SelectChurchSearch.d.ts +10 -0
- package/dist/pageComponents/components/SelectChurchSearch.d.ts.map +1 -0
- package/dist/pageComponents/components/SelectChurchSearch.js +61 -0
- package/dist/pageComponents/components/SelectChurchSearch.js.map +1 -0
- package/dist/pageComponents/components/SelectableChurch.d.ts +9 -0
- package/dist/pageComponents/components/SelectableChurch.d.ts.map +1 -0
- package/dist/pageComponents/components/SelectableChurch.js +31 -0
- package/dist/pageComponents/components/SelectableChurch.js.map +1 -0
- package/dist/pageComponents/index.d.ts +4 -0
- package/dist/pageComponents/index.d.ts.map +1 -0
- package/dist/pageComponents/index.js +10 -0
- package/dist/pageComponents/index.js.map +1 -0
- package/package.json +77 -0
- package/src/components/CreatePerson.tsx +80 -0
- package/src/components/DisplayBox.tsx +68 -0
- package/src/components/ErrorMessages.tsx +26 -0
- package/src/components/ExportLink.tsx +61 -0
- package/src/components/FloatingSupport.tsx +16 -0
- package/src/components/FormSubmissionEdit.tsx +122 -0
- package/src/components/HelpIcon.tsx +10 -0
- package/src/components/ImageEditor.tsx +126 -0
- package/src/components/InputBox.tsx +73 -0
- package/src/components/Loading.tsx +29 -0
- package/src/components/PersonAdd.tsx +75 -0
- package/src/components/QuestionEdit.tsx +62 -0
- package/src/components/SmallButton.tsx +39 -0
- package/src/components/SupportModal.tsx +26 -0
- package/src/components/TabPanel.tsx +34 -0
- package/src/components/gallery/GalleryModal.tsx +102 -0
- package/src/components/gallery/StockPhotos.tsx +74 -0
- package/src/components/index.tsx +18 -0
- package/src/components/markdownEditor/Editor.tsx +132 -0
- package/src/components/markdownEditor/MarkdownEditor.tsx +16 -0
- package/src/components/markdownEditor/MarkdownModal.tsx +46 -0
- package/src/components/markdownEditor/MarkdownPreview.tsx +14 -0
- package/src/components/markdownEditor/editor.css +787 -0
- package/src/components/markdownEditor/images/emoji/1F600.png +0 -0
- package/src/components/markdownEditor/images/emoji/1F641.png +0 -0
- package/src/components/markdownEditor/images/emoji/1F642.png +0 -0
- package/src/components/markdownEditor/images/emoji/2764.png +0 -0
- package/src/components/markdownEditor/images/icons/arrow-clockwise.svg +4 -0
- package/src/components/markdownEditor/images/icons/arrow-counterclockwise.svg +4 -0
- package/src/components/markdownEditor/images/icons/chat-square-quote.svg +4 -0
- package/src/components/markdownEditor/images/icons/chevron-down.svg +3 -0
- package/src/components/markdownEditor/images/icons/code.svg +3 -0
- package/src/components/markdownEditor/images/icons/journal-code.svg +5 -0
- package/src/components/markdownEditor/images/icons/journal-text.svg +5 -0
- package/src/components/markdownEditor/images/icons/justify.svg +3 -0
- package/src/components/markdownEditor/images/icons/link.svg +4 -0
- package/src/components/markdownEditor/images/icons/list-ol.svg +4 -0
- package/src/components/markdownEditor/images/icons/list-ul.svg +3 -0
- package/src/components/markdownEditor/images/icons/pencil-fill.svg +3 -0
- package/src/components/markdownEditor/images/icons/text-center.svg +3 -0
- package/src/components/markdownEditor/images/icons/text-left.svg +3 -0
- package/src/components/markdownEditor/images/icons/text-paragraph.svg +3 -0
- package/src/components/markdownEditor/images/icons/text-right.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-bold.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-h1.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-h2.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-h3.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-h4.svg +13 -0
- package/src/components/markdownEditor/images/icons/type-italic.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-strikethrough.svg +3 -0
- package/src/components/markdownEditor/images/icons/type-underline.svg +3 -0
- package/src/components/markdownEditor/plugins/AutoLinkPlugin.tsx +35 -0
- package/src/components/markdownEditor/plugins/ControlledEditorPlugin.tsx +24 -0
- package/src/components/markdownEditor/plugins/ListMaxIndentLevelPlugin.tsx +68 -0
- package/src/components/markdownEditor/plugins/MarkdownTransformers.ts +106 -0
- package/src/components/markdownEditor/plugins/ReadOnlyPlugin.tsx +15 -0
- package/src/components/markdownEditor/plugins/ToolbarPlugin.tsx +401 -0
- package/src/components/markdownEditor/plugins/customLink/CustomLinkNode.tsx +224 -0
- package/src/components/markdownEditor/plugins/customLink/CustomLinkNodePlugin.tsx +32 -0
- package/src/components/markdownEditor/plugins/customLink/CustomLinkNodeTransformer.tsx +102 -0
- package/src/components/markdownEditor/plugins/customLink/FloatingLinkEditor.tsx +243 -0
- package/src/components/markdownEditor/plugins/customLink/FloatingLinkEditor.types.ts +11 -0
- package/src/components/markdownEditor/plugins/emoji/EmojiNode.tsx +95 -0
- package/src/components/markdownEditor/plugins/emoji/EmojiNodeTransform.ts +41 -0
- package/src/components/markdownEditor/plugins/emoji/EmojiPickerPlugin.tsx +152 -0
- package/src/components/markdownEditor/plugins/emoji/EmojisPlugin.tsx +65 -0
- package/src/components/markdownEditor/plugins/index.ts +6 -0
- package/src/components/markdownEditor/theme.ts +65 -0
- package/src/components/material/AppList.tsx +20 -0
- package/src/components/material/ChurchList.tsx +22 -0
- package/src/components/material/NavItem.tsx +41 -0
- package/src/components/material/NewPrivateMessage.tsx +103 -0
- package/src/components/material/PrivateMessageDetails.tsx +23 -0
- package/src/components/material/PrivateMessages.tsx +87 -0
- package/src/components/material/SiteWrapper.tsx +140 -0
- package/src/components/material/UserMenu.tsx +141 -0
- package/src/components/material/iconPicker/IconNamesList.ts +2240 -0
- package/src/components/material/iconPicker/IconPicker.tsx +153 -0
- package/src/components/material/index.tsx +5 -0
- package/src/components/notes/AddNote.tsx +90 -0
- package/src/components/notes/Conversation.tsx +82 -0
- package/src/components/notes/Conversations.tsx +58 -0
- package/src/components/notes/NewConversation.tsx +78 -0
- package/src/components/notes/Note.tsx +44 -0
- package/src/components/notes/Notes.tsx +52 -0
- package/src/components/reporting/ChartReport.tsx +98 -0
- package/src/components/reporting/ReportFilter.tsx +54 -0
- package/src/components/reporting/ReportFilterField.tsx +160 -0
- package/src/components/reporting/ReportOutput.tsx +79 -0
- package/src/components/reporting/ReportWithFilter.tsx +70 -0
- package/src/components/reporting/TableReport.tsx +57 -0
- package/src/components/reporting/TreeReport.tsx +111 -0
- package/src/components/reporting/index.ts +4 -0
- package/src/donationComponents/DonationPage.tsx +136 -0
- package/src/donationComponents/components/BankForm.tsx +159 -0
- package/src/donationComponents/components/CardForm.tsx +104 -0
- package/src/donationComponents/components/DonationForm.tsx +228 -0
- package/src/donationComponents/components/FundDonation.tsx +49 -0
- package/src/donationComponents/components/FundDonations.tsx +39 -0
- package/src/donationComponents/components/NonAuthDonation.tsx +31 -0
- package/src/donationComponents/components/NonAuthDonationInner.tsx +208 -0
- package/src/donationComponents/components/PaymentMethods.tsx +135 -0
- package/src/donationComponents/components/RecurringDonations.tsx +121 -0
- package/src/donationComponents/components/RecurringDonationsEdit.tsx +93 -0
- package/src/donationComponents/components/index.tsx +9 -0
- package/src/donationComponents/modals/DonationPreviewModal.tsx +66 -0
- package/src/helpers/AnalyticsHelper.ts +33 -0
- package/src/helpers/ApiHelper.ts +125 -0
- package/src/helpers/AppearanceHelper.ts +69 -0
- package/src/helpers/ArrayHelper.ts +81 -0
- package/src/helpers/CommonEnvironmentHelper.ts +80 -0
- package/src/helpers/CurrencyHelper.ts +10 -0
- package/src/helpers/DateHelper.ts +108 -0
- package/src/helpers/DonationHelper.ts +26 -0
- package/src/helpers/ErrorHelper.ts +36 -0
- package/src/helpers/EventHelper.ts +52 -0
- package/src/helpers/FileHelper.ts +31 -0
- package/src/helpers/PersonHelper.ts +60 -0
- package/src/helpers/SocketHelper.ts +76 -0
- package/src/helpers/Themes.ts +14 -0
- package/src/helpers/UniqueIdHelper.ts +36 -0
- package/src/helpers/UserHelper.ts +59 -0
- package/src/helpers/createEmotionCache.ts +17 -0
- package/src/helpers/index.ts +15 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useMountedState.ts +16 -0
- package/src/index.ts +6 -0
- package/src/interfaces/Access.ts +24 -0
- package/src/interfaces/Attendance.ts +8 -0
- package/src/interfaces/Content.ts +10 -0
- package/src/interfaces/Doing.ts +24 -0
- package/src/interfaces/Donation.ts +45 -0
- package/src/interfaces/Error.ts +17 -0
- package/src/interfaces/Membership.ts +51 -0
- package/src/interfaces/Messaging.ts +20 -0
- package/src/interfaces/Permissions.ts +68 -0
- package/src/interfaces/Reporting.ts +7 -0
- package/src/interfaces/UserContextInterface.ts +13 -0
- package/src/interfaces/index.ts +12 -0
- package/src/pageComponents/LoginPage.tsx +244 -0
- package/src/pageComponents/LogoutPage.tsx +28 -0
- package/src/pageComponents/components/Forgot.tsx +79 -0
- package/src/pageComponents/components/Login.tsx +54 -0
- package/src/pageComponents/components/LoginSetPassword.tsx +63 -0
- package/src/pageComponents/components/Register.tsx +107 -0
- package/src/pageComponents/components/SelectChurchModal.tsx +41 -0
- package/src/pageComponents/components/SelectChurchRegister.tsx +88 -0
- package/src/pageComponents/components/SelectChurchSearch.tsx +69 -0
- package/src/pageComponents/components/SelectableChurch.tsx +38 -0
- package/src/pageComponents/index.ts +3 -0
- package/tsconfig.json +35 -0
- package/tslint.json +15 -0
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import type {LexicalEditor} from 'lexical';
|
|
10
|
+
import 'material-symbols';
|
|
11
|
+
import {useLexicalComposerContext} from '@lexical/react/LexicalComposerContext';
|
|
12
|
+
import {$createTextNode, TextNode} from 'lexical';
|
|
13
|
+
import {useEffect} from 'react';
|
|
14
|
+
import materialIcons from '../../../material/iconPicker/IconNamesList';
|
|
15
|
+
|
|
16
|
+
import {$createEmojiNode, EmojiNode} from './EmojiNode';
|
|
17
|
+
import { EMOJI_NODE_MARKDOWN_REGEX } from './EmojiNodeTransform';
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
function useEmojis(editor: LexicalEditor): void {
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
if (!editor.hasNodes([EmojiNode, TextNode])) {
|
|
23
|
+
throw new Error('EmojisPlugin: EmojiNode not registered on editor');
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
return editor.registerNodeTransform(TextNode, (textNode) => {
|
|
27
|
+
if (EMOJI_NODE_MARKDOWN_REGEX.test(textNode.getTextContent()) || materialIcons.map((materialIcon : string) => ':' + materialIcon + ':').some((materialIcon : string) => textNode.getTextContent().includes(materialIcon))) {
|
|
28
|
+
|
|
29
|
+
const materialIconToInsert = materialIcons.find((materialIcon : string) => textNode.getTextContent().replaceAll(':', '').includes(materialIcon));
|
|
30
|
+
|
|
31
|
+
if (!materialIconToInsert) return;
|
|
32
|
+
|
|
33
|
+
const initialTextInput = textNode.getTextContent();
|
|
34
|
+
const emojiNode = $createEmojiNode(materialIconToInsert);
|
|
35
|
+
|
|
36
|
+
const leftoverTextNodes : Array<TextNode> = [];
|
|
37
|
+
|
|
38
|
+
initialTextInput?.split(':').forEach((leftoverTextString : string, index : number) => {
|
|
39
|
+
if (materialIcons.includes(leftoverTextString)) {
|
|
40
|
+
const emojiNode = $createEmojiNode(leftoverTextString);
|
|
41
|
+
|
|
42
|
+
leftoverTextNodes.push(emojiNode);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
leftoverTextNodes.push($createTextNode(leftoverTextString));
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
textNode.setTextContent('');
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
textNode.getParent().splice(textNode.getIndexWithinParent(), 1, leftoverTextNodes);
|
|
52
|
+
|
|
53
|
+
(leftoverTextNodes.find((node : TextNode) => materialIcons.includes(node.__text)) || leftoverTextNodes[leftoverTextNodes.length - 1]).select();
|
|
54
|
+
|
|
55
|
+
textNode.remove();
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}, [editor]);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export default function EmojisPlugin(): JSX.Element | null {
|
|
62
|
+
const [editor] = useLexicalComposerContext();
|
|
63
|
+
useEmojis(editor);
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { ToolbarPlugin } from "./ToolbarPlugin";
|
|
2
|
+
export { CustomAutoLinkPlugin } from "./AutoLinkPlugin";
|
|
3
|
+
export { ListMaxIndentLevelPlugin } from "./ListMaxIndentLevelPlugin";
|
|
4
|
+
export { PLAYGROUND_TRANSFORMERS } from "./MarkdownTransformers";
|
|
5
|
+
export { ReadOnlyPlugin } from "./ReadOnlyPlugin";
|
|
6
|
+
export { ControlledEditorPlugin } from "./ControlledEditorPlugin";
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export const theme = {
|
|
2
|
+
placeholder: "editor-placeholder",
|
|
3
|
+
paragraph: "editor-paragraph",
|
|
4
|
+
quote: "editor-quote",
|
|
5
|
+
heading: {
|
|
6
|
+
h1: "editor-heading-h1",
|
|
7
|
+
h2: "editor-heading-h2",
|
|
8
|
+
h3: "editor-heading-h3",
|
|
9
|
+
h4: "editor-heading-h4",
|
|
10
|
+
h5: "editor-heading-h5"
|
|
11
|
+
},
|
|
12
|
+
list: {
|
|
13
|
+
nested: {
|
|
14
|
+
listitem: "editor-nested-listitem"
|
|
15
|
+
},
|
|
16
|
+
ol: "editor-list-ol",
|
|
17
|
+
ul: "editor-list-ul",
|
|
18
|
+
listitem: "editor-listitem"
|
|
19
|
+
},
|
|
20
|
+
image: "editor-image",
|
|
21
|
+
link: "editor-link",
|
|
22
|
+
text: {
|
|
23
|
+
bold: "editor-text-bold",
|
|
24
|
+
italic: "editor-text-italic",
|
|
25
|
+
overflowed: "editor-text-overflowed",
|
|
26
|
+
hashtag: "editor-text-hashtag",
|
|
27
|
+
underline: "editor-text-underline",
|
|
28
|
+
strikethrough: "editor-text-strikethrough",
|
|
29
|
+
underlineStrikethrough: "editor-text-underlineStrikethrough",
|
|
30
|
+
code: "editor-text-code"
|
|
31
|
+
},
|
|
32
|
+
code: "editor-code",
|
|
33
|
+
codeHighlight: {
|
|
34
|
+
atrule: "editor-tokenAttr",
|
|
35
|
+
attr: "editor-tokenAttr",
|
|
36
|
+
boolean: "editor-tokenProperty",
|
|
37
|
+
builtin: "editor-tokenSelector",
|
|
38
|
+
cdata: "editor-tokenComment",
|
|
39
|
+
char: "editor-tokenSelector",
|
|
40
|
+
class: "editor-tokenFunction",
|
|
41
|
+
"class-name": "editor-tokenFunction",
|
|
42
|
+
comment: "editor-tokenComment",
|
|
43
|
+
constant: "editor-tokenProperty",
|
|
44
|
+
deleted: "editor-tokenProperty",
|
|
45
|
+
doctype: "editor-tokenComment",
|
|
46
|
+
entity: "editor-tokenOperator",
|
|
47
|
+
function: "editor-tokenFunction",
|
|
48
|
+
important: "editor-tokenVariable",
|
|
49
|
+
inserted: "editor-tokenSelector",
|
|
50
|
+
keyword: "editor-tokenAttr",
|
|
51
|
+
namespace: "editor-tokenVariable",
|
|
52
|
+
number: "editor-tokenProperty",
|
|
53
|
+
operator: "editor-tokenOperator",
|
|
54
|
+
prolog: "editor-tokenComment",
|
|
55
|
+
property: "editor-tokenProperty",
|
|
56
|
+
punctuation: "editor-tokenPunctuation",
|
|
57
|
+
regex: "editor-tokenVariable",
|
|
58
|
+
selector: "editor-tokenSelector",
|
|
59
|
+
string: "editor-tokenSelector",
|
|
60
|
+
symbol: "editor-tokenProperty",
|
|
61
|
+
tag: "editor-tokenProperty",
|
|
62
|
+
url: "editor-tokenOperator",
|
|
63
|
+
variable: "editor-tokenVariable"
|
|
64
|
+
}
|
|
65
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ApiHelper } from "../../helpers/ApiHelper";
|
|
3
|
+
import { UserHelper } from "../../helpers/UserHelper";
|
|
4
|
+
import { NavItem } from "./NavItem";
|
|
5
|
+
import { CommonEnvironmentHelper } from "../../helpers/CommonEnvironmentHelper";
|
|
6
|
+
import { LoginUserChurchInterface } from "../../interfaces";
|
|
7
|
+
|
|
8
|
+
export interface Props { appName: string; currentUserChurch: LoginUserChurchInterface; router?: any; }
|
|
9
|
+
|
|
10
|
+
export const AppList: React.FC<Props> = props => {
|
|
11
|
+
const jwt = ApiHelper.getConfig("MembershipApi").jwt;
|
|
12
|
+
const churchId = UserHelper.currentUserChurch.church.id;
|
|
13
|
+
return (
|
|
14
|
+
<>
|
|
15
|
+
<NavItem url={`${CommonEnvironmentHelper.ChumsRoot}/login?jwt=${jwt}&churchId=${churchId}`} selected={props.appName === "CHUMS"} external={true} label="Chums" icon="logout" router={props.router} />
|
|
16
|
+
<NavItem url={`${CommonEnvironmentHelper.B1Root.replace("{key}", props.currentUserChurch.church.subDomain)}/login?jwt=${jwt}&churchId=${churchId}`} selected={props.appName === "B1.church"} external={true} label="B1.Church" icon="logout" router={props.router} />
|
|
17
|
+
<NavItem url={`${CommonEnvironmentHelper.LessonsRoot}/login?jwt=${jwt}&churchId=${churchId}`} selected={props.appName === "Lessons.church"} external={true} label="Lessons.church" icon="logout" router={props.router} />
|
|
18
|
+
</>
|
|
19
|
+
);
|
|
20
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { LoginUserChurchInterface, UserContextInterface } from "../../interfaces";
|
|
3
|
+
import { UserHelper } from "../../helpers/UserHelper";
|
|
4
|
+
import { NavItem } from "./NavItem";
|
|
5
|
+
|
|
6
|
+
export interface Props { userChurches: LoginUserChurchInterface[], currentUserChurch: LoginUserChurchInterface, context: UserContextInterface }
|
|
7
|
+
|
|
8
|
+
export const ChurchList: React.FC<Props> = props => {
|
|
9
|
+
|
|
10
|
+
if (props.userChurches.length < 2) return <></>;
|
|
11
|
+
else {
|
|
12
|
+
let result: JSX.Element[] = [];
|
|
13
|
+
const userChurches = props.userChurches.filter(uc => uc.apis.length > 0)
|
|
14
|
+
userChurches.forEach(uc => {
|
|
15
|
+
const userChurch = uc;
|
|
16
|
+
const churchName = uc.church.name;
|
|
17
|
+
result.push(<NavItem key={userChurch.church.id} selected={(uc.church.id === props.currentUserChurch.church.id) && true} onClick={() => UserHelper.selectChurch(props.context, userChurch.church.id, null)} label={churchName} icon="church" />);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
return <>{result}</>;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Icon, ListItemButton, ListItemIcon, ListItemText, styled, Tooltip } from "@mui/material";
|
|
3
|
+
import { NavLink, useLocation } from "react-router-dom";
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
url?: string;
|
|
7
|
+
target?: string;
|
|
8
|
+
label: string;
|
|
9
|
+
icon: string;
|
|
10
|
+
onClick?: () => void;
|
|
11
|
+
router?: any;
|
|
12
|
+
external?: boolean;
|
|
13
|
+
selected?: boolean;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const StyledNavLink = styled(NavLink)({
|
|
17
|
+
textDecoration: "none",
|
|
18
|
+
"&:hover": { textDecoration: "none" },
|
|
19
|
+
"& .MuiListItemIcon-root": { minWidth: 40 }
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
export const NavItem: React.FC<Props> = (props) => {
|
|
23
|
+
let isReact = false;
|
|
24
|
+
try {
|
|
25
|
+
const a = typeof useLocation();
|
|
26
|
+
if (a !== null) isReact = true;
|
|
27
|
+
} catch { }
|
|
28
|
+
|
|
29
|
+
const getIcon = () => <Icon>{props.icon}</Icon>
|
|
30
|
+
|
|
31
|
+
const getLinkContents = () => (<ListItemButton>
|
|
32
|
+
<Tooltip title={props.label || ""} arrow placement="right">
|
|
33
|
+
<ListItemIcon sx={{ minWidth: "40px" }}>{getIcon()}</ListItemIcon>
|
|
34
|
+
</Tooltip>
|
|
35
|
+
<ListItemText primary={props.label} />
|
|
36
|
+
</ListItemButton>)
|
|
37
|
+
|
|
38
|
+
if (props.router) return (<a href={props.url} target={props.target} onClick={(e) => { e.preventDefault(); props.onClick ? props.onClick() : props.router.push(props.url) }} className={(props.selected) ? "selected" : ""}>{getLinkContents()}</a>)
|
|
39
|
+
else if (props.external || !isReact) return (<a href={props.url} target={props.target} rel="noreferrer" style={{ textDecoration: "none" }} className={(props.selected) ? "selected" : ""} onClick={(e) => { e.preventDefault(); props.onClick ? props.onClick() : window.location.href = props.url }}>{getLinkContents()}</a>)
|
|
40
|
+
else return (<StyledNavLink to={props.url || "about:blank"} target={props.target} className={(props.selected) ? "selected" : ""} onClick={props.onClick ? (e) => { e.preventDefault(); props.onClick() } : null}>{getLinkContents()}</StyledNavLink>)
|
|
41
|
+
};
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { Button, TextField, TableRow, TableCell, Table, TableBody } from "@mui/material";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { ApiHelper, PersonHelper } from "../../helpers";
|
|
4
|
+
import { ConversationInterface, PersonInterface, PrivateMessageInterface, UserContextInterface } from "../../interfaces";
|
|
5
|
+
import { AddNote } from "../notes/AddNote";
|
|
6
|
+
import { SmallButton } from "../SmallButton";
|
|
7
|
+
|
|
8
|
+
interface Props {
|
|
9
|
+
context: UserContextInterface;
|
|
10
|
+
onSelectMessage: (pm: PrivateMessageInterface) => void
|
|
11
|
+
onBack: () => void
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const NewPrivateMessage: React.FC<Props> = (props) => {
|
|
15
|
+
|
|
16
|
+
const [searchText, setSearchText] = React.useState("");
|
|
17
|
+
const [searchResults, setSearchResults] = React.useState([]);
|
|
18
|
+
const [selectedPerson, setSelectedPerson] = React.useState<PersonInterface>(null);
|
|
19
|
+
|
|
20
|
+
const handleSubmit = (e: React.MouseEvent) => {
|
|
21
|
+
if (e !== null) e.preventDefault();
|
|
22
|
+
let term = escape(searchText.trim());
|
|
23
|
+
ApiHelper.get("/people/search?term=" + term, "MembershipApi").then(data => setSearchResults(data));
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
27
|
+
setSearchText(e.currentTarget.value);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/*
|
|
31
|
+
const handleKeyDown = (e: React.KeyboardEvent<any>) => {
|
|
32
|
+
//if (e.key === "Enter") { e.preventDefault(); handleSubmit(null); }
|
|
33
|
+
}
|
|
34
|
+
*/
|
|
35
|
+
|
|
36
|
+
const handlePersonSelected = async (person: PersonInterface) => {
|
|
37
|
+
const existing: PrivateMessageInterface = await ApiHelper.get("/privateMessages/existing/" + person.id, "MessagingApi");
|
|
38
|
+
if (existing.id) {
|
|
39
|
+
existing.person = person;
|
|
40
|
+
props.onSelectMessage(existing);
|
|
41
|
+
}
|
|
42
|
+
else setSelectedPerson(person);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
const getPeople = () => {
|
|
46
|
+
let result = [];
|
|
47
|
+
for (let i = 0; i < searchResults.length; i++) {
|
|
48
|
+
const p = searchResults[i];
|
|
49
|
+
result.push(<TableRow key={p.id}>
|
|
50
|
+
<TableCell><img src={PersonHelper.getPhotoUrl(p)} alt="avatar" /></TableCell>
|
|
51
|
+
<TableCell><a href="about:blank" onClick={(e) => { e.preventDefault(); handlePersonSelected(p) }}>{p.name.display}</a></TableCell>
|
|
52
|
+
</TableRow>);
|
|
53
|
+
}
|
|
54
|
+
return result;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const handleNoteAdded = () => {
|
|
58
|
+
handlePersonSelected(selectedPerson);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
const createConversation = async () => {
|
|
62
|
+
const conv: ConversationInterface = { allowAnonymousPosts: false, contentType: "privateMessage", contentId: props.context.person.id, title: props.context.person.name.display + " Private Message", visibility: "hidden" }
|
|
63
|
+
const result: ConversationInterface[] = await ApiHelper.post("/conversations", [conv], "MessagingApi");
|
|
64
|
+
|
|
65
|
+
const pm: PrivateMessageInterface = {
|
|
66
|
+
fromPersonId: props.context.person.id,
|
|
67
|
+
toPersonId: selectedPerson.id,
|
|
68
|
+
conversationId: result[0].id
|
|
69
|
+
}
|
|
70
|
+
const privateMessages: PrivateMessageInterface[] = await ApiHelper.post("/privateMessages", [pm], "MessagingApi");
|
|
71
|
+
return privateMessages[0].conversationId;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
if (!selectedPerson) return (
|
|
75
|
+
<div style={{ paddingLeft: 10, paddingRight: 10 }}>
|
|
76
|
+
<span style={{ float: "right" }}>
|
|
77
|
+
<SmallButton icon="chevron_left" text="Back" onClick={props.onBack} />
|
|
78
|
+
</span>
|
|
79
|
+
<b>New Private Message</b>
|
|
80
|
+
<div>Search for a person</div>
|
|
81
|
+
|
|
82
|
+
<TextField fullWidth label="Name" id="searchText" data-cy="search-input" name="searchText" type="text" placeholder="Name" value={searchText} onChange={handleChange}
|
|
83
|
+
InputProps={{ endAdornment: <Button variant="contained" id="searchButton" data-cy="search-button" onClick={handleSubmit}>Search</Button> }}
|
|
84
|
+
/>
|
|
85
|
+
<br />
|
|
86
|
+
<Table id="smallPeopleTable" size="small">
|
|
87
|
+
<TableBody>{getPeople()}</TableBody>
|
|
88
|
+
</Table>
|
|
89
|
+
</div>
|
|
90
|
+
);
|
|
91
|
+
else {
|
|
92
|
+
return (
|
|
93
|
+
<div style={{ paddingLeft: 10, paddingRight: 10 }}>
|
|
94
|
+
<span style={{ float: "right" }}>
|
|
95
|
+
<SmallButton icon="chevron_left" text="Back" onClick={props.onBack} />
|
|
96
|
+
</span>
|
|
97
|
+
<b>New Private Message</b>
|
|
98
|
+
<div>To: {selectedPerson.name.display}</div>
|
|
99
|
+
<AddNote context={props.context} conversationId={null} onUpdate={handleNoteAdded} createConversation={createConversation} />
|
|
100
|
+
</div>
|
|
101
|
+
)
|
|
102
|
+
}
|
|
103
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { SmallButton } from "../SmallButton";
|
|
3
|
+
import { PrivateMessageInterface, UserContextInterface } from "../../interfaces";
|
|
4
|
+
import { Notes } from "../notes/Notes";
|
|
5
|
+
|
|
6
|
+
interface Props {
|
|
7
|
+
context: UserContextInterface;
|
|
8
|
+
privateMessage: PrivateMessageInterface;
|
|
9
|
+
onBack: () => void
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export const PrivateMessageDetails: React.FC<Props> = (props) => (
|
|
13
|
+
<>
|
|
14
|
+
<div style={{ paddingLeft: 10, paddingRight: 10, paddingBottom: 10 }}>
|
|
15
|
+
<span style={{ float: "right" }}>
|
|
16
|
+
<SmallButton icon="chevron_left" text="Back" onClick={props.onBack} />
|
|
17
|
+
</span>
|
|
18
|
+
Chat with {props.privateMessage.person.name.display}
|
|
19
|
+
</div>
|
|
20
|
+
<Notes context={props.context} conversationId={props.privateMessage.conversationId} noDisplayBox={true} />
|
|
21
|
+
</>
|
|
22
|
+
);
|
|
23
|
+
|
|
@@ -0,0 +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
|
+
};
|
|
@@ -0,0 +1,140 @@
|
|
|
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
|
+
React.useEffect(() => {
|
|
91
|
+
const getChurchLogo = async () => {
|
|
92
|
+
if (UserHelper.currentUserChurch) {
|
|
93
|
+
setChurchLogo(AppearanceHelper.getLogoDark(props.appearance, "/images/logo-wrapper.png"));
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
if (!isMounted()) {
|
|
98
|
+
getChurchLogo();
|
|
99
|
+
}
|
|
100
|
+
}, [isMounted, props.appearance]);
|
|
101
|
+
|
|
102
|
+
React.useEffect(() => {
|
|
103
|
+
if (!props.context.userChurch) SocketHelper.setUserChurch({userId:null, churchId:null});
|
|
104
|
+
else SocketHelper.setUserChurch({userId:props.context.user.id, churchId:props.context.userChurch?.church.id});
|
|
105
|
+
}, [props.context.userChurch]);
|
|
106
|
+
|
|
107
|
+
React.useEffect(() => {
|
|
108
|
+
SocketHelper.addHandler("notification", "notificationBell", handleNotification);
|
|
109
|
+
SocketHelper.init();
|
|
110
|
+
}, []);
|
|
111
|
+
|
|
112
|
+
return <>
|
|
113
|
+
<CustomAppBar position="absolute">
|
|
114
|
+
<Toolbar sx={{ pr: "24px" }}>
|
|
115
|
+
<IconButton edge="start" color="inherit" aria-label="open drawer" onClick={toggleDrawer} sx={{ marginRight: "36px", ...(open && { display: "none" }) }}>
|
|
116
|
+
<Icon>menu</Icon>
|
|
117
|
+
</IconButton>
|
|
118
|
+
<Typography variant="h6" noWrap>{UserHelper.currentUserChurch?.church?.name || ""}</Typography>
|
|
119
|
+
<div style={{ flex: 1 }}></div>
|
|
120
|
+
{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} />}
|
|
121
|
+
{!UserHelper.user && <Link href="/login" color="inherit" style={{ textDecoration: "none" }}>Login</Link>}
|
|
122
|
+
</Toolbar>
|
|
123
|
+
</CustomAppBar>
|
|
124
|
+
|
|
125
|
+
<CustomDrawer variant="permanent" open={open}>
|
|
126
|
+
<Toolbar sx={{ display: "flex", alignItems: "center", width: "100%", px: [1] }}>
|
|
127
|
+
<img src={churchLogo || "/images/logo-wrapper.png"} alt="logo" style={{ maxWidth: 170 }} />
|
|
128
|
+
<div style={{ justifyContent: "flex-end", flex: 1, display: "flex" }}>
|
|
129
|
+
<IconButton onClick={toggleDrawer}><Icon style={{ color: "#FFFFFF" }}>chevron_left</Icon></IconButton>
|
|
130
|
+
</div>
|
|
131
|
+
</Toolbar>
|
|
132
|
+
{props.navContent}
|
|
133
|
+
</CustomDrawer>
|
|
134
|
+
<Box component="main" sx={{ flexGrow: 1, overflow: "auto", marginTop: 8, minHeight: "90vh" }}>
|
|
135
|
+
<Container maxWidth={false} sx={{ mt: 4, mb: 4 }}>
|
|
136
|
+
{props.children}
|
|
137
|
+
</Container>
|
|
138
|
+
</Box>
|
|
139
|
+
</>
|
|
140
|
+
};
|