studiokit-scaffolding-js 7.0.12-next.1.4 → 7.0.12-next.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (258) hide show
  1. package/lib/components/ActionList.js +170 -34
  2. package/lib/components/AlertDialog.js +133 -9
  3. package/lib/components/AlertWithIcon.js +92 -25
  4. package/lib/components/ConnectedModal.js +43 -13
  5. package/lib/components/Dropdowns/GroupsDropdown.js +69 -44
  6. package/lib/components/Dropdowns/ManagedNavDropdown.js +100 -67
  7. package/lib/components/Dropdowns/UserDropdown.js +111 -21
  8. package/lib/components/Dropdowns/index.js +27 -9
  9. package/lib/components/EntityOwnerList.js +52 -18
  10. package/lib/components/Error.js +106 -11
  11. package/lib/components/ErrorBoundary.js +134 -35
  12. package/lib/components/ErrorMessage.js +44 -9
  13. package/lib/components/Forms/DateField.js +61 -42
  14. package/lib/components/Forms/TimeField.js +81 -42
  15. package/lib/components/Forms/index.js +27 -4
  16. package/lib/components/Groups/CreateEditCopySaveButtons.js +114 -11
  17. package/lib/components/Groups/ExternalGroups/Attach.js +212 -148
  18. package/lib/components/Groups/ExternalGroups/Table.js +181 -45
  19. package/lib/components/Groups/GroupCreateOrEditCommonProps.js +5 -1
  20. package/lib/components/Groups/RosterSyncInfo.js +147 -20
  21. package/lib/components/HOC/AccessibleAppComponent.js +98 -73
  22. package/lib/components/HOC/ActivityRequiredComponent.js +92 -49
  23. package/lib/components/HOC/AsyncComponent.js +54 -39
  24. package/lib/components/HOC/AuthenticatedComponent.js +58 -38
  25. package/lib/components/HOC/CollectionComponent.js +170 -110
  26. package/lib/components/HOC/CollectionFirstItemComponent.js +51 -38
  27. package/lib/components/HOC/CollectionItemComponent.js +168 -106
  28. package/lib/components/HOC/ConnectedModalComponent.js +109 -80
  29. package/lib/components/HOC/DataDependentComponent.js +29 -21
  30. package/lib/components/HOC/EntityComponent.js +71 -57
  31. package/lib/components/HOC/FullscreenModalComponent.js +163 -123
  32. package/lib/components/HOC/GroupActivityRequiredComponent.js +45 -31
  33. package/lib/components/HOC/GuidComponent.js +29 -22
  34. package/lib/components/HOC/ModelContextDependencyVerifyComponent.js +41 -31
  35. package/lib/components/HOC/ModelErrorRedirectComponent.js +51 -47
  36. package/lib/components/HOC/SearchPersistorComponent.js +240 -166
  37. package/lib/components/HOC/UnauthenticatedComponent.js +37 -25
  38. package/lib/components/HOC/UserComponent.js +12 -7
  39. package/lib/components/Icons/IconAlphaList.js +33 -5
  40. package/lib/components/Icons/IconExternalUser.js +33 -5
  41. package/lib/components/Icons/IconImpersonation.js +33 -5
  42. package/lib/components/Icons/IconStopImpersonating.js +33 -5
  43. package/lib/components/Icons/IconTable.js +35 -7
  44. package/lib/components/Icons/IconTableDeleteCol.js +33 -5
  45. package/lib/components/Icons/IconTableDeleteRow.js +33 -5
  46. package/lib/components/Icons/IconTableInsertCol.js +33 -5
  47. package/lib/components/Icons/IconTableInsertRow.js +33 -5
  48. package/lib/components/Impersonation/Button.js +77 -13
  49. package/lib/components/Impersonation/Link.js +77 -13
  50. package/lib/components/Impersonation/UserDetail.js +66 -9
  51. package/lib/components/Loading.js +26 -4
  52. package/lib/components/LockDownBrowser/Check.js +194 -49
  53. package/lib/components/LockDownBrowser/ExitButton.js +26 -9
  54. package/lib/components/LockDownBrowser/Launch.js +70 -62
  55. package/lib/components/Lti/Confirm.js +152 -11
  56. package/lib/components/Lti/CreateNonLtiGroupAlertDialog.js +170 -33
  57. package/lib/components/Lti/Launch.js +105 -24
  58. package/lib/components/Lti/LaunchGroup.js +85 -13
  59. package/lib/components/ManageTable.js +309 -87
  60. package/lib/components/ManageTableNoDataComponent.js +42 -4
  61. package/lib/components/NewVersionAlert.js +82 -46
  62. package/lib/components/NotFound.js +86 -10
  63. package/lib/components/Notifications.js +185 -126
  64. package/lib/components/PaginationNextButton.js +33 -6
  65. package/lib/components/PaginationPreviousButton.js +33 -6
  66. package/lib/components/Quill/CustomToolbar.js +432 -218
  67. package/lib/components/Quill/Formats/Image.js +73 -63
  68. package/lib/components/Quill/Formats/List.js +45 -45
  69. package/lib/components/Quill/Formats/Video.js +28 -24
  70. package/lib/components/Quill/ImageDropModule.js +147 -117
  71. package/lib/components/Quill/ImageWarning.js +47 -9
  72. package/lib/components/Quill/ImageWithAltTextModal.js +425 -86
  73. package/lib/components/Quill/Specs/CustomImageSpec.js +42 -34
  74. package/lib/components/Quill/Specs/CustomVideoSpec.js +34 -28
  75. package/lib/components/Quill/TableModule/Blots/BaseTableBlot.js +98 -98
  76. package/lib/components/Quill/TableModule/Blots/TableBlot.js +52 -47
  77. package/lib/components/Quill/TableModule/Blots/TableBodyBlot.js +53 -48
  78. package/lib/components/Quill/TableModule/Blots/TableCellBlot.js +224 -221
  79. package/lib/components/Quill/TableModule/Blots/TableContainer.js +80 -83
  80. package/lib/components/Quill/TableModule/Blots/TableRowBlot.js +75 -70
  81. package/lib/components/Quill/TableModule/constants.js +45 -41
  82. package/lib/components/Quill/TableModule/index.js +362 -301
  83. package/lib/components/Quill/TableModule/utils.js +42 -38
  84. package/lib/components/Quill/accessibilityFix.js +234 -232
  85. package/lib/components/Quill/index.js +34 -28
  86. package/lib/components/RefreshIndicator/Bordered.js +47 -6
  87. package/lib/components/RefreshIndicator/Inline.js +47 -8
  88. package/lib/components/RefreshIndicator/index.js +263 -59
  89. package/lib/components/SearchControls.js +216 -11
  90. package/lib/components/SentryRoute.js +11 -6
  91. package/lib/components/Tables/RoleFilter.js +69 -32
  92. package/lib/components/Tables/TextFilter.js +62 -13
  93. package/lib/components/UserRoles/Add.js +199 -96
  94. package/lib/components/UserRoles/Context.js +11 -7
  95. package/lib/components/UserRoles/RoleCell.js +181 -72
  96. package/lib/components/UserRoles/Select.js +157 -17
  97. package/lib/components/UserRoles/Table.js +221 -80
  98. package/lib/components/UserRoles/index.js +534 -384
  99. package/lib/config/eslint/index.js +32 -28
  100. package/lib/config/eslint/lib/order.js +26 -27
  101. package/lib/config/eslint/lib/prettier.js +20 -18
  102. package/lib/config/eslint/lib/typescript.js +93 -112
  103. package/lib/config/eslint/react.js +24 -14
  104. package/lib/constants/baseActivity.js +30 -26
  105. package/lib/constants/baseRole.js +14 -10
  106. package/lib/constants/configuration.js +33 -29
  107. package/lib/constants/externalProviderType.js +10 -6
  108. package/lib/constants/fetchErrorData.js +15 -11
  109. package/lib/constants/index.js +137 -14
  110. package/lib/constants/lockDownBrowser.js +28 -24
  111. package/lib/constants/mockData.js +382 -297
  112. package/lib/constants/modelStatus.js +15 -11
  113. package/lib/constants/notificationType.js +12 -8
  114. package/lib/constants/operatingSystem.js +12 -8
  115. package/lib/constants/shard.js +11 -7
  116. package/lib/constants/table.js +21 -21
  117. package/lib/constants/tier.js +12 -8
  118. package/lib/constants/userRole.js +15 -5
  119. package/lib/endpointMappings.js +197 -181
  120. package/lib/hooks/useCollection.js +82 -62
  121. package/lib/hooks/useCollectionConfiguration.js +228 -83
  122. package/lib/hooks/useCollectionItem.js +154 -54
  123. package/lib/hooks/useGuid.js +20 -8
  124. package/lib/hooks/usePrevious.js +19 -13
  125. package/lib/index.js +157 -25
  126. package/lib/redux/actionCreator.js +50 -28
  127. package/lib/redux/actions/AuthAction.js +44 -31
  128. package/lib/redux/actions/ModalAction.js +10 -6
  129. package/lib/redux/actions/ModelAction.js +77 -39
  130. package/lib/redux/actions/NotificationAction.js +10 -6
  131. package/lib/redux/actions/SearchAction.js +9 -5
  132. package/lib/redux/actions/index.js +60 -7
  133. package/lib/redux/configureReducers.js +60 -49
  134. package/lib/redux/configureStore.js +83 -87
  135. package/lib/redux/helpers.js +6 -2
  136. package/lib/redux/reducers/authReducer.js +50 -43
  137. package/lib/redux/reducers/index.js +41 -13
  138. package/lib/redux/reducers/modalsReducer.js +47 -29
  139. package/lib/redux/reducers/modelsReducer.js +178 -173
  140. package/lib/redux/reducers/notificationsReducer.js +24 -18
  141. package/lib/redux/reducers/searchReducer.js +25 -19
  142. package/lib/redux/sagas/appInsightsSaga.js +22 -18
  143. package/lib/redux/sagas/authSaga.js +253 -218
  144. package/lib/redux/sagas/caliperSaga.js +159 -143
  145. package/lib/redux/sagas/clockOffsetSaga.js +34 -31
  146. package/lib/redux/sagas/configurationSaga.js +11 -7
  147. package/lib/redux/sagas/downtimeApiErrorSaga.js +20 -17
  148. package/lib/redux/sagas/errorSaga.js +27 -21
  149. package/lib/redux/sagas/googleAnalyticsSaga.js +28 -24
  150. package/lib/redux/sagas/identityProviderSaga.js +22 -18
  151. package/lib/redux/sagas/initialDataLoadSaga.js +37 -28
  152. package/lib/redux/sagas/lockDownBrowserErrorSaga.js +29 -20
  153. package/lib/redux/sagas/modelFetchSaga.js +355 -322
  154. package/lib/redux/sagas/noStoreSaga.js +61 -48
  155. package/lib/redux/sagas/postLoginDataSaga.js +45 -34
  156. package/lib/redux/sagas/postLoginRedirectSaga.js +27 -27
  157. package/lib/redux/sagas/rootSaga.js +82 -57
  158. package/lib/redux/sagas/sentrySaga.js +29 -25
  159. package/lib/redux/sagas/userIdSaga.js +16 -12
  160. package/lib/services/codeProviderService.js +25 -19
  161. package/lib/services/dateService.js +12 -7
  162. package/lib/services/documentService.js +17 -12
  163. package/lib/services/fetchService.js +129 -112
  164. package/lib/services/persistenceService.js +33 -29
  165. package/lib/services/ticketProviderService.js +29 -23
  166. package/lib/services/tokenPersistenceService.js +12 -8
  167. package/lib/services/windowService.js +18 -14
  168. package/lib/startup.js +132 -114
  169. package/lib/types/AppConfiguration.js +5 -1
  170. package/lib/types/Artifact.js +11 -7
  171. package/lib/types/BaseReduxState.js +5 -1
  172. package/lib/types/Client.js +5 -1
  173. package/lib/types/Collection.js +5 -1
  174. package/lib/types/Configuration.js +5 -1
  175. package/lib/types/DeepLinkingResponseRequest.js +5 -1
  176. package/lib/types/DeletableModel.js +5 -1
  177. package/lib/types/Event.js +5 -1
  178. package/lib/types/ExternalGroup.js +5 -1
  179. package/lib/types/ExternalProvider.js +5 -1
  180. package/lib/types/ExternalTerm.js +5 -1
  181. package/lib/types/Group.js +5 -1
  182. package/lib/types/IdentityProvider.js +5 -1
  183. package/lib/types/LtiLaunch.js +5 -1
  184. package/lib/types/NameOnlyEntity.js +5 -1
  185. package/lib/types/Notification.js +5 -1
  186. package/lib/types/OptionalRecord.js +5 -1
  187. package/lib/types/OwnerSchedule.js +5 -1
  188. package/lib/types/PropertyOfType.js +5 -1
  189. package/lib/types/Quill.js +5 -1
  190. package/lib/types/RoleDescription.js +5 -1
  191. package/lib/types/Search.js +5 -1
  192. package/lib/types/SimpleLocation.js +5 -1
  193. package/lib/types/UniTime.js +5 -1
  194. package/lib/types/User.js +5 -1
  195. package/lib/types/UserRole.js +5 -1
  196. package/lib/types/auth/AuthState.js +5 -1
  197. package/lib/types/auth/CasV1LoginRequestBody.js +5 -1
  198. package/lib/types/auth/ClientCredentials.js +5 -1
  199. package/lib/types/auth/CodeProviderService.js +5 -1
  200. package/lib/types/auth/LocalLoginRequestBody.js +5 -1
  201. package/lib/types/auth/TicketProviderService.js +5 -1
  202. package/lib/types/auth/TokenPersistenceService.js +5 -1
  203. package/lib/types/auth/index.js +82 -9
  204. package/lib/types/externals.d.js +2 -0
  205. package/lib/types/index.js +313 -30
  206. package/lib/types/net/EndpointConfig.js +5 -1
  207. package/lib/types/net/EndpointMapping.js +5 -1
  208. package/lib/types/net/EndpointMappings.js +5 -1
  209. package/lib/types/net/ErrorHandler.js +5 -1
  210. package/lib/types/net/FetchConfig.js +5 -1
  211. package/lib/types/net/FetchErrorData.js +10 -6
  212. package/lib/types/net/FetchResult.js +5 -1
  213. package/lib/types/net/HTTPMethod.js +5 -1
  214. package/lib/types/net/HTTPStatusCode.js +16 -12
  215. package/lib/types/net/Metadata.js +5 -1
  216. package/lib/types/net/Model.js +5 -1
  217. package/lib/types/net/ModelCollection.js +5 -1
  218. package/lib/types/net/ModelsState.js +5 -1
  219. package/lib/types/net/OAuthToken.js +5 -1
  220. package/lib/types/net/OAuthTokenOrNull.js +5 -1
  221. package/lib/types/net/TokenAccessFunction.js +5 -1
  222. package/lib/types/net/index.js +181 -18
  223. package/lib/utils/baseActivity.js +133 -123
  224. package/lib/utils/baseRole.js +37 -33
  225. package/lib/utils/collection.js +425 -298
  226. package/lib/utils/cookies.js +22 -19
  227. package/lib/utils/date.js +303 -279
  228. package/lib/utils/dom.js +176 -165
  229. package/lib/utils/domainIdentifier.js +9 -5
  230. package/lib/utils/entityUserRole.js +6 -2
  231. package/lib/utils/error.js +17 -15
  232. package/lib/utils/events.js +40 -31
  233. package/lib/utils/externalGroup.js +22 -18
  234. package/lib/utils/externalProviders.js +8 -4
  235. package/lib/utils/externalTerms.js +10 -3
  236. package/lib/utils/fetch.js +179 -180
  237. package/lib/utils/group.js +18 -7
  238. package/lib/utils/groupDates.js +37 -33
  239. package/lib/utils/groupRoles.js +25 -21
  240. package/lib/utils/lockDownBrowser.js +15 -11
  241. package/lib/utils/logger.js +26 -22
  242. package/lib/utils/lti.js +9 -4
  243. package/lib/utils/model.js +36 -41
  244. package/lib/utils/number.js +21 -18
  245. package/lib/utils/promise.js +28 -21
  246. package/lib/utils/quill.js +65 -62
  247. package/lib/utils/route.js +58 -55
  248. package/lib/utils/search.js +76 -80
  249. package/lib/utils/shard.js +37 -37
  250. package/lib/utils/sort.js +50 -42
  251. package/lib/utils/string.js +13 -8
  252. package/lib/utils/table.js +38 -33
  253. package/lib/utils/timezone.js +10 -6
  254. package/lib/utils/url.js +142 -142
  255. package/lib/utils/user.js +58 -55
  256. package/lib/utils/userAgent.js +10 -10
  257. package/lib/utils/userRole.js +57 -49
  258. package/package.json +17 -3
@@ -1,68 +1,82 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
3
7
  exports.configureMapStateToProps = exports.configureEntityComponent = void 0;
4
8
  exports.default = entityComponent;
5
- const tslib_1 = require("tslib");
6
- const jsx_runtime_1 = require("react/jsx-runtime");
7
- const react_1 = require("react");
8
- const react_redux_1 = require("react-redux");
9
- const react_router_dom_1 = require("react-router-dom");
10
- const baseActivity_1 = require("../../utils/baseActivity");
11
- const route_1 = require("../../utils/route");
12
- const CollectionItemComponent_1 = tslib_1.__importDefault(require("./CollectionItemComponent"));
13
- const ModelErrorRedirectComponent_1 = tslib_1.__importDefault(require("./ModelErrorRedirectComponent"));
9
+ var _react = require("react");
10
+ var _reactRedux = require("react-redux");
11
+ var _reactRouterDom = require("react-router-dom");
12
+ var _baseActivity = require("../../utils/baseActivity");
13
+ var _route = require("../../utils/route");
14
+ var _CollectionItemComponent = _interopRequireDefault(require("./CollectionItemComponent"));
15
+ var _ModelErrorRedirectComponent = _interopRequireDefault(require("./ModelErrorRedirectComponent"));
16
+ var _jsxRuntime = require("react/jsx-runtime");
14
17
  const configureEntityComponent = (WrappedComponent, WrappedHeader, propName, entityName) => {
15
- return class EntityComponent extends react_1.Component {
16
- render() {
17
- const { model, modelName } = this.props;
18
- const newProps = {
19
- [propName]: model
20
- };
21
- return ((0, jsx_runtime_1.jsxs)("div", { children: [!!WrappedHeader && (0, jsx_runtime_1.jsx)(WrappedHeader, Object.assign({}, newProps)), model.isDeleted ? ((0, jsx_runtime_1.jsx)(react_router_dom_1.Redirect, { to: `/${entityName === 'groups' ? 'courses' : entityName}` })) : ((0, jsx_runtime_1.jsx)(WrappedComponent, Object.assign({}, newProps, { modelName: modelName })))] }));
22
- }
23
- };
18
+ return class EntityComponent extends _react.Component {
19
+ render() {
20
+ const {
21
+ model,
22
+ modelName
23
+ } = this.props;
24
+ const newProps = {
25
+ [propName]: model
26
+ };
27
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
28
+ children: [!!WrappedHeader && /*#__PURE__*/(0, _jsxRuntime.jsx)(WrappedHeader, {
29
+ ...newProps
30
+ }), model.isDeleted ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactRouterDom.Redirect, {
31
+ to: `/${entityName === 'groups' ? 'courses' : entityName}`
32
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsx)(WrappedComponent, {
33
+ ...newProps,
34
+ modelName: modelName
35
+ })]
36
+ });
37
+ }
38
+ };
24
39
  };
25
40
  exports.configureEntityComponent = configureEntityComponent;
26
41
  const configureMapStateToProps = (readActivity, modelName) => (state, ownProps) => {
27
- const canReadGlobally = (0, baseActivity_1.canPerformActivityGlobally)(readActivity, (0, baseActivity_1.defaultOptions)(state));
28
- // override modelName if admin does not have a role in the given entity
29
- let newModelName = modelName;
30
- const modelId = (0, route_1.getModelIdFromRouteMatchParams)(ownProps.match.params, newModelName);
31
- let hasAccess;
32
- if (modelId === undefined) {
33
- hasAccess = false;
34
- }
35
- else {
36
- hasAccess =
37
- !!state.models[modelName] &&
38
- !!state.models[modelName][modelId] &&
39
- !!state.models[modelName][modelId].id;
40
- }
41
- if (canReadGlobally && !hasAccess) {
42
- newModelName = `search.${newModelName}`;
43
- }
44
- return {
45
- modelName: newModelName
46
- };
42
+ const canReadGlobally = (0, _baseActivity.canPerformActivityGlobally)(readActivity, (0, _baseActivity.defaultOptions)(state));
43
+
44
+ // override modelName if admin does not have a role in the given entity
45
+ let newModelName = modelName;
46
+ const modelId = (0, _route.getModelIdFromRouteMatchParams)(ownProps.match.params, newModelName);
47
+ let hasAccess;
48
+ if (modelId === undefined) {
49
+ hasAccess = false;
50
+ } else {
51
+ hasAccess = !!state.models[modelName] && !!state.models[modelName][modelId] && !!state.models[modelName][modelId].id;
52
+ }
53
+ if (canReadGlobally && !hasAccess) {
54
+ newModelName = `search.${newModelName}`;
55
+ }
56
+ return {
57
+ modelName: newModelName
58
+ };
47
59
  };
48
- exports.configureMapStateToProps = configureMapStateToProps;
49
- /**
50
- * A wrapper using CollectionItemComponent that passes down the `model`, to allow nesting of collection components.
51
- * Uses `CollectionItemComponent`, `ModelErrorRedirectComponent`, `withRouter`, and `connect`.
52
- *
53
- * This HOC does NOT pass extra props through to children
54
- *
55
- * @param WrappedComponent The wrapped component
56
- * @param WrappedHeader The wrapped header
57
- * @param readActivity Read activity that will be checked for global access
58
- * @param modelName Model name passed to wrapped component and `CollectionItemComponent`. May be modified when only global read is available
59
- * @param propName The name for the prop with which the `model` will be passed to the wrapped component
60
+
61
+ /**
62
+ * A wrapper using CollectionItemComponent that passes down the `model`, to allow nesting of collection components.
63
+ * Uses `CollectionItemComponent`, `ModelErrorRedirectComponent`, `withRouter`, and `connect`.
64
+ *
65
+ * This HOC does NOT pass extra props through to children
66
+ *
67
+ * @param WrappedComponent The wrapped component
68
+ * @param WrappedHeader The wrapped header
69
+ * @param readActivity Read activity that will be checked for global access
70
+ * @param modelName Model name passed to wrapped component and `CollectionItemComponent`. May be modified when only global read is available
71
+ * @param propName The name for the prop with which the `model` will be passed to the wrapped component
60
72
  */
73
+ exports.configureMapStateToProps = configureMapStateToProps;
61
74
  function entityComponent(WrappedComponent, WrappedHeader, readActivity, modelName, propName) {
62
- const EntityComponent = (0, exports.configureEntityComponent)(WrappedComponent, WrappedHeader, propName, modelName);
63
- const mapStateToProps = (0, exports.configureMapStateToProps)(readActivity, modelName);
64
- // @ts-ignore: could not match inferred type from the `connect` HOC
65
- return (0, react_router_dom_1.withRouter)(
66
- // @ts-ignore: could not match inferred type from the `connect` HOC
67
- (0, react_redux_1.connect)(mapStateToProps)((0, CollectionItemComponent_1.default)((0, ModelErrorRedirectComponent_1.default)(EntityComponent), modelName)));
75
+ const EntityComponent = configureEntityComponent(WrappedComponent, WrappedHeader, propName, modelName);
76
+ const mapStateToProps = configureMapStateToProps(readActivity, modelName);
77
+ // @ts-ignore: could not match inferred type from the `connect` HOC
78
+ return (0, _reactRouterDom.withRouter)(
79
+ // @ts-ignore: could not match inferred type from the `connect` HOC
80
+ (0, _reactRedux.connect)(mapStateToProps)((0, _CollectionItemComponent.default)((0, _ModelErrorRedirectComponent.default)(EntityComponent), modelName)));
68
81
  }
82
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_reactRedux","_reactRouterDom","_baseActivity","_route","_CollectionItemComponent","_interopRequireDefault","_ModelErrorRedirectComponent","_jsxRuntime","configureEntityComponent","WrappedComponent","WrappedHeader","propName","entityName","EntityComponent","Component","render","model","modelName","props","newProps","jsxs","children","jsx","isDeleted","Redirect","to","exports","configureMapStateToProps","readActivity","state","ownProps","canReadGlobally","canPerformActivityGlobally","defaultOptions","newModelName","modelId","getModelIdFromRouteMatchParams","match","params","hasAccess","undefined","models","id","entityComponent","mapStateToProps","withRouter","connect","CollectionItemComponent","ModelErrorRedirectComponent"],"sources":["../../../src/components/HOC/EntityComponent.tsx"],"sourcesContent":["import { Component, ComponentClass, ComponentType } from 'react'\r\nimport { connect } from 'react-redux'\r\nimport { Redirect, RouteComponentProps, withRouter } from 'react-router-dom'\r\nimport { BaseReduxState, DeletableModel, Model, ModelCollection } from '../../types'\r\nimport { CollectionCommonProps } from '../../types/Collection'\r\nimport { canPerformActivityGlobally, defaultOptions } from '../../utils/baseActivity'\r\nimport { getModelIdFromRouteMatchParams } from '../../utils/route'\r\nimport CollectionItemComponent, { CollectionItemComponentWrappedProps } from './CollectionItemComponent'\r\nimport ModelErrorRedirectComponent from './ModelErrorRedirectComponent'\r\n\r\nexport interface EntityComponentProps<T extends DeletableModel>\r\n\textends CollectionItemComponentWrappedProps<T>,\r\n\t\tRouteComponentProps {\r\n\tmodel: T\r\n}\r\n\r\nexport type EntityComponentWrappedHeaderProps<T extends DeletableModel, TProp extends keyof any> = { [P in TProp]: T }\r\n\r\nexport type EntityComponentWrappedProps<\r\n\tT extends DeletableModel,\r\n\tTProp extends keyof any\r\n> = EntityComponentWrappedHeaderProps<T, TProp> & {\r\n\tmodelName: string\r\n}\r\n\r\nexport const configureEntityComponent = <T extends DeletableModel, TPropName extends keyof any>(\r\n\tWrappedComponent: ComponentType<EntityComponentWrappedProps<T, TPropName>>,\r\n\tWrappedHeader: ComponentType<EntityComponentWrappedHeaderProps<T, TPropName>> | undefined,\r\n\tpropName: TPropName,\r\n\tentityName: string\r\n) => {\r\n\treturn class EntityComponent extends Component<EntityComponentProps<T>> {\r\n\t\trender() {\r\n\t\t\tconst { model, modelName }: { model: T; modelName: string } = this.props\r\n\t\t\tconst newProps = {\r\n\t\t\t\t[propName]: model\r\n\t\t\t} as EntityComponentWrappedHeaderProps<T, TPropName>\r\n\t\t\treturn (\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{!!WrappedHeader && <WrappedHeader {...newProps} />}\r\n\t\t\t\t\t{model.isDeleted ? (\r\n\t\t\t\t\t\t<Redirect to={`/${entityName === 'groups' ? 'courses' : entityName}`} />\r\n\t\t\t\t\t) : (\r\n\t\t\t\t\t\t<WrappedComponent {...newProps} modelName={modelName} />\r\n\t\t\t\t\t)}\r\n\t\t\t\t</div>\r\n\t\t\t)\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport const configureMapStateToProps =\r\n\t<T extends DeletableModel>(readActivity: string, modelName: string) =>\r\n\t(state: BaseReduxState, ownProps: EntityComponentProps<T>) => {\r\n\t\tconst canReadGlobally = canPerformActivityGlobally(readActivity, defaultOptions(state))\r\n\r\n\t\t// override modelName if admin does not have a role in the given entity\r\n\t\tlet newModelName = modelName\r\n\t\tconst modelId = getModelIdFromRouteMatchParams(ownProps.match.params, newModelName)\r\n\t\tlet hasAccess\r\n\t\tif (modelId === undefined) {\r\n\t\t\thasAccess = false\r\n\t\t} else {\r\n\t\t\thasAccess =\r\n\t\t\t\t!!state.models[modelName] &&\r\n\t\t\t\t!!(state.models[modelName] as ModelCollection)[modelId] &&\r\n\t\t\t\t!!((state.models[modelName] as ModelCollection)[modelId] as Model).id\r\n\t\t}\r\n\t\tif (canReadGlobally && !hasAccess) {\r\n\t\t\tnewModelName = `search.${newModelName}`\r\n\t\t}\r\n\r\n\t\treturn {\r\n\t\t\tmodelName: newModelName\r\n\t\t}\r\n\t}\r\n\r\n/**\r\n * A wrapper using CollectionItemComponent that passes down the `model`, to allow nesting of collection components.\r\n * Uses `CollectionItemComponent`, `ModelErrorRedirectComponent`, `withRouter`, and `connect`.\r\n *\r\n * This HOC does NOT pass extra props through to children\r\n *\r\n * @param WrappedComponent The wrapped component\r\n * @param WrappedHeader The wrapped header\r\n * @param readActivity Read activity that will be checked for global access\r\n * @param modelName Model name passed to wrapped component and `CollectionItemComponent`. May be modified when only global read is available\r\n * @param propName The name for the prop with which the `model` will be passed to the wrapped component\r\n */\r\nexport default function entityComponent<T extends DeletableModel, TPropName extends keyof any>(\r\n\tWrappedComponent: ComponentType<EntityComponentWrappedProps<T, TPropName>>,\r\n\tWrappedHeader: ComponentType<EntityComponentWrappedHeaderProps<T, TPropName>> | undefined,\r\n\treadActivity: string,\r\n\tmodelName: string,\r\n\tpropName: TPropName\r\n): ComponentClass<Partial<CollectionCommonProps>> {\r\n\tconst EntityComponent = configureEntityComponent<T, TPropName>(WrappedComponent, WrappedHeader, propName, modelName)\r\n\tconst mapStateToProps = configureMapStateToProps(readActivity, modelName)\r\n\t// @ts-ignore: could not match inferred type from the `connect` HOC\r\n\treturn withRouter(\r\n\t\t// @ts-ignore: could not match inferred type from the `connect` HOC\r\n\t\tconnect(mapStateToProps)(CollectionItemComponent(ModelErrorRedirectComponent(EntityComponent), modelName))\r\n\t)\r\n}\r\n"],"mappings":"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","ignoreList":[]}
@@ -1,134 +1,174 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
3
7
  exports.configureFullscreenModalComponent = configureFullscreenModalComponent;
8
+ exports.default = void 0;
4
9
  exports.fullscreenModalComponent = fullscreenModalComponent;
5
- const tslib_1 = require("tslib");
6
- const jsx_runtime_1 = require("react/jsx-runtime");
7
- const react_1 = require("react");
8
- const react_modal_1 = tslib_1.__importDefault(require("react-modal"));
9
- const ConnectedModalComponent_1 = require("./ConnectedModalComponent");
10
- /**
11
- * HOC that manages a `ReactModal`, adds inline css, and
12
- * coordinates modal state in redux using.
13
- *
14
- * NOTE: Meant for testing. Should be wrapped in `connectedModalComponent` normally.
15
- *
16
- * @param WrappedComponent The component to wrap.
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+ var _react = require("react");
12
+ var _reactModal = _interopRequireDefault(require("react-modal"));
13
+ var _ConnectedModalComponent = require("./ConnectedModalComponent");
14
+ var _jsxRuntime = require("react/jsx-runtime");
15
+ /**
16
+ * The props that are provided to the HOC component directly from the caller, not other wrapping HOCs
17
+ * NOTE: if more flexibility is needed, add more props from `ReactModal.Props`
18
+ */
19
+
20
+ /** The props that are provided to the HOC component, either directly or from other wrapping HOCs */
21
+
22
+ /** The props that are provide to the wrapped component. */
23
+
24
+ /**
25
+ * HOC that manages a `ReactModal`, adds inline css, and
26
+ * coordinates modal state in redux using.
27
+ *
28
+ * NOTE: Meant for testing. Should be wrapped in `connectedModalComponent` normally.
29
+ *
30
+ * @param WrappedComponent The component to wrap.
17
31
  */
18
32
  function configureFullscreenModalComponent(WrappedComponent) {
19
- return class FullscreenModalComponent extends react_1.Component {
20
- constructor(props) {
21
- super(props);
22
- this.disableScroll = (e) => {
23
- document.documentElement.scrollTop = 0;
24
- e.preventDefault();
25
- return false;
26
- };
27
- this.onOpen = () => {
28
- document.documentElement.addEventListener('touchmove', this.disableScroll);
29
- this.props.onEntering();
30
- };
31
- this.onClose = () => {
32
- document.documentElement.removeEventListener('touchmove', this.disableScroll);
33
- this.props.onExited();
34
- };
35
- this.closeModal = () => {
36
- if (this.props.closeModal) {
37
- this.props.closeModal();
38
- return;
39
- }
40
- this.setState({
41
- isOpen: false
42
- });
43
- };
44
- this.state = {
45
- isOpen: props.isOpen === undefined ? true : props.isOpen
46
- };
47
- // https://github.com/reactjs/react-modal#app-element
48
- // Accessibility fixed when reading the content in the modal
49
- if (document.getElementById('root')) {
50
- react_modal_1.default.setAppElement('#root');
51
- }
52
- }
53
- componentDidMount() {
54
- const { isOpen } = this.state;
55
- if (isOpen) {
56
- this.onOpen();
57
- }
58
- }
59
- componentWillUnmount() {
60
- document.documentElement.removeEventListener('touchmove', this.disableScroll);
61
- }
62
- componentDidUpdate(prevProps, prevState) {
63
- let isOpen;
64
- if (this.props.isOpen !== undefined && this.props.isOpen !== this.state.isOpen) {
65
- // using props to handle isOpen, update state
66
- isOpen = this.props.isOpen;
67
- }
68
- else if (this.props.isOpen === undefined && prevState.isOpen !== this.state.isOpen) {
69
- // using state only to handle isOpen
70
- isOpen = this.state.isOpen;
71
- }
72
- if (isOpen === undefined) {
73
- return;
74
- }
75
- if (isOpen) {
76
- this.onOpen();
77
- }
78
- else {
79
- this.onClose();
80
- }
81
- this.setState({
82
- isOpen
83
- });
33
+ return class FullscreenModalComponent extends _react.Component {
34
+ constructor(props) {
35
+ super(props);
36
+ (0, _defineProperty2.default)(this, "disableScroll", e => {
37
+ document.documentElement.scrollTop = 0;
38
+ e.preventDefault();
39
+ return false;
40
+ });
41
+ (0, _defineProperty2.default)(this, "onOpen", () => {
42
+ document.documentElement.addEventListener('touchmove', this.disableScroll);
43
+ this.props.onEntering();
44
+ });
45
+ (0, _defineProperty2.default)(this, "onClose", () => {
46
+ document.documentElement.removeEventListener('touchmove', this.disableScroll);
47
+ this.props.onExited();
48
+ });
49
+ (0, _defineProperty2.default)(this, "closeModal", () => {
50
+ if (this.props.closeModal) {
51
+ this.props.closeModal();
52
+ return;
84
53
  }
85
- render() {
86
- const _a = this.props, { contentLabel, isTopOpenFullscreenModal, onEntering, onExited, isOpen: _, closeModal, zIndex } = _a, remainingProps = tslib_1.__rest(_a, ["contentLabel", "isTopOpenFullscreenModal", "onEntering", "onExited", "isOpen", "closeModal", "zIndex"]);
87
- // do not pass ConnectedModalWrappedProps to wrapped component
88
- const wrappedProps = Object.assign(Object.assign({}, remainingProps), { closeModal: this.closeModal });
89
- const { isOpen } = this.state;
90
- return ((0, jsx_runtime_1.jsx)(react_modal_1.default, { isOpen: isOpen, contentLabel: contentLabel, style: {
91
- content: {
92
- position: 'absolute',
93
- top: 0,
94
- left: 0,
95
- right: 0,
96
- bottom: 0,
97
- overflow: 'hidden',
98
- padding: 0,
99
- border: 'none',
100
- backgroundColor: 'white'
101
- },
102
- overlay: {
103
- position: 'absolute',
104
- top: 0,
105
- left: 0,
106
- right: 0,
107
- bottom: 0,
108
- zIndex: zIndex !== null && zIndex !== void 0 ? zIndex : 2000
109
- }
110
- },
111
- // hide the rendered portal if this is not the top open fullscreen modal
112
- portalClassName: `ReactModalPortal${!isTopOpenFullscreenModal ? ' dn' : ''}`, shouldCloseOnOverlayClick: false, children: (0, jsx_runtime_1.jsx)(WrappedComponent, Object.assign({}, wrappedProps)) }));
54
+ this.setState({
55
+ isOpen: false
56
+ });
57
+ });
58
+ this.state = {
59
+ isOpen: props.isOpen === undefined ? true : props.isOpen
60
+ };
61
+
62
+ // https://github.com/reactjs/react-modal#app-element
63
+ // Accessibility fixed when reading the content in the modal
64
+ if (document.getElementById('root')) {
65
+ _reactModal.default.setAppElement('#root');
66
+ }
67
+ }
68
+ componentDidMount() {
69
+ const {
70
+ isOpen
71
+ } = this.state;
72
+ if (isOpen) {
73
+ this.onOpen();
74
+ }
75
+ }
76
+ componentWillUnmount() {
77
+ document.documentElement.removeEventListener('touchmove', this.disableScroll);
78
+ }
79
+ componentDidUpdate(prevProps, prevState) {
80
+ let isOpen;
81
+ if (this.props.isOpen !== undefined && this.props.isOpen !== this.state.isOpen) {
82
+ // using props to handle isOpen, update state
83
+ isOpen = this.props.isOpen;
84
+ } else if (this.props.isOpen === undefined && prevState.isOpen !== this.state.isOpen) {
85
+ // using state only to handle isOpen
86
+ isOpen = this.state.isOpen;
87
+ }
88
+ if (isOpen === undefined) {
89
+ return;
90
+ }
91
+ if (isOpen) {
92
+ this.onOpen();
93
+ } else {
94
+ this.onClose();
95
+ }
96
+ this.setState({
97
+ isOpen
98
+ });
99
+ }
100
+ render() {
101
+ const {
102
+ contentLabel,
103
+ isTopOpenFullscreenModal,
104
+ onEntering,
105
+ onExited,
106
+ isOpen: _,
107
+ closeModal,
108
+ zIndex,
109
+ ...remainingProps
110
+ } = this.props;
111
+ // do not pass ConnectedModalWrappedProps to wrapped component
112
+ const wrappedProps = {
113
+ ...remainingProps,
114
+ closeModal: this.closeModal
115
+ };
116
+ const {
117
+ isOpen
118
+ } = this.state;
119
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactModal.default, {
120
+ isOpen: isOpen,
121
+ contentLabel: contentLabel,
122
+ style: {
123
+ content: {
124
+ position: 'absolute',
125
+ top: 0,
126
+ left: 0,
127
+ right: 0,
128
+ bottom: 0,
129
+ overflow: 'hidden',
130
+ padding: 0,
131
+ border: 'none',
132
+ backgroundColor: 'white'
133
+ },
134
+ overlay: {
135
+ position: 'absolute',
136
+ top: 0,
137
+ left: 0,
138
+ right: 0,
139
+ bottom: 0,
140
+ zIndex: zIndex ?? 2000
141
+ }
113
142
  }
114
- };
143
+ // hide the rendered portal if this is not the top open fullscreen modal
144
+ ,
145
+ portalClassName: `ReactModalPortal${!isTopOpenFullscreenModal ? ' dn' : ''}`,
146
+ shouldCloseOnOverlayClick: false,
147
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(WrappedComponent, {
148
+ ...wrappedProps
149
+ })
150
+ });
151
+ }
152
+ };
115
153
  }
116
- /**
117
- * HOC that contains a `ReactModal` which can be auto managed or managed with props,
118
- * adds fullscreen styles, and coordinates modal state in redux.
119
- *
120
- * Uses `connectedModalComponent`.
121
- *
122
- * NOTE: Please add the following css
123
- *
124
- * .ReactModal__Body--open {
125
- * overflow: hidden;
126
- * }
127
- *
128
- * @param WrappedComponent The component to wrap.
154
+
155
+ /**
156
+ * HOC that contains a `ReactModal` which can be auto managed or managed with props,
157
+ * adds fullscreen styles, and coordinates modal state in redux.
158
+ *
159
+ * Uses `connectedModalComponent`.
160
+ *
161
+ * NOTE: Please add the following css
162
+ *
163
+ * .ReactModal__Body--open {
164
+ * overflow: hidden;
165
+ * }
166
+ *
167
+ * @param WrappedComponent The component to wrap.
129
168
  */
130
169
  function fullscreenModalComponent(WrappedComponent) {
131
- const component = configureFullscreenModalComponent(WrappedComponent);
132
- return (0, ConnectedModalComponent_1.connectedModalComponent)(component, true);
170
+ const component = configureFullscreenModalComponent(WrappedComponent);
171
+ return (0, _ConnectedModalComponent.connectedModalComponent)(component, true);
133
172
  }
134
- exports.default = fullscreenModalComponent;
173
+ var _default = exports.default = fullscreenModalComponent;
174
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_reactModal","_interopRequireDefault","_ConnectedModalComponent","_jsxRuntime","configureFullscreenModalComponent","WrappedComponent","FullscreenModalComponent","Component","constructor","props","_defineProperty2","default","e","document","documentElement","scrollTop","preventDefault","addEventListener","disableScroll","onEntering","removeEventListener","onExited","closeModal","setState","isOpen","state","undefined","getElementById","ReactModal","setAppElement","componentDidMount","onOpen","componentWillUnmount","componentDidUpdate","prevProps","prevState","onClose","render","contentLabel","isTopOpenFullscreenModal","_","zIndex","remainingProps","wrappedProps","jsx","style","content","position","top","left","right","bottom","overflow","padding","border","backgroundColor","overlay","portalClassName","shouldCloseOnOverlayClick","children","fullscreenModalComponent","component","connectedModalComponent","_default","exports"],"sources":["../../../src/components/HOC/FullscreenModalComponent.tsx"],"sourcesContent":["import { Component, ComponentClass, ComponentType } from 'react'\r\nimport ReactModal from 'react-modal'\r\nimport { connectedModalComponent, ConnectedModalWrappedProps } from './ConnectedModalComponent'\r\nimport { GuidComponentWrappedProps } from './GuidComponent'\r\n\r\n/**\r\n * The props that are provided to the HOC component directly from the caller, not other wrapping HOCs\r\n * NOTE: if more flexibility is needed, add more props from `ReactModal.Props`\r\n */\r\nexport interface FullscreenModalOwnProps {\r\n\t/* Boolean describing if the modal should be shown or not. If not provided, the modal manages itself, defaulting to open. */\r\n\tisOpen?: boolean\r\n\r\n\t/**\r\n\t * Function that will be called when the modal should be closed, and the parent should set `props.isOpen` to `false`.\r\n\t * If not provided, the modal manages itself.\r\n\t */\r\n\tcloseModal?: () => void\r\n\r\n\t/* String indicating how the content container should be announced to screen readers. */\r\n\tcontentLabel?: string\r\n\r\n\t/* Optional value indicating the zIndex the modal overlay should have */\r\n\tzIndex?: number\r\n}\r\n\r\n/** The props that are provided to the HOC component, either directly or from other wrapping HOCs */\r\nexport type FullscreenModalComponentProps = FullscreenModalOwnProps &\r\n\tConnectedModalWrappedProps &\r\n\tGuidComponentWrappedProps\r\n\r\n/** The props that are provide to the wrapped component. */\r\nexport interface FullscreenModalWrappedProps {\r\n\t/** GUID of the fullscreen modal, used in state.modals. */\r\n\tguid: string\r\n\t/** Function that will close the modal. */\r\n\tcloseModal: () => void\r\n}\r\n\r\ninterface FullscreenModalState {\r\n\tisOpen: boolean\r\n}\r\n\r\n/**\r\n * HOC that manages a `ReactModal`, adds inline css, and\r\n * coordinates modal state in redux using.\r\n *\r\n * NOTE: Meant for testing. Should be wrapped in `connectedModalComponent` normally.\r\n *\r\n * @param WrappedComponent The component to wrap.\r\n */\r\nexport function configureFullscreenModalComponent<TOwnProps extends object>(\r\n\tWrappedComponent: ComponentType<TOwnProps & FullscreenModalWrappedProps>\r\n) {\r\n\ttype HocProps = TOwnProps & FullscreenModalComponentProps\r\n\treturn class FullscreenModalComponent extends Component<HocProps, FullscreenModalState> {\r\n\t\tconstructor(props: HocProps) {\r\n\t\t\tsuper(props)\r\n\r\n\t\t\tthis.state = {\r\n\t\t\t\tisOpen: props.isOpen === undefined ? true : props.isOpen\r\n\t\t\t}\r\n\r\n\t\t\t// https://github.com/reactjs/react-modal#app-element\r\n\t\t\t// Accessibility fixed when reading the content in the modal\r\n\t\t\tif (document.getElementById('root')) {\r\n\t\t\t\tReactModal.setAppElement('#root')\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tcomponentDidMount() {\r\n\t\t\tconst { isOpen } = this.state\r\n\t\t\tif (isOpen) {\r\n\t\t\t\tthis.onOpen()\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tcomponentWillUnmount() {\r\n\t\t\tdocument.documentElement.removeEventListener('touchmove', this.disableScroll)\r\n\t\t}\r\n\r\n\t\tcomponentDidUpdate(prevProps: HocProps, prevState: FullscreenModalState) {\r\n\t\t\tlet isOpen: boolean | undefined\r\n\r\n\t\t\tif (this.props.isOpen !== undefined && this.props.isOpen !== this.state.isOpen) {\r\n\t\t\t\t// using props to handle isOpen, update state\r\n\t\t\t\tisOpen = this.props.isOpen\r\n\t\t\t} else if (this.props.isOpen === undefined && prevState.isOpen !== this.state.isOpen) {\r\n\t\t\t\t// using state only to handle isOpen\r\n\t\t\t\tisOpen = this.state.isOpen\r\n\t\t\t}\r\n\r\n\t\t\tif (isOpen === undefined) {\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\r\n\t\t\tif (isOpen) {\r\n\t\t\t\tthis.onOpen()\r\n\t\t\t} else {\r\n\t\t\t\tthis.onClose()\r\n\t\t\t}\r\n\t\t\tthis.setState({\r\n\t\t\t\tisOpen\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\tdisableScroll = (e: Event) => {\r\n\t\t\tdocument.documentElement.scrollTop = 0\r\n\t\t\te.preventDefault()\r\n\t\t\treturn false\r\n\t\t}\r\n\r\n\t\tonOpen = () => {\r\n\t\t\tdocument.documentElement.addEventListener('touchmove', this.disableScroll)\r\n\t\t\tthis.props.onEntering()\r\n\t\t}\r\n\r\n\t\tonClose = () => {\r\n\t\t\tdocument.documentElement.removeEventListener('touchmove', this.disableScroll)\r\n\t\t\tthis.props.onExited()\r\n\t\t}\r\n\r\n\t\tcloseModal = () => {\r\n\t\t\tif (this.props.closeModal) {\r\n\t\t\t\tthis.props.closeModal()\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\t\t\tthis.setState({\r\n\t\t\t\tisOpen: false\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\trender() {\r\n\t\t\tconst {\r\n\t\t\t\tcontentLabel,\r\n\t\t\t\tisTopOpenFullscreenModal,\r\n\t\t\t\tonEntering,\r\n\t\t\t\tonExited,\r\n\t\t\t\tisOpen: _,\r\n\t\t\t\tcloseModal,\r\n\t\t\t\tzIndex,\r\n\t\t\t\t...remainingProps\r\n\t\t\t} = this.props\r\n\t\t\t// do not pass ConnectedModalWrappedProps to wrapped component\r\n\t\t\tconst wrappedProps = {\r\n\t\t\t\t...remainingProps,\r\n\t\t\t\tcloseModal: this.closeModal\r\n\t\t\t} as TOwnProps & FullscreenModalWrappedProps\r\n\t\t\tconst { isOpen } = this.state\r\n\t\t\treturn (\r\n\t\t\t\t<ReactModal\r\n\t\t\t\t\tisOpen={isOpen}\r\n\t\t\t\t\tcontentLabel={contentLabel}\r\n\t\t\t\t\tstyle={{\r\n\t\t\t\t\t\tcontent: {\r\n\t\t\t\t\t\t\tposition: 'absolute',\r\n\t\t\t\t\t\t\ttop: 0,\r\n\t\t\t\t\t\t\tleft: 0,\r\n\t\t\t\t\t\t\tright: 0,\r\n\t\t\t\t\t\t\tbottom: 0,\r\n\t\t\t\t\t\t\toverflow: 'hidden',\r\n\t\t\t\t\t\t\tpadding: 0,\r\n\t\t\t\t\t\t\tborder: 'none',\r\n\t\t\t\t\t\t\tbackgroundColor: 'white'\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\toverlay: {\r\n\t\t\t\t\t\t\tposition: 'absolute',\r\n\t\t\t\t\t\t\ttop: 0,\r\n\t\t\t\t\t\t\tleft: 0,\r\n\t\t\t\t\t\t\tright: 0,\r\n\t\t\t\t\t\t\tbottom: 0,\r\n\t\t\t\t\t\t\tzIndex: zIndex ?? 2000\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}}\r\n\t\t\t\t\t// hide the rendered portal if this is not the top open fullscreen modal\r\n\t\t\t\t\tportalClassName={`ReactModalPortal${!isTopOpenFullscreenModal ? ' dn' : ''}`}\r\n\t\t\t\t\tshouldCloseOnOverlayClick={false}>\r\n\t\t\t\t\t<WrappedComponent {...wrappedProps} />\r\n\t\t\t\t</ReactModal>\r\n\t\t\t)\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/**\r\n * HOC that contains a `ReactModal` which can be auto managed or managed with props,\r\n * adds fullscreen styles, and coordinates modal state in redux.\r\n *\r\n * Uses `connectedModalComponent`.\r\n *\r\n * NOTE: Please add the following css\r\n *\r\n * .ReactModal__Body--open {\r\n * \toverflow: hidden;\r\n * }\r\n *\r\n * @param WrappedComponent The component to wrap.\r\n */\r\nexport function fullscreenModalComponent<TOwnProps extends object>(\r\n\tWrappedComponent: ComponentType<TOwnProps & FullscreenModalWrappedProps>\r\n): ComponentClass<TOwnProps & FullscreenModalOwnProps> {\r\n\tconst component = configureFullscreenModalComponent<TOwnProps>(WrappedComponent)\r\n\treturn connectedModalComponent(component, true)\r\n}\r\n\r\nexport default fullscreenModalComponent\r\n"],"mappings":"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","ignoreList":[]}
@@ -1,40 +1,54 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
3
6
  exports.configureMapStateToProps = void 0;
4
7
  exports.default = groupActivityRequiredComponent;
5
- const react_redux_1 = require("react-redux");
6
- const baseActivity_1 = require("../../utils/baseActivity");
7
- const ActivityRequiredComponent_1 = require("./ActivityRequiredComponent");
8
- /**
9
- * Return `mapStateToProps` function. Add a `hasAccess` boolean property to the component's props
10
- * checking whether the user has the passed `requiredActivity` for the group referenced by
11
- * `ownProps.model.groupId`, if any.
12
- *
13
- * @param accessPredicate A predicate accepting a required activity and an optional entity and/or userInfo object
14
- * @param requiredActivity The required activity which is passed to the predicate for evaluation
15
- * @param redirectPath (Optional) A string or function that provides the redirect path for when `accessPredicate` is false. Defaults to '/'.
8
+ var _reactRedux = require("react-redux");
9
+ var _baseActivity = require("../../utils/baseActivity");
10
+ var _ActivityRequiredComponent = require("./ActivityRequiredComponent");
11
+ /**
12
+ * An entity that has a `groupId`
13
+ */
14
+
15
+ /**
16
+ * Return `mapStateToProps` function. Add a `hasAccess` boolean property to the component's props
17
+ * checking whether the user has the passed `requiredActivity` for the group referenced by
18
+ * `ownProps.model.groupId`, if any.
19
+ *
20
+ * @param accessPredicate A predicate accepting a required activity and an optional entity and/or userInfo object
21
+ * @param requiredActivity The required activity which is passed to the predicate for evaluation
22
+ * @param redirectPath (Optional) A string or function that provides the redirect path for when `accessPredicate` is false. Defaults to '/'.
16
23
  */
17
24
  const configureMapStateToProps = (accessPredicate, requiredActivity, redirectPath) => (state, ownProps) => {
18
- const entity = ownProps && state.models.groups ? state.models.groups[ownProps.model.groupId] : undefined;
19
- const options = Object.assign(Object.assign({}, (0, baseActivity_1.defaultOptions)(state, ownProps)), { entity });
20
- return {
21
- hasAccess: accessPredicate(requiredActivity, options),
22
- redirectPath: (typeof redirectPath === 'function' ? redirectPath(options) : redirectPath) || '/'
23
- };
25
+ const entity = ownProps && state.models.groups ? state.models.groups[ownProps.model.groupId] : undefined;
26
+ const options = {
27
+ ...(0, _baseActivity.defaultOptions)(state, ownProps),
28
+ ...{
29
+ entity
30
+ }
31
+ };
32
+ return {
33
+ hasAccess: accessPredicate(requiredActivity, options),
34
+ redirectPath: (typeof redirectPath === 'function' ? redirectPath(options) : redirectPath) || '/'
35
+ };
24
36
  };
25
- exports.configureMapStateToProps = configureMapStateToProps;
26
- /**
27
- * This HOC ensures that the wrapped component is only rendered if the group referenced by
28
- * `props.model.groupId`, if any, satisfies the `accessPredicate` for the `requiredActivity`.
29
- *
30
- * @param WrappedComponent The component which requires activity/activities in order to render
31
- * @param accessPredicate A predicate accepting a required activity and an optional entity and/or userInfo object
32
- * @param requiredActivity The required activity which is passed to the predicate for evaluation
33
- * @param redirectPath (Optional) A string or function that provides the redirect path for when `accessPredicate` is false. Defaults to '/'.
37
+
38
+ /**
39
+ * This HOC ensures that the wrapped component is only rendered if the group referenced by
40
+ * `props.model.groupId`, if any, satisfies the `accessPredicate` for the `requiredActivity`.
41
+ *
42
+ * @param WrappedComponent The component which requires activity/activities in order to render
43
+ * @param accessPredicate A predicate accepting a required activity and an optional entity and/or userInfo object
44
+ * @param requiredActivity The required activity which is passed to the predicate for evaluation
45
+ * @param redirectPath (Optional) A string or function that provides the redirect path for when `accessPredicate` is false. Defaults to '/'.
34
46
  */
47
+ exports.configureMapStateToProps = configureMapStateToProps;
35
48
  function groupActivityRequiredComponent(WrappedComponent, accessPredicate, requiredActivity, redirectPath) {
36
- const ActivityRequiredComponent = (0, ActivityRequiredComponent_1.configureActivityRequiredComponent)(WrappedComponent);
37
- const mapStateToProps = (0, exports.configureMapStateToProps)(accessPredicate, requiredActivity, redirectPath);
38
- // @ts-ignore: could not match inferred type from the `connect` HOC
39
- return (0, react_redux_1.connect)(mapStateToProps)(ActivityRequiredComponent);
49
+ const ActivityRequiredComponent = (0, _ActivityRequiredComponent.configureActivityRequiredComponent)(WrappedComponent);
50
+ const mapStateToProps = configureMapStateToProps(accessPredicate, requiredActivity, redirectPath);
51
+ // @ts-ignore: could not match inferred type from the `connect` HOC
52
+ return (0, _reactRedux.connect)(mapStateToProps)(ActivityRequiredComponent);
40
53
  }
54
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3RSZWR1eCIsInJlcXVpcmUiLCJfYmFzZUFjdGl2aXR5IiwiX0FjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQiLCJjb25maWd1cmVNYXBTdGF0ZVRvUHJvcHMiLCJhY2Nlc3NQcmVkaWNhdGUiLCJyZXF1aXJlZEFjdGl2aXR5IiwicmVkaXJlY3RQYXRoIiwic3RhdGUiLCJvd25Qcm9wcyIsImVudGl0eSIsIm1vZGVscyIsImdyb3VwcyIsIm1vZGVsIiwiZ3JvdXBJZCIsInVuZGVmaW5lZCIsIm9wdGlvbnMiLCJkZWZhdWx0T3B0aW9ucyIsImhhc0FjY2VzcyIsImV4cG9ydHMiLCJncm91cEFjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQiLCJXcmFwcGVkQ29tcG9uZW50IiwiQWN0aXZpdHlSZXF1aXJlZENvbXBvbmVudCIsImNvbmZpZ3VyZUFjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQiLCJtYXBTdGF0ZVRvUHJvcHMiLCJjb25uZWN0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvSE9DL0dyb3VwQWN0aXZpdHlSZXF1aXJlZENvbXBvbmVudC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50Q2xhc3MsIENvbXBvbmVudFR5cGUgfSBmcm9tICdyZWFjdCdcclxuaW1wb3J0IHsgY29ubmVjdCB9IGZyb20gJ3JlYWN0LXJlZHV4J1xyXG5pbXBvcnQgeyBCYXNlUmVkdXhTdGF0ZSwgTW9kZWwgfSBmcm9tICcuLi8uLi90eXBlcydcclxuaW1wb3J0IHsgQWN0aXZpdHlPcHRpb25zLCBkZWZhdWx0T3B0aW9ucyB9IGZyb20gJy4uLy4uL3V0aWxzL2Jhc2VBY3Rpdml0eSdcclxuaW1wb3J0IHsgQWN0aXZpdHlSZXF1aXJlZFN0YXRlUHJvcHMsIGNvbmZpZ3VyZUFjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQgfSBmcm9tICcuL0FjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQnXHJcbmltcG9ydCB7IENvbGxlY3Rpb25JdGVtQ29tcG9uZW50V3JhcHBlZFByb3BzIH0gZnJvbSAnLi9Db2xsZWN0aW9uSXRlbUNvbXBvbmVudCdcclxuXHJcbi8qKlxyXG4gKiBBbiBlbnRpdHkgdGhhdCBoYXMgYSBgZ3JvdXBJZGBcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgR3JvdXBSZWxhdGVkRW50aXR5IGV4dGVuZHMgTW9kZWwge1xyXG5cdGdyb3VwSWQ6IG51bWJlclxyXG59XHJcblxyXG4vKipcclxuICogUmV0dXJuIGBtYXBTdGF0ZVRvUHJvcHNgIGZ1bmN0aW9uLiBBZGQgYSBgaGFzQWNjZXNzYCBib29sZWFuIHByb3BlcnR5IHRvIHRoZSBjb21wb25lbnQncyBwcm9wc1xyXG4gKiBjaGVja2luZyB3aGV0aGVyIHRoZSB1c2VyIGhhcyB0aGUgcGFzc2VkIGByZXF1aXJlZEFjdGl2aXR5YCBmb3IgdGhlIGdyb3VwIHJlZmVyZW5jZWQgYnlcclxuICogYG93blByb3BzLm1vZGVsLmdyb3VwSWRgLCBpZiBhbnkuXHJcbiAqXHJcbiAqIEBwYXJhbSBhY2Nlc3NQcmVkaWNhdGUgQSBwcmVkaWNhdGUgYWNjZXB0aW5nIGEgcmVxdWlyZWQgYWN0aXZpdHkgYW5kIGFuIG9wdGlvbmFsIGVudGl0eSBhbmQvb3IgdXNlckluZm8gb2JqZWN0XHJcbiAqIEBwYXJhbSByZXF1aXJlZEFjdGl2aXR5IFRoZSByZXF1aXJlZCBhY3Rpdml0eSB3aGljaCBpcyBwYXNzZWQgdG8gdGhlIHByZWRpY2F0ZSBmb3IgZXZhbHVhdGlvblxyXG4gKiBAcGFyYW0gcmVkaXJlY3RQYXRoIChPcHRpb25hbCkgQSBzdHJpbmcgb3IgZnVuY3Rpb24gdGhhdCBwcm92aWRlcyB0aGUgcmVkaXJlY3QgcGF0aCBmb3Igd2hlbiBgYWNjZXNzUHJlZGljYXRlYCBpcyBmYWxzZS4gRGVmYXVsdHMgdG8gJy8nLlxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IGNvbmZpZ3VyZU1hcFN0YXRlVG9Qcm9wcyA9XHJcblx0KFxyXG5cdFx0YWNjZXNzUHJlZGljYXRlOiAocmVxdWlyZWRBY3Rpdml0eTogc3RyaW5nLCBvcHRpb25zOiBBY3Rpdml0eU9wdGlvbnMpID0+IGJvb2xlYW4sXHJcblx0XHRyZXF1aXJlZEFjdGl2aXR5OiBzdHJpbmcsXHJcblx0XHRyZWRpcmVjdFBhdGg/OiBzdHJpbmcgfCAoKG9wdGlvbnM6IEFjdGl2aXR5T3B0aW9ucykgPT4gc3RyaW5nIHwgdW5kZWZpbmVkKVxyXG5cdCkgPT5cclxuXHQoXHJcblx0XHRzdGF0ZTogQmFzZVJlZHV4U3RhdGUsXHJcblx0XHRvd25Qcm9wcz86IENvbGxlY3Rpb25JdGVtQ29tcG9uZW50V3JhcHBlZFByb3BzPEdyb3VwUmVsYXRlZEVudGl0eT5cclxuXHQpOiBBY3Rpdml0eVJlcXVpcmVkU3RhdGVQcm9wcyA9PiB7XHJcblx0XHRjb25zdCBlbnRpdHkgPSBvd25Qcm9wcyAmJiBzdGF0ZS5tb2RlbHMuZ3JvdXBzID8gc3RhdGUubW9kZWxzLmdyb3Vwc1tvd25Qcm9wcy5tb2RlbC5ncm91cElkXSA6IHVuZGVmaW5lZFxyXG5cdFx0Y29uc3Qgb3B0aW9ucyA9IHsgLi4uZGVmYXVsdE9wdGlvbnMoc3RhdGUsIG93blByb3BzKSwgLi4ueyBlbnRpdHkgfSB9IGFzIEFjdGl2aXR5T3B0aW9uc1xyXG5cdFx0cmV0dXJuIHtcclxuXHRcdFx0aGFzQWNjZXNzOiBhY2Nlc3NQcmVkaWNhdGUocmVxdWlyZWRBY3Rpdml0eSwgb3B0aW9ucyksXHJcblx0XHRcdHJlZGlyZWN0UGF0aDogKHR5cGVvZiByZWRpcmVjdFBhdGggPT09ICdmdW5jdGlvbicgPyByZWRpcmVjdFBhdGgob3B0aW9ucykgOiByZWRpcmVjdFBhdGgpIHx8ICcvJ1xyXG5cdFx0fVxyXG5cdH1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIEhPQyBlbnN1cmVzIHRoYXQgdGhlIHdyYXBwZWQgY29tcG9uZW50IGlzIG9ubHkgcmVuZGVyZWQgaWYgdGhlIGdyb3VwIHJlZmVyZW5jZWQgYnlcclxuICogYHByb3BzLm1vZGVsLmdyb3VwSWRgLCBpZiBhbnksIHNhdGlzZmllcyB0aGUgYGFjY2Vzc1ByZWRpY2F0ZWAgZm9yIHRoZSBgcmVxdWlyZWRBY3Rpdml0eWAuXHJcbiAqXHJcbiAqIEBwYXJhbSBXcmFwcGVkQ29tcG9uZW50IFRoZSBjb21wb25lbnQgd2hpY2ggcmVxdWlyZXMgYWN0aXZpdHkvYWN0aXZpdGllcyBpbiBvcmRlciB0byByZW5kZXJcclxuICogQHBhcmFtIGFjY2Vzc1ByZWRpY2F0ZSBBIHByZWRpY2F0ZSBhY2NlcHRpbmcgYSByZXF1aXJlZCBhY3Rpdml0eSBhbmQgYW4gb3B0aW9uYWwgZW50aXR5IGFuZC9vciB1c2VySW5mbyBvYmplY3RcclxuICogQHBhcmFtIHJlcXVpcmVkQWN0aXZpdHkgVGhlIHJlcXVpcmVkIGFjdGl2aXR5IHdoaWNoIGlzIHBhc3NlZCB0byB0aGUgcHJlZGljYXRlIGZvciBldmFsdWF0aW9uXHJcbiAqIEBwYXJhbSByZWRpcmVjdFBhdGggKE9wdGlvbmFsKSBBIHN0cmluZyBvciBmdW5jdGlvbiB0aGF0IHByb3ZpZGVzIHRoZSByZWRpcmVjdCBwYXRoIGZvciB3aGVuIGBhY2Nlc3NQcmVkaWNhdGVgIGlzIGZhbHNlLiBEZWZhdWx0cyB0byAnLycuXHJcbiAqL1xyXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBncm91cEFjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQ8XHJcblx0VE93blByb3BzIGV4dGVuZHMgQ29sbGVjdGlvbkl0ZW1Db21wb25lbnRXcmFwcGVkUHJvcHM8R3JvdXBSZWxhdGVkRW50aXR5PlxyXG4+KFxyXG5cdFdyYXBwZWRDb21wb25lbnQ6IENvbXBvbmVudFR5cGU8VE93blByb3BzPixcclxuXHRhY2Nlc3NQcmVkaWNhdGU6IChyZXF1aXJlZEFjdGl2aXR5OiBzdHJpbmcsIG9wdGlvbnM6IGFueSkgPT4gYm9vbGVhbixcclxuXHRyZXF1aXJlZEFjdGl2aXR5OiBzdHJpbmcsXHJcblx0cmVkaXJlY3RQYXRoPzogc3RyaW5nIHwgKChvcHRpb25zOiBBY3Rpdml0eU9wdGlvbnMpID0+IHN0cmluZyB8IHVuZGVmaW5lZClcclxuKTogQ29tcG9uZW50Q2xhc3M8VE93blByb3BzPiB7XHJcblx0Y29uc3QgQWN0aXZpdHlSZXF1aXJlZENvbXBvbmVudCA9IGNvbmZpZ3VyZUFjdGl2aXR5UmVxdWlyZWRDb21wb25lbnQoV3JhcHBlZENvbXBvbmVudClcclxuXHRjb25zdCBtYXBTdGF0ZVRvUHJvcHMgPSBjb25maWd1cmVNYXBTdGF0ZVRvUHJvcHMoYWNjZXNzUHJlZGljYXRlLCByZXF1aXJlZEFjdGl2aXR5LCByZWRpcmVjdFBhdGgpXHJcblx0Ly8gQHRzLWlnbm9yZTogY291bGQgbm90IG1hdGNoIGluZmVycmVkIHR5cGUgZnJvbSB0aGUgYGNvbm5lY3RgIEhPQ1xyXG5cdHJldHVybiBjb25uZWN0KG1hcFN0YXRlVG9Qcm9wcykoQWN0aXZpdHlSZXF1aXJlZENvbXBvbmVudClcclxufVxyXG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFDQSxJQUFBQSxXQUFBLEdBQUFDLE9BQUE7QUFFQSxJQUFBQyxhQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSwwQkFBQSxHQUFBRixPQUFBO0FBR0E7QUFDQTtBQUNBOztBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNPLE1BQU1HLHdCQUF3QixHQUNwQ0EsQ0FDQ0MsZUFBZ0YsRUFDaEZDLGdCQUF3QixFQUN4QkMsWUFBMEUsS0FFM0UsQ0FDQ0MsS0FBcUIsRUFDckJDLFFBQWtFLEtBQ2xDO0VBQ2hDLE1BQU1DLE1BQU0sR0FBR0QsUUFBUSxJQUFJRCxLQUFLLENBQUNHLE1BQU0sQ0FBQ0MsTUFBTSxHQUFHSixLQUFLLENBQUNHLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDSCxRQUFRLENBQUNJLEtBQUssQ0FBQ0MsT0FBTyxDQUFDLEdBQUdDLFNBQVM7RUFDeEcsTUFBTUMsT0FBTyxHQUFHO0lBQUUsR0FBRyxJQUFBQyw0QkFBYyxFQUFDVCxLQUFLLEVBQUVDLFFBQVEsQ0FBQztJQUFFLEdBQUc7TUFBRUM7SUFBTztFQUFFLENBQW9CO0VBQ3hGLE9BQU87SUFDTlEsU0FBUyxFQUFFYixlQUFlLENBQUNDLGdCQUFnQixFQUFFVSxPQUFPLENBQUM7SUFDckRULFlBQVksRUFBRSxDQUFDLE9BQU9BLFlBQVksS0FBSyxVQUFVLEdBQUdBLFlBQVksQ0FBQ1MsT0FBTyxDQUFDLEdBQUdULFlBQVksS0FBSztFQUM5RixDQUFDO0FBQ0YsQ0FBQzs7QUFFRjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFSQVksT0FBQSxDQUFBZix3QkFBQSxHQUFBQSx3QkFBQTtBQVNlLFNBQVNnQiw4QkFBOEJBLENBR3JEQyxnQkFBMEMsRUFDMUNoQixlQUFvRSxFQUNwRUMsZ0JBQXdCLEVBQ3hCQyxZQUEwRSxFQUM5QztFQUM1QixNQUFNZSx5QkFBeUIsR0FBRyxJQUFBQyw2REFBa0MsRUFBQ0YsZ0JBQWdCLENBQUM7RUFDdEYsTUFBTUcsZUFBZSxHQUFHcEIsd0JBQXdCLENBQUNDLGVBQWUsRUFBRUMsZ0JBQWdCLEVBQUVDLFlBQVksQ0FBQztFQUNqRztFQUNBLE9BQU8sSUFBQWtCLG1CQUFPLEVBQUNELGVBQWUsQ0FBQyxDQUFDRix5QkFBeUIsQ0FBQztBQUMzRCIsImlnbm9yZUxpc3QiOltdfQ==