@selfcommunity/react-core 0.1.2-alpha.0
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/LICENSE.md +21 -0
- package/README.md +13 -0
- package/lib/cjs/components/provider/SCAlertMessagesProvider/index.js +67 -0
- package/lib/cjs/components/provider/SCContextProvider/index.js +117 -0
- package/lib/cjs/components/provider/SCLocaleProvider/index.js +158 -0
- package/lib/cjs/components/provider/SCNotificationProvider/index.js +73 -0
- package/lib/cjs/components/provider/SCPreferencesProvider/index.js +93 -0
- package/lib/cjs/components/provider/SCRoutingProvider/index.js +146 -0
- package/lib/cjs/components/provider/SCThemeProvider/index.js +123 -0
- package/lib/cjs/components/provider/SCUserProvider/index.js +310 -0
- package/lib/cjs/components/router/index.js +91 -0
- package/lib/cjs/constants/Actions.js +6 -0
- package/lib/cjs/constants/ContextProviders.js +29 -0
- package/lib/cjs/constants/Device.js +11 -0
- package/lib/cjs/constants/Errors.js +10 -0
- package/lib/cjs/constants/Features.js +84 -0
- package/lib/cjs/constants/Locale.js +19 -0
- package/lib/cjs/constants/Notification.js +67 -0
- package/lib/cjs/constants/Notifications.js +27 -0
- package/lib/cjs/constants/Preferences.js +344 -0
- package/lib/cjs/constants/Routes.js +68 -0
- package/lib/cjs/constants/Session.js +22 -0
- package/lib/cjs/constants/Theme.js +6 -0
- package/lib/cjs/constants/WebSocket.js +10 -0
- package/lib/cjs/hooks/useSCAuth.js +340 -0
- package/lib/cjs/hooks/useSCCachingManager.js +58 -0
- package/lib/cjs/hooks/useSCConnectionsManager.js +285 -0
- package/lib/cjs/hooks/useSCFetchCategories.js +71 -0
- package/lib/cjs/hooks/useSCFetchCategory.js +68 -0
- package/lib/cjs/hooks/useSCFetchCommentObject.js +68 -0
- package/lib/cjs/hooks/useSCFetchCommentObjects.js +296 -0
- package/lib/cjs/hooks/useSCFetchCustomAdv.js +84 -0
- package/lib/cjs/hooks/useSCFetchFeedObject.js +79 -0
- package/lib/cjs/hooks/useSCFetchIncubator.js +68 -0
- package/lib/cjs/hooks/useSCFetchTag.js +68 -0
- package/lib/cjs/hooks/useSCFetchUser.js +68 -0
- package/lib/cjs/hooks/useSCFollowedCategoriesManager.js +162 -0
- package/lib/cjs/hooks/useSCFollowersManager.js +232 -0
- package/lib/cjs/hooks/useSCMediaClick.js +27 -0
- package/lib/cjs/hooks/useSCSubscribedIncubatorsManager.js +165 -0
- package/lib/cjs/hooks/useSCWebPushMessaging.js +286 -0
- package/lib/cjs/hooks/useSCWebSocket.js +120 -0
- package/lib/cjs/index.js +169 -0
- package/lib/cjs/scss/styles.scss +1 -0
- package/lib/cjs/themes/theme.js +165 -0
- package/lib/cjs/types/context.js +3 -0
- package/lib/cjs/types/index.js +22 -0
- package/lib/cjs/utils/errors.js +196 -0
- package/lib/cjs/utils/locale.js +56 -0
- package/lib/cjs/utils/logger.js +32 -0
- package/lib/cjs/utils/object.js +44 -0
- package/lib/cjs/utils/session.js +17 -0
- package/lib/cjs/utils/string.js +57 -0
- package/lib/cjs/utils/url.js +70 -0
- package/lib/cjs/utils/user.js +83 -0
- package/lib/cjs/utils/validator.js +771 -0
- package/lib/cjs/utils/webPushMessaging.js +110 -0
- package/lib/cjs/utils/websocket.js +307 -0
- package/lib/esm/api-services/src/client/index.d.ts +115 -0
- package/lib/esm/api-services/src/client/index.d.ts.map +1 -0
- package/lib/esm/api-services/src/constants/Endpoints.d.ts +10 -0
- package/lib/esm/api-services/src/constants/Endpoints.d.ts.map +1 -0
- package/lib/esm/api-services/src/index.d.ts +24 -0
- package/lib/esm/api-services/src/index.d.ts.map +1 -0
- package/lib/esm/api-services/src/services/category/index.d.ts +13 -0
- package/lib/esm/api-services/src/services/category/index.d.ts.map +1 -0
- package/lib/esm/api-services/src/services/feature/index.d.ts +10 -0
- package/lib/esm/api-services/src/services/feature/index.d.ts.map +1 -0
- package/lib/esm/api-services/src/services/preference/index.d.ts +16 -0
- package/lib/esm/api-services/src/services/preference/index.d.ts.map +1 -0
- package/lib/esm/api-services/src/services/user/index.d.ts +16 -0
- package/lib/esm/api-services/src/services/user/index.d.ts.map +1 -0
- package/lib/esm/api-services/src/utils/http.d.ts +6 -0
- package/lib/esm/api-services/src/utils/http.d.ts.map +1 -0
- package/lib/esm/api-services/src/utils/token.d.ts +16 -0
- package/lib/esm/api-services/src/utils/token.d.ts.map +1 -0
- package/lib/esm/components/provider/SCAlertMessagesProvider/index.js +67 -0
- package/lib/esm/components/provider/SCContextProvider/index.js +117 -0
- package/lib/esm/components/provider/SCLocaleProvider/index.js +158 -0
- package/lib/esm/components/provider/SCNotificationProvider/index.js +73 -0
- package/lib/esm/components/provider/SCPreferencesProvider/index.js +93 -0
- package/lib/esm/components/provider/SCRoutingProvider/index.js +146 -0
- package/lib/esm/components/provider/SCThemeProvider/index.js +123 -0
- package/lib/esm/components/provider/SCUserProvider/index.js +310 -0
- package/lib/esm/components/router/index.js +91 -0
- package/lib/esm/constants/Actions.js +6 -0
- package/lib/esm/constants/ContextProviders.js +29 -0
- package/lib/esm/constants/Device.js +11 -0
- package/lib/esm/constants/Errors.js +10 -0
- package/lib/esm/constants/Features.js +84 -0
- package/lib/esm/constants/Locale.js +19 -0
- package/lib/esm/constants/Notification.js +67 -0
- package/lib/esm/constants/Notifications.js +27 -0
- package/lib/esm/constants/Preferences.js +344 -0
- package/lib/esm/constants/Routes.js +68 -0
- package/lib/esm/constants/Session.js +22 -0
- package/lib/esm/constants/Theme.js +6 -0
- package/lib/esm/constants/WebSocket.js +10 -0
- package/lib/esm/hooks/useSCAuth.js +340 -0
- package/lib/esm/hooks/useSCCachingManager.js +58 -0
- package/lib/esm/hooks/useSCConnectionsManager.js +285 -0
- package/lib/esm/hooks/useSCFetchCategories.js +71 -0
- package/lib/esm/hooks/useSCFetchCategory.js +68 -0
- package/lib/esm/hooks/useSCFetchCommentObject.js +68 -0
- package/lib/esm/hooks/useSCFetchCommentObjects.js +296 -0
- package/lib/esm/hooks/useSCFetchCustomAdv.js +84 -0
- package/lib/esm/hooks/useSCFetchFeedObject.js +79 -0
- package/lib/esm/hooks/useSCFetchIncubator.js +68 -0
- package/lib/esm/hooks/useSCFetchTag.js +68 -0
- package/lib/esm/hooks/useSCFetchUser.js +68 -0
- package/lib/esm/hooks/useSCFollowedCategoriesManager.js +162 -0
- package/lib/esm/hooks/useSCFollowersManager.js +232 -0
- package/lib/esm/hooks/useSCMediaClick.js +27 -0
- package/lib/esm/hooks/useSCSubscribedIncubatorsManager.js +165 -0
- package/lib/esm/hooks/useSCWebPushMessaging.js +286 -0
- package/lib/esm/hooks/useSCWebSocket.js +120 -0
- package/lib/esm/index.js +169 -0
- package/lib/esm/react-core/src/components/provider/SCAlertMessagesProvider/index.d.ts +37 -0
- package/lib/esm/react-core/src/components/provider/SCAlertMessagesProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCContextProvider/index.d.ts +35 -0
- package/lib/esm/react-core/src/components/provider/SCContextProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCLocaleProvider/index.d.ts +42 -0
- package/lib/esm/react-core/src/components/provider/SCLocaleProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCNotificationProvider/index.d.ts +37 -0
- package/lib/esm/react-core/src/components/provider/SCNotificationProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCPreferencesProvider/index.d.ts +38 -0
- package/lib/esm/react-core/src/components/provider/SCPreferencesProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCRoutingProvider/index.d.ts +39 -0
- package/lib/esm/react-core/src/components/provider/SCRoutingProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCThemeProvider/index.d.ts +49 -0
- package/lib/esm/react-core/src/components/provider/SCThemeProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/provider/SCUserProvider/index.d.ts +38 -0
- package/lib/esm/react-core/src/components/provider/SCUserProvider/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/components/router/index.d.ts +34 -0
- package/lib/esm/react-core/src/components/router/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Actions.d.ts +2 -0
- package/lib/esm/react-core/src/constants/Actions.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/ContextProviders.d.ts +6 -0
- package/lib/esm/react-core/src/constants/ContextProviders.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Device.d.ts +6 -0
- package/lib/esm/react-core/src/constants/Device.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Errors.d.ts +5 -0
- package/lib/esm/react-core/src/constants/Errors.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Features.d.ts +41 -0
- package/lib/esm/react-core/src/constants/Features.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Locale.d.ts +8 -0
- package/lib/esm/react-core/src/constants/Locale.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Notification.d.ts +55 -0
- package/lib/esm/react-core/src/constants/Notification.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Notifications.d.ts +11 -0
- package/lib/esm/react-core/src/constants/Notifications.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Routes.d.ts +29 -0
- package/lib/esm/react-core/src/constants/Routes.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Session.d.ts +10 -0
- package/lib/esm/react-core/src/constants/Session.d.ts.map +1 -0
- package/lib/esm/react-core/src/constants/Theme.d.ts +2 -0
- package/lib/esm/react-core/src/constants/Theme.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCAuth.d.ts +56 -0
- package/lib/esm/react-core/src/hooks/useSCAuth.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCCachingManager.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCCachingManager.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCConnectionsManager.d.ts +40 -0
- package/lib/esm/react-core/src/hooks/useSCConnectionsManager.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCategories.d.ts +17 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCategories.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCategory.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCategory.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCommentObject.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCommentObject.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCommentObjects.d.ts +54 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCommentObjects.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCustomAdv.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCFetchCustomAdv.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchFeedObject.d.ts +21 -0
- package/lib/esm/react-core/src/hooks/useSCFetchFeedObject.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchIncubator.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCFetchIncubator.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchTag.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCFetchTag.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFetchUser.d.ts +19 -0
- package/lib/esm/react-core/src/hooks/useSCFetchUser.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFollowedCategoriesManager.d.ts +37 -0
- package/lib/esm/react-core/src/hooks/useSCFollowedCategoriesManager.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCFollowersManager.d.ts +37 -0
- package/lib/esm/react-core/src/hooks/useSCFollowersManager.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCMediaClick.d.ts +4 -0
- package/lib/esm/react-core/src/hooks/useSCMediaClick.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCSubscribedIncubatorsManager.d.ts +27 -0
- package/lib/esm/react-core/src/hooks/useSCSubscribedIncubatorsManager.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCWebPushMessaging.d.ts +9 -0
- package/lib/esm/react-core/src/hooks/useSCWebPushMessaging.d.ts.map +1 -0
- package/lib/esm/react-core/src/hooks/useSCWebSocket.d.ts +12 -0
- package/lib/esm/react-core/src/hooks/useSCWebSocket.d.ts.map +1 -0
- package/lib/esm/react-core/src/index.d.ts +77 -0
- package/lib/esm/react-core/src/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/types/context.d.ts +428 -0
- package/lib/esm/react-core/src/types/context.d.ts.map +1 -0
- package/lib/esm/react-core/src/types/index.d.ts +3 -0
- package/lib/esm/react-core/src/types/index.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/errors.d.ts +98 -0
- package/lib/esm/react-core/src/utils/errors.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/locale.d.ts +10 -0
- package/lib/esm/react-core/src/utils/locale.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/logger.d.ts +11 -0
- package/lib/esm/react-core/src/utils/logger.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/object.d.ts +13 -0
- package/lib/esm/react-core/src/utils/object.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/session.d.ts +6 -0
- package/lib/esm/react-core/src/utils/session.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/string.d.ts +21 -0
- package/lib/esm/react-core/src/utils/string.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/url.d.ts +22 -0
- package/lib/esm/react-core/src/utils/url.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/user.d.ts +41 -0
- package/lib/esm/react-core/src/utils/user.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/validator.d.ts +239 -0
- package/lib/esm/react-core/src/utils/validator.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/webPushMessaging.d.ts +14 -0
- package/lib/esm/react-core/src/utils/webPushMessaging.d.ts.map +1 -0
- package/lib/esm/react-core/src/utils/websocket.d.ts +177 -0
- package/lib/esm/react-core/src/utils/websocket.d.ts.map +1 -0
- package/lib/esm/react-i18n/src/index.d.ts +815 -0
- package/lib/esm/react-i18n/src/index.d.ts.map +1 -0
- package/lib/esm/scss/styles.scss +1 -0
- package/lib/esm/themes/theme.js +165 -0
- package/lib/esm/types/context.js +3 -0
- package/lib/esm/types/index.js +22 -0
- package/lib/esm/types/src/index.d.ts +9 -0
- package/lib/esm/types/src/index.d.ts.map +1 -0
- package/lib/esm/types/src/types/auth.d.ts +26 -0
- package/lib/esm/types/src/types/auth.d.ts.map +1 -0
- package/lib/esm/types/src/types/broadcastMessage.d.ts +73 -0
- package/lib/esm/types/src/types/broadcastMessage.d.ts.map +1 -0
- package/lib/esm/types/src/types/category.d.ts +100 -0
- package/lib/esm/types/src/types/category.d.ts.map +1 -0
- package/lib/esm/types/src/types/comment.d.ts +97 -0
- package/lib/esm/types/src/types/comment.d.ts.map +1 -0
- package/lib/esm/types/src/types/customAdv.d.ts +53 -0
- package/lib/esm/types/src/types/customAdv.d.ts.map +1 -0
- package/lib/esm/types/src/types/customNotification.d.ts +28 -0
- package/lib/esm/types/src/types/customNotification.d.ts.map +1 -0
- package/lib/esm/types/src/types/embed.d.ts +33 -0
- package/lib/esm/types/src/types/embed.d.ts.map +1 -0
- package/lib/esm/types/src/types/feed.d.ts +208 -0
- package/lib/esm/types/src/types/feed.d.ts.map +1 -0
- package/lib/esm/types/src/types/incubator.d.ts +53 -0
- package/lib/esm/types/src/types/incubator.d.ts.map +1 -0
- package/lib/esm/types/src/types/index.d.ts +22 -0
- package/lib/esm/types/src/types/index.d.ts.map +1 -0
- package/lib/esm/types/src/types/location.d.ts +61 -0
- package/lib/esm/types/src/types/location.d.ts.map +1 -0
- package/lib/esm/types/src/types/media.d.ts +52 -0
- package/lib/esm/types/src/types/media.d.ts.map +1 -0
- package/lib/esm/types/src/types/notification.d.ts +416 -0
- package/lib/esm/types/src/types/notification.d.ts.map +1 -0
- package/lib/esm/types/src/types/poll.d.ts +77 -0
- package/lib/esm/types/src/types/poll.d.ts.map +1 -0
- package/lib/esm/types/src/types/privateMessage.d.ts +109 -0
- package/lib/esm/types/src/types/privateMessage.d.ts.map +1 -0
- package/lib/esm/types/src/types/prize.d.ts +48 -0
- package/lib/esm/types/src/types/prize.d.ts.map +1 -0
- package/lib/esm/types/src/types/tag.d.ts +47 -0
- package/lib/esm/types/src/types/tag.d.ts.map +1 -0
- package/lib/esm/types/src/types/user.d.ts +227 -0
- package/lib/esm/types/src/types/user.d.ts.map +1 -0
- package/lib/esm/utils/errors.js +196 -0
- package/lib/esm/utils/locale.js +56 -0
- package/lib/esm/utils/logger.js +32 -0
- package/lib/esm/utils/object.js +44 -0
- package/lib/esm/utils/session.js +17 -0
- package/lib/esm/utils/src/index.d.ts +7 -0
- package/lib/esm/utils/src/index.d.ts.map +1 -0
- package/lib/esm/utils/src/utils/string.d.ts +21 -0
- package/lib/esm/utils/src/utils/string.d.ts.map +1 -0
- package/lib/esm/utils/src/utils/url.d.ts +22 -0
- package/lib/esm/utils/src/utils/url.d.ts.map +1 -0
- package/lib/esm/utils/string.js +57 -0
- package/lib/esm/utils/url.js +70 -0
- package/lib/esm/utils/user.js +83 -0
- package/lib/esm/utils/validator.js +771 -0
- package/lib/esm/utils/webPushMessaging.js +110 -0
- package/lib/esm/utils/websocket.js +307 -0
- package/lib/umd/react-core.js +2 -0
- package/lib/umd/react-core.js.LICENSE.txt +1 -0
- package/package.json +128 -0
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generate a JWT
|
|
3
|
+
:::tipContext can be consumed as following:
|
|
4
|
+
```jsx
|
|
5
|
+
1. const token = await generateJWTToken(userId, secretKey, expirationTime);
|
|
6
|
+
```
|
|
7
|
+
```jsx
|
|
8
|
+
2. generateJWTToken(userId, secretKey, expirationTime).then(token => {...});
|
|
9
|
+
```
|
|
10
|
+
:::
|
|
11
|
+
* @param userId
|
|
12
|
+
* @param secretKey
|
|
13
|
+
* @param expirationTime
|
|
14
|
+
*/
|
|
15
|
+
export declare function generateJWTToken(userId: any, secretKey: any, expirationTime: any): Promise<string>;
|
|
16
|
+
//# sourceMappingURL=token.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.d.ts","sourceRoot":"","sources":["../../../../../../api-services/src/utils/token.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;;;GAaG;AACH,wBAAsB,gBAAgB,CAAC,MAAM,KAAA,EAAE,SAAS,KAAA,EAAE,cAAc,KAAA,mBAWvE"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.SCAlertMessagesContext = void 0;
|
|
5
|
+
exports.default = SCAlertMessagesProvider;
|
|
6
|
+
exports.useSCAlertMessages = useSCAlertMessages;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _notistack = require("notistack");
|
|
11
|
+
|
|
12
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
|
+
|
|
14
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Creates Global Context
|
|
18
|
+
*
|
|
19
|
+
:::tipContext can be consumed in one of the following ways:
|
|
20
|
+
```jsx
|
|
21
|
+
1. <SCAlertMessagesContext.Consumer>{(options,) => (...)}</SCAlertMessagesContext.Consumer>
|
|
22
|
+
```
|
|
23
|
+
```jsx
|
|
24
|
+
2. const scAlertMessagesContext: SCAlertMessagesContextType = useContext(SCAlertMessagesContext)
|
|
25
|
+
```
|
|
26
|
+
```jsx
|
|
27
|
+
3. const scAlertMessagesContext: SCAlertMessagesContextType = useSCAlertMessages();
|
|
28
|
+
````
|
|
29
|
+
:::
|
|
30
|
+
|
|
31
|
+
*/
|
|
32
|
+
const SCAlertMessagesContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
33
|
+
/**
|
|
34
|
+
* #### Description:
|
|
35
|
+
* This component makes the `intl` available down the React tree.
|
|
36
|
+
* @param children
|
|
37
|
+
* @return
|
|
38
|
+
* ```jsx
|
|
39
|
+
* <SCAlertMessagesContext.Provider value={{options}}>
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
|
|
43
|
+
exports.SCAlertMessagesContext = SCAlertMessagesContext;
|
|
44
|
+
|
|
45
|
+
function SCAlertMessagesProvider({
|
|
46
|
+
children = null
|
|
47
|
+
}) {
|
|
48
|
+
const [options, setOptions] = (0, _react.useState)({
|
|
49
|
+
maxSnack: 3,
|
|
50
|
+
autoHideDuration: null
|
|
51
|
+
});
|
|
52
|
+
return /*#__PURE__*/_react.default.createElement(SCAlertMessagesContext.Provider, {
|
|
53
|
+
value: {
|
|
54
|
+
options,
|
|
55
|
+
setOptions
|
|
56
|
+
}
|
|
57
|
+
}, /*#__PURE__*/_react.default.createElement(_notistack.SnackbarProvider, options, children));
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Let's only export the `useSCAlertMessages` hook instead of the context.
|
|
61
|
+
* We only want to use the hook directly and never the context component.
|
|
62
|
+
*/
|
|
63
|
+
|
|
64
|
+
|
|
65
|
+
function useSCAlertMessages() {
|
|
66
|
+
return (0, _react.useContext)(SCAlertMessagesContext);
|
|
67
|
+
}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.SCContext = void 0;
|
|
5
|
+
exports.default = SCContextProvider;
|
|
6
|
+
exports.useSCContext = useSCContext;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _apiServices = require("@selfcommunity/api-services");
|
|
11
|
+
|
|
12
|
+
var _useDeepCompareEffect = _interopRequireDefault(require("use-deep-compare-effect"));
|
|
13
|
+
|
|
14
|
+
var _validator = require("../../../utils/validator");
|
|
15
|
+
|
|
16
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
17
|
+
|
|
18
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
19
|
+
|
|
20
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Creates Global Context
|
|
24
|
+
*
|
|
25
|
+
:::tipContext can be consumed in one of the following ways:
|
|
26
|
+
```jsx
|
|
27
|
+
1. <SCContext.Consumer>{settings => (...)}</SCContext.Consumer>
|
|
28
|
+
```
|
|
29
|
+
```jsx
|
|
30
|
+
2. const scContext: SCContextType = useContext(SCContext);
|
|
31
|
+
```
|
|
32
|
+
```jsx
|
|
33
|
+
3. const scContext: SCContextType = useSCContext();
|
|
34
|
+
````
|
|
35
|
+
:::
|
|
36
|
+
*/
|
|
37
|
+
const SCContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
38
|
+
/**
|
|
39
|
+
* This component imports all providers
|
|
40
|
+
* @param object
|
|
41
|
+
* @param object.conf
|
|
42
|
+
* @param object.children
|
|
43
|
+
* @return
|
|
44
|
+
* ```jsx
|
|
45
|
+
* <SCContext.Provider value={{settings}}>
|
|
46
|
+
* ```
|
|
47
|
+
*/
|
|
48
|
+
|
|
49
|
+
exports.SCContext = SCContext;
|
|
50
|
+
|
|
51
|
+
function SCContextProvider({
|
|
52
|
+
conf,
|
|
53
|
+
children
|
|
54
|
+
}) {
|
|
55
|
+
const [settings, setSettings] = (0, _react.useState)(null);
|
|
56
|
+
/**
|
|
57
|
+
* Export the provider as we need to wrap the entire app with it
|
|
58
|
+
* This provider keeps current user logged and session
|
|
59
|
+
*/
|
|
60
|
+
|
|
61
|
+
(0, _useDeepCompareEffect.default)(() => {
|
|
62
|
+
/**
|
|
63
|
+
* Validate initial settings
|
|
64
|
+
*/
|
|
65
|
+
const {
|
|
66
|
+
validationResult,
|
|
67
|
+
settings
|
|
68
|
+
} = (0, _validator.validateOptions)(conf, _validator.validOptions);
|
|
69
|
+
/**
|
|
70
|
+
* Init provider
|
|
71
|
+
*/
|
|
72
|
+
|
|
73
|
+
if (validationResult.hasErrors()) {
|
|
74
|
+
/**
|
|
75
|
+
* Exist errors in initial conf
|
|
76
|
+
*/
|
|
77
|
+
validationResult.emit();
|
|
78
|
+
} else {
|
|
79
|
+
/**
|
|
80
|
+
* Emit warnings if exist
|
|
81
|
+
*/
|
|
82
|
+
validationResult.emitWarnings();
|
|
83
|
+
/**
|
|
84
|
+
* Set the base path on the http objects
|
|
85
|
+
*/
|
|
86
|
+
|
|
87
|
+
_apiServices.http.setBasePortal(settings.portal);
|
|
88
|
+
/**
|
|
89
|
+
* Render all Providers
|
|
90
|
+
*/
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
setSettings(settings);
|
|
94
|
+
}
|
|
95
|
+
}, [conf]);
|
|
96
|
+
/**
|
|
97
|
+
* Nesting all necessary providers
|
|
98
|
+
* All child components will use help contexts to works
|
|
99
|
+
*/
|
|
100
|
+
|
|
101
|
+
return /*#__PURE__*/_react.default.createElement(SCContext.Provider, {
|
|
102
|
+
value: {
|
|
103
|
+
settings
|
|
104
|
+
}
|
|
105
|
+
}, settings && settings.contextProviders.reduceRight((memo, ContextProvider) => {
|
|
106
|
+
return /*#__PURE__*/_react.default.createElement(ContextProvider, null, memo);
|
|
107
|
+
}, children));
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Let's only export the `useSCContext` hook instead of the context.
|
|
111
|
+
* We only want to use the hook directly and never the context component.
|
|
112
|
+
*/
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
function useSCContext() {
|
|
116
|
+
return (0, _react.useContext)(SCContext);
|
|
117
|
+
}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.SCLocaleContext = void 0;
|
|
5
|
+
exports.default = SCLocaleProvider;
|
|
6
|
+
exports.useSCLocale = useSCLocale;
|
|
7
|
+
exports.withSCLocale = void 0;
|
|
8
|
+
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
|
|
11
|
+
var _SCContextProvider = require("../SCContextProvider");
|
|
12
|
+
|
|
13
|
+
var _locale = require("../../../utils/locale");
|
|
14
|
+
|
|
15
|
+
var _Locale = require("../../../constants/Locale");
|
|
16
|
+
|
|
17
|
+
var _reactIntl = require("react-intl");
|
|
18
|
+
|
|
19
|
+
var _logger = require("../../../utils/logger");
|
|
20
|
+
|
|
21
|
+
var _Errors = require("../../../constants/Errors");
|
|
22
|
+
|
|
23
|
+
var _useDeepCompareEffect = _interopRequireDefault(require("use-deep-compare-effect"));
|
|
24
|
+
|
|
25
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
26
|
+
|
|
27
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
28
|
+
|
|
29
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
30
|
+
|
|
31
|
+
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Creates Global Context
|
|
35
|
+
*
|
|
36
|
+
:::tipContext can be consumed in one of the following ways:
|
|
37
|
+
|
|
38
|
+
```jsx
|
|
39
|
+
1. <SCLocaleContext.Consumer>{(locale,) => (...)}</SCLocaleContext.Consumer>
|
|
40
|
+
```
|
|
41
|
+
```jsx
|
|
42
|
+
2. const scLocaleContext: SCLocaleContextType = useContext(SCLocaleContext);
|
|
43
|
+
```
|
|
44
|
+
```jsx
|
|
45
|
+
3. const scLocaleContext: SCLocaleContextType = useSCLocale();
|
|
46
|
+
````
|
|
47
|
+
:::
|
|
48
|
+
*/
|
|
49
|
+
const SCLocaleContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
50
|
+
/**
|
|
51
|
+
* #### Description:
|
|
52
|
+
* This component makes the `intl` available down the React tree.
|
|
53
|
+
* @param children
|
|
54
|
+
* @return
|
|
55
|
+
* ```jsx
|
|
56
|
+
* <SCLocaleContext.Provider value={{locale, messages, selectLocale}}>
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
|
|
60
|
+
exports.SCLocaleContext = SCLocaleContext;
|
|
61
|
+
|
|
62
|
+
function SCLocaleProvider({
|
|
63
|
+
children = null
|
|
64
|
+
}) {
|
|
65
|
+
var _scContext$settings$l;
|
|
66
|
+
|
|
67
|
+
const scContext = (0, _SCContextProvider.useSCContext)();
|
|
68
|
+
const initialLocale = (_scContext$settings$l = scContext.settings.locale) != null && _scContext$settings$l.default ? scContext.settings.locale.default : _Locale.DEFAULT_LANGUAGE_UI;
|
|
69
|
+
const initial = (0, _locale.loadLocaleData)(initialLocale, scContext.settings);
|
|
70
|
+
const [locale, setLocale] = (0, _react.useState)(initial.locale);
|
|
71
|
+
const [messages, setMessages] = (0, _react.useState)(initial.messages);
|
|
72
|
+
/**
|
|
73
|
+
* Update current locale state
|
|
74
|
+
* @param _intl
|
|
75
|
+
*/
|
|
76
|
+
|
|
77
|
+
const updateLocale = _intl => {
|
|
78
|
+
setLocale(_intl.locale);
|
|
79
|
+
setMessages(_intl.messages);
|
|
80
|
+
};
|
|
81
|
+
/**
|
|
82
|
+
* Select locale loading data
|
|
83
|
+
*/
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
const selectLocale = (0, _react.useMemo)(() => l => {
|
|
87
|
+
const {
|
|
88
|
+
messages,
|
|
89
|
+
locale
|
|
90
|
+
} = (0, _locale.loadLocaleData)(l, scContext.settings);
|
|
91
|
+
updateLocale({
|
|
92
|
+
messages,
|
|
93
|
+
locale
|
|
94
|
+
});
|
|
95
|
+
}, [locale]);
|
|
96
|
+
/**
|
|
97
|
+
* Update locale and messages if initial conf changes
|
|
98
|
+
*/
|
|
99
|
+
|
|
100
|
+
(0, _useDeepCompareEffect.default)(() => {
|
|
101
|
+
var _scContext$settings$l2;
|
|
102
|
+
|
|
103
|
+
selectLocale((_scContext$settings$l2 = scContext.settings.locale) != null && _scContext$settings$l2.default ? scContext.settings.locale.default : _Locale.DEFAULT_LANGUAGE_UI);
|
|
104
|
+
}, [scContext.settings.locale]);
|
|
105
|
+
/**
|
|
106
|
+
* handleIntlError
|
|
107
|
+
* @param error
|
|
108
|
+
*/
|
|
109
|
+
|
|
110
|
+
const handleIntlError = error => {
|
|
111
|
+
if (error.code === 'MISSING_TRANSLATION') {
|
|
112
|
+
_logger.Logger.warn(_Errors.SCOPE_SC_CORE, `Missing translation: ${error.message}`);
|
|
113
|
+
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
throw error;
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
return /*#__PURE__*/_react.default.createElement(SCLocaleContext.Provider, {
|
|
121
|
+
value: {
|
|
122
|
+
locale,
|
|
123
|
+
messages,
|
|
124
|
+
selectLocale
|
|
125
|
+
}
|
|
126
|
+
}, /*#__PURE__*/_react.default.createElement(_reactIntl.IntlProvider, {
|
|
127
|
+
key: locale,
|
|
128
|
+
locale: locale,
|
|
129
|
+
messages: messages,
|
|
130
|
+
onError: handleIntlError
|
|
131
|
+
}, children));
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Export hoc to inject the base theme to components
|
|
135
|
+
* @param Component
|
|
136
|
+
*/
|
|
137
|
+
|
|
138
|
+
|
|
139
|
+
const withSCLocale = Component => props => {
|
|
140
|
+
const scLocaleContext = (0, _react.useContext)(SCLocaleContext);
|
|
141
|
+
return /*#__PURE__*/_react.default.createElement(_reactIntl.IntlProvider, {
|
|
142
|
+
locale: scLocaleContext.locale,
|
|
143
|
+
messages: scLocaleContext.messages
|
|
144
|
+
}, /*#__PURE__*/_react.default.createElement(Component, _extends({
|
|
145
|
+
setLanguage: scLocaleContext.selectLocale
|
|
146
|
+
}, props)));
|
|
147
|
+
};
|
|
148
|
+
/**
|
|
149
|
+
* Let's only export the `useSCLocale` hook instead of the context.
|
|
150
|
+
* We only want to use the hook directly and never the context component.
|
|
151
|
+
*/
|
|
152
|
+
|
|
153
|
+
|
|
154
|
+
exports.withSCLocale = withSCLocale;
|
|
155
|
+
|
|
156
|
+
function useSCLocale() {
|
|
157
|
+
return (0, _react.useContext)(SCLocaleContext);
|
|
158
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.SCNotificationContext = void 0;
|
|
5
|
+
exports.default = SCNotificationProvider;
|
|
6
|
+
exports.useSCNotification = useSCNotification;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _useSCWebSocket = _interopRequireDefault(require("../../../hooks/useSCWebSocket"));
|
|
11
|
+
|
|
12
|
+
var _useSCWebPushMessaging = _interopRequireDefault(require("../../../hooks/useSCWebPushMessaging"));
|
|
13
|
+
|
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
|
+
|
|
16
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
17
|
+
|
|
18
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Creates Global Context
|
|
22
|
+
*
|
|
23
|
+
:::tipContext can be consumed in one of the following ways:
|
|
24
|
+
|
|
25
|
+
```jsx
|
|
26
|
+
1. <SCNotificationContext.Consumer>{(wsInstance, subscribe,) => (...)}</SCNotificationContext.Consumer>
|
|
27
|
+
```
|
|
28
|
+
```jsx
|
|
29
|
+
2. const scNotificationContext: SCNotificationContextType = useContext(SCNotificationContext);
|
|
30
|
+
```
|
|
31
|
+
```jsx
|
|
32
|
+
3. const scNotificationContext: SCNotificationContextType = useSCNotification();
|
|
33
|
+
````
|
|
34
|
+
:::
|
|
35
|
+
*/
|
|
36
|
+
const SCNotificationContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
37
|
+
/**
|
|
38
|
+
* #### Description:
|
|
39
|
+
* This component makes the notification context available down the React tree.
|
|
40
|
+
* @param children
|
|
41
|
+
* @return
|
|
42
|
+
* ```jsx
|
|
43
|
+
* <SCNotificationContext.Provider value={{wsInstance}}>{children}</SCNotificationContext.Provider>
|
|
44
|
+
* ```
|
|
45
|
+
*/
|
|
46
|
+
|
|
47
|
+
exports.SCNotificationContext = SCNotificationContext;
|
|
48
|
+
|
|
49
|
+
function SCNotificationProvider({
|
|
50
|
+
children = null
|
|
51
|
+
}) {
|
|
52
|
+
const {
|
|
53
|
+
wsInstance
|
|
54
|
+
} = (0, _useSCWebSocket.default)();
|
|
55
|
+
const {
|
|
56
|
+
wpSubscription
|
|
57
|
+
} = (0, _useSCWebPushMessaging.default)();
|
|
58
|
+
return /*#__PURE__*/_react.default.createElement(SCNotificationContext.Provider, {
|
|
59
|
+
value: {
|
|
60
|
+
wsInstance,
|
|
61
|
+
wpSubscription
|
|
62
|
+
}
|
|
63
|
+
}, children);
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Let's only export the `useSCNotification` hook instead of the context.
|
|
67
|
+
* We only want to use the hook directly and never the context component.
|
|
68
|
+
*/
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
function useSCNotification() {
|
|
72
|
+
return (0, _react.useContext)(SCNotificationContext);
|
|
73
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.SCPreferencesContext = void 0;
|
|
5
|
+
exports.default = SCPreferencesProvider;
|
|
6
|
+
exports.useSCPreferences = useSCPreferences;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _apiServices = require("@selfcommunity/api-services");
|
|
11
|
+
|
|
12
|
+
var _logger = require("../../../utils/logger");
|
|
13
|
+
|
|
14
|
+
var _Errors = require("../../../constants/Errors");
|
|
15
|
+
|
|
16
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
17
|
+
|
|
18
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Creates Preferences/Features Context
|
|
22
|
+
*
|
|
23
|
+
:::tipContext can be consumed in one of the following ways:
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
```jsx
|
|
27
|
+
1. <SCPreferencesContext.Consumer>{(preferences) => (...)}</SCPreferencesContext.Consumer>
|
|
28
|
+
```
|
|
29
|
+
```jsx
|
|
30
|
+
2. const scPreferences: SCPreferencesType = usePreferencesContext(SCPreferencesContext);
|
|
31
|
+
```
|
|
32
|
+
```jsx
|
|
33
|
+
3. const scPreferences: SCPreferencesType = useSCPreferences();
|
|
34
|
+
````
|
|
35
|
+
:::
|
|
36
|
+
*/
|
|
37
|
+
const SCPreferencesContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
38
|
+
/**
|
|
39
|
+
* #### Description:
|
|
40
|
+
* This component imports all preferences and features enabled.
|
|
41
|
+
* @param children
|
|
42
|
+
* @return
|
|
43
|
+
* ```jsx
|
|
44
|
+
* <SCPreferencesContext.Provider value={{preferences, features}}>{!loading && children}</SCPreferencesContext.Provider>
|
|
45
|
+
* ```
|
|
46
|
+
*/
|
|
47
|
+
|
|
48
|
+
exports.SCPreferencesContext = SCPreferencesContext;
|
|
49
|
+
|
|
50
|
+
function SCPreferencesProvider({
|
|
51
|
+
children = null
|
|
52
|
+
}) {
|
|
53
|
+
const [preferences, setPreferences] = (0, _react.useState)({});
|
|
54
|
+
const [features, setFeatures] = (0, _react.useState)([]);
|
|
55
|
+
const [, setError] = (0, _react.useState)();
|
|
56
|
+
const [loading, setLoading] = (0, _react.useState)(true);
|
|
57
|
+
/**
|
|
58
|
+
* Load all dynamic preferences and features enabled
|
|
59
|
+
* to manages configurations of the project
|
|
60
|
+
*/
|
|
61
|
+
|
|
62
|
+
(0, _react.useEffect)(() => {
|
|
63
|
+
Promise.all([_apiServices.PreferenceService.getAllPreferences(), _apiServices.FeatureService.getAllFeatures()]).then(function (results) {
|
|
64
|
+
setPreferences(results[0]);
|
|
65
|
+
setFeatures(results[1]);
|
|
66
|
+
setLoading(false);
|
|
67
|
+
}).catch(_error => {
|
|
68
|
+
_logger.Logger.error(_Errors.SCOPE_SC_CORE, _error);
|
|
69
|
+
|
|
70
|
+
setError(_error);
|
|
71
|
+
});
|
|
72
|
+
}, []);
|
|
73
|
+
/**
|
|
74
|
+
* Nesting all necessary providers
|
|
75
|
+
* All child components will use help contexts to works
|
|
76
|
+
*/
|
|
77
|
+
|
|
78
|
+
return /*#__PURE__*/_react.default.createElement(SCPreferencesContext.Provider, {
|
|
79
|
+
value: {
|
|
80
|
+
preferences,
|
|
81
|
+
features
|
|
82
|
+
}
|
|
83
|
+
}, !loading && children);
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Let's only export the `useSCPreferences` hook instead of the context.
|
|
87
|
+
* We only want to use the hook directly and never the context component.
|
|
88
|
+
*/
|
|
89
|
+
|
|
90
|
+
|
|
91
|
+
function useSCPreferences() {
|
|
92
|
+
return (0, _react.useContext)(SCPreferencesContext);
|
|
93
|
+
}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.SCRoutingContext = void 0;
|
|
5
|
+
exports.default = SCRoutingProvider;
|
|
6
|
+
exports.useSCRouting = useSCRouting;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
|
|
10
|
+
var _SCContextProvider = require("../SCContextProvider");
|
|
11
|
+
|
|
12
|
+
var _SCPreferencesProvider = require("../SCPreferencesProvider");
|
|
13
|
+
|
|
14
|
+
var SCPreferences = _interopRequireWildcard(require("../../../constants/Preferences"));
|
|
15
|
+
|
|
16
|
+
var _Routes = require("../../../constants/Routes");
|
|
17
|
+
|
|
18
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
19
|
+
|
|
20
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Creates Global Context
|
|
24
|
+
*
|
|
25
|
+
:::tipContext can be consumed in one of the following ways:
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
```jsx
|
|
29
|
+
1. <SCRoutingContext.Consumer>{(routerLink, routes, url) => (...)}</SCRoutingContext.Consumer>
|
|
30
|
+
```
|
|
31
|
+
```jsx
|
|
32
|
+
2. const scRoutingContext: SCRoutingContextType = useContext(SCRoutingContext);
|
|
33
|
+
```
|
|
34
|
+
```jsx
|
|
35
|
+
3. const scRoutingContext: SCRoutingContextType = useSCRouting();
|
|
36
|
+
````
|
|
37
|
+
|
|
38
|
+
:::
|
|
39
|
+
*/
|
|
40
|
+
const SCRoutingContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
41
|
+
/**
|
|
42
|
+
* #### Description:
|
|
43
|
+
* This component provides routing context.
|
|
44
|
+
* @param children
|
|
45
|
+
* @return
|
|
46
|
+
* ```jsx
|
|
47
|
+
* <SCRoutingContext.Provider value={contextValue}>{children}</SCRoutingContext.Provider>
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
|
|
51
|
+
exports.SCRoutingContext = SCRoutingContext;
|
|
52
|
+
|
|
53
|
+
function SCRoutingProvider({
|
|
54
|
+
children = null
|
|
55
|
+
}) {
|
|
56
|
+
const scPreferencesContext = (0, _react.useContext)(_SCPreferencesProvider.SCPreferencesContext);
|
|
57
|
+
const scContext = (0, _SCContextProvider.useSCContext)();
|
|
58
|
+
const router = scContext.settings.router ? scContext.settings.router : {};
|
|
59
|
+
const routerLink = router.routerLink ? router.routerLink : null;
|
|
60
|
+
|
|
61
|
+
const _routes = Object.assign(getPreferencesRoutes(), _Routes.defaultRoutes);
|
|
62
|
+
|
|
63
|
+
const routes = router.routes ? Object.assign({}, _routes, router.routes) : _Routes.defaultRoutes;
|
|
64
|
+
/**
|
|
65
|
+
* Normalize template url (preferences)
|
|
66
|
+
*/
|
|
67
|
+
|
|
68
|
+
function normalizeUrl(url) {
|
|
69
|
+
let tpl = url;
|
|
70
|
+
const re = /\{([^/]+)?\}/g;
|
|
71
|
+
let match = re.exec(url);
|
|
72
|
+
|
|
73
|
+
while (match) {
|
|
74
|
+
tpl = tpl.replace(match[0], `:${match[1]}`);
|
|
75
|
+
re.lastIndex = 0;
|
|
76
|
+
match = re.exec(tpl);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return tpl;
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Get override routes from community preferences
|
|
83
|
+
*/
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
function getPreferencesRoutes() {
|
|
87
|
+
return {
|
|
88
|
+
[_Routes.POST_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_POST].value),
|
|
89
|
+
[_Routes.DISCUSSION_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_DISCUSSION].value),
|
|
90
|
+
[_Routes.STATUS_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_STATUS].value),
|
|
91
|
+
[_Routes.COMMENT_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_COMMENT].value),
|
|
92
|
+
[_Routes.CATEGORY_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_CATEGORY].value),
|
|
93
|
+
[_Routes.CATEGORIES_LIST_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_CATEGORIES_LIST].value),
|
|
94
|
+
[_Routes.USER_PROFILE_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_USER_PROFILE].value),
|
|
95
|
+
[_Routes.USER_PROFILE_SETTINGS_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_USER_PROFILE_SETTINGS].value),
|
|
96
|
+
[_Routes.USER_NOTIFICATIONS_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_USER_NOTIFICATIONS].value),
|
|
97
|
+
[_Routes.USER_PRIVATE_MESSAGES_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_USER_PRIVATE_MESSAGES].value),
|
|
98
|
+
[_Routes.INCUBATOR_ROUTE_NAME]: normalizeUrl(scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_URL_TEMPLATE_INCUBATOR].value)
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Generate path
|
|
103
|
+
*/
|
|
104
|
+
|
|
105
|
+
|
|
106
|
+
function url(name = '', params = {}) {
|
|
107
|
+
const replacer = (tpl, data) => {
|
|
108
|
+
const re = /:([^/|^?|^#]+)?/g;
|
|
109
|
+
let _tpl = tpl;
|
|
110
|
+
let match = re.exec(tpl);
|
|
111
|
+
|
|
112
|
+
while (match) {
|
|
113
|
+
_tpl = _tpl.replace(match[0], data[match[1]]);
|
|
114
|
+
re.lastIndex = 0;
|
|
115
|
+
match = re.exec(_tpl);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
if (router.handleRoute) {
|
|
119
|
+
// Handle override url
|
|
120
|
+
return router.handleRoute(name, _tpl, params, tpl);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
return _tpl;
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
return replacer(routes[name], params);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const contextValue = (0, _react.useMemo)(() => ({
|
|
130
|
+
routerLink,
|
|
131
|
+
routes,
|
|
132
|
+
url
|
|
133
|
+
}), [routerLink, routes]);
|
|
134
|
+
return /*#__PURE__*/_react.default.createElement(SCRoutingContext.Provider, {
|
|
135
|
+
value: contextValue
|
|
136
|
+
}, children);
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Let's only export the `useSCTheme` hook instead of the context.
|
|
140
|
+
* We only want to use the hook directly and never the context component.
|
|
141
|
+
*/
|
|
142
|
+
|
|
143
|
+
|
|
144
|
+
function useSCRouting() {
|
|
145
|
+
return (0, _react.useContext)(SCRoutingContext);
|
|
146
|
+
}
|