@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,75 @@
|
|
|
1
|
+
import React, { useState } from "react";
|
|
2
|
+
import { ApiHelper } from "../helpers";
|
|
3
|
+
import { PersonInterface } from "../interfaces"
|
|
4
|
+
import { TextField, Button, Table, TableBody, TableRow, TableCell } from "@mui/material";
|
|
5
|
+
import { SmallButton } from "./SmallButton";
|
|
6
|
+
import { CreatePerson } from "./CreatePerson";
|
|
7
|
+
|
|
8
|
+
interface Props {
|
|
9
|
+
addFunction: (person: PersonInterface) => void;
|
|
10
|
+
person?: PersonInterface;
|
|
11
|
+
getPhotoUrl: (person: PersonInterface) => string;
|
|
12
|
+
searchClicked?: () => void;
|
|
13
|
+
filterList?: string[];
|
|
14
|
+
includeEmail?: boolean;
|
|
15
|
+
actionLabel?: string;
|
|
16
|
+
showCreatePersonOnNotFound?: boolean;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export const PersonAdd: React.FC<Props> = ({ addFunction, getPhotoUrl, searchClicked, filterList = [], includeEmail = false, actionLabel, showCreatePersonOnNotFound = false }) => {
|
|
20
|
+
const [searchResults, setSearchResults] = useState<PersonInterface[]>([]);
|
|
21
|
+
const [searchText, setSearchText] = useState("");
|
|
22
|
+
const [hasSearched, setHasSearched] = useState<boolean>(false);
|
|
23
|
+
|
|
24
|
+
const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => { e.preventDefault(); setHasSearched(false); setSearchText(e.currentTarget.value); }
|
|
25
|
+
const handleKeyDown = (e: React.KeyboardEvent<any>) => { if (e.key === "Enter") { e.preventDefault(); handleSearch(null); } }
|
|
26
|
+
|
|
27
|
+
const handleSearch = (e: React.MouseEvent) => {
|
|
28
|
+
if (e !== null) e.preventDefault();
|
|
29
|
+
let term = searchText.trim();
|
|
30
|
+
ApiHelper.post("/people/search", { term: term }, "MembershipApi")
|
|
31
|
+
.then((data: PersonInterface[]) => {
|
|
32
|
+
setHasSearched(true);
|
|
33
|
+
const filteredResult = data.filter(s => !filterList.includes(s.id))
|
|
34
|
+
setSearchResults(filteredResult);
|
|
35
|
+
if (searchClicked) {
|
|
36
|
+
searchClicked();
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
const handleAdd = (person: PersonInterface) => {
|
|
41
|
+
let sr: PersonInterface[] = [...searchResults];
|
|
42
|
+
const idx = sr.indexOf(person);
|
|
43
|
+
sr.splice(idx, 1);
|
|
44
|
+
setSearchResults(sr);
|
|
45
|
+
addFunction(person);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
//<button className="text-success no-default-style" aria-label="addPerson" data-index={i} onClick={handleAdd}><Icon>person</Icon> Add</button>
|
|
49
|
+
let rows = [];
|
|
50
|
+
for (let i = 0; i < searchResults.length; i++) {
|
|
51
|
+
const sr = searchResults[i];
|
|
52
|
+
|
|
53
|
+
rows.push(
|
|
54
|
+
<TableRow key={sr.id}>
|
|
55
|
+
<TableCell><img src={getPhotoUrl(sr)} alt="avatar" /></TableCell>
|
|
56
|
+
<TableCell>{sr.name.display}{includeEmail && (<><br /><i style={{ color: "#999" }}>{sr.contactInfo.email}</i></>)}</TableCell>
|
|
57
|
+
<TableCell>
|
|
58
|
+
<SmallButton color="success" icon="person" text={actionLabel || "Add"} ariaLabel="addPerson" onClick={() => handleAdd(sr)} />
|
|
59
|
+
</TableCell>
|
|
60
|
+
</TableRow>
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return (
|
|
65
|
+
<>
|
|
66
|
+
<TextField fullWidth name="personAddText" label="Person" value={searchText} onChange={handleChange} onKeyDown={handleKeyDown}
|
|
67
|
+
InputProps={{ endAdornment: <Button variant="contained" id="searchButton" data-cy="search-button" onClick={handleSearch}>Search</Button> }}
|
|
68
|
+
/>
|
|
69
|
+
{showCreatePersonOnNotFound && hasSearched && searchText && searchResults.length === 0 && (
|
|
70
|
+
<CreatePerson navigateOnCreate={false} onCreate={person => { setSearchText(""); setSearchResults([person]) }} />
|
|
71
|
+
)}
|
|
72
|
+
<Table size="small" id="householdMemberAddTable"><TableBody>{rows}</TableBody></Table>
|
|
73
|
+
</>
|
|
74
|
+
);
|
|
75
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { AnswerInterface, QuestionInterface } from "../interfaces";
|
|
3
|
+
import { Select, MenuItem, SelectChangeEvent, FormControl, InputLabel, TextField } from "@mui/material";
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
answer: AnswerInterface
|
|
7
|
+
question: QuestionInterface,
|
|
8
|
+
noBackground?: boolean,
|
|
9
|
+
changeFunction: (questionId: string, value: string) => void
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export const QuestionEdit: React.FC<Props> = ({noBackground = false, ...props}) => {
|
|
13
|
+
const handleChange = (e: React.ChangeEvent<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement> | SelectChangeEvent<string>) => {
|
|
14
|
+
props.changeFunction(props.question.id, e.target.value);
|
|
15
|
+
}
|
|
16
|
+
let q = props.question;
|
|
17
|
+
|
|
18
|
+
if (q.fieldType === "Heading") return <h5>{q.title}</h5>;
|
|
19
|
+
else {
|
|
20
|
+
let input = null;
|
|
21
|
+
let choiceOptions = [];
|
|
22
|
+
if (q.choices !== undefined && q.choices !== null) {
|
|
23
|
+
for (let i = 0; i < q.choices.length; i++) choiceOptions.push(<MenuItem key={i} value={q.choices[i].value}>{q.choices[i].text}</MenuItem>);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
let answerValue = (props.answer === null) ? "" : props.answer.value
|
|
27
|
+
switch (q.fieldType) {
|
|
28
|
+
case "Textbox": input = <TextField fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}} label={q.title} placeholder={q.placeholder} value={answerValue} onChange={handleChange} />; break;
|
|
29
|
+
case "Multiple Choice": {
|
|
30
|
+
input = (
|
|
31
|
+
<FormControl fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}}>
|
|
32
|
+
<InputLabel>{q.title}</InputLabel>
|
|
33
|
+
<Select fullWidth label={q.title} value={answerValue} onChange={handleChange}>{choiceOptions}</Select>
|
|
34
|
+
</FormControl>);
|
|
35
|
+
break;
|
|
36
|
+
}
|
|
37
|
+
case "Yes/No": {
|
|
38
|
+
input = (
|
|
39
|
+
<FormControl fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}}>
|
|
40
|
+
<InputLabel>{q.title}</InputLabel>
|
|
41
|
+
<Select fullWidth label={q.title} value={answerValue} onChange={handleChange}>
|
|
42
|
+
<MenuItem value="False">No</MenuItem>
|
|
43
|
+
<MenuItem value="True">Yes</MenuItem>
|
|
44
|
+
</Select>
|
|
45
|
+
</FormControl>);
|
|
46
|
+
break;
|
|
47
|
+
}
|
|
48
|
+
case "Whole Number":
|
|
49
|
+
case "Decimal":
|
|
50
|
+
input = <TextField fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}} type="number" InputLabelProps={{shrink: true}} label={q.title} placeholder={q.placeholder} value={answerValue} onChange={handleChange} />;
|
|
51
|
+
break;
|
|
52
|
+
case "Date": input = <TextField fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}} type="date" InputLabelProps={{shrink: true}} label={q.title} placeholder={q.placeholder} value={answerValue} onChange={handleChange} />; break;
|
|
53
|
+
case "Phone Number": input = <TextField fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}} type="number" InputLabelProps={{shrink: true}} label={q.title} placeholder="555-555-5555" value={answerValue} onChange={handleChange} />; break;
|
|
54
|
+
case "Email": input = <TextField fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}} type="email" label={q.title} placeholder="john@doe.com" value={answerValue} onChange={handleChange} />; break;
|
|
55
|
+
case "Text Area": input = <TextField fullWidth style={noBackground ? {backgroundColor: "white", borderRadius: "4px"} : {}} multiline rows={4} label={q.title} placeholder={q.placeholder} value={answerValue} onChange={handleChange} />; break;
|
|
56
|
+
default: return null;
|
|
57
|
+
}
|
|
58
|
+
return input;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
}
|
|
62
|
+
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Button, Icon, Tooltip } from "@mui/material";
|
|
3
|
+
import { Navigate } from "react-router-dom";
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
ariaLabel?: string;
|
|
7
|
+
text?: string;
|
|
8
|
+
icon: string;
|
|
9
|
+
color?: "inherit" | "primary" | "secondary" | "success" | "error" | "info" | "warning";
|
|
10
|
+
toolTip?: string;
|
|
11
|
+
onClick?: (e: React.MouseEvent) => void;
|
|
12
|
+
href?: string;
|
|
13
|
+
disabled?: boolean
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const SmallButton = React.forwardRef<HTMLDivElement, Props>((props, ref) => {
|
|
17
|
+
const [redirectUrl, setRedirectUrl] = React.useState("");
|
|
18
|
+
|
|
19
|
+
const handleClick = (e: React.MouseEvent) => {
|
|
20
|
+
e.preventDefault();
|
|
21
|
+
if (props.href) setRedirectUrl(props.href);
|
|
22
|
+
else props.onClick(e);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const style = (props.text)
|
|
26
|
+
? { backgroundColor: props.color, "& span": { marginRight: 1 } }
|
|
27
|
+
: { minWidth: "auto", padding: "4px 4px" }
|
|
28
|
+
|
|
29
|
+
if (redirectUrl) return <Navigate to={redirectUrl} />
|
|
30
|
+
else return (
|
|
31
|
+
<Tooltip title={props.toolTip || ""} arrow placement="top">
|
|
32
|
+
<Button sx={style} disabled={props.disabled} variant={props.text ? "outlined" : "text"} color={props.color} aria-label={props.ariaLabel || "editButton"} onClick={handleClick} size="small">
|
|
33
|
+
<Icon>{props.icon}</Icon>{(props.text) ? props.text : ""}
|
|
34
|
+
</Button>
|
|
35
|
+
</Tooltip>
|
|
36
|
+
);
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
SmallButton.displayName = "SmallButton";
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Button, Dialog, DialogActions, DialogContent, DialogTitle, Icon, Stack } from "@mui/material";
|
|
2
|
+
import React from "react";
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
appName?: string
|
|
6
|
+
onClose: () => void
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const SupportModal: React.FC<Props> = ({ appName = "", onClose }) => {
|
|
10
|
+
const subject = appName ? `?subject=${appName} Support` : ""
|
|
11
|
+
|
|
12
|
+
return (<>
|
|
13
|
+
<Dialog open={true} onClose={onClose}>
|
|
14
|
+
<DialogTitle>Get Support</DialogTitle>
|
|
15
|
+
<DialogContent>
|
|
16
|
+
<Stack direction="row" alignItems="center" sx={{flexWrap: "wrap"}} mb={2}><b><Stack direction="row" alignItems="center" mr="5px"><Icon sx={{marginRight: "5px"}}>mail</Icon> Email:</Stack></b> <a href={"mailto:support@livecs.org" + subject}>support@livecs.org</a></Stack>
|
|
17
|
+
<Stack direction="row" alignItems="center" sx={{flexWrap: "wrap"}} mb={2}><b><Stack direction="row" alignItems="center" mr="5px"><Icon sx={{marginRight: "5px"}}>phone_iphone</Icon> Phone:</Stack></b> <a href="tel:+19189942638">+1 (918) 994-2638</a></Stack>
|
|
18
|
+
<Stack direction="row" alignItems="center" sx={{flexWrap: "wrap"}} mb={2}><b><Stack direction="row" alignItems="center" mr="5px"><Icon sx={{marginRight: "5px"}}>forum</Icon> Messenger:</Stack></b> <a href="https://m.me/livecsolutions" target="_new">https://m.me/livecsolutions</a></Stack>
|
|
19
|
+
<Stack direction="row" alignItems="center" sx={{flexWrap: "wrap"}}><b><Stack direction="row" alignItems="center" mr="5px"><Icon sx={{marginRight: "5px"}}>info</Icon> Knowledge Base:</Stack></b> <a href="https://support.churchapps.org" target="_new">https://support.churchapps.org</a></Stack>
|
|
20
|
+
</DialogContent>
|
|
21
|
+
<DialogActions sx={{ paddingX: "16px", paddingBottom: "12px" }}>
|
|
22
|
+
<Button variant="outlined" onClick={onClose}>Close</Button>
|
|
23
|
+
</DialogActions>
|
|
24
|
+
</Dialog>
|
|
25
|
+
</>);
|
|
26
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Box, styled } from "@mui/material";
|
|
2
|
+
import React from "react"
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
children?: React.ReactNode;
|
|
6
|
+
index: number;
|
|
7
|
+
value: number;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const TabPanel: React.FC<Props> = (props: Props) => {
|
|
11
|
+
|
|
12
|
+
const { children, value, index } = props;
|
|
13
|
+
const StyledMenuBox = styled(Box)(
|
|
14
|
+
({ theme }) => ({
|
|
15
|
+
paddingTop: 10,
|
|
16
|
+
"& .MuiListItemButton-root": { paddingLeft: 30 },
|
|
17
|
+
"& .MuiListItemIcon-root": {
|
|
18
|
+
color: theme.palette.primary.main
|
|
19
|
+
},
|
|
20
|
+
"& .MuiListItemText-root": { color: theme.palette.text.primary },
|
|
21
|
+
"& .selected .MuiListItemText-root span": { fontWeight: "bold" }
|
|
22
|
+
})
|
|
23
|
+
);
|
|
24
|
+
|
|
25
|
+
return (
|
|
26
|
+
<div role="tabpanel" hidden={value !== index} id={`userMenuPanel-${index}`}>
|
|
27
|
+
{value === index && (
|
|
28
|
+
<StyledMenuBox>
|
|
29
|
+
<Box>{children}</Box>
|
|
30
|
+
</StyledMenuBox>
|
|
31
|
+
)}
|
|
32
|
+
</div>
|
|
33
|
+
);
|
|
34
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { FileHelper, ApiHelper } from "../../helpers";
|
|
2
|
+
import { CommonEnvironmentHelper } from "../../helpers/CommonEnvironmentHelper";
|
|
3
|
+
import { } from "../../helpers";
|
|
4
|
+
import { Button, Dialog, DialogActions, DialogContent, DialogTitle, FormControl, Grid, InputLabel, MenuItem, Select, Tab, Tabs } from "@mui/material";
|
|
5
|
+
import React, { useState } from "react";
|
|
6
|
+
import { ImageEditor } from "../ImageEditor";
|
|
7
|
+
import { TabPanel } from "../TabPanel";
|
|
8
|
+
import { StockPhotos } from "./StockPhotos";
|
|
9
|
+
|
|
10
|
+
interface Props {
|
|
11
|
+
aspectRatio: number,
|
|
12
|
+
onClose: () => void,
|
|
13
|
+
onSelect: (img: string) => void
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const GalleryModal: React.FC<Props> = (props: Props) => {
|
|
17
|
+
const [images, setImages] = useState<string[]>([]);
|
|
18
|
+
const [tabIndex, setTabIndex] = React.useState(0);
|
|
19
|
+
const [aspectRatio, setAspectRatio] = React.useState(Math.round(props.aspectRatio * 100) / 100);
|
|
20
|
+
const [editorPhotoUrl, setEditorPhotoUrl] = React.useState("");
|
|
21
|
+
|
|
22
|
+
const handleTabChange = (el: any, newValue: any) => { setTabIndex(newValue); }
|
|
23
|
+
|
|
24
|
+
const loadData = () => { ApiHelper.get("/gallery/" + aspectRatio.toString(), "ContentApi").then(data => setImages(data.images)); }
|
|
25
|
+
|
|
26
|
+
const handleImageUpdated = async (dataUrl: string) => {
|
|
27
|
+
const fileName = Math.floor(Date.now() / 1000).toString() + ".jpg"
|
|
28
|
+
const blob = FileHelper.dataURLtoBlob(dataUrl);
|
|
29
|
+
const file = new File([blob], "file_name");
|
|
30
|
+
|
|
31
|
+
const params = { folder: aspectRatio.toString(), fileName };
|
|
32
|
+
const presigned = await ApiHelper.post("/gallery/requestUpload", params, "ContentApi");
|
|
33
|
+
const doUpload = presigned.key !== undefined;
|
|
34
|
+
if (doUpload) await FileHelper.postPresignedFile(presigned, file, () => { });
|
|
35
|
+
//return doUpload;
|
|
36
|
+
setTabIndex(0);
|
|
37
|
+
loadData();
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
React.useEffect(() => { if (aspectRatio !== props.aspectRatio) setAspectRatio(Math.round(props.aspectRatio * 100) / 100) }, [props.aspectRatio]); //eslint-disable-line
|
|
41
|
+
React.useEffect(loadData, [aspectRatio]); //eslint-disable-line
|
|
42
|
+
|
|
43
|
+
const getImages = () => {
|
|
44
|
+
let result: JSX.Element[] = [];
|
|
45
|
+
images.forEach(img => {
|
|
46
|
+
result.push(<Grid item md={4} xs={12}>
|
|
47
|
+
<a href="about:blank" onClick={(e) => { e.preventDefault(); props.onSelect(CommonEnvironmentHelper.ContentRoot + "/" + img) }}>
|
|
48
|
+
<img src={CommonEnvironmentHelper.ContentRoot + "/" + img} className="img-fluid" alt="custom" />
|
|
49
|
+
</a>
|
|
50
|
+
</Grid>);
|
|
51
|
+
})
|
|
52
|
+
return result;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const handleStockSelect = (url: string) => {
|
|
56
|
+
setEditorPhotoUrl(url);
|
|
57
|
+
setTabIndex(1);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
return (<>
|
|
61
|
+
<Dialog open={true} onClose={props.onClose}>
|
|
62
|
+
<DialogTitle>Select a Photo</DialogTitle>
|
|
63
|
+
<DialogContent style={{ minWidth: 600 }}>
|
|
64
|
+
|
|
65
|
+
<Tabs variant="fullWidth" value={tabIndex} onChange={handleTabChange}>
|
|
66
|
+
<Tab label="Gallery" />
|
|
67
|
+
<Tab label="Upload" />
|
|
68
|
+
<Tab label="Stock Photos" />
|
|
69
|
+
</Tabs>
|
|
70
|
+
<TabPanel value={tabIndex} index={0}>
|
|
71
|
+
{(props.aspectRatio === 0) && (
|
|
72
|
+
<FormControl fullWidth>
|
|
73
|
+
<InputLabel>Aspect Ratio</InputLabel>
|
|
74
|
+
<Select size="small" label="Aspect Ratio" name="aspectRatio" value={aspectRatio} onChange={(e) => setAspectRatio(parseFloat(e.target.value.toString()))}>
|
|
75
|
+
<MenuItem value="0">Free Form</MenuItem>
|
|
76
|
+
<MenuItem value="1">1:1</MenuItem>
|
|
77
|
+
<MenuItem value="2">2:1</MenuItem>
|
|
78
|
+
<MenuItem value="4">4:1</MenuItem>
|
|
79
|
+
<MenuItem value="1.33">4:3</MenuItem>
|
|
80
|
+
<MenuItem value="1.78">16:9</MenuItem>
|
|
81
|
+
<MenuItem value="0.5">1:2</MenuItem>
|
|
82
|
+
<MenuItem value="0.5625">9:16</MenuItem>
|
|
83
|
+
</Select>
|
|
84
|
+
</FormControl>
|
|
85
|
+
)}
|
|
86
|
+
<Grid container spacing={3} alignItems="center">
|
|
87
|
+
{getImages()}
|
|
88
|
+
</Grid>
|
|
89
|
+
</TabPanel>
|
|
90
|
+
<TabPanel value={tabIndex} index={1}>
|
|
91
|
+
<ImageEditor onUpdate={handleImageUpdated} photoUrl={editorPhotoUrl} aspectRatio={aspectRatio} outputWidth={1280} outputHeight={768} hideDelete={true} />
|
|
92
|
+
</TabPanel>
|
|
93
|
+
<TabPanel value={tabIndex} index={2}>
|
|
94
|
+
<StockPhotos aspectRatio={aspectRatio} onSelect={props.onSelect} onStockSelect={handleStockSelect} />
|
|
95
|
+
</TabPanel>
|
|
96
|
+
</DialogContent>
|
|
97
|
+
<DialogActions sx={{ paddingX: "16px", paddingBottom: "12px" }}>
|
|
98
|
+
<Button variant="outlined" onClick={props.onClose}>Close</Button>
|
|
99
|
+
</DialogActions>
|
|
100
|
+
</Dialog>
|
|
101
|
+
</>);
|
|
102
|
+
};
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { Button, Grid, TextField } from "@mui/material";
|
|
2
|
+
import React, { useState } from "react";
|
|
3
|
+
import { ApiHelper } from "../../helpers";
|
|
4
|
+
import { CommonEnvironmentHelper } from "../../helpers/CommonEnvironmentHelper";
|
|
5
|
+
|
|
6
|
+
interface Props {
|
|
7
|
+
aspectRatio: number,
|
|
8
|
+
onSelect: (img: string) => void,
|
|
9
|
+
onStockSelect: (img: string) => void
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
interface SearchResult { description: string, url: string, photographer: string, photographerUrl: string, large: string, thumbnail: string }
|
|
13
|
+
|
|
14
|
+
export const StockPhotos: React.FC<Props> = (props: Props) => {
|
|
15
|
+
const [images, setImages] = useState<string[]>([]);
|
|
16
|
+
const [searchText, setSearchText] = useState("");
|
|
17
|
+
const [searchResults, setSearchResults] = useState<SearchResult[]>(null);
|
|
18
|
+
|
|
19
|
+
const loadData = () => { ApiHelper.getAnonymous("/gallery/stock/" + props.aspectRatio.toString(), "ContentApi").then(data => setImages(data.images)); }
|
|
20
|
+
|
|
21
|
+
React.useEffect(loadData, [props.aspectRatio]); //eslint-disable-line
|
|
22
|
+
|
|
23
|
+
const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => { e.preventDefault(); setSearchText(e.currentTarget.value); }
|
|
24
|
+
|
|
25
|
+
const handleSearch = (e: React.MouseEvent) => {
|
|
26
|
+
if (e !== null) e.preventDefault();
|
|
27
|
+
let term = searchText.trim();
|
|
28
|
+
ApiHelper.post("/stock/search", { term: term }, "ContentApi").then((data: SearchResult[]) => { setSearchResults(data) });
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
const getImages = () => {
|
|
32
|
+
if (searchResults) return getResults();
|
|
33
|
+
else return getSuggested();
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const getResults = () => {
|
|
37
|
+
let result: JSX.Element[] = [];
|
|
38
|
+
searchResults.forEach(p => {
|
|
39
|
+
result.push(<Grid item md={4} xs={12}>
|
|
40
|
+
<a href="about:blank" onClick={(e) => { e.preventDefault(); props.onStockSelect(p.large) }}>
|
|
41
|
+
<img src={p.thumbnail} className="img-fluid" alt="stock" />
|
|
42
|
+
</a>
|
|
43
|
+
<div>
|
|
44
|
+
<i style={{ fontSize: 12 }}>
|
|
45
|
+
<a href={p.url} target="_blank" rel="noreferrer noopener">Photo</a> by: <a href={p.photographerUrl} target="_blank" rel="noreferrer noopener">{p.photographer}</a></i>
|
|
46
|
+
</div>
|
|
47
|
+
</Grid>);
|
|
48
|
+
})
|
|
49
|
+
return result;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const getSuggested = () => {
|
|
53
|
+
let result: JSX.Element[] = [];
|
|
54
|
+
images.forEach(img => {
|
|
55
|
+
result.push(<Grid item md={4} xs={12}>
|
|
56
|
+
<a href="about:blank" onClick={(e) => { e.preventDefault(); props.onSelect(CommonEnvironmentHelper.ContentRoot + "/" + img) }}>
|
|
57
|
+
<img src={CommonEnvironmentHelper.ContentRoot + "/" + img} className="img-fluid" alt="stock" />
|
|
58
|
+
</a>
|
|
59
|
+
</Grid>);
|
|
60
|
+
})
|
|
61
|
+
return result;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return (<>
|
|
65
|
+
<TextField fullWidth name="personAddText" label="Search Term" value={searchText} onChange={handleChange}
|
|
66
|
+
InputProps={{ endAdornment: <Button variant="contained" id="searchButton" data-cy="search-button" onClick={handleSearch}>Search</Button> }}
|
|
67
|
+
/>
|
|
68
|
+
{searchResults && <div>Stock photos provided by <a href="https://pexels.com">Pexels</a>.</div>}
|
|
69
|
+
<Grid container spacing={3} alignItems="center">
|
|
70
|
+
{getImages()}
|
|
71
|
+
</Grid>
|
|
72
|
+
|
|
73
|
+
</>);
|
|
74
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export { CreatePerson } from "./CreatePerson";
|
|
2
|
+
export { ErrorMessages } from "./ErrorMessages";
|
|
3
|
+
export { ExportLink } from "./ExportLink";
|
|
4
|
+
export { DisplayBox } from "./DisplayBox";
|
|
5
|
+
export { FloatingSupport } from "./FloatingSupport";
|
|
6
|
+
export { FormSubmissionEdit } from "./FormSubmissionEdit";
|
|
7
|
+
export { HelpIcon } from "./HelpIcon";
|
|
8
|
+
export { ImageEditor } from "./ImageEditor";
|
|
9
|
+
export { InputBox } from "./InputBox";
|
|
10
|
+
export { Loading } from "./Loading";
|
|
11
|
+
export { Notes } from "./notes/Notes";
|
|
12
|
+
export { PersonAdd } from "./PersonAdd";
|
|
13
|
+
export { QuestionEdit } from "./QuestionEdit";
|
|
14
|
+
export { SmallButton } from "./SmallButton";
|
|
15
|
+
export { MarkdownEditor } from "./markdownEditor/MarkdownEditor";
|
|
16
|
+
export { MarkdownPreview } from "./markdownEditor/MarkdownPreview";
|
|
17
|
+
|
|
18
|
+
export * from "./material";
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import React, {useCallback, useMemo} from "react";
|
|
2
|
+
import { LexicalComposer } from "@lexical/react/LexicalComposer";
|
|
3
|
+
import { RichTextPlugin } from "@lexical/react/LexicalRichTextPlugin";
|
|
4
|
+
import { ContentEditable } from "@lexical/react/LexicalContentEditable";
|
|
5
|
+
import { HistoryPlugin } from "@lexical/react/LexicalHistoryPlugin";
|
|
6
|
+
import { OnChangePlugin } from "@lexical/react/LexicalOnChangePlugin";
|
|
7
|
+
import { AutoFocusPlugin } from "@lexical/react/LexicalAutoFocusPlugin";
|
|
8
|
+
import LexicalErrorBoundary from "@lexical/react/LexicalErrorBoundary";
|
|
9
|
+
import { ListPlugin } from "@lexical/react/LexicalListPlugin";
|
|
10
|
+
import { LexicalNode } from "lexical";
|
|
11
|
+
import { MarkdownShortcutPlugin } from "@lexical/react/LexicalMarkdownShortcutPlugin";
|
|
12
|
+
import { TRANSFORMERS, $convertToMarkdownString, $convertFromMarkdownString } from "@lexical/markdown";
|
|
13
|
+
import { HeadingNode, QuoteNode } from "@lexical/rich-text";
|
|
14
|
+
import { ListItemNode, ListNode } from "@lexical/list";
|
|
15
|
+
import { TableCellNode, TableNode, TableRowNode } from "@lexical/table";
|
|
16
|
+
import { AutoLinkNode, LinkNode } from "@lexical/link";
|
|
17
|
+
import { CodeHighlightNode, CodeNode } from "@lexical/code";
|
|
18
|
+
import { theme } from "./theme";
|
|
19
|
+
import { ToolbarPlugin, CustomAutoLinkPlugin, ListMaxIndentLevelPlugin, PLAYGROUND_TRANSFORMERS, ReadOnlyPlugin, ControlledEditorPlugin } from "./plugins";
|
|
20
|
+
import { MarkdownModal } from "./MarkdownModal";
|
|
21
|
+
import CustomLinkNodePlugin from "./plugins/customLink/CustomLinkNodePlugin";
|
|
22
|
+
import { CustomLinkNode } from "./plugins/customLink/CustomLinkNode";
|
|
23
|
+
import EmojisPlugin from "./plugins/emoji/EmojisPlugin";
|
|
24
|
+
import { EmojiNode } from "./plugins/emoji/EmojiNode";
|
|
25
|
+
import EmojiPickerPlugin from "./plugins/emoji/EmojiPickerPlugin";
|
|
26
|
+
|
|
27
|
+
interface Props {
|
|
28
|
+
value: string;
|
|
29
|
+
onChange?: (value: string) => void;
|
|
30
|
+
mode?: "interactive" | "preview";
|
|
31
|
+
style?: any;
|
|
32
|
+
textAlign?: "left" | "center" | "right";
|
|
33
|
+
placeholder?: string;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function Editor({ value, onChange = () => { }, mode = "interactive", textAlign = "left", style, placeholder = "Enter some text..." }: Props) {
|
|
37
|
+
const [fullScreen, setFullScreen] = React.useState(false);
|
|
38
|
+
|
|
39
|
+
const handleChange = (editorState: any) => {
|
|
40
|
+
editorState.read(() => {
|
|
41
|
+
const markdown = $convertToMarkdownString(PLAYGROUND_TRANSFORMERS);
|
|
42
|
+
onChange(markdown);
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
const onError = (error: any) => {
|
|
47
|
+
console.error(error);
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
const handleModalOnChange = (value : string) => {
|
|
51
|
+
onChange(value);
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
const handleCloseFullScreen = () => {
|
|
55
|
+
setFullScreen(false);
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
const initialConfig = {
|
|
59
|
+
editorState: () => $convertFromMarkdownString(value, PLAYGROUND_TRANSFORMERS),
|
|
60
|
+
namespace: "editor",
|
|
61
|
+
theme,
|
|
62
|
+
onError,
|
|
63
|
+
nodes: [
|
|
64
|
+
HeadingNode,
|
|
65
|
+
ListNode,
|
|
66
|
+
ListItemNode,
|
|
67
|
+
QuoteNode,
|
|
68
|
+
CodeNode,
|
|
69
|
+
CodeHighlightNode,
|
|
70
|
+
TableNode,
|
|
71
|
+
TableCellNode,
|
|
72
|
+
TableRowNode,
|
|
73
|
+
AutoLinkNode,
|
|
74
|
+
LinkNode,
|
|
75
|
+
CustomLinkNode,
|
|
76
|
+
EmojiNode,
|
|
77
|
+
{
|
|
78
|
+
replace: LinkNode,
|
|
79
|
+
with: (node: LexicalNode) => (
|
|
80
|
+
new CustomLinkNode(node.__url, node.__target, [])
|
|
81
|
+
)
|
|
82
|
+
}
|
|
83
|
+
]
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
let textAlignClass = ""
|
|
87
|
+
switch (textAlign) {
|
|
88
|
+
case "center":
|
|
89
|
+
textAlignClass = "text-center"
|
|
90
|
+
break;
|
|
91
|
+
case "right":
|
|
92
|
+
textAlignClass = "text-right"
|
|
93
|
+
break;
|
|
94
|
+
case "left":
|
|
95
|
+
default:
|
|
96
|
+
textAlignClass = "text-left"
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
return (
|
|
101
|
+
<>
|
|
102
|
+
<LexicalComposer initialConfig={initialConfig}>
|
|
103
|
+
<div className={(mode === "preview") ? `editor-container preview ${textAlignClass}` : `editor-container ${textAlignClass}`} style={Object.assign({ border: mode === "preview" ? "none" : "1px solid lightgray" }, style)}>
|
|
104
|
+
{mode !== "preview" && <ToolbarPlugin goFullScreen={() => { setFullScreen(true) }} />}
|
|
105
|
+
<div className="editor-inner">
|
|
106
|
+
{!fullScreen && <RichTextPlugin
|
|
107
|
+
contentEditable={<ContentEditable className="editor-input" style={{ minHeight: mode === "preview" ? "auto" : "150px" }} />}
|
|
108
|
+
placeholder={mode !== "preview" ? <div className="editor-placeholder">{placeholder}</div> : null}
|
|
109
|
+
ErrorBoundary={LexicalErrorBoundary}
|
|
110
|
+
/> }
|
|
111
|
+
<CustomLinkNodePlugin />
|
|
112
|
+
{mode !== "preview" && <EmojiPickerPlugin />}
|
|
113
|
+
<EmojisPlugin />
|
|
114
|
+
<OnChangePlugin onChange={handleChange} />
|
|
115
|
+
{mode !== "preview" && <AutoFocusPlugin />}
|
|
116
|
+
<HistoryPlugin />
|
|
117
|
+
<ListPlugin />
|
|
118
|
+
<CustomAutoLinkPlugin />
|
|
119
|
+
|
|
120
|
+
<ListMaxIndentLevelPlugin maxDepth={7} />
|
|
121
|
+
<ReadOnlyPlugin isDisabled={mode === "preview"} />
|
|
122
|
+
<ControlledEditorPlugin isFullscreen={fullScreen} value={value} isPreview={mode === "preview"} />
|
|
123
|
+
<MarkdownShortcutPlugin transformers={TRANSFORMERS} />
|
|
124
|
+
</div>
|
|
125
|
+
</div>
|
|
126
|
+
</LexicalComposer>
|
|
127
|
+
{fullScreen && <MarkdownModal onChange={handleModalOnChange} value={value} hideModal={handleCloseFullScreen} />}
|
|
128
|
+
</>
|
|
129
|
+
);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
export default Editor;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { lazy, Suspense } from 'react';
|
|
3
|
+
import { Loading } from "../Loading";
|
|
4
|
+
const Editor = lazy(() => import('./Editor'));
|
|
5
|
+
|
|
6
|
+
interface Props {
|
|
7
|
+
value: string;
|
|
8
|
+
onChange?: (newValue: string) => void;
|
|
9
|
+
style?: any;
|
|
10
|
+
textAlign?: "left" | "center" | "right";
|
|
11
|
+
placeholder?: string;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function MarkdownEditor({ value: markdownString = "", onChange, style, textAlign, placeholder }: Props) {
|
|
15
|
+
return <Suspense fallback={<Loading />}><Editor value={markdownString} onChange={onChange} style={style} textAlign={textAlign} placeholder={placeholder} /></Suspense>
|
|
16
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
|
+
import { Button, Dialog, DialogActions, DialogContent, DialogTitle, Grid, TextField } from "@mui/material";
|
|
3
|
+
import { MarkdownPreview } from "./MarkdownPreview";
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
hideModal: () => void
|
|
7
|
+
onChange: (newValue: string) => void
|
|
8
|
+
value?: string;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
const guideLink = <a href="https://www.markdownguide.org/cheat-sheet/" target="_blank" rel="noopener noreferrer" style={{ float: "right" }}>Markdown Guide</a>;
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
export const MarkdownModal: React.FC<Props> = ({ value, onChange, hideModal }) => {
|
|
15
|
+
const [inputVal, setInputVal] = useState(value);
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
if (value.trim() === inputVal.trim()) return;
|
|
20
|
+
setInputVal(value);
|
|
21
|
+
}, [value, inputVal]);
|
|
22
|
+
|
|
23
|
+
useEffect(() => { onChange(inputVal); }, [inputVal, onChange]);
|
|
24
|
+
|
|
25
|
+
return (<Dialog open={true} onClose={() => { hideModal() }} fullScreen={true}>
|
|
26
|
+
<DialogTitle>Markdown Editor</DialogTitle>
|
|
27
|
+
<DialogContent>
|
|
28
|
+
<Grid container spacing={3}>
|
|
29
|
+
<Grid item xs={6}>
|
|
30
|
+
<TextField fullWidth multiline label={<>Content {guideLink}</>} name="modalMarkdown" className="modalMarkdown" InputProps={{ style: { height: "80vh" } }} value={inputVal} onChange={(e) => {
|
|
31
|
+
setInputVal(e.target.value);
|
|
32
|
+
}} placeholder="" />
|
|
33
|
+
</Grid>
|
|
34
|
+
<Grid item xs={6}>
|
|
35
|
+
<div style={{ border: "1px solid #BBB", borderRadius: 5, marginTop: 15, padding: 10, height: "80vh", overflowY: "scroll" }} id="markdownPreview">
|
|
36
|
+
<div style={{ marginTop: -20, marginBottom: -10, position: "absolute" }}><span style={{ backgroundColor: "#FFFFFF", color: "#999", fontSize: 13 }}> Preview </span></div>
|
|
37
|
+
<MarkdownPreview value={inputVal} />
|
|
38
|
+
</div>
|
|
39
|
+
</Grid>
|
|
40
|
+
</Grid>
|
|
41
|
+
</DialogContent>
|
|
42
|
+
<DialogActions sx={{ paddingX: "16px", paddingBottom: "12px" }}>
|
|
43
|
+
<Button variant="outlined" onClick={() => { hideModal() }}>Close</Button>
|
|
44
|
+
</DialogActions>
|
|
45
|
+
</Dialog>)
|
|
46
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React, { Suspense } from "react";
|
|
2
|
+
import { lazy } from 'react';
|
|
3
|
+
const Editor = lazy(() => import('./Editor'));
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
value: string;
|
|
7
|
+
textAlign?: "left" | "center" | "right"
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export function MarkdownPreview({ value: markdownString = "", textAlign }: Props) {
|
|
11
|
+
return <Suspense fallback={<div>{markdownString || ""}</div>}>
|
|
12
|
+
<Editor mode="preview" value={markdownString || ""} textAlign={textAlign} />
|
|
13
|
+
</Suspense>
|
|
14
|
+
}
|