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.
- package/lib/components/ActionList.js +170 -34
- package/lib/components/AlertDialog.js +133 -9
- package/lib/components/AlertWithIcon.js +92 -25
- package/lib/components/ConnectedModal.js +43 -13
- package/lib/components/Dropdowns/GroupsDropdown.js +69 -44
- package/lib/components/Dropdowns/ManagedNavDropdown.js +100 -67
- package/lib/components/Dropdowns/UserDropdown.js +111 -21
- package/lib/components/Dropdowns/index.js +27 -9
- package/lib/components/EntityOwnerList.js +52 -18
- package/lib/components/Error.js +106 -11
- package/lib/components/ErrorBoundary.js +134 -35
- package/lib/components/ErrorMessage.js +44 -9
- package/lib/components/Forms/DateField.js +61 -42
- package/lib/components/Forms/TimeField.js +81 -42
- package/lib/components/Forms/index.js +27 -4
- package/lib/components/Groups/CreateEditCopySaveButtons.js +114 -11
- package/lib/components/Groups/ExternalGroups/Attach.js +212 -148
- package/lib/components/Groups/ExternalGroups/Table.js +181 -45
- package/lib/components/Groups/GroupCreateOrEditCommonProps.js +5 -1
- package/lib/components/Groups/RosterSyncInfo.js +147 -20
- package/lib/components/HOC/AccessibleAppComponent.js +98 -73
- package/lib/components/HOC/ActivityRequiredComponent.js +92 -49
- package/lib/components/HOC/AsyncComponent.js +54 -39
- package/lib/components/HOC/AuthenticatedComponent.js +58 -38
- package/lib/components/HOC/CollectionComponent.js +170 -110
- package/lib/components/HOC/CollectionFirstItemComponent.js +51 -38
- package/lib/components/HOC/CollectionItemComponent.js +168 -106
- package/lib/components/HOC/ConnectedModalComponent.js +109 -80
- package/lib/components/HOC/DataDependentComponent.js +29 -21
- package/lib/components/HOC/EntityComponent.js +71 -57
- package/lib/components/HOC/FullscreenModalComponent.js +163 -123
- package/lib/components/HOC/GroupActivityRequiredComponent.js +45 -31
- package/lib/components/HOC/GuidComponent.js +29 -22
- package/lib/components/HOC/ModelContextDependencyVerifyComponent.js +41 -31
- package/lib/components/HOC/ModelErrorRedirectComponent.js +51 -47
- package/lib/components/HOC/SearchPersistorComponent.js +240 -166
- package/lib/components/HOC/UnauthenticatedComponent.js +37 -25
- package/lib/components/HOC/UserComponent.js +12 -7
- package/lib/components/Icons/IconAlphaList.js +33 -5
- package/lib/components/Icons/IconExternalUser.js +33 -5
- package/lib/components/Icons/IconImpersonation.js +33 -5
- package/lib/components/Icons/IconStopImpersonating.js +33 -5
- package/lib/components/Icons/IconTable.js +35 -7
- package/lib/components/Icons/IconTableDeleteCol.js +33 -5
- package/lib/components/Icons/IconTableDeleteRow.js +33 -5
- package/lib/components/Icons/IconTableInsertCol.js +33 -5
- package/lib/components/Icons/IconTableInsertRow.js +33 -5
- package/lib/components/Impersonation/Button.js +77 -13
- package/lib/components/Impersonation/Link.js +77 -13
- package/lib/components/Impersonation/UserDetail.js +66 -9
- package/lib/components/Loading.js +26 -4
- package/lib/components/LockDownBrowser/Check.js +194 -49
- package/lib/components/LockDownBrowser/ExitButton.js +26 -9
- package/lib/components/LockDownBrowser/Launch.js +70 -62
- package/lib/components/Lti/Confirm.js +152 -11
- package/lib/components/Lti/CreateNonLtiGroupAlertDialog.js +170 -33
- package/lib/components/Lti/Launch.js +105 -24
- package/lib/components/Lti/LaunchGroup.js +85 -13
- package/lib/components/ManageTable.js +309 -87
- package/lib/components/ManageTableNoDataComponent.js +42 -4
- package/lib/components/NewVersionAlert.js +82 -46
- package/lib/components/NotFound.js +86 -10
- package/lib/components/Notifications.js +185 -126
- package/lib/components/PaginationNextButton.js +33 -6
- package/lib/components/PaginationPreviousButton.js +33 -6
- package/lib/components/Quill/CustomToolbar.js +432 -218
- package/lib/components/Quill/Formats/Image.js +73 -63
- package/lib/components/Quill/Formats/List.js +45 -45
- package/lib/components/Quill/Formats/Video.js +28 -24
- package/lib/components/Quill/ImageDropModule.js +147 -117
- package/lib/components/Quill/ImageWarning.js +47 -9
- package/lib/components/Quill/ImageWithAltTextModal.js +425 -86
- package/lib/components/Quill/Specs/CustomImageSpec.js +42 -34
- package/lib/components/Quill/Specs/CustomVideoSpec.js +34 -28
- package/lib/components/Quill/TableModule/Blots/BaseTableBlot.js +98 -98
- package/lib/components/Quill/TableModule/Blots/TableBlot.js +52 -47
- package/lib/components/Quill/TableModule/Blots/TableBodyBlot.js +53 -48
- package/lib/components/Quill/TableModule/Blots/TableCellBlot.js +224 -221
- package/lib/components/Quill/TableModule/Blots/TableContainer.js +80 -83
- package/lib/components/Quill/TableModule/Blots/TableRowBlot.js +75 -70
- package/lib/components/Quill/TableModule/constants.js +45 -41
- package/lib/components/Quill/TableModule/index.js +362 -301
- package/lib/components/Quill/TableModule/utils.js +42 -38
- package/lib/components/Quill/accessibilityFix.js +234 -232
- package/lib/components/Quill/index.js +34 -28
- package/lib/components/RefreshIndicator/Bordered.js +47 -6
- package/lib/components/RefreshIndicator/Inline.js +47 -8
- package/lib/components/RefreshIndicator/index.js +263 -59
- package/lib/components/SearchControls.js +216 -11
- package/lib/components/SentryRoute.js +11 -6
- package/lib/components/Tables/RoleFilter.js +69 -32
- package/lib/components/Tables/TextFilter.js +62 -13
- package/lib/components/UserRoles/Add.js +199 -96
- package/lib/components/UserRoles/Context.js +11 -7
- package/lib/components/UserRoles/RoleCell.js +181 -72
- package/lib/components/UserRoles/Select.js +157 -17
- package/lib/components/UserRoles/Table.js +221 -80
- package/lib/components/UserRoles/index.js +534 -384
- package/lib/config/eslint/index.js +32 -28
- package/lib/config/eslint/lib/order.js +26 -27
- package/lib/config/eslint/lib/prettier.js +20 -18
- package/lib/config/eslint/lib/typescript.js +93 -112
- package/lib/config/eslint/react.js +24 -14
- package/lib/constants/baseActivity.js +30 -26
- package/lib/constants/baseRole.js +14 -10
- package/lib/constants/configuration.js +33 -29
- package/lib/constants/externalProviderType.js +10 -6
- package/lib/constants/fetchErrorData.js +15 -11
- package/lib/constants/index.js +137 -14
- package/lib/constants/lockDownBrowser.js +28 -24
- package/lib/constants/mockData.js +382 -297
- package/lib/constants/modelStatus.js +15 -11
- package/lib/constants/notificationType.js +12 -8
- package/lib/constants/operatingSystem.js +12 -8
- package/lib/constants/shard.js +11 -7
- package/lib/constants/table.js +21 -21
- package/lib/constants/tier.js +12 -8
- package/lib/constants/userRole.js +15 -5
- package/lib/endpointMappings.js +197 -181
- package/lib/hooks/useCollection.js +82 -62
- package/lib/hooks/useCollectionConfiguration.js +228 -83
- package/lib/hooks/useCollectionItem.js +154 -54
- package/lib/hooks/useGuid.js +20 -8
- package/lib/hooks/usePrevious.js +19 -13
- package/lib/index.js +157 -25
- package/lib/redux/actionCreator.js +50 -28
- package/lib/redux/actions/AuthAction.js +44 -31
- package/lib/redux/actions/ModalAction.js +10 -6
- package/lib/redux/actions/ModelAction.js +77 -39
- package/lib/redux/actions/NotificationAction.js +10 -6
- package/lib/redux/actions/SearchAction.js +9 -5
- package/lib/redux/actions/index.js +60 -7
- package/lib/redux/configureReducers.js +60 -49
- package/lib/redux/configureStore.js +83 -87
- package/lib/redux/helpers.js +6 -2
- package/lib/redux/reducers/authReducer.js +50 -43
- package/lib/redux/reducers/index.js +41 -13
- package/lib/redux/reducers/modalsReducer.js +47 -29
- package/lib/redux/reducers/modelsReducer.js +178 -173
- package/lib/redux/reducers/notificationsReducer.js +24 -18
- package/lib/redux/reducers/searchReducer.js +25 -19
- package/lib/redux/sagas/appInsightsSaga.js +22 -18
- package/lib/redux/sagas/authSaga.js +253 -218
- package/lib/redux/sagas/caliperSaga.js +159 -143
- package/lib/redux/sagas/clockOffsetSaga.js +34 -31
- package/lib/redux/sagas/configurationSaga.js +11 -7
- package/lib/redux/sagas/downtimeApiErrorSaga.js +20 -17
- package/lib/redux/sagas/errorSaga.js +27 -21
- package/lib/redux/sagas/googleAnalyticsSaga.js +28 -24
- package/lib/redux/sagas/identityProviderSaga.js +22 -18
- package/lib/redux/sagas/initialDataLoadSaga.js +37 -28
- package/lib/redux/sagas/lockDownBrowserErrorSaga.js +29 -20
- package/lib/redux/sagas/modelFetchSaga.js +355 -322
- package/lib/redux/sagas/noStoreSaga.js +61 -48
- package/lib/redux/sagas/postLoginDataSaga.js +45 -34
- package/lib/redux/sagas/postLoginRedirectSaga.js +27 -27
- package/lib/redux/sagas/rootSaga.js +82 -57
- package/lib/redux/sagas/sentrySaga.js +29 -25
- package/lib/redux/sagas/userIdSaga.js +16 -12
- package/lib/services/codeProviderService.js +25 -19
- package/lib/services/dateService.js +12 -7
- package/lib/services/documentService.js +17 -12
- package/lib/services/fetchService.js +129 -112
- package/lib/services/persistenceService.js +33 -29
- package/lib/services/ticketProviderService.js +29 -23
- package/lib/services/tokenPersistenceService.js +12 -8
- package/lib/services/windowService.js +18 -14
- package/lib/startup.js +132 -114
- package/lib/types/AppConfiguration.js +5 -1
- package/lib/types/Artifact.js +11 -7
- package/lib/types/BaseReduxState.js +5 -1
- package/lib/types/Client.js +5 -1
- package/lib/types/Collection.js +5 -1
- package/lib/types/Configuration.js +5 -1
- package/lib/types/DeepLinkingResponseRequest.js +5 -1
- package/lib/types/DeletableModel.js +5 -1
- package/lib/types/Event.js +5 -1
- package/lib/types/ExternalGroup.js +5 -1
- package/lib/types/ExternalProvider.js +5 -1
- package/lib/types/ExternalTerm.js +5 -1
- package/lib/types/Group.js +5 -1
- package/lib/types/IdentityProvider.js +5 -1
- package/lib/types/LtiLaunch.js +5 -1
- package/lib/types/NameOnlyEntity.js +5 -1
- package/lib/types/Notification.js +5 -1
- package/lib/types/OptionalRecord.js +5 -1
- package/lib/types/OwnerSchedule.js +5 -1
- package/lib/types/PropertyOfType.js +5 -1
- package/lib/types/Quill.js +5 -1
- package/lib/types/RoleDescription.js +5 -1
- package/lib/types/Search.js +5 -1
- package/lib/types/SimpleLocation.js +5 -1
- package/lib/types/UniTime.js +5 -1
- package/lib/types/User.js +5 -1
- package/lib/types/UserRole.js +5 -1
- package/lib/types/auth/AuthState.js +5 -1
- package/lib/types/auth/CasV1LoginRequestBody.js +5 -1
- package/lib/types/auth/ClientCredentials.js +5 -1
- package/lib/types/auth/CodeProviderService.js +5 -1
- package/lib/types/auth/LocalLoginRequestBody.js +5 -1
- package/lib/types/auth/TicketProviderService.js +5 -1
- package/lib/types/auth/TokenPersistenceService.js +5 -1
- package/lib/types/auth/index.js +82 -9
- package/lib/types/externals.d.js +2 -0
- package/lib/types/index.js +313 -30
- package/lib/types/net/EndpointConfig.js +5 -1
- package/lib/types/net/EndpointMapping.js +5 -1
- package/lib/types/net/EndpointMappings.js +5 -1
- package/lib/types/net/ErrorHandler.js +5 -1
- package/lib/types/net/FetchConfig.js +5 -1
- package/lib/types/net/FetchErrorData.js +10 -6
- package/lib/types/net/FetchResult.js +5 -1
- package/lib/types/net/HTTPMethod.js +5 -1
- package/lib/types/net/HTTPStatusCode.js +16 -12
- package/lib/types/net/Metadata.js +5 -1
- package/lib/types/net/Model.js +5 -1
- package/lib/types/net/ModelCollection.js +5 -1
- package/lib/types/net/ModelsState.js +5 -1
- package/lib/types/net/OAuthToken.js +5 -1
- package/lib/types/net/OAuthTokenOrNull.js +5 -1
- package/lib/types/net/TokenAccessFunction.js +5 -1
- package/lib/types/net/index.js +181 -18
- package/lib/utils/baseActivity.js +133 -123
- package/lib/utils/baseRole.js +37 -33
- package/lib/utils/collection.js +425 -298
- package/lib/utils/cookies.js +22 -19
- package/lib/utils/date.js +303 -279
- package/lib/utils/dom.js +176 -165
- package/lib/utils/domainIdentifier.js +9 -5
- package/lib/utils/entityUserRole.js +6 -2
- package/lib/utils/error.js +17 -15
- package/lib/utils/events.js +40 -31
- package/lib/utils/externalGroup.js +22 -18
- package/lib/utils/externalProviders.js +8 -4
- package/lib/utils/externalTerms.js +10 -3
- package/lib/utils/fetch.js +179 -180
- package/lib/utils/group.js +18 -7
- package/lib/utils/groupDates.js +37 -33
- package/lib/utils/groupRoles.js +25 -21
- package/lib/utils/lockDownBrowser.js +15 -11
- package/lib/utils/logger.js +26 -22
- package/lib/utils/lti.js +9 -4
- package/lib/utils/model.js +36 -41
- package/lib/utils/number.js +21 -18
- package/lib/utils/promise.js +28 -21
- package/lib/utils/quill.js +65 -62
- package/lib/utils/route.js +58 -55
- package/lib/utils/search.js +76 -80
- package/lib/utils/shard.js +37 -37
- package/lib/utils/sort.js +50 -42
- package/lib/utils/string.js +13 -8
- package/lib/utils/table.js +38 -33
- package/lib/utils/timezone.js +10 -6
- package/lib/utils/url.js +142 -142
- package/lib/utils/user.js +58 -55
- package/lib/utils/userAgent.js +10 -10
- package/lib/utils/userRole.js +57 -49
- package/package.json +17 -3
|
@@ -1,68 +1,82 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
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
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
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
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
|
-
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
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
|
-
|
|
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
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
*
|
|
12
|
-
*
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
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
|
-
|
|
118
|
-
*
|
|
119
|
-
*
|
|
120
|
-
*
|
|
121
|
-
*
|
|
122
|
-
*
|
|
123
|
-
*
|
|
124
|
-
*
|
|
125
|
-
*
|
|
126
|
-
*
|
|
127
|
-
*
|
|
128
|
-
*
|
|
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
|
-
|
|
132
|
-
|
|
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":";;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,wBAAA,GAAAH,OAAA;AAA+F,IAAAI,WAAA,GAAAJ,OAAA;AAG/F;AACA;AACA;AACA;;AAkBA;;AAKA;;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASK,iCAAiCA,CAChDC,gBAAwE,EACvE;EAED,OAAO,MAAMC,wBAAwB,SAASC,gBAAS,CAAiC;IACvFC,WAAWA,CAACC,KAAe,EAAE;MAC5B,KAAK,CAACA,KAAK,CAAC;MAAA,IAAAC,gBAAA,CAAAC,OAAA,yBAiDIC,CAAQ,IAAK;QAC7BC,QAAQ,CAACC,eAAe,CAACC,SAAS,GAAG,CAAC;QACtCH,CAAC,CAACI,cAAc,CAAC,CAAC;QAClB,OAAO,KAAK;MACb,CAAC;MAAA,IAAAN,gBAAA,CAAAC,OAAA,kBAEQ,MAAM;QACdE,QAAQ,CAACC,eAAe,CAACG,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAACC,aAAa,CAAC;QAC1E,IAAI,CAACT,KAAK,CAACU,UAAU,CAAC,CAAC;MACxB,CAAC;MAAA,IAAAT,gBAAA,CAAAC,OAAA,mBAES,MAAM;QACfE,QAAQ,CAACC,eAAe,CAACM,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAACF,aAAa,CAAC;QAC7E,IAAI,CAACT,KAAK,CAACY,QAAQ,CAAC,CAAC;MACtB,CAAC;MAAA,IAAAX,gBAAA,CAAAC,OAAA,sBAEY,MAAM;QAClB,IAAI,IAAI,CAACF,KAAK,CAACa,UAAU,EAAE;UAC1B,IAAI,CAACb,KAAK,CAACa,UAAU,CAAC,CAAC;UACvB;QACD;QACA,IAAI,CAACC,QAAQ,CAAC;UACbC,MAAM,EAAE;QACT,CAAC,CAAC;MACH,CAAC;MAvEA,IAAI,CAACC,KAAK,GAAG;QACZD,MAAM,EAAEf,KAAK,CAACe,MAAM,KAAKE,SAAS,GAAG,IAAI,GAAGjB,KAAK,CAACe;MACnD,CAAC;;MAED;MACA;MACA,IAAIX,QAAQ,CAACc,cAAc,CAAC,MAAM,CAAC,EAAE;QACpCC,mBAAU,CAACC,aAAa,CAAC,OAAO,CAAC;MAClC;IACD;IAEAC,iBAAiBA,CAAA,EAAG;MACnB,MAAM;QAAEN;MAAO,CAAC,GAAG,IAAI,CAACC,KAAK;MAC7B,IAAID,MAAM,EAAE;QACX,IAAI,CAACO,MAAM,CAAC,CAAC;MACd;IACD;IAEAC,oBAAoBA,CAAA,EAAG;MACtBnB,QAAQ,CAACC,eAAe,CAACM,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAACF,aAAa,CAAC;IAC9E;IAEAe,kBAAkBA,CAACC,SAAmB,EAAEC,SAA+B,EAAE;MACxE,IAAIX,MAA2B;MAE/B,IAAI,IAAI,CAACf,KAAK,CAACe,MAAM,KAAKE,SAAS,IAAI,IAAI,CAACjB,KAAK,CAACe,MAAM,KAAK,IAAI,CAACC,KAAK,CAACD,MAAM,EAAE;QAC/E;QACAA,MAAM,GAAG,IAAI,CAACf,KAAK,CAACe,MAAM;MAC3B,CAAC,MAAM,IAAI,IAAI,CAACf,KAAK,CAACe,MAAM,KAAKE,SAAS,IAAIS,SAAS,CAACX,MAAM,KAAK,IAAI,CAACC,KAAK,CAACD,MAAM,EAAE;QACrF;QACAA,MAAM,GAAG,IAAI,CAACC,KAAK,CAACD,MAAM;MAC3B;MAEA,IAAIA,MAAM,KAAKE,SAAS,EAAE;QACzB;MACD;MAEA,IAAIF,MAAM,EAAE;QACX,IAAI,CAACO,MAAM,CAAC,CAAC;MACd,CAAC,MAAM;QACN,IAAI,CAACK,OAAO,CAAC,CAAC;MACf;MACA,IAAI,CAACb,QAAQ,CAAC;QACbC;MACD,CAAC,CAAC;IACH;IA4BAa,MAAMA,CAAA,EAAG;MACR,MAAM;QACLC,YAAY;QACZC,wBAAwB;QACxBpB,UAAU;QACVE,QAAQ;QACRG,MAAM,EAAEgB,CAAC;QACTlB,UAAU;QACVmB,MAAM;QACN,GAAGC;MACJ,CAAC,GAAG,IAAI,CAACjC,KAAK;MACd;MACA,MAAMkC,YAAY,GAAG;QACpB,GAAGD,cAAc;QACjBpB,UAAU,EAAE,IAAI,CAACA;MAClB,CAA4C;MAC5C,MAAM;QAAEE;MAAO,CAAC,GAAG,IAAI,CAACC,KAAK;MAC7B,oBACC,IAAAtB,WAAA,CAAAyC,GAAA,EAAC5C,WAAA,CAAAW,OAAU;QACVa,MAAM,EAAEA,MAAO;QACfc,YAAY,EAAEA,YAAa;QAC3BO,KAAK,EAAE;UACNC,OAAO,EAAE;YACRC,QAAQ,EAAE,UAAU;YACpBC,GAAG,EAAE,CAAC;YACNC,IAAI,EAAE,CAAC;YACPC,KAAK,EAAE,CAAC;YACRC,MAAM,EAAE,CAAC;YACTC,QAAQ,EAAE,QAAQ;YAClBC,OAAO,EAAE,CAAC;YACVC,MAAM,EAAE,MAAM;YACdC,eAAe,EAAE;UAClB,CAAC;UACDC,OAAO,EAAE;YACRT,QAAQ,EAAE,UAAU;YACpBC,GAAG,EAAE,CAAC;YACNC,IAAI,EAAE,CAAC;YACPC,KAAK,EAAE,CAAC;YACRC,MAAM,EAAE,CAAC;YACTV,MAAM,EAAEA,MAAM,IAAI;UACnB;QACD;QACA;QAAA;QACAgB,eAAe,EAAE,mBAAmB,CAAClB,wBAAwB,GAAG,KAAK,GAAG,EAAE,EAAG;QAC7EmB,yBAAyB,EAAE,KAAM;QAAAC,QAAA,eACjC,IAAAxD,WAAA,CAAAyC,GAAA,EAACvC,gBAAgB;UAAA,GAAKsC;QAAY,CAAG;MAAC,CAC3B,CAAC;IAEf;EACD,CAAC;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASiB,wBAAwBA,CACvCvD,gBAAwE,EAClB;EACtD,MAAMwD,SAAS,GAAGzD,iCAAiC,CAAYC,gBAAgB,CAAC;EAChF,OAAO,IAAAyD,gDAAuB,EAACD,SAAS,EAAE,IAAI,CAAC;AAChD;AAAC,IAAAE,QAAA,GAAAC,OAAA,CAAArD,OAAA,GAEciD,wBAAwB","ignoreList":[]}
|
|
@@ -1,40 +1,54 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.configureMapStateToProps = void 0;
|
|
4
7
|
exports.default = groupActivityRequiredComponent;
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
*
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
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
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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
|
-
|
|
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
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
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==
|