@selfcommunity/react-core 0.4.0-alpha.11 → 0.4.0-alpha.110
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/lib/cjs/components/provider/SCAlertMessagesProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCAlertMessagesProvider/index.js +2 -25
- package/lib/cjs/components/provider/SCContextProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCContextProvider/index.js +3 -29
- package/lib/cjs/components/provider/SCLocaleProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCLocaleProvider/index.js +2 -25
- package/lib/cjs/components/provider/SCNotificationProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCNotificationProvider/index.js +7 -31
- package/lib/cjs/components/provider/SCPreferencesProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCPreferencesProvider/index.js +2 -25
- package/lib/cjs/components/provider/SCRoutingProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCRoutingProvider/index.js +4 -27
- package/lib/cjs/components/provider/SCThemeProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCThemeProvider/index.js +6 -32
- package/lib/cjs/components/provider/SCUserProvider/index.d.ts +0 -1
- package/lib/cjs/components/provider/SCUserProvider/index.js +32 -49
- package/lib/cjs/components/provider/SCVoteProvider/index.d.ts +37 -0
- package/lib/cjs/components/provider/SCVoteProvider/index.js +112 -0
- package/lib/cjs/components/router/index.d.ts +0 -1
- package/lib/cjs/components/router/index.js +5 -39
- package/lib/cjs/constants/Actions.d.ts +0 -1
- package/lib/cjs/constants/Actions.js +0 -1
- package/lib/cjs/constants/Cache.d.ts +23 -15
- package/lib/cjs/constants/Cache.js +28 -17
- package/lib/cjs/constants/ContextProviders.d.ts +0 -1
- package/lib/cjs/constants/ContextProviders.js +12 -13
- package/lib/cjs/constants/Device.d.ts +22 -1
- package/lib/cjs/constants/Device.js +27 -2
- package/lib/cjs/constants/Errors.d.ts +0 -1
- package/lib/cjs/constants/Errors.js +0 -1
- package/lib/cjs/constants/Features.d.ts +0 -43
- package/lib/cjs/constants/Features.js +1 -44
- package/lib/cjs/constants/Locale.d.ts +0 -1
- package/lib/cjs/constants/Locale.js +0 -1
- package/lib/cjs/constants/Notification.d.ts +0 -1
- package/lib/cjs/constants/Notification.js +0 -1
- package/lib/cjs/constants/Notifications.d.ts +3 -1
- package/lib/cjs/constants/Notifications.js +7 -2
- package/lib/cjs/constants/Preferences.d.ts +13 -2
- package/lib/cjs/constants/Preferences.js +21 -5
- package/lib/cjs/constants/Routes.d.ts +3 -1
- package/lib/cjs/constants/Routes.js +8 -3
- package/lib/cjs/constants/Session.d.ts +0 -1
- package/lib/cjs/constants/Session.js +0 -1
- package/lib/cjs/constants/Theme.d.ts +0 -1
- package/lib/cjs/constants/Theme.js +0 -1
- package/lib/cjs/constants/Vote.d.ts +6 -0
- package/lib/cjs/constants/Vote.js +9 -0
- package/lib/cjs/constants/WebSocket.d.ts +0 -1
- package/lib/cjs/constants/WebSocket.js +0 -1
- package/lib/cjs/hooks/useSCAuth.d.ts +0 -1
- package/lib/cjs/hooks/useSCAuth.js +34 -51
- package/lib/cjs/hooks/useSCBlockedUsersManager.d.ts +30 -0
- package/lib/cjs/hooks/useSCBlockedUsersManager.js +108 -0
- package/lib/cjs/hooks/useSCCachingManager.d.ts +5 -5
- package/lib/cjs/hooks/useSCCachingManager.js +21 -6
- package/lib/cjs/hooks/useSCConnectionsManager.d.ts +8 -5
- package/lib/cjs/hooks/useSCConnectionsManager.js +141 -91
- package/lib/cjs/hooks/useSCFetchAddressingTagList.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchAddressingTagList.js +2 -26
- package/lib/cjs/hooks/useSCFetchBroadcastMessages.d.ts +30 -0
- package/lib/cjs/hooks/useSCFetchBroadcastMessages.js +91 -0
- package/lib/cjs/hooks/useSCFetchCategories.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchCategories.js +2 -11
- package/lib/cjs/hooks/useSCFetchCategory.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchCategory.js +13 -12
- package/lib/cjs/hooks/useSCFetchCommentObject.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchCommentObject.js +1 -2
- package/lib/cjs/hooks/useSCFetchCommentObjects.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchCommentObjects.js +2 -5
- package/lib/cjs/hooks/useSCFetchContributors.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchContributors.js +2 -5
- package/lib/cjs/hooks/useSCFetchCustomAdv.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchCustomAdv.js +2 -5
- package/lib/cjs/hooks/useSCFetchFeed.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchFeed.js +3 -6
- package/lib/cjs/hooks/useSCFetchFeedObject.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchFeedObject.js +0 -1
- package/lib/cjs/hooks/useSCFetchIncubator.d.ts +4 -2
- package/lib/cjs/hooks/useSCFetchIncubator.js +28 -8
- package/lib/cjs/hooks/useSCFetchPrivateMessageSnippets.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchPrivateMessageSnippets.js +16 -26
- package/lib/cjs/hooks/useSCFetchReactions.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchReactions.js +3 -50
- package/lib/cjs/hooks/useSCFetchTag.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchTag.js +0 -1
- package/lib/cjs/hooks/useSCFetchUser.d.ts +2 -1
- package/lib/cjs/hooks/useSCFetchUser.js +33 -8
- package/lib/cjs/hooks/useSCFetchUserBlockedBy.d.ts +17 -0
- package/lib/cjs/hooks/useSCFetchUserBlockedBy.js +83 -0
- package/lib/cjs/hooks/useSCFetchUserProviders.d.ts +0 -1
- package/lib/cjs/hooks/useSCFetchUserProviders.js +0 -1
- package/lib/cjs/hooks/useSCFetchVote.d.ts +2 -3
- package/lib/cjs/hooks/useSCFetchVote.js +58 -73
- package/lib/cjs/hooks/useSCFollowedCategoriesManager.d.ts +4 -5
- package/lib/cjs/hooks/useSCFollowedCategoriesManager.js +26 -17
- package/lib/cjs/hooks/useSCFollowedManager.d.ts +4 -5
- package/lib/cjs/hooks/useSCFollowedManager.js +38 -24
- package/lib/cjs/hooks/useSCFollowersManager.d.ts +4 -5
- package/lib/cjs/hooks/useSCFollowersManager.js +7 -10
- package/lib/cjs/hooks/useSCMediaClick.d.ts +0 -1
- package/lib/cjs/hooks/useSCMediaClick.js +0 -1
- package/lib/cjs/hooks/useSCMobileNativePushMessaging.d.ts +19 -0
- package/lib/cjs/hooks/useSCMobileNativePushMessaging.js +143 -0
- package/lib/cjs/hooks/useSCSettingsManager.d.ts +0 -1
- package/lib/cjs/hooks/useSCSettingsManager.js +0 -1
- package/lib/cjs/hooks/useSCSubscribedIncubatorsManager.d.ts +12 -3
- package/lib/cjs/hooks/useSCSubscribedIncubatorsManager.js +39 -32
- package/lib/cjs/hooks/useSCUserIsBlocked.d.ts +18 -0
- package/lib/cjs/hooks/useSCUserIsBlocked.js +33 -0
- package/lib/cjs/hooks/useSCWebPushMessaging.d.ts +12 -2
- package/lib/cjs/hooks/useSCWebPushMessaging.js +188 -106
- package/lib/cjs/hooks/useSCWebSocket.d.ts +1 -2
- package/lib/cjs/hooks/useSCWebSocket.js +3 -6
- package/lib/cjs/index.d.ts +4 -2
- package/lib/cjs/index.js +41 -61
- package/lib/cjs/themes/theme.d.ts +0 -1
- package/lib/cjs/themes/theme.js +4 -80
- package/lib/cjs/types/context.d.ts +96 -6
- package/lib/cjs/types/context.js +0 -1
- package/lib/cjs/types/index.d.ts +2 -3
- package/lib/cjs/types/index.js +0 -1
- package/lib/cjs/types/theme.d.ts +1 -2
- package/lib/cjs/types/theme.js +0 -1
- package/lib/cjs/utils/errors.d.ts +5 -6
- package/lib/cjs/utils/errors.js +13 -34
- package/lib/cjs/utils/hooks/index.d.ts +0 -1
- package/lib/cjs/utils/hooks/index.js +6 -9
- package/lib/cjs/utils/hooks/useEffectOnce.d.ts +0 -1
- package/lib/cjs/utils/hooks/useEffectOnce.js +0 -1
- package/lib/cjs/utils/hooks/useIsComponentMountedRef.d.ts +0 -1
- package/lib/cjs/utils/hooks/useIsComponentMountedRef.js +0 -1
- package/lib/cjs/utils/hooks/useIsomorphicLayoutEffect.d.ts +0 -1
- package/lib/cjs/utils/hooks/useIsomorphicLayoutEffect.js +0 -1
- package/lib/cjs/utils/hooks/useNoInitialEffect.d.ts +0 -1
- package/lib/cjs/utils/hooks/useNoInitialEffect.js +0 -1
- package/lib/cjs/utils/hooks/usePreviousValue.d.ts +0 -1
- package/lib/cjs/utils/hooks/usePreviousValue.js +0 -1
- package/lib/cjs/utils/locale.d.ts +0 -1
- package/lib/cjs/utils/locale.js +2 -5
- package/lib/cjs/utils/notification.d.ts +8 -0
- package/lib/cjs/utils/notification.js +20 -0
- package/lib/cjs/utils/pagination.d.ts +0 -1
- package/lib/cjs/utils/pagination.js +0 -1
- package/lib/cjs/utils/user.d.ts +0 -1
- package/lib/cjs/utils/user.js +0 -1
- package/lib/cjs/utils/validator.d.ts +49 -3
- package/lib/cjs/utils/validator.js +144 -41
- package/lib/esm/components/provider/SCAlertMessagesProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCAlertMessagesProvider/index.js +0 -1
- package/lib/esm/components/provider/SCContextProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCContextProvider/index.js +0 -1
- package/lib/esm/components/provider/SCLocaleProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCLocaleProvider/index.js +0 -1
- package/lib/esm/components/provider/SCNotificationProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCNotificationProvider/index.js +3 -2
- package/lib/esm/components/provider/SCPreferencesProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCPreferencesProvider/index.js +0 -1
- package/lib/esm/components/provider/SCRoutingProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCRoutingProvider/index.js +1 -2
- package/lib/esm/components/provider/SCThemeProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCThemeProvider/index.js +1 -2
- package/lib/esm/components/provider/SCUserProvider/index.d.ts +0 -1
- package/lib/esm/components/provider/SCUserProvider/index.js +22 -14
- package/lib/esm/components/provider/SCVoteProvider/index.d.ts +37 -0
- package/lib/esm/components/provider/SCVoteProvider/index.js +106 -0
- package/lib/esm/components/router/index.d.ts +0 -1
- package/lib/esm/components/router/index.js +2 -13
- package/lib/esm/constants/Actions.d.ts +0 -1
- package/lib/esm/constants/Actions.js +0 -1
- package/lib/esm/constants/Cache.d.ts +23 -15
- package/lib/esm/constants/Cache.js +23 -15
- package/lib/esm/constants/ContextProviders.d.ts +0 -1
- package/lib/esm/constants/ContextProviders.js +4 -3
- package/lib/esm/constants/Device.d.ts +22 -1
- package/lib/esm/constants/Device.js +26 -1
- package/lib/esm/constants/Errors.d.ts +0 -1
- package/lib/esm/constants/Errors.js +0 -1
- package/lib/esm/constants/Features.d.ts +0 -43
- package/lib/esm/constants/Features.js +0 -43
- package/lib/esm/constants/Locale.d.ts +0 -1
- package/lib/esm/constants/Locale.js +0 -1
- package/lib/esm/constants/Notification.d.ts +0 -1
- package/lib/esm/constants/Notification.js +0 -1
- package/lib/esm/constants/Notifications.d.ts +3 -1
- package/lib/esm/constants/Notifications.js +6 -1
- package/lib/esm/constants/Preferences.d.ts +13 -2
- package/lib/esm/constants/Preferences.js +18 -3
- package/lib/esm/constants/Routes.d.ts +3 -1
- package/lib/esm/constants/Routes.js +7 -2
- package/lib/esm/constants/Session.d.ts +0 -1
- package/lib/esm/constants/Session.js +0 -1
- package/lib/esm/constants/Theme.d.ts +0 -1
- package/lib/esm/constants/Theme.js +0 -1
- package/lib/esm/constants/Vote.d.ts +6 -0
- package/lib/esm/constants/Vote.js +6 -0
- package/lib/esm/constants/WebSocket.d.ts +0 -1
- package/lib/esm/constants/WebSocket.js +0 -1
- package/lib/esm/hooks/useSCAuth.d.ts +0 -1
- package/lib/esm/hooks/useSCAuth.js +31 -22
- package/lib/esm/hooks/useSCBlockedUsersManager.d.ts +30 -0
- package/lib/esm/hooks/useSCBlockedUsersManager.js +105 -0
- package/lib/esm/hooks/useSCCachingManager.d.ts +5 -5
- package/lib/esm/hooks/useSCCachingManager.js +21 -6
- package/lib/esm/hooks/useSCConnectionsManager.d.ts +8 -5
- package/lib/esm/hooks/useSCConnectionsManager.js +138 -86
- package/lib/esm/hooks/useSCFetchAddressingTagList.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchAddressingTagList.js +3 -4
- package/lib/esm/hooks/useSCFetchBroadcastMessages.d.ts +30 -0
- package/lib/esm/hooks/useSCFetchBroadcastMessages.js +89 -0
- package/lib/esm/hooks/useSCFetchCategories.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchCategories.js +1 -10
- package/lib/esm/hooks/useSCFetchCategory.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchCategory.js +15 -14
- package/lib/esm/hooks/useSCFetchCommentObject.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchCommentObject.js +1 -2
- package/lib/esm/hooks/useSCFetchCommentObjects.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchCommentObjects.js +0 -1
- package/lib/esm/hooks/useSCFetchContributors.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchContributors.js +0 -1
- package/lib/esm/hooks/useSCFetchCustomAdv.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchCustomAdv.js +0 -1
- package/lib/esm/hooks/useSCFetchFeed.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchFeed.js +1 -2
- package/lib/esm/hooks/useSCFetchFeedObject.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchFeedObject.js +0 -1
- package/lib/esm/hooks/useSCFetchIncubator.d.ts +4 -2
- package/lib/esm/hooks/useSCFetchIncubator.js +29 -9
- package/lib/esm/hooks/useSCFetchPrivateMessageSnippets.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchPrivateMessageSnippets.js +15 -25
- package/lib/esm/hooks/useSCFetchReactions.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchReactions.js +5 -29
- package/lib/esm/hooks/useSCFetchTag.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchTag.js +0 -1
- package/lib/esm/hooks/useSCFetchUser.d.ts +2 -1
- package/lib/esm/hooks/useSCFetchUser.js +34 -9
- package/lib/esm/hooks/useSCFetchUserBlockedBy.d.ts +17 -0
- package/lib/esm/hooks/useSCFetchUserBlockedBy.js +80 -0
- package/lib/esm/hooks/useSCFetchUserProviders.d.ts +0 -1
- package/lib/esm/hooks/useSCFetchUserProviders.js +0 -1
- package/lib/esm/hooks/useSCFetchVote.d.ts +2 -3
- package/lib/esm/hooks/useSCFetchVote.js +56 -69
- package/lib/esm/hooks/useSCFollowedCategoriesManager.d.ts +4 -5
- package/lib/esm/hooks/useSCFollowedCategoriesManager.js +25 -14
- package/lib/esm/hooks/useSCFollowedManager.d.ts +4 -5
- package/lib/esm/hooks/useSCFollowedManager.js +37 -21
- package/lib/esm/hooks/useSCFollowersManager.d.ts +4 -5
- package/lib/esm/hooks/useSCFollowersManager.js +4 -5
- package/lib/esm/hooks/useSCMediaClick.d.ts +0 -1
- package/lib/esm/hooks/useSCMediaClick.js +0 -1
- package/lib/esm/hooks/useSCMobileNativePushMessaging.d.ts +19 -0
- package/lib/esm/hooks/useSCMobileNativePushMessaging.js +140 -0
- package/lib/esm/hooks/useSCSettingsManager.d.ts +0 -1
- package/lib/esm/hooks/useSCSettingsManager.js +0 -1
- package/lib/esm/hooks/useSCSubscribedIncubatorsManager.d.ts +12 -3
- package/lib/esm/hooks/useSCSubscribedIncubatorsManager.js +38 -29
- package/lib/esm/hooks/useSCUserIsBlocked.d.ts +18 -0
- package/lib/esm/hooks/useSCUserIsBlocked.js +29 -0
- package/lib/esm/hooks/useSCWebPushMessaging.d.ts +12 -2
- package/lib/esm/hooks/useSCWebPushMessaging.js +185 -82
- package/lib/esm/hooks/useSCWebSocket.d.ts +1 -2
- package/lib/esm/hooks/useSCWebSocket.js +1 -2
- package/lib/esm/index.d.ts +4 -2
- package/lib/esm/index.js +4 -2
- package/lib/esm/themes/theme.d.ts +0 -1
- package/lib/esm/themes/theme.js +1 -75
- package/lib/esm/types/context.d.ts +96 -6
- package/lib/esm/types/context.js +0 -1
- package/lib/esm/types/index.d.ts +2 -3
- package/lib/esm/types/index.js +0 -1
- package/lib/esm/types/theme.d.ts +1 -2
- package/lib/esm/types/theme.js +0 -1
- package/lib/esm/utils/errors.d.ts +5 -6
- package/lib/esm/utils/errors.js +10 -8
- package/lib/esm/utils/hooks/index.d.ts +0 -1
- package/lib/esm/utils/hooks/index.js +0 -1
- package/lib/esm/utils/hooks/useEffectOnce.d.ts +0 -1
- package/lib/esm/utils/hooks/useEffectOnce.js +0 -1
- package/lib/esm/utils/hooks/useIsComponentMountedRef.d.ts +0 -1
- package/lib/esm/utils/hooks/useIsComponentMountedRef.js +0 -1
- package/lib/esm/utils/hooks/useIsomorphicLayoutEffect.d.ts +0 -1
- package/lib/esm/utils/hooks/useIsomorphicLayoutEffect.js +0 -1
- package/lib/esm/utils/hooks/useNoInitialEffect.d.ts +0 -1
- package/lib/esm/utils/hooks/useNoInitialEffect.js +0 -1
- package/lib/esm/utils/hooks/usePreviousValue.d.ts +0 -1
- package/lib/esm/utils/hooks/usePreviousValue.js +0 -1
- package/lib/esm/utils/locale.d.ts +0 -1
- package/lib/esm/utils/locale.js +0 -1
- package/lib/esm/utils/notification.d.ts +8 -0
- package/lib/esm/utils/notification.js +15 -0
- package/lib/esm/utils/pagination.d.ts +0 -1
- package/lib/esm/utils/pagination.js +0 -1
- package/lib/esm/utils/user.d.ts +0 -1
- package/lib/esm/utils/user.js +0 -1
- package/lib/esm/utils/validator.d.ts +49 -3
- package/lib/esm/utils/validator.js +129 -8
- package/lib/umd/251.js +2 -0
- package/lib/umd/251.js.LICENSE.txt +1 -0
- package/lib/umd/react-core.js +1 -1
- package/lib/umd/react-core.js.LICENSE.txt +1 -1
- package/package.json +25 -24
- package/lib/cjs/components/provider/SCAlertMessagesProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCAlertMessagesProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCContextProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCContextProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCLocaleProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCLocaleProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCNotificationProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCNotificationProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCPreferencesProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCPreferencesProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCRoutingProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCRoutingProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCThemeProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCThemeProvider/index.js.map +0 -1
- package/lib/cjs/components/provider/SCUserProvider/index.d.ts.map +0 -1
- package/lib/cjs/components/provider/SCUserProvider/index.js.map +0 -1
- package/lib/cjs/components/router/index.d.ts.map +0 -1
- package/lib/cjs/components/router/index.js.map +0 -1
- package/lib/cjs/constants/Actions.d.ts.map +0 -1
- package/lib/cjs/constants/Actions.js.map +0 -1
- package/lib/cjs/constants/Cache.d.ts.map +0 -1
- package/lib/cjs/constants/Cache.js.map +0 -1
- package/lib/cjs/constants/ContextProviders.d.ts.map +0 -1
- package/lib/cjs/constants/ContextProviders.js.map +0 -1
- package/lib/cjs/constants/Device.d.ts.map +0 -1
- package/lib/cjs/constants/Device.js.map +0 -1
- package/lib/cjs/constants/Errors.d.ts.map +0 -1
- package/lib/cjs/constants/Errors.js.map +0 -1
- package/lib/cjs/constants/Features.d.ts.map +0 -1
- package/lib/cjs/constants/Features.js.map +0 -1
- package/lib/cjs/constants/Locale.d.ts.map +0 -1
- package/lib/cjs/constants/Locale.js.map +0 -1
- package/lib/cjs/constants/Notification.d.ts.map +0 -1
- package/lib/cjs/constants/Notification.js.map +0 -1
- package/lib/cjs/constants/Notifications.d.ts.map +0 -1
- package/lib/cjs/constants/Notifications.js.map +0 -1
- package/lib/cjs/constants/Preferences.d.ts.map +0 -1
- package/lib/cjs/constants/Preferences.js.map +0 -1
- package/lib/cjs/constants/Routes.d.ts.map +0 -1
- package/lib/cjs/constants/Routes.js.map +0 -1
- package/lib/cjs/constants/Session.d.ts.map +0 -1
- package/lib/cjs/constants/Session.js.map +0 -1
- package/lib/cjs/constants/Theme.d.ts.map +0 -1
- package/lib/cjs/constants/Theme.js.map +0 -1
- package/lib/cjs/constants/WebSocket.d.ts.map +0 -1
- package/lib/cjs/constants/WebSocket.js.map +0 -1
- package/lib/cjs/hooks/useSCAuth.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCAuth.js.map +0 -1
- package/lib/cjs/hooks/useSCCachingManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCCachingManager.js.map +0 -1
- package/lib/cjs/hooks/useSCConnectionsManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCConnectionsManager.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchAddressingTagList.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchAddressingTagList.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchCategories.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchCategories.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchCategory.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchCategory.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchCommentObject.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchCommentObject.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchCommentObjects.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchCommentObjects.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchContributors.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchContributors.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchCustomAdv.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchCustomAdv.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchFeed.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchFeed.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchFeedObject.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchFeedObject.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchIncubator.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchIncubator.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchPrivateMessageSnippets.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchPrivateMessageSnippets.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchReactions.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchReactions.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchTag.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchTag.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchUser.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchUser.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchUserProviders.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchUserProviders.js.map +0 -1
- package/lib/cjs/hooks/useSCFetchVote.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFetchVote.js.map +0 -1
- package/lib/cjs/hooks/useSCFollowedCategoriesManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFollowedCategoriesManager.js.map +0 -1
- package/lib/cjs/hooks/useSCFollowedManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFollowedManager.js.map +0 -1
- package/lib/cjs/hooks/useSCFollowersManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCFollowersManager.js.map +0 -1
- package/lib/cjs/hooks/useSCMediaClick.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCMediaClick.js.map +0 -1
- package/lib/cjs/hooks/useSCSettingsManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCSettingsManager.js.map +0 -1
- package/lib/cjs/hooks/useSCSubscribedIncubatorsManager.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCSubscribedIncubatorsManager.js.map +0 -1
- package/lib/cjs/hooks/useSCWebPushMessaging.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCWebPushMessaging.js.map +0 -1
- package/lib/cjs/hooks/useSCWebSocket.d.ts.map +0 -1
- package/lib/cjs/hooks/useSCWebSocket.js.map +0 -1
- package/lib/cjs/index.d.ts.map +0 -1
- package/lib/cjs/index.js.map +0 -1
- package/lib/cjs/themes/theme.d.ts.map +0 -1
- package/lib/cjs/themes/theme.js.map +0 -1
- package/lib/cjs/types/context.d.ts.map +0 -1
- package/lib/cjs/types/context.js.map +0 -1
- package/lib/cjs/types/index.d.ts.map +0 -1
- package/lib/cjs/types/index.js.map +0 -1
- package/lib/cjs/types/theme.d.ts.map +0 -1
- package/lib/cjs/types/theme.js.map +0 -1
- package/lib/cjs/utils/errors.d.ts.map +0 -1
- package/lib/cjs/utils/errors.js.map +0 -1
- package/lib/cjs/utils/hooks/index.d.ts.map +0 -1
- package/lib/cjs/utils/hooks/index.js.map +0 -1
- package/lib/cjs/utils/hooks/useEffectOnce.d.ts.map +0 -1
- package/lib/cjs/utils/hooks/useEffectOnce.js.map +0 -1
- package/lib/cjs/utils/hooks/useIsComponentMountedRef.d.ts.map +0 -1
- package/lib/cjs/utils/hooks/useIsComponentMountedRef.js.map +0 -1
- package/lib/cjs/utils/hooks/useIsomorphicLayoutEffect.d.ts.map +0 -1
- package/lib/cjs/utils/hooks/useIsomorphicLayoutEffect.js.map +0 -1
- package/lib/cjs/utils/hooks/useNoInitialEffect.d.ts.map +0 -1
- package/lib/cjs/utils/hooks/useNoInitialEffect.js.map +0 -1
- package/lib/cjs/utils/hooks/usePreviousValue.d.ts.map +0 -1
- package/lib/cjs/utils/hooks/usePreviousValue.js.map +0 -1
- package/lib/cjs/utils/locale.d.ts.map +0 -1
- package/lib/cjs/utils/locale.js.map +0 -1
- package/lib/cjs/utils/pagination.d.ts.map +0 -1
- package/lib/cjs/utils/pagination.js.map +0 -1
- package/lib/cjs/utils/user.d.ts.map +0 -1
- package/lib/cjs/utils/user.js.map +0 -1
- package/lib/cjs/utils/validator.d.ts.map +0 -1
- package/lib/cjs/utils/validator.js.map +0 -1
- package/lib/esm/components/provider/SCAlertMessagesProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCAlertMessagesProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCContextProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCContextProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCLocaleProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCLocaleProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCNotificationProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCNotificationProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCPreferencesProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCPreferencesProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCRoutingProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCRoutingProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCThemeProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCThemeProvider/index.js.map +0 -1
- package/lib/esm/components/provider/SCUserProvider/index.d.ts.map +0 -1
- package/lib/esm/components/provider/SCUserProvider/index.js.map +0 -1
- package/lib/esm/components/router/index.d.ts.map +0 -1
- package/lib/esm/components/router/index.js.map +0 -1
- package/lib/esm/constants/Actions.d.ts.map +0 -1
- package/lib/esm/constants/Actions.js.map +0 -1
- package/lib/esm/constants/Cache.d.ts.map +0 -1
- package/lib/esm/constants/Cache.js.map +0 -1
- package/lib/esm/constants/ContextProviders.d.ts.map +0 -1
- package/lib/esm/constants/ContextProviders.js.map +0 -1
- package/lib/esm/constants/Device.d.ts.map +0 -1
- package/lib/esm/constants/Device.js.map +0 -1
- package/lib/esm/constants/Errors.d.ts.map +0 -1
- package/lib/esm/constants/Errors.js.map +0 -1
- package/lib/esm/constants/Features.d.ts.map +0 -1
- package/lib/esm/constants/Features.js.map +0 -1
- package/lib/esm/constants/Locale.d.ts.map +0 -1
- package/lib/esm/constants/Locale.js.map +0 -1
- package/lib/esm/constants/Notification.d.ts.map +0 -1
- package/lib/esm/constants/Notification.js.map +0 -1
- package/lib/esm/constants/Notifications.d.ts.map +0 -1
- package/lib/esm/constants/Notifications.js.map +0 -1
- package/lib/esm/constants/Preferences.d.ts.map +0 -1
- package/lib/esm/constants/Preferences.js.map +0 -1
- package/lib/esm/constants/Routes.d.ts.map +0 -1
- package/lib/esm/constants/Routes.js.map +0 -1
- package/lib/esm/constants/Session.d.ts.map +0 -1
- package/lib/esm/constants/Session.js.map +0 -1
- package/lib/esm/constants/Theme.d.ts.map +0 -1
- package/lib/esm/constants/Theme.js.map +0 -1
- package/lib/esm/constants/WebSocket.d.ts.map +0 -1
- package/lib/esm/constants/WebSocket.js.map +0 -1
- package/lib/esm/hooks/useSCAuth.d.ts.map +0 -1
- package/lib/esm/hooks/useSCAuth.js.map +0 -1
- package/lib/esm/hooks/useSCCachingManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCCachingManager.js.map +0 -1
- package/lib/esm/hooks/useSCConnectionsManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCConnectionsManager.js.map +0 -1
- package/lib/esm/hooks/useSCFetchAddressingTagList.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchAddressingTagList.js.map +0 -1
- package/lib/esm/hooks/useSCFetchCategories.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchCategories.js.map +0 -1
- package/lib/esm/hooks/useSCFetchCategory.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchCategory.js.map +0 -1
- package/lib/esm/hooks/useSCFetchCommentObject.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchCommentObject.js.map +0 -1
- package/lib/esm/hooks/useSCFetchCommentObjects.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchCommentObjects.js.map +0 -1
- package/lib/esm/hooks/useSCFetchContributors.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchContributors.js.map +0 -1
- package/lib/esm/hooks/useSCFetchCustomAdv.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchCustomAdv.js.map +0 -1
- package/lib/esm/hooks/useSCFetchFeed.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchFeed.js.map +0 -1
- package/lib/esm/hooks/useSCFetchFeedObject.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchFeedObject.js.map +0 -1
- package/lib/esm/hooks/useSCFetchIncubator.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchIncubator.js.map +0 -1
- package/lib/esm/hooks/useSCFetchPrivateMessageSnippets.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchPrivateMessageSnippets.js.map +0 -1
- package/lib/esm/hooks/useSCFetchReactions.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchReactions.js.map +0 -1
- package/lib/esm/hooks/useSCFetchTag.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchTag.js.map +0 -1
- package/lib/esm/hooks/useSCFetchUser.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchUser.js.map +0 -1
- package/lib/esm/hooks/useSCFetchUserProviders.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchUserProviders.js.map +0 -1
- package/lib/esm/hooks/useSCFetchVote.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFetchVote.js.map +0 -1
- package/lib/esm/hooks/useSCFollowedCategoriesManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFollowedCategoriesManager.js.map +0 -1
- package/lib/esm/hooks/useSCFollowedManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFollowedManager.js.map +0 -1
- package/lib/esm/hooks/useSCFollowersManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCFollowersManager.js.map +0 -1
- package/lib/esm/hooks/useSCMediaClick.d.ts.map +0 -1
- package/lib/esm/hooks/useSCMediaClick.js.map +0 -1
- package/lib/esm/hooks/useSCSettingsManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCSettingsManager.js.map +0 -1
- package/lib/esm/hooks/useSCSubscribedIncubatorsManager.d.ts.map +0 -1
- package/lib/esm/hooks/useSCSubscribedIncubatorsManager.js.map +0 -1
- package/lib/esm/hooks/useSCWebPushMessaging.d.ts.map +0 -1
- package/lib/esm/hooks/useSCWebPushMessaging.js.map +0 -1
- package/lib/esm/hooks/useSCWebSocket.d.ts.map +0 -1
- package/lib/esm/hooks/useSCWebSocket.js.map +0 -1
- package/lib/esm/index.d.ts.map +0 -1
- package/lib/esm/index.js.map +0 -1
- package/lib/esm/themes/theme.d.ts.map +0 -1
- package/lib/esm/themes/theme.js.map +0 -1
- package/lib/esm/types/context.d.ts.map +0 -1
- package/lib/esm/types/context.js.map +0 -1
- package/lib/esm/types/index.d.ts.map +0 -1
- package/lib/esm/types/index.js.map +0 -1
- package/lib/esm/types/theme.d.ts.map +0 -1
- package/lib/esm/types/theme.js.map +0 -1
- package/lib/esm/utils/errors.d.ts.map +0 -1
- package/lib/esm/utils/errors.js.map +0 -1
- package/lib/esm/utils/hooks/index.d.ts.map +0 -1
- package/lib/esm/utils/hooks/index.js.map +0 -1
- package/lib/esm/utils/hooks/useEffectOnce.d.ts.map +0 -1
- package/lib/esm/utils/hooks/useEffectOnce.js.map +0 -1
- package/lib/esm/utils/hooks/useIsComponentMountedRef.d.ts.map +0 -1
- package/lib/esm/utils/hooks/useIsComponentMountedRef.js.map +0 -1
- package/lib/esm/utils/hooks/useIsomorphicLayoutEffect.d.ts.map +0 -1
- package/lib/esm/utils/hooks/useIsomorphicLayoutEffect.js.map +0 -1
- package/lib/esm/utils/hooks/useNoInitialEffect.d.ts.map +0 -1
- package/lib/esm/utils/hooks/useNoInitialEffect.js.map +0 -1
- package/lib/esm/utils/hooks/usePreviousValue.d.ts.map +0 -1
- package/lib/esm/utils/hooks/usePreviousValue.js.map +0 -1
- package/lib/esm/utils/locale.d.ts.map +0 -1
- package/lib/esm/utils/locale.js.map +0 -1
- package/lib/esm/utils/pagination.d.ts.map +0 -1
- package/lib/esm/utils/pagination.js.map +0 -1
- package/lib/esm/utils/user.d.ts.map +0 -1
- package/lib/esm/utils/user.js.map +0 -1
- package/lib/esm/utils/validator.d.ts.map +0 -1
- package/lib/esm/utils/validator.js.map +0 -1
|
@@ -9,8 +9,6 @@ import useSCFetchReactions from './useSCFetchReactions';
|
|
|
9
9
|
import { useIntl } from 'react-intl';
|
|
10
10
|
import { useSCContext } from '../components/provider/SCContextProvider';
|
|
11
11
|
import { useSCUser } from '../components/provider/SCUserProvider';
|
|
12
|
-
import { UserUtils } from '../index';
|
|
13
|
-
import useDeepCompareEffect from 'use-deep-compare-effect';
|
|
14
12
|
/**
|
|
15
13
|
:::info
|
|
16
14
|
This custom hook is used to fetch a contribution vote.
|
|
@@ -83,65 +81,32 @@ export default function useSCFetchVote({ id, contribution = null, contributionTy
|
|
|
83
81
|
});
|
|
84
82
|
}
|
|
85
83
|
}, [id, contributionType, scUserContext.user]);
|
|
86
|
-
|
|
84
|
+
useEffect(() => {
|
|
87
85
|
if (contribution) {
|
|
88
86
|
setObj(contribution);
|
|
89
87
|
}
|
|
90
88
|
}, [contribution]);
|
|
91
89
|
// HANDLERS
|
|
92
90
|
const handleVote = (reaction) => {
|
|
93
|
-
if (
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
};
|
|
113
|
-
if (reaction && ((_a = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _a === void 0 ? void 0 : _a.id) !== reaction.id) {
|
|
114
|
-
// AGGUINTA / MODIFICA
|
|
115
|
-
const add = !(obj === null || obj === void 0 ? void 0 : obj.reaction);
|
|
116
|
-
const addCount = obj.reactions_count.findIndex((count) => count.reaction.id === reaction.id) === -1;
|
|
117
|
-
_obj = {
|
|
118
|
-
voted: add ? true : obj.voted,
|
|
119
|
-
vote_count: add ? obj.vote_count + 1 : obj.vote_count,
|
|
120
|
-
reaction,
|
|
121
|
-
reactions_count: [
|
|
122
|
-
...obj.reactions_count.map((count) => {
|
|
123
|
-
var _a, _b;
|
|
124
|
-
if (count.reaction.id === ((_a = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _a === void 0 ? void 0 : _a.id) && count.count - 1 === 0) {
|
|
125
|
-
return null;
|
|
126
|
-
}
|
|
127
|
-
else if (count.reaction.id === ((_b = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _b === void 0 ? void 0 : _b.id) && count.count - 1 > 0) {
|
|
128
|
-
return { count: count.count - 1, reaction: count.reaction };
|
|
129
|
-
}
|
|
130
|
-
else if (count.reaction.id === reaction.id) {
|
|
131
|
-
return { count: count.count + 1, reaction: count.reaction };
|
|
132
|
-
}
|
|
133
|
-
return count;
|
|
134
|
-
}),
|
|
135
|
-
addCount ? { count: 1, reaction } : null,
|
|
136
|
-
].filter((count) => Boolean(count)),
|
|
137
|
-
};
|
|
138
|
-
}
|
|
139
|
-
else if (reaction && (obj === null || obj === void 0 ? void 0 : obj.reaction) && ((_b = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _b === void 0 ? void 0 : _b.id) === reaction.id) {
|
|
140
|
-
// RIMOZIONE
|
|
141
|
-
_obj = Object.assign({}, _obj, {
|
|
142
|
-
reaction: null,
|
|
143
|
-
reactions_count: obj.reactions_count
|
|
144
|
-
.map((count) => {
|
|
91
|
+
if (scUserContext.user && obj && !isVoting) {
|
|
92
|
+
setIsVoting(true);
|
|
93
|
+
performVote(reaction)
|
|
94
|
+
.then(() => {
|
|
95
|
+
var _a, _b;
|
|
96
|
+
let _obj = {
|
|
97
|
+
voted: !obj.voted,
|
|
98
|
+
vote_count: obj.voted ? obj.vote_count - 1 : obj.vote_count + 1,
|
|
99
|
+
};
|
|
100
|
+
if (reaction && ((_a = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _a === void 0 ? void 0 : _a.id) !== reaction.id) {
|
|
101
|
+
// AGGUINTA / MODIFICA
|
|
102
|
+
const add = !(obj === null || obj === void 0 ? void 0 : obj.reaction);
|
|
103
|
+
const addCount = obj.reactions_count.findIndex((count) => count.reaction.id === reaction.id) === -1;
|
|
104
|
+
_obj = {
|
|
105
|
+
voted: add ? true : obj.voted,
|
|
106
|
+
vote_count: add ? obj.vote_count + 1 : obj.vote_count,
|
|
107
|
+
reaction,
|
|
108
|
+
reactions_count: [
|
|
109
|
+
...obj.reactions_count.map((count) => {
|
|
145
110
|
var _a, _b;
|
|
146
111
|
if (count.reaction.id === ((_a = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _a === void 0 ? void 0 : _a.id) && count.count - 1 === 0) {
|
|
147
112
|
return null;
|
|
@@ -149,20 +114,43 @@ export default function useSCFetchVote({ id, contribution = null, contributionTy
|
|
|
149
114
|
else if (count.reaction.id === ((_b = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _b === void 0 ? void 0 : _b.id) && count.count - 1 > 0) {
|
|
150
115
|
return { count: count.count - 1, reaction: count.reaction };
|
|
151
116
|
}
|
|
117
|
+
else if (count.reaction.id === reaction.id) {
|
|
118
|
+
return { count: count.count + 1, reaction: count.reaction };
|
|
119
|
+
}
|
|
152
120
|
return count;
|
|
153
|
-
})
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
121
|
+
}),
|
|
122
|
+
addCount ? { count: 1, reaction } : null,
|
|
123
|
+
].filter((count) => Boolean(count)),
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
else if (reaction && (obj === null || obj === void 0 ? void 0 : obj.reaction) && ((_b = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _b === void 0 ? void 0 : _b.id) === reaction.id) {
|
|
127
|
+
// RIMOZIONE
|
|
128
|
+
_obj = Object.assign({}, _obj, {
|
|
129
|
+
reaction: null,
|
|
130
|
+
reactions_count: obj.reactions_count
|
|
131
|
+
.map((count) => {
|
|
132
|
+
var _a, _b;
|
|
133
|
+
if (count.reaction.id === ((_a = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _a === void 0 ? void 0 : _a.id) && count.count - 1 === 0) {
|
|
134
|
+
return null;
|
|
135
|
+
}
|
|
136
|
+
else if (count.reaction.id === ((_b = obj === null || obj === void 0 ? void 0 : obj.reaction) === null || _b === void 0 ? void 0 : _b.id) && count.count - 1 > 0) {
|
|
137
|
+
return { count: count.count - 1, reaction: count.reaction };
|
|
138
|
+
}
|
|
139
|
+
return count;
|
|
140
|
+
})
|
|
141
|
+
.filter((count) => Boolean(count)),
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
const newObj = Object.assign({}, obj, _obj);
|
|
145
|
+
setObj(newObj);
|
|
146
|
+
setIsVoting(false);
|
|
147
|
+
onVote && onVote(newObj, null);
|
|
148
|
+
})
|
|
149
|
+
.catch((error) => {
|
|
150
|
+
Logger.error(SCOPE_SC_CORE, error);
|
|
151
|
+
setIsVoting(false);
|
|
152
|
+
onVote && onVote(obj, error);
|
|
153
|
+
});
|
|
166
154
|
}
|
|
167
155
|
};
|
|
168
156
|
const handleFetchVoteList = ({ reaction = null, reset = false }) => {
|
|
@@ -200,4 +188,3 @@ export default function useSCFetchVote({ id, contribution = null, contributionTy
|
|
|
200
188
|
voteList,
|
|
201
189
|
isLoadingVoteList, voteListHasNext: Boolean(voteListNext) });
|
|
202
190
|
}
|
|
203
|
-
//# sourceMappingURL=useSCFetchVote.js.map
|
|
@@ -15,8 +15,8 @@ import { SCCategoryType, SCUserType } from '@selfcommunity/types';
|
|
|
15
15
|
*/
|
|
16
16
|
export default function useSCFollowedCategoriesManager(user?: SCUserType, updateUser?: (info: any) => void): {
|
|
17
17
|
categories: any[];
|
|
18
|
-
loading:
|
|
19
|
-
isLoading: (
|
|
18
|
+
loading: any[];
|
|
19
|
+
isLoading: (v: number | {
|
|
20
20
|
id: number;
|
|
21
21
|
}) => boolean;
|
|
22
22
|
follow?: undefined;
|
|
@@ -25,8 +25,8 @@ export default function useSCFollowedCategoriesManager(user?: SCUserType, update
|
|
|
25
25
|
emptyCache?: undefined;
|
|
26
26
|
} | {
|
|
27
27
|
categories: any[];
|
|
28
|
-
loading:
|
|
29
|
-
isLoading: (
|
|
28
|
+
loading: any[];
|
|
29
|
+
isLoading: (v: number | {
|
|
30
30
|
id: number;
|
|
31
31
|
}) => boolean;
|
|
32
32
|
follow: (category: SCCategoryType) => Promise<any>;
|
|
@@ -34,4 +34,3 @@ export default function useSCFollowedCategoriesManager(user?: SCUserType, update
|
|
|
34
34
|
refresh: () => void;
|
|
35
35
|
emptyCache: () => void;
|
|
36
36
|
};
|
|
37
|
-
//# sourceMappingURL=useSCFollowedCategoriesManager.d.ts.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { useMemo } from
|
|
1
|
+
import { useEffect, useMemo } from "react";
|
|
2
2
|
import { http, Endpoints } from '@selfcommunity/api-services';
|
|
3
3
|
import useSCCachingManager from './useSCCachingManager';
|
|
4
4
|
import { SCOPE_SC_CORE } from '../constants/Errors';
|
|
@@ -18,7 +18,8 @@ import { Logger } from '@selfcommunity/utils';
|
|
|
18
18
|
:::
|
|
19
19
|
*/
|
|
20
20
|
export default function useSCFollowedCategoriesManager(user, updateUser) {
|
|
21
|
-
const { cache, updateCache, emptyCache, data, setData, loading, setLoading, isLoading } = useSCCachingManager();
|
|
21
|
+
const { cache, updateCache, emptyCache, data, setData, loading, setLoading, setUnLoading, isLoading } = useSCCachingManager();
|
|
22
|
+
const authUserId = user ? user.id : null;
|
|
22
23
|
/**
|
|
23
24
|
* Memoized refresh all categories
|
|
24
25
|
* It makes a single request to the server and retrieves
|
|
@@ -54,7 +55,7 @@ export default function useSCFollowedCategoriesManager(user, updateUser) {
|
|
|
54
55
|
* Toggle action
|
|
55
56
|
*/
|
|
56
57
|
const follow = useMemo(() => (category) => {
|
|
57
|
-
setLoading(
|
|
58
|
+
setLoading(category.id);
|
|
58
59
|
return http
|
|
59
60
|
.request({
|
|
60
61
|
url: Endpoints.FollowCategory.url({ id: category.id }),
|
|
@@ -67,7 +68,7 @@ export default function useSCFollowedCategoriesManager(user, updateUser) {
|
|
|
67
68
|
updateCache([category.id]);
|
|
68
69
|
const isFollowed = data.includes(category.id);
|
|
69
70
|
setData((prev) => (isFollowed ? prev.filter((id) => id !== category.id) : [...[category.id], ...prev]));
|
|
70
|
-
|
|
71
|
+
setUnLoading(category.id);
|
|
71
72
|
updateUser({ categories_counter: isFollowed ? data.length - 1 : data.length + 1 });
|
|
72
73
|
return Promise.resolve(res.data);
|
|
73
74
|
});
|
|
@@ -79,7 +80,7 @@ export default function useSCFollowedCategoriesManager(user, updateUser) {
|
|
|
79
80
|
* @param category
|
|
80
81
|
*/
|
|
81
82
|
const checkIsCategoryFollowed = (category) => {
|
|
82
|
-
setLoading(
|
|
83
|
+
setLoading(category.id);
|
|
83
84
|
http
|
|
84
85
|
.request({
|
|
85
86
|
url: Endpoints.CheckCategoryIsFollowed.url({ id: category.id }),
|
|
@@ -91,12 +92,12 @@ export default function useSCFollowedCategoriesManager(user, updateUser) {
|
|
|
91
92
|
}
|
|
92
93
|
updateCache([category.id]);
|
|
93
94
|
setData((prev) => (res.data.is_followed ? [...[category.id], ...prev] : prev.filter((id) => id !== category.id)));
|
|
94
|
-
|
|
95
|
+
setUnLoading(category.id);
|
|
95
96
|
return Promise.resolve(res.data);
|
|
96
97
|
});
|
|
97
98
|
};
|
|
98
99
|
/**
|
|
99
|
-
* Bypass remote check if the
|
|
100
|
+
* Bypass remote check if the category is followed
|
|
100
101
|
*/
|
|
101
102
|
const getFollowStatus = useMemo(() => (category) => {
|
|
102
103
|
const isFollowed = category.followed || false;
|
|
@@ -110,20 +111,30 @@ export default function useSCFollowedCategoriesManager(user, updateUser) {
|
|
|
110
111
|
* otherwise, check if user follow the category
|
|
111
112
|
*/
|
|
112
113
|
const isFollowed = useMemo(() => (category) => {
|
|
114
|
+
// Cache is valid also for anonymous user
|
|
113
115
|
if (cache.includes(category.id)) {
|
|
114
116
|
return Boolean(data.includes(category.id));
|
|
115
117
|
}
|
|
116
|
-
if (
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
118
|
+
if (authUserId) {
|
|
119
|
+
if ('followed' in category) {
|
|
120
|
+
return getFollowStatus(category);
|
|
121
|
+
}
|
|
122
|
+
if (!isLoading(category)) {
|
|
123
|
+
checkIsCategoryFollowed(category);
|
|
124
|
+
}
|
|
121
125
|
}
|
|
122
126
|
return false;
|
|
123
|
-
}, [data, loading, cache]);
|
|
127
|
+
}, [data, loading, cache, authUserId]);
|
|
128
|
+
/**
|
|
129
|
+
* Empty cache on logout
|
|
130
|
+
*/
|
|
131
|
+
useEffect(() => {
|
|
132
|
+
if (!authUserId) {
|
|
133
|
+
emptyCache();
|
|
134
|
+
}
|
|
135
|
+
}, [authUserId]);
|
|
124
136
|
if (!user) {
|
|
125
137
|
return { categories: data, loading, isLoading };
|
|
126
138
|
}
|
|
127
139
|
return { categories: data, loading, isLoading, follow, isFollowed, refresh, emptyCache };
|
|
128
140
|
}
|
|
129
|
-
//# sourceMappingURL=useSCFollowedCategoriesManager.js.map
|
|
@@ -15,8 +15,8 @@ import { SCUserType } from '@selfcommunity/types';
|
|
|
15
15
|
*/
|
|
16
16
|
export default function useSCFollowedManager(user?: SCUserType): {
|
|
17
17
|
followed: any[];
|
|
18
|
-
loading:
|
|
19
|
-
isLoading: (
|
|
18
|
+
loading: any[];
|
|
19
|
+
isLoading: (v: number | {
|
|
20
20
|
id: number;
|
|
21
21
|
}) => boolean;
|
|
22
22
|
follow?: undefined;
|
|
@@ -25,8 +25,8 @@ export default function useSCFollowedManager(user?: SCUserType): {
|
|
|
25
25
|
emptyCache?: undefined;
|
|
26
26
|
} | {
|
|
27
27
|
followed: any[];
|
|
28
|
-
loading:
|
|
29
|
-
isLoading: (
|
|
28
|
+
loading: any[];
|
|
29
|
+
isLoading: (v: number | {
|
|
30
30
|
id: number;
|
|
31
31
|
}) => boolean;
|
|
32
32
|
follow: (user: SCUserType) => Promise<any>;
|
|
@@ -34,4 +34,3 @@ export default function useSCFollowedManager(user?: SCUserType): {
|
|
|
34
34
|
refresh: () => void;
|
|
35
35
|
emptyCache: () => void;
|
|
36
36
|
};
|
|
37
|
-
//# sourceMappingURL=useSCFollowedManager.d.ts.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { useMemo } from 'react';
|
|
1
|
+
import { useEffect, useMemo } from 'react';
|
|
2
2
|
import { http, Endpoints } from '@selfcommunity/api-services';
|
|
3
3
|
import { Logger } from '@selfcommunity/utils';
|
|
4
4
|
import { SCOPE_SC_CORE } from '../constants/Errors';
|
|
@@ -26,8 +26,9 @@ const STATUS_FOLLOWED = 'followed';
|
|
|
26
26
|
:::
|
|
27
27
|
*/
|
|
28
28
|
export default function useSCFollowedManager(user) {
|
|
29
|
-
const { cache, updateCache, emptyCache, data, setData, loading, setLoading, isLoading } = useSCCachingManager();
|
|
29
|
+
const { cache, updateCache, emptyCache, data, setData, loading, setLoading, setUnLoading, isLoading } = useSCCachingManager();
|
|
30
30
|
const scPreferencesContext = useSCPreferences();
|
|
31
|
+
const authUserId = user ? user.id : null;
|
|
31
32
|
const followEnabled = CONFIGURATIONS_FOLLOW_ENABLED in scPreferencesContext.preferences && scPreferencesContext.preferences[CONFIGURATIONS_FOLLOW_ENABLED].value;
|
|
32
33
|
/**
|
|
33
34
|
* Memoized refresh all followed
|
|
@@ -51,8 +52,8 @@ export default function useSCFollowedManager(user) {
|
|
|
51
52
|
}
|
|
52
53
|
updateCache(Object.keys(res.data.connection_statuses).map((id) => parseInt(id)));
|
|
53
54
|
setData(Object.entries(res.data.connection_statuses)
|
|
54
|
-
.filter(([
|
|
55
|
-
.map(([k
|
|
55
|
+
.filter(([, v]) => v === STATUS_FOLLOWED)
|
|
56
|
+
.map(([k]) => parseInt(k)));
|
|
56
57
|
return Promise.resolve(res.data);
|
|
57
58
|
})
|
|
58
59
|
.catch((e) => {
|
|
@@ -66,7 +67,7 @@ export default function useSCFollowedManager(user) {
|
|
|
66
67
|
* Toggle action
|
|
67
68
|
*/
|
|
68
69
|
const follow = useMemo(() => (user) => {
|
|
69
|
-
setLoading(
|
|
70
|
+
setLoading(user.id);
|
|
70
71
|
return http
|
|
71
72
|
.request({
|
|
72
73
|
url: Endpoints.FollowUser.url({ id: user.id }),
|
|
@@ -79,8 +80,12 @@ export default function useSCFollowedManager(user) {
|
|
|
79
80
|
updateCache([user.id]);
|
|
80
81
|
const isFollowed = data.includes(user.id);
|
|
81
82
|
setData((prev) => (isFollowed ? prev.filter((id) => id !== user.id) : [...[user.id], ...prev]));
|
|
82
|
-
|
|
83
|
-
return Promise.resolve(res
|
|
83
|
+
setUnLoading(user.id);
|
|
84
|
+
return Promise.resolve(res);
|
|
85
|
+
})
|
|
86
|
+
.catch((e) => {
|
|
87
|
+
setUnLoading(user.id);
|
|
88
|
+
return Promise.reject(e);
|
|
84
89
|
});
|
|
85
90
|
}, [data, loading, cache]);
|
|
86
91
|
/**
|
|
@@ -90,7 +95,7 @@ export default function useSCFollowedManager(user) {
|
|
|
90
95
|
* @param user
|
|
91
96
|
*/
|
|
92
97
|
const checkIsUserFollowed = (user) => {
|
|
93
|
-
setLoading(
|
|
98
|
+
setLoading(user.id);
|
|
94
99
|
http
|
|
95
100
|
.request({
|
|
96
101
|
url: Endpoints.CheckUserFollowed.url({ id: user.id }),
|
|
@@ -102,7 +107,7 @@ export default function useSCFollowedManager(user) {
|
|
|
102
107
|
}
|
|
103
108
|
updateCache([user.id]);
|
|
104
109
|
setData((prev) => (res.data.is_followed ? [...prev, ...[user.id]] : prev.filter((id) => id !== user.id)));
|
|
105
|
-
|
|
110
|
+
setUnLoading(user.id);
|
|
106
111
|
return Promise.resolve(res.data);
|
|
107
112
|
});
|
|
108
113
|
};
|
|
@@ -120,21 +125,32 @@ export default function useSCFollowedManager(user) {
|
|
|
120
125
|
* If user is already in cache -> check if the user is in followed,
|
|
121
126
|
* otherwise, check if auth user follow the user
|
|
122
127
|
*/
|
|
123
|
-
const isFollowed = useMemo(() =>
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
128
|
+
const isFollowed = useMemo(() => {
|
|
129
|
+
return (user) => {
|
|
130
|
+
if (cache.includes(user.id)) {
|
|
131
|
+
return Boolean(data.includes(user.id));
|
|
132
|
+
}
|
|
133
|
+
if (authUserId) {
|
|
134
|
+
if ('connection_status' in user) {
|
|
135
|
+
return getConnectionStatus(user);
|
|
136
|
+
}
|
|
137
|
+
if (!isLoading(user)) {
|
|
138
|
+
checkIsUserFollowed(user);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
return false;
|
|
142
|
+
};
|
|
143
|
+
}, [data, loading, cache, authUserId]);
|
|
144
|
+
/**
|
|
145
|
+
* Empty cache on logout
|
|
146
|
+
*/
|
|
147
|
+
useEffect(() => {
|
|
148
|
+
if (!authUserId) {
|
|
149
|
+
emptyCache();
|
|
132
150
|
}
|
|
133
|
-
|
|
134
|
-
}, [data, loading, cache]);
|
|
151
|
+
}, [authUserId]);
|
|
135
152
|
if (!followEnabled || !user) {
|
|
136
153
|
return { followed: data, loading, isLoading };
|
|
137
154
|
}
|
|
138
155
|
return { followed: data, loading, isLoading, follow, isFollowed, refresh, emptyCache };
|
|
139
156
|
}
|
|
140
|
-
//# sourceMappingURL=useSCFollowedManager.js.map
|
|
@@ -15,19 +15,18 @@ import { SCUserType } from '@selfcommunity/types';
|
|
|
15
15
|
*/
|
|
16
16
|
export default function useSCFollowersManager(user?: SCUserType): {
|
|
17
17
|
followers: any[];
|
|
18
|
-
loading:
|
|
19
|
-
isLoading: (
|
|
18
|
+
loading: any[];
|
|
19
|
+
isLoading: (v: number | {
|
|
20
20
|
id: number;
|
|
21
21
|
}) => boolean;
|
|
22
22
|
isFollower?: undefined;
|
|
23
23
|
emptyCache?: undefined;
|
|
24
24
|
} | {
|
|
25
25
|
followers: any[];
|
|
26
|
-
loading:
|
|
27
|
-
isLoading: (
|
|
26
|
+
loading: any[];
|
|
27
|
+
isLoading: (v: number | {
|
|
28
28
|
id: number;
|
|
29
29
|
}) => boolean;
|
|
30
30
|
isFollower: (user: SCUserType) => boolean;
|
|
31
31
|
emptyCache: () => void;
|
|
32
32
|
};
|
|
33
|
-
//# sourceMappingURL=useSCFollowersManager.d.ts.map
|
|
@@ -21,7 +21,7 @@ import { SCNotificationMapping } from '../constants/Notification';
|
|
|
21
21
|
:::
|
|
22
22
|
*/
|
|
23
23
|
export default function useSCFollowersManager(user) {
|
|
24
|
-
const { cache, updateCache, emptyCache, data, setData, loading, setLoading, isLoading } = useSCCachingManager();
|
|
24
|
+
const { cache, updateCache, emptyCache, data, setData, loading, setLoading, setUnLoading, isLoading } = useSCCachingManager();
|
|
25
25
|
const scPreferencesContext = useSCPreferences();
|
|
26
26
|
const followEnabled = CONFIGURATIONS_FOLLOW_ENABLED in scPreferencesContext.preferences && scPreferencesContext.preferences[CONFIGURATIONS_FOLLOW_ENABLED].value;
|
|
27
27
|
const notificationFollowSubscription = useRef(null);
|
|
@@ -62,7 +62,7 @@ export default function useSCFollowersManager(user) {
|
|
|
62
62
|
* @param user
|
|
63
63
|
*/
|
|
64
64
|
const checkIsUserFollowers = (user) => {
|
|
65
|
-
setLoading(
|
|
65
|
+
setLoading(user.id);
|
|
66
66
|
http
|
|
67
67
|
.request({
|
|
68
68
|
url: Endpoints.CheckUserFollower.url({ id: user.id }),
|
|
@@ -74,7 +74,7 @@ export default function useSCFollowersManager(user) {
|
|
|
74
74
|
}
|
|
75
75
|
updateCache([user.id]);
|
|
76
76
|
setData((prev) => (res.data.is_follower ? [...prev, ...[user.id]] : prev.filter((id) => id !== user.id)));
|
|
77
|
-
|
|
77
|
+
setUnLoading(user.id);
|
|
78
78
|
return Promise.resolve(res.data);
|
|
79
79
|
});
|
|
80
80
|
};
|
|
@@ -87,7 +87,7 @@ export default function useSCFollowersManager(user) {
|
|
|
87
87
|
if (cache.includes(user.id)) {
|
|
88
88
|
return Boolean(data.includes(user.id));
|
|
89
89
|
}
|
|
90
|
-
if (!
|
|
90
|
+
if (!isLoading(user)) {
|
|
91
91
|
checkIsUserFollowers(user);
|
|
92
92
|
}
|
|
93
93
|
return false;
|
|
@@ -97,4 +97,3 @@ export default function useSCFollowersManager(user) {
|
|
|
97
97
|
}
|
|
98
98
|
return { followers: data, loading, isLoading, isFollower, emptyCache };
|
|
99
99
|
}
|
|
100
|
-
//# sourceMappingURL=useSCFollowersManager.js.map
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { SCDeviceType } from '@selfcommunity/types';
|
|
3
|
+
/**
|
|
4
|
+
:::info
|
|
5
|
+
This custom hook is used to manage native push notification:
|
|
6
|
+
- register device (Android/iOS)
|
|
7
|
+
- unregister device (Android/iOS)
|
|
8
|
+
!important: the device is registered only if exist in the global window
|
|
9
|
+
object (or as keys in the localstorage) the follow:
|
|
10
|
+
- _platform: <android|iOS>
|
|
11
|
+
- _notification_service: <gcm:fcm:apns>
|
|
12
|
+
- _registration_id: <registration_id>
|
|
13
|
+
- _device_id: <device_id>
|
|
14
|
+
:::
|
|
15
|
+
*/
|
|
16
|
+
export default function useSCMobileNativePushMessaging(): {
|
|
17
|
+
mnpmInstance: SCDeviceType;
|
|
18
|
+
setMnpmInstance: import("react").Dispatch<import("react").SetStateAction<SCDeviceType>>;
|
|
19
|
+
};
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { useSCContext } from '../components/provider/SCContextProvider';
|
|
3
|
+
import { useSCUser } from '../components/provider/SCUserProvider';
|
|
4
|
+
import { LocalStorageDB, Logger } from '@selfcommunity/utils';
|
|
5
|
+
import { SCOPE_SC_CORE } from '../constants/Errors';
|
|
6
|
+
import { http, Endpoints } from '@selfcommunity/api-services';
|
|
7
|
+
import { PLATFORM, ANDROID_PUSH_NOTIFICATION_FCM_DEVICE_TYPE, ANDROID_PUSH_NOTIFICATION_GCM_DEVICE_TYPE, IOS_PUSH_NOTIFICATION_IOS_DEVICE_TYPE, PLATFORM_KEY, REGISTRATION_ID_KEY, NOTIFICATION_SERVICE_KEY, DEVICE_ID_KEY, NOTIFICATIONS_SERVICES, PLATFORMS, } from '../constants/Device';
|
|
8
|
+
import { isMobileNativeNotificationEnabled } from '../utils/notification';
|
|
9
|
+
/**
|
|
10
|
+
:::info
|
|
11
|
+
This custom hook is used to manage native push notification:
|
|
12
|
+
- register device (Android/iOS)
|
|
13
|
+
- unregister device (Android/iOS)
|
|
14
|
+
!important: the device is registered only if exist in the global window
|
|
15
|
+
object (or as keys in the localstorage) the follow:
|
|
16
|
+
- _platform: <android|iOS>
|
|
17
|
+
- _notification_service: <gcm:fcm:apns>
|
|
18
|
+
- _registration_id: <registration_id>
|
|
19
|
+
- _device_id: <device_id>
|
|
20
|
+
:::
|
|
21
|
+
*/
|
|
22
|
+
export default function useSCMobileNativePushMessaging() {
|
|
23
|
+
const scContext = useSCContext();
|
|
24
|
+
const scUserContext = useSCUser();
|
|
25
|
+
const [mnpmInstance, setMnpmInstance] = useState(null);
|
|
26
|
+
const [isLoading, setLoading] = useState(false);
|
|
27
|
+
/**
|
|
28
|
+
* Validate notification service
|
|
29
|
+
* @param data
|
|
30
|
+
*/
|
|
31
|
+
const isValid = (data) => {
|
|
32
|
+
return (data &&
|
|
33
|
+
data.registration_id &&
|
|
34
|
+
((data.platform === PLATFORM.ANDROID &&
|
|
35
|
+
(data.notification_service === ANDROID_PUSH_NOTIFICATION_GCM_DEVICE_TYPE ||
|
|
36
|
+
data.notification_service === ANDROID_PUSH_NOTIFICATION_FCM_DEVICE_TYPE)) ||
|
|
37
|
+
(data.platform === PLATFORM.IOS &&
|
|
38
|
+
(data.notification_service === IOS_PUSH_NOTIFICATION_IOS_DEVICE_TYPE ||
|
|
39
|
+
data.notification_service === ANDROID_PUSH_NOTIFICATION_FCM_DEVICE_TYPE))));
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* Perform device registration
|
|
43
|
+
* @param data
|
|
44
|
+
* @param remove
|
|
45
|
+
*/
|
|
46
|
+
const performUpdateDevice = (data, remove = false) => {
|
|
47
|
+
const url = remove
|
|
48
|
+
? Endpoints.DeleteDevice.url({ type: data.notification_service, id: data.registration_id })
|
|
49
|
+
: Endpoints.NewDevice.url({ type: data.notification_service });
|
|
50
|
+
const method = remove ? Endpoints.DeleteDevice.method : Endpoints.NewDevice.method;
|
|
51
|
+
setLoading(true);
|
|
52
|
+
return http
|
|
53
|
+
.request(Object.assign({ url,
|
|
54
|
+
method }, (remove
|
|
55
|
+
? {}
|
|
56
|
+
: {
|
|
57
|
+
data: Object.assign({ registration_id: data.registration_id, cloud_message_type: data.notification_service.toUpperCase(), name: `${data.platform} device` }, (data.device_id ? { device_id: data.device_id } : {})),
|
|
58
|
+
})))
|
|
59
|
+
.then((res) => {
|
|
60
|
+
if (res.status >= 300) {
|
|
61
|
+
return Promise.reject(res);
|
|
62
|
+
}
|
|
63
|
+
setLoading(false);
|
|
64
|
+
return Promise.resolve(res.data);
|
|
65
|
+
})
|
|
66
|
+
.catch((e) => {
|
|
67
|
+
setLoading(false);
|
|
68
|
+
return Promise.reject(e);
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
/**
|
|
72
|
+
* Collect data
|
|
73
|
+
*/
|
|
74
|
+
const getDataInstance = () => {
|
|
75
|
+
if (window &&
|
|
76
|
+
window[PLATFORM_KEY] &&
|
|
77
|
+
PLATFORMS.includes(window[PLATFORM_KEY]) &&
|
|
78
|
+
window[REGISTRATION_ID_KEY] &&
|
|
79
|
+
window[NOTIFICATION_SERVICE_KEY] &&
|
|
80
|
+
NOTIFICATIONS_SERVICES.includes(window[NOTIFICATION_SERVICE_KEY])) {
|
|
81
|
+
return Object.assign({ platform: window[PLATFORM_KEY], registration_id: window[REGISTRATION_ID_KEY], notification_service: window[NOTIFICATION_SERVICE_KEY] }, (window[DEVICE_ID_KEY] ? { device_id: window[DEVICE_ID_KEY] } : {}));
|
|
82
|
+
}
|
|
83
|
+
else if (LocalStorageDB.checkifSupport() &&
|
|
84
|
+
LocalStorageDB.get(PLATFORM_KEY) &&
|
|
85
|
+
PLATFORMS.includes(LocalStorageDB.get(PLATFORM_KEY)) &&
|
|
86
|
+
LocalStorageDB.get(REGISTRATION_ID_KEY) &&
|
|
87
|
+
LocalStorageDB.get(NOTIFICATION_SERVICE_KEY) &&
|
|
88
|
+
NOTIFICATIONS_SERVICES.includes(LocalStorageDB.get(NOTIFICATION_SERVICE_KEY))) {
|
|
89
|
+
return Object.assign({ platform: LocalStorageDB.get(PLATFORM_KEY), registration_id: LocalStorageDB.get(REGISTRATION_ID_KEY), notification_service: LocalStorageDB.get(NOTIFICATION_SERVICE_KEY) }, (window[DEVICE_ID_KEY] ? { device_id: window[DEVICE_ID_KEY] } : {}));
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
return null;
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
/**
|
|
96
|
+
* Unsubscribe device
|
|
97
|
+
*/
|
|
98
|
+
const unsubscribeDevice = () => {
|
|
99
|
+
if (mnpmInstance && !isLoading) {
|
|
100
|
+
Logger.info(SCOPE_SC_CORE, 'Mobile native notification is disabled. Unregister the device.');
|
|
101
|
+
performUpdateDevice(mnpmInstance, true)
|
|
102
|
+
.then((res) => {
|
|
103
|
+
setMnpmInstance(null);
|
|
104
|
+
Logger.info(SCOPE_SC_CORE, 'Device unregistration successful. Your device will not be able to receive mobile push notifications.');
|
|
105
|
+
})
|
|
106
|
+
.catch(() => {
|
|
107
|
+
setMnpmInstance(null);
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
/**
|
|
112
|
+
* Check if there is a currently active session and a
|
|
113
|
+
* instance when the provider is mounted for the first time.
|
|
114
|
+
*/
|
|
115
|
+
useEffect(() => {
|
|
116
|
+
if (scUserContext.user && isMobileNativeNotificationEnabled() && !scContext.settings.notifications.mobileNativePushMessaging.disable) {
|
|
117
|
+
const _data = getDataInstance();
|
|
118
|
+
if (isValid(_data)) {
|
|
119
|
+
if ((!mnpmInstance || (mnpmInstance && mnpmInstance.registration_id !== _data.registration_id)) && !isLoading) {
|
|
120
|
+
Logger.info(SCOPE_SC_CORE, 'Mobile native notification is enabled. Checking and validate data...');
|
|
121
|
+
// Register the device only if app-platform and app-registrationId and app-notificationService
|
|
122
|
+
// exists in window/localStorage
|
|
123
|
+
Logger.info(SCOPE_SC_CORE, 'Data is valid to register the device for receive mobile push notification.');
|
|
124
|
+
performUpdateDevice(_data).then((res) => {
|
|
125
|
+
setMnpmInstance(Object.assign(Object.assign({}, _data), { id: res.id }));
|
|
126
|
+
Logger.info(SCOPE_SC_CORE, 'Device registration successful. Your device will now be able to receive mobile push notifications.');
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
Logger.warn(SCOPE_SC_CORE, 'Invalid data. Unable to register the device for native push notification.');
|
|
132
|
+
unsubscribeDevice();
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
unsubscribeDevice();
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
return { mnpmInstance, setMnpmInstance };
|
|
140
|
+
}
|