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