studiokit-scaffolding-js 7.0.14-alpha.1 → 7.1.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.d.ts +2 -2
- package/lib/components/ActionList.js +166 -87
- package/lib/components/AlertDialog.d.ts +3 -3
- package/lib/components/AlertDialog.js +133 -18
- package/lib/components/AlertWithIcon.js +93 -52
- package/lib/components/ConnectedModal.d.ts +1 -2
- package/lib/components/ConnectedModal.js +41 -35
- package/lib/components/Dropdowns/GroupsDropdown.d.ts +4 -4
- package/lib/components/Dropdowns/GroupsDropdown.js +69 -82
- package/lib/components/Dropdowns/ManagedNavDropdown.d.ts +2 -2
- package/lib/components/Dropdowns/ManagedNavDropdown.js +96 -108
- package/lib/components/Dropdowns/UserDropdown.js +109 -70
- package/lib/components/Dropdowns/index.js +27 -11
- package/lib/components/EntityOwnerList.d.ts +3 -3
- package/lib/components/EntityOwnerList.js +52 -60
- package/lib/components/Error.js +107 -27
- package/lib/components/ErrorBoundary.js +133 -94
- package/lib/components/ErrorMessage.d.ts +2 -2
- package/lib/components/ErrorMessage.js +44 -14
- package/lib/components/Forms/DateField.d.ts +2 -2
- package/lib/components/Forms/DateField.js +63 -95
- package/lib/components/Forms/TimeField.d.ts +2 -2
- package/lib/components/Forms/TimeField.js +84 -108
- package/lib/components/Forms/index.js +27 -13
- package/lib/components/Groups/CreateEditCopySaveButtons.d.ts +2 -2
- package/lib/components/Groups/CreateEditCopySaveButtons.js +102 -14
- package/lib/components/Groups/ExternalGroups/Attach.d.ts +6 -7
- package/lib/components/Groups/ExternalGroups/Attach.js +213 -188
- package/lib/components/Groups/ExternalGroups/Table.js +183 -76
- package/lib/components/Groups/GroupCreateOrEditCommonProps.js +5 -1
- package/lib/components/Groups/RosterSyncInfo.js +140 -49
- package/lib/components/HOC/AccessibleAppComponent.d.ts +2 -2
- package/lib/components/HOC/AccessibleAppComponent.js +96 -119
- package/lib/components/HOC/ActivityRequiredComponent.d.ts +14 -14
- package/lib/components/HOC/ActivityRequiredComponent.js +72 -86
- package/lib/components/HOC/AsyncComponent.d.ts +9 -9
- package/lib/components/HOC/AsyncComponent.js +53 -129
- package/lib/components/HOC/AuthenticatedComponent.d.ts +4 -4
- package/lib/components/HOC/AuthenticatedComponent.js +59 -96
- package/lib/components/HOC/CollectionComponent.d.ts +12 -12
- package/lib/components/HOC/CollectionComponent.js +161 -161
- package/lib/components/HOC/CollectionFirstItemComponent.d.ts +13 -13
- package/lib/components/HOC/CollectionFirstItemComponent.js +49 -91
- package/lib/components/HOC/CollectionItemComponent.d.ts +9 -9
- package/lib/components/HOC/CollectionItemComponent.js +159 -158
- package/lib/components/HOC/ConnectedModalComponent.d.ts +9 -9
- package/lib/components/HOC/ConnectedModalComponent.js +96 -126
- package/lib/components/HOC/DataDependentComponent.d.ts +3 -55
- package/lib/components/HOC/DataDependentComponent.js +30 -79
- package/lib/components/HOC/EntityComponent.d.ts +13 -13
- package/lib/components/HOC/EntityComponent.js +63 -101
- package/lib/components/HOC/FullscreenModalComponent.d.ts +9 -9
- package/lib/components/HOC/FullscreenModalComponent.js +145 -165
- package/lib/components/HOC/GroupActivityRequiredComponent.d.ts +2 -2
- package/lib/components/HOC/GroupActivityRequiredComponent.js +32 -31
- package/lib/components/HOC/GuidComponent.d.ts +1 -1
- package/lib/components/HOC/GuidComponent.js +25 -64
- package/lib/components/HOC/ModelContextDependencyVerifyComponent.d.ts +28 -29
- package/lib/components/HOC/ModelContextDependencyVerifyComponent.js +36 -59
- package/lib/components/HOC/ModelErrorRedirectComponent.d.ts +10 -10
- package/lib/components/HOC/ModelErrorRedirectComponent.js +40 -83
- package/lib/components/HOC/SearchPersistorComponent.d.ts +4 -4
- package/lib/components/HOC/SearchPersistorComponent.js +243 -216
- package/lib/components/HOC/UnauthenticatedComponent.d.ts +12 -12
- package/lib/components/HOC/UnauthenticatedComponent.js +37 -82
- package/lib/components/HOC/UserComponent.d.ts +1 -1
- package/lib/components/HOC/UserComponent.js +12 -11
- package/lib/components/Icons/IconAlphaList.js +34 -20
- package/lib/components/Icons/IconExternalUser.js +34 -20
- package/lib/components/Icons/IconImpersonation.js +34 -20
- package/lib/components/Icons/IconStopImpersonating.js +34 -20
- package/lib/components/Icons/IconTable.js +35 -21
- package/lib/components/Icons/IconTableDeleteCol.js +34 -20
- package/lib/components/Icons/IconTableDeleteRow.js +34 -20
- package/lib/components/Icons/IconTableInsertCol.js +34 -20
- package/lib/components/Icons/IconTableInsertRow.js +34 -20
- package/lib/components/Impersonation/Button.d.ts +2 -2
- package/lib/components/Impersonation/Button.js +76 -56
- package/lib/components/Impersonation/Link.d.ts +2 -2
- package/lib/components/Impersonation/Link.js +76 -53
- package/lib/components/Impersonation/UserDetail.d.ts +2 -2
- package/lib/components/Impersonation/UserDetail.js +64 -15
- package/lib/components/Loading.js +27 -21
- package/lib/components/LockDownBrowser/Check.js +194 -107
- package/lib/components/LockDownBrowser/ExitButton.js +27 -14
- package/lib/components/LockDownBrowser/Launch.js +70 -85
- package/lib/components/Lti/Confirm.js +152 -33
- package/lib/components/Lti/CreateNonLtiGroupAlertDialog.d.ts +4 -2
- package/lib/components/Lti/CreateNonLtiGroupAlertDialog.js +170 -78
- package/lib/components/Lti/Launch.js +105 -49
- package/lib/components/Lti/LaunchGroup.js +85 -39
- package/lib/components/ManageTable.d.ts +1 -2
- package/lib/components/ManageTable.js +309 -104
- package/lib/components/ManageTableNoDataComponent.js +42 -22
- package/lib/components/NewVersionAlert.d.ts +2 -2
- package/lib/components/NewVersionAlert.js +82 -91
- package/lib/components/NotFound.js +87 -28
- package/lib/components/Notifications.d.ts +4 -4
- package/lib/components/Notifications.js +187 -169
- package/lib/components/PaginationNextButton.js +33 -21
- package/lib/components/PaginationPreviousButton.js +33 -21
- package/lib/components/Quill/CustomToolbar.d.ts +2 -2
- package/lib/components/Quill/CustomToolbar.js +432 -257
- package/lib/components/Quill/Formats/Image.d.ts +10 -25
- package/lib/components/Quill/Formats/Image.js +76 -82
- package/lib/components/Quill/Formats/List.d.ts +6 -3
- package/lib/components/Quill/Formats/List.js +50 -72
- package/lib/components/Quill/Formats/Video.d.ts +2 -1
- package/lib/components/Quill/Formats/Video.js +29 -43
- package/lib/components/Quill/ImageDropModule.d.ts +1 -1
- package/lib/components/Quill/ImageDropModule.js +142 -115
- package/lib/components/Quill/ImageWarning.d.ts +2 -2
- package/lib/components/Quill/ImageWarning.js +45 -32
- package/lib/components/Quill/ImageWithAltTextModal.d.ts +0 -1
- package/lib/components/Quill/ImageWithAltTextModal.js +425 -141
- package/lib/components/Quill/Specs/CustomImageSpec.d.ts +1 -1
- package/lib/components/Quill/Specs/CustomImageSpec.js +37 -45
- package/lib/components/Quill/Specs/CustomVideoSpec.d.ts +1 -1
- package/lib/components/Quill/Specs/CustomVideoSpec.js +27 -36
- package/lib/components/Quill/TableModule/Blots/BaseTableBlot.d.ts +2 -1
- package/lib/components/Quill/TableModule/Blots/BaseTableBlot.js +100 -116
- package/lib/components/Quill/TableModule/Blots/TableBlot.js +53 -66
- package/lib/components/Quill/TableModule/Blots/TableBodyBlot.js +54 -67
- package/lib/components/Quill/TableModule/Blots/TableCellBlot.d.ts +1 -1
- package/lib/components/Quill/TableModule/Blots/TableCellBlot.js +225 -241
- package/lib/components/Quill/TableModule/Blots/TableContainer.js +82 -99
- package/lib/components/Quill/TableModule/Blots/TableRowBlot.js +76 -87
- package/lib/components/Quill/TableModule/constants.js +45 -41
- package/lib/components/Quill/TableModule/index.css +25 -25
- package/lib/components/Quill/TableModule/index.d.ts +14 -5
- package/lib/components/Quill/TableModule/index.js +373 -313
- package/lib/components/Quill/TableModule/utils.js +45 -45
- package/lib/components/Quill/accessibilityFix.d.ts +0 -1
- package/lib/components/Quill/accessibilityFix.js +222 -238
- package/lib/components/Quill/index.js +36 -32
- package/lib/components/RefreshIndicator/Bordered.js +48 -32
- package/lib/components/RefreshIndicator/Inline.js +48 -33
- package/lib/components/RefreshIndicator/index.d.ts +2 -2
- package/lib/components/RefreshIndicator/index.js +263 -113
- package/lib/components/SearchControls.js +216 -31
- package/lib/components/SentryRoute.js +10 -23
- package/lib/components/Tables/RoleFilter.d.ts +3 -4
- package/lib/components/Tables/RoleFilter.js +71 -46
- package/lib/components/Tables/TextFilter.d.ts +2 -3
- package/lib/components/Tables/TextFilter.js +62 -20
- package/lib/components/UserRoles/Add.d.ts +3 -3
- package/lib/components/UserRoles/Add.js +199 -161
- package/lib/components/UserRoles/Context.js +8 -6
- package/lib/components/UserRoles/RoleCell.js +181 -100
- package/lib/components/UserRoles/Select.js +168 -54
- package/lib/components/UserRoles/Table.js +221 -102
- package/lib/components/UserRoles/index.d.ts +6 -6
- package/lib/components/UserRoles/index.js +535 -464
- package/lib/config/eslint/index.d.ts +2 -0
- package/lib/config/eslint/index.js +36 -0
- package/lib/config/eslint/lib/order.d.ts +3 -0
- package/lib/config/eslint/lib/order.js +30 -0
- package/lib/config/eslint/lib/prettier.d.ts +3 -0
- package/lib/config/eslint/lib/prettier.js +23 -0
- package/lib/config/eslint/lib/typescript.d.ts +2 -0
- package/lib/config/eslint/lib/typescript.js +98 -0
- package/lib/config/eslint/react.d.ts +2 -0
- package/lib/config/eslint/react.js +30 -0
- package/lib/constants/baseActivity.js +30 -26
- package/lib/constants/baseRole.js +14 -10
- package/lib/constants/configuration.d.ts +1 -1
- package/lib/constants/configuration.js +43 -39
- package/lib/constants/externalProviderType.js +10 -6
- package/lib/constants/fetchErrorData.js +15 -11
- package/lib/constants/index.js +137 -23
- package/lib/constants/lockDownBrowser.js +28 -24
- package/lib/constants/mockData.d.ts +4 -6
- package/lib/constants/mockData.js +383 -324
- 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.d.ts +1 -2
- package/lib/constants/userRole.js +15 -17
- package/lib/css/components/_buttons.css +11 -3
- package/lib/css/components/_quill.css +3 -3
- package/lib/css/components/_tables.css +6 -5
- package/lib/css/utils/_display.css +12 -19
- package/lib/css/utils/_general.css +1 -1
- package/lib/css/utils/_text.css +2 -1
- package/lib/css/variables.css +0 -4
- package/lib/endpointMappings.js +197 -193
- package/lib/hooks/useCollection.js +83 -65
- package/lib/hooks/useCollectionConfiguration.d.ts +0 -1
- package/lib/hooks/useCollectionConfiguration.js +179 -82
- package/lib/hooks/useCollectionItem.js +155 -58
- package/lib/hooks/useEventCalback.d.ts +14 -0
- package/lib/hooks/useEventCalback.js +51 -0
- package/lib/hooks/useGuid.js +19 -8
- package/lib/hooks/usePrevious.d.ts +24 -1
- package/lib/hooks/usePrevious.js +82 -12
- package/lib/index.js +156 -36
- package/lib/redux/actionCreator.d.ts +6 -6
- package/lib/redux/actionCreator.js +51 -40
- package/lib/redux/actions/AuthAction.js +44 -31
- package/lib/redux/actions/ModalAction.d.ts +1 -1
- package/lib/redux/actions/ModalAction.js +10 -6
- package/lib/redux/actions/ModelAction.d.ts +1 -1
- package/lib/redux/actions/ModelAction.js +77 -49
- package/lib/redux/actions/NotificationAction.js +10 -6
- package/lib/redux/actions/SearchAction.js +9 -5
- package/lib/redux/actions/index.js +60 -16
- package/lib/redux/configureReducers.d.ts +2 -5
- package/lib/redux/configureReducers.js +61 -72
- package/lib/redux/configureStore.d.ts +2 -2
- package/lib/redux/configureStore.js +83 -115
- package/lib/redux/helpers.js +7 -2
- package/lib/redux/reducers/authReducer.js +50 -44
- package/lib/redux/reducers/index.js +41 -15
- package/lib/redux/reducers/modalsReducer.js +49 -52
- package/lib/redux/reducers/modelsReducer.d.ts +2 -2
- package/lib/redux/reducers/modelsReducer.js +136 -135
- package/lib/redux/reducers/notificationsReducer.js +26 -21
- package/lib/redux/reducers/searchReducer.js +18 -12
- package/lib/redux/sagas/appInsightsSaga.js +24 -62
- package/lib/redux/sagas/authSaga.js +287 -414
- package/lib/redux/sagas/caliperSaga.js +154 -248
- package/lib/redux/sagas/clockOffsetSaga.js +35 -76
- package/lib/redux/sagas/configurationSaga.js +13 -46
- package/lib/redux/sagas/downtimeApiErrorSaga.d.ts +0 -1
- package/lib/redux/sagas/downtimeApiErrorSaga.js +23 -64
- package/lib/redux/sagas/errorSaga.d.ts +0 -1
- package/lib/redux/sagas/errorSaga.js +29 -63
- package/lib/redux/sagas/googleAnalyticsSaga.js +29 -69
- package/lib/redux/sagas/identityProviderSaga.js +24 -69
- package/lib/redux/sagas/initialDataLoadSaga.js +38 -29
- package/lib/redux/sagas/lockDownBrowserErrorSaga.d.ts +0 -1
- package/lib/redux/sagas/lockDownBrowserErrorSaga.js +32 -81
- package/lib/redux/sagas/modelFetchSaga.js +331 -411
- package/lib/redux/sagas/noStoreSaga.d.ts +1 -1
- package/lib/redux/sagas/noStoreSaga.js +68 -101
- package/lib/redux/sagas/postLoginDataSaga.js +42 -74
- package/lib/redux/sagas/postLoginRedirectSaga.js +27 -68
- package/lib/redux/sagas/rootSaga.js +85 -137
- package/lib/redux/sagas/sentrySaga.js +29 -85
- package/lib/redux/sagas/userIdSaga.js +18 -54
- package/lib/services/codeProviderService.js +25 -29
- package/lib/services/dateService.js +12 -10
- package/lib/services/documentService.js +15 -10
- package/lib/services/fetchService.js +110 -144
- package/lib/services/persistenceService.d.ts +4 -4
- package/lib/services/persistenceService.js +45 -43
- package/lib/services/ticketProviderService.js +29 -33
- package/lib/services/tokenPersistenceService.js +13 -9
- package/lib/services/windowService.js +21 -17
- package/lib/startup.d.ts +1 -1
- package/lib/startup.js +115 -118
- 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.d.ts +3 -3
- 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.d.ts +2 -2
- package/lib/types/Notification.js +5 -1
- package/lib/types/OptionalRecord.d.ts +1 -1
- package/lib/types/OptionalRecord.js +5 -1
- package/lib/types/OwnerSchedule.d.ts +3 -1
- package/lib/types/OwnerSchedule.js +5 -1
- package/lib/types/PropertyOfType.d.ts +3 -3
- package/lib/types/PropertyOfType.js +5 -1
- package/lib/types/Quill.js +5 -1
- package/lib/types/RoleDescription.d.ts +0 -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 -18
- package/lib/types/externals.d.js +2 -0
- package/lib/types/index.js +313 -39
- 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.d.ts +1 -1
- package/lib/types/net/ErrorHandler.js +5 -1
- package/lib/types/net/FetchConfig.d.ts +1 -1
- package/lib/types/net/FetchConfig.js +5 -1
- package/lib/types/net/FetchErrorData.js +10 -6
- package/lib/types/net/FetchResult.d.ts +2 -2
- package/lib/types/net/FetchResult.js +5 -1
- package/lib/types/net/HTTPMethod.d.ts +1 -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.d.ts +1 -1
- package/lib/types/net/OAuthTokenOrNull.js +5 -1
- package/lib/types/net/TokenAccessFunction.d.ts +1 -1
- package/lib/types/net/TokenAccessFunction.js +5 -1
- package/lib/types/net/index.js +181 -27
- package/lib/utils/baseActivity.d.ts +2 -2
- package/lib/utils/baseActivity.js +93 -91
- package/lib/utils/baseRole.js +37 -33
- package/lib/utils/collection.js +413 -291
- package/lib/utils/cookies.js +22 -37
- package/lib/utils/date.js +210 -210
- package/lib/utils/dom.js +145 -133
- package/lib/utils/domainIdentifier.js +9 -9
- package/lib/utils/entityUserRole.js +6 -2
- package/lib/utils/error.d.ts +1 -1
- package/lib/utils/error.js +18 -16
- package/lib/utils/events.js +37 -30
- package/lib/utils/externalGroup.js +25 -21
- package/lib/utils/externalProviders.js +8 -4
- package/lib/utils/externalTerms.js +9 -6
- package/lib/utils/fetch.d.ts +1 -1
- package/lib/utils/fetch.js +179 -176
- package/lib/utils/group.js +17 -9
- package/lib/utils/groupDates.d.ts +1 -1
- package/lib/utils/groupDates.js +43 -39
- package/lib/utils/groupRoles.js +28 -28
- package/lib/utils/lockDownBrowser.js +16 -12
- package/lib/utils/logger.js +30 -25
- package/lib/utils/lti.js +10 -5
- package/lib/utils/model.d.ts +2 -2
- package/lib/utils/model.js +35 -44
- package/lib/utils/number.js +13 -16
- package/lib/utils/promise.d.ts +6 -1
- package/lib/utils/promise.js +34 -15
- package/lib/utils/quill.js +60 -71
- package/lib/utils/route.d.ts +2 -2
- package/lib/utils/route.js +61 -60
- package/lib/utils/search.d.ts +1 -1
- package/lib/utils/search.js +78 -85
- package/lib/utils/shard.js +38 -41
- package/lib/utils/sort.d.ts +3 -3
- package/lib/utils/sort.js +62 -58
- package/lib/utils/string.js +14 -10
- package/lib/utils/table.d.ts +3 -3
- package/lib/utils/table.js +36 -33
- package/lib/utils/timezone.js +12 -26
- package/lib/utils/url.d.ts +2 -1
- package/lib/utils/url.js +139 -193
- package/lib/utils/user.js +59 -61
- package/lib/utils/userAgent.js +11 -11
- package/lib/utils/userRole.d.ts +3 -3
- package/lib/utils/userRole.js +46 -44
- package/package.json +90 -73
- package/lib/config/eslint/index.cjs +0 -21
- package/lib/config/eslint/lib/order.cjs +0 -22
- package/lib/config/eslint/lib/prettier.cjs +0 -18
- package/lib/config/eslint/lib/typescript.cjs +0 -86
- package/lib/config/eslint/react.cjs +0 -9
- package/lib/css/utils/_focus.css +0 -4
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.shouldDisplayCreateNonLtiGroupAlert = void 0;
|
|
4
|
-
var
|
|
5
|
-
|
|
6
|
-
|
|
7
|
+
var _externalProviderType = require("../constants/externalProviderType");
|
|
8
|
+
const shouldDisplayCreateNonLtiGroupAlert = externalProviders => {
|
|
9
|
+
return externalProviders.some(ep => ep.typename === _externalProviderType.EXTERNAL_PROVIDER_TYPE.LTI && ep.shouldDisplayCreateNonLtiGroupAlert);
|
|
7
10
|
};
|
|
8
11
|
exports.shouldDisplayCreateNonLtiGroupAlert = shouldDisplayCreateNonLtiGroupAlert;
|
|
12
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZXh0ZXJuYWxQcm92aWRlclR5cGUiLCJyZXF1aXJlIiwic2hvdWxkRGlzcGxheUNyZWF0ZU5vbkx0aUdyb3VwQWxlcnQiLCJleHRlcm5hbFByb3ZpZGVycyIsInNvbWUiLCJlcCIsInR5cGVuYW1lIiwiRVhURVJOQUxfUFJPVklERVJfVFlQRSIsIkxUSSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvZXh0ZXJuYWxQcm92aWRlcnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRVhURVJOQUxfUFJPVklERVJfVFlQRSB9IGZyb20gJy4uL2NvbnN0YW50cy9leHRlcm5hbFByb3ZpZGVyVHlwZSdcbmltcG9ydCB7IEV4dGVybmFsUHJvdmlkZXIgfSBmcm9tICcuLi90eXBlcy9FeHRlcm5hbFByb3ZpZGVyJ1xuXG5leHBvcnQgY29uc3Qgc2hvdWxkRGlzcGxheUNyZWF0ZU5vbkx0aUdyb3VwQWxlcnQgPSAoZXh0ZXJuYWxQcm92aWRlcnM6IEV4dGVybmFsUHJvdmlkZXJbXSkgPT4ge1xuXHRyZXR1cm4gZXh0ZXJuYWxQcm92aWRlcnMuc29tZShcblx0XHRlcCA9PiBlcC50eXBlbmFtZSA9PT0gRVhURVJOQUxfUFJPVklERVJfVFlQRS5MVEkgJiYgZXAuc2hvdWxkRGlzcGxheUNyZWF0ZU5vbkx0aUdyb3VwQWxlcnRcblx0KVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxxQkFBQSxHQUFBQyxPQUFBO0FBR08sTUFBTUMsbUNBQW1DLEdBQUlDLGlCQUFxQyxJQUFLO0VBQzdGLE9BQU9BLGlCQUFpQixDQUFDQyxJQUFJLENBQzVCQyxFQUFFLElBQUlBLEVBQUUsQ0FBQ0MsUUFBUSxLQUFLQyw0Q0FBc0IsQ0FBQ0MsR0FBRyxJQUFJSCxFQUFFLENBQUNILG1DQUN4RCxDQUFDO0FBQ0YsQ0FBQztBQUFBTyxPQUFBLENBQUFQLG1DQUFBLEdBQUFBLG1DQUFBIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.filterByCurrentAndFuture = void 0;
|
|
4
|
-
var
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
return externalTerms.filter(function (et) { return date_2.isNowBeforeDate(et.endDate, nowUtc); });
|
|
7
|
+
var _date = require("../utils/date");
|
|
8
|
+
const filterByCurrentAndFuture = function (externalTerms) {
|
|
9
|
+
let nowUtc = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (0, _date.getServerNowUtc)().toISOString();
|
|
10
|
+
return externalTerms.filter(et => (0, _date.isNowBeforeDate)(et.endDate, nowUtc));
|
|
9
11
|
};
|
|
10
12
|
exports.filterByCurrentAndFuture = filterByCurrentAndFuture;
|
|
13
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF0ZSIsInJlcXVpcmUiLCJmaWx0ZXJCeUN1cnJlbnRBbmRGdXR1cmUiLCJleHRlcm5hbFRlcm1zIiwibm93VXRjIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwidW5kZWZpbmVkIiwiZ2V0U2VydmVyTm93VXRjIiwidG9JU09TdHJpbmciLCJmaWx0ZXIiLCJldCIsImlzTm93QmVmb3JlRGF0ZSIsImVuZERhdGUiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2V4dGVybmFsVGVybXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXh0ZXJuYWxUZXJtIH0gZnJvbSAnLi4vdHlwZXMvRXh0ZXJuYWxUZXJtJ1xuaW1wb3J0IHsgZ2V0U2VydmVyTm93VXRjLCBpc05vd0JlZm9yZURhdGUgfSBmcm9tICcuLi91dGlscy9kYXRlJ1xuXG5leHBvcnQgY29uc3QgZmlsdGVyQnlDdXJyZW50QW5kRnV0dXJlID0gKGV4dGVybmFsVGVybXM6IEV4dGVybmFsVGVybVtdLCBub3dVdGMgPSBnZXRTZXJ2ZXJOb3dVdGMoKS50b0lTT1N0cmluZygpKSA9PlxuXHRleHRlcm5hbFRlcm1zLmZpbHRlcihldCA9PiBpc05vd0JlZm9yZURhdGUoZXQuZW5kRGF0ZSwgbm93VXRjKSlcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsSUFBQUEsS0FBQSxHQUFBQyxPQUFBO0FBRU8sTUFBTUMsd0JBQXdCLEdBQUcsU0FBQUEsQ0FBQ0MsYUFBNkI7RUFBQSxJQUFFQyxNQUFNLEdBQUFDLFNBQUEsQ0FBQUMsTUFBQSxRQUFBRCxTQUFBLFFBQUFFLFNBQUEsR0FBQUYsU0FBQSxNQUFHLElBQUFHLHFCQUFlLEVBQUMsQ0FBQyxDQUFDQyxXQUFXLENBQUMsQ0FBQztFQUFBLE9BQy9HTixhQUFhLENBQUNPLE1BQU0sQ0FBQ0MsRUFBRSxJQUFJLElBQUFDLHFCQUFlLEVBQUNELEVBQUUsQ0FBQ0UsT0FBTyxFQUFFVCxNQUFNLENBQUMsQ0FBQztBQUFBO0FBQUFVLE9BQUEsQ0FBQVosd0JBQUEsR0FBQUEsd0JBQUEiLCJpZ25vcmVMaXN0IjpbXX0=
|
package/lib/utils/fetch.d.ts
CHANGED
|
@@ -25,4 +25,4 @@ export interface PrepareFetchResult {
|
|
|
25
25
|
* @param modelFetchRequestAction The action dispatched by the client
|
|
26
26
|
* @param endpointMappings The EndpointMappings object
|
|
27
27
|
*/
|
|
28
|
-
export declare function prepareFetch(modelFetchRequestAction: ModelFetchRequestAction | PeriodicModelFetchRequestAction, endpointMappings: EndpointMappings): PrepareFetchResult;
|
|
28
|
+
export declare function prepareFetch(modelFetchRequestAction: ModelFetchRequestAction | PeriodicModelFetchRequestAction, endpointMappings: EndpointMappings | undefined): PrepareFetchResult;
|
package/lib/utils/fetch.js
CHANGED
|
@@ -1,21 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.isFetchErrorData = void 0;
|
|
7
|
+
exports.prepareFetch = prepareFetch;
|
|
8
|
+
var _lodash = require("lodash");
|
|
9
|
+
var _uuid = require("uuid");
|
|
10
|
+
var _error = require("./error");
|
|
7
11
|
/**
|
|
8
12
|
* Type check method to confirm if a value is `FetchErrorData`.
|
|
9
13
|
*
|
|
10
14
|
* Checks if `value` is an object, and has `status`, `title`, and `detail` properties.
|
|
11
15
|
*/
|
|
12
|
-
|
|
13
|
-
return !!value &&
|
|
14
|
-
typeof value === 'object' &&
|
|
15
|
-
Object.prototype.hasOwnProperty.call(value, 'status') &&
|
|
16
|
-
Object.prototype.hasOwnProperty.call(value, 'title') &&
|
|
17
|
-
Object.prototype.hasOwnProperty.call(value, 'detail');
|
|
18
|
-
};
|
|
16
|
+
const isFetchErrorData = value => !!value && typeof value === 'object' && Object.prototype.hasOwnProperty.call(value, 'status') && Object.prototype.hasOwnProperty.call(value, 'title') && Object.prototype.hasOwnProperty.call(value, 'detail');
|
|
19
17
|
exports.isFetchErrorData = isFetchErrorData;
|
|
20
18
|
/**
|
|
21
19
|
* Prepare fetchConfig to pass to fetchService. Also set up state to handle response correctly.
|
|
@@ -24,172 +22,177 @@ exports.isFetchErrorData = isFetchErrorData;
|
|
|
24
22
|
* @param endpointMappings The EndpointMappings object
|
|
25
23
|
*/
|
|
26
24
|
function prepareFetch(modelFetchRequestAction, endpointMappings) {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
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
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
}
|
|
132
|
-
if (!fetchConfig_1.path) {
|
|
133
|
-
fetchConfig_1.path = "/api/" + modelPath_1;
|
|
134
|
-
}
|
|
135
|
-
// determine if we need to append an "{:id}" hook
|
|
136
|
-
var pathLevels = (fetchConfig_1.path.match(/{:id}/g) || []).length;
|
|
137
|
-
// GET, PUT, PATCH, DELETE => append '/{:id}'
|
|
138
|
-
isCollectionItemFetch = !!endpointConfig.isCollection && pathParams_1.length > pathLevels;
|
|
139
|
-
// POST
|
|
140
|
-
isCollectionItemCreate = !!endpointConfig.isCollection && fetchConfig_1.method === 'POST';
|
|
141
|
-
isCollectionItemDelete = !!endpointConfig.isCollection && fetchConfig_1.method === 'DELETE';
|
|
142
|
-
// insert pathParam hooks into path and modelPath
|
|
143
|
-
// track collection item requests by id (update, delete) or guid (create)
|
|
144
|
-
if (isCollectionItemFetch && !isCollectionItemCreate) {
|
|
145
|
-
fetchConfig_1.path = fetchConfig_1.path + "/{:id}";
|
|
146
|
-
modelPath_1 = modelPath_1 + ".{:id}";
|
|
147
|
-
}
|
|
148
|
-
else if (isCollectionItemCreate) {
|
|
149
|
-
modelPath_1 = modelPath_1 + "." + (modelFetchRequestAction.guid || uuid_1.v4());
|
|
25
|
+
try {
|
|
26
|
+
if (!modelFetchRequestAction.modelName) {
|
|
27
|
+
throw new Error("'modelFetchRequestAction.modelName' is required");
|
|
28
|
+
}
|
|
29
|
+
if (!endpointMappings) {
|
|
30
|
+
throw new Error("'endpointMappings' is required");
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Get fetch parameters from global fetch dictionary using the modelName passed in to locate them
|
|
34
|
+
// Combine parameters from global dictionary with any passed in - locals override dictionary
|
|
35
|
+
const endpointMapping = (0, _lodash.get)(endpointMappings, modelFetchRequestAction.modelName);
|
|
36
|
+
if (!endpointMapping) {
|
|
37
|
+
throw new Error(`Cannot find '${modelFetchRequestAction.modelName}' in 'endpointMappings'`);
|
|
38
|
+
}
|
|
39
|
+
const endpointConfig = (0, _lodash.merge)({}, endpointMapping._config);
|
|
40
|
+
const fetchConfig = (0, _lodash.merge)({}, endpointConfig.fetch, {
|
|
41
|
+
headers: (0, _lodash.merge)({}, modelFetchRequestAction.headers),
|
|
42
|
+
queryParams: (0, _lodash.merge)({}, modelFetchRequestAction.queryParams)
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
// set "method" if defined
|
|
46
|
+
if (modelFetchRequestAction.method) {
|
|
47
|
+
fetchConfig.method = modelFetchRequestAction.method;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// set or merge "body"
|
|
51
|
+
// If the body is a string, we are assuming it's an 'application/x-www-form-urlencoded'
|
|
52
|
+
if (modelFetchRequestAction.body && (typeof modelFetchRequestAction.body === 'string' || modelFetchRequestAction.body instanceof FormData)) {
|
|
53
|
+
fetchConfig.body = modelFetchRequestAction.body;
|
|
54
|
+
fetchConfig.contentType = 'application/x-www-form-urlencoded';
|
|
55
|
+
} else if (fetchConfig.body || modelFetchRequestAction.body) {
|
|
56
|
+
// if the action body is an array, ensure the request body is an array
|
|
57
|
+
if (!!modelFetchRequestAction.body && (0, _lodash.isArray)(modelFetchRequestAction.body)) {
|
|
58
|
+
fetchConfig.body = (0, _lodash.union)([],
|
|
59
|
+
// use the default body from the config if it is also an array
|
|
60
|
+
!!fetchConfig.body && (0, _lodash.isArray)(fetchConfig.body) ? fetchConfig.body : [], modelFetchRequestAction.body);
|
|
61
|
+
} else {
|
|
62
|
+
fetchConfig.body = (0, _lodash.merge)({}, fetchConfig.body, modelFetchRequestAction.body);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// set "contentType" if defined, overriding the default 'application/x-www-form-urlencoded'
|
|
67
|
+
// that may have been set previously
|
|
68
|
+
if (modelFetchRequestAction.contentType) {
|
|
69
|
+
fetchConfig.contentType = modelFetchRequestAction.contentType;
|
|
70
|
+
}
|
|
71
|
+
let modelPath = modelFetchRequestAction.modelName;
|
|
72
|
+
let isCollectionItemFetch = false;
|
|
73
|
+
let isCollectionItemCreate = false;
|
|
74
|
+
let isCollectionItemDelete = false;
|
|
75
|
+
// copy pathParams into two arrays, to manage them separately
|
|
76
|
+
let pathParams = (0, _lodash.merge)([], modelFetchRequestAction.pathParams);
|
|
77
|
+
const modelPathParams = (0, _lodash.merge)([], modelFetchRequestAction.pathParams);
|
|
78
|
+
|
|
79
|
+
// find all the model levels from 'modelPath'
|
|
80
|
+
const modelPathLevels = modelPath.split('.');
|
|
81
|
+
let lastModelLevel = endpointMappings;
|
|
82
|
+
const modelLevels = modelPathLevels.map(levelName => {
|
|
83
|
+
const modelLevel = (0, _lodash.get)(lastModelLevel, levelName);
|
|
84
|
+
lastModelLevel = modelLevel;
|
|
85
|
+
return modelLevel;
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
// find the levels that are collections
|
|
89
|
+
const collectionModelLevels = modelLevels.filter(level => level._config && level._config.isCollection);
|
|
90
|
+
const isAnyLevelCollection = collectionModelLevels.length > 0;
|
|
91
|
+
|
|
92
|
+
// if any level is a collection, we need to concat their fetch paths and modelNames
|
|
93
|
+
if (isAnyLevelCollection) {
|
|
94
|
+
if (modelPathLevels.length > 1) {
|
|
95
|
+
modelLevels.forEach((modelLevel, index) => {
|
|
96
|
+
const levelName = modelPathLevels[index];
|
|
97
|
+
const currentModelConfig = (0, _lodash.merge)({}, modelLevel._config);
|
|
98
|
+
const currentFetchConfig = (0, _lodash.merge)({}, currentModelConfig.fetch);
|
|
99
|
+
const currentPath = !(0, _lodash.isUndefined)(currentFetchConfig.path) ? currentFetchConfig.path : index === 0 ? `/api/${levelName}` : levelName;
|
|
100
|
+
|
|
101
|
+
// first level, just use its values
|
|
102
|
+
if (index === 0) {
|
|
103
|
+
fetchConfig.path = currentPath;
|
|
104
|
+
modelPath = levelName;
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// if previous level isCollection, we need to use "{:id}" hooks when appending new level
|
|
109
|
+
// otherwise, just append using the divider
|
|
110
|
+
const prevModelConfig = (0, _lodash.merge)({}, modelLevels[index - 1]._config);
|
|
111
|
+
const divider = !!fetchConfig.path && fetchConfig.path.length > 0 && currentPath.length > 0 ? '/' : '';
|
|
112
|
+
if (prevModelConfig.isCollection) {
|
|
113
|
+
fetchConfig.path = `${fetchConfig.path}${divider}{:id}/${currentPath}`;
|
|
114
|
+
modelPath = `${modelPath}.{:id}.${levelName}`;
|
|
115
|
+
} else {
|
|
116
|
+
fetchConfig.path = `${fetchConfig.path}${divider}${currentPath}`;
|
|
117
|
+
modelPath = `${modelPath}.${levelName}`;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
// an absolute path resets the fetch path, and ignores previous pathParams moving forward
|
|
121
|
+
// it does not affect modelPath params for redux
|
|
122
|
+
if (currentPath.indexOf('/') === 0) {
|
|
123
|
+
fetchConfig.path = currentPath;
|
|
124
|
+
const collectionLevelIndex = collectionModelLevels.indexOf(modelLevel);
|
|
125
|
+
if (collectionLevelIndex > 0) {
|
|
126
|
+
// since `collectionLevelIndex` is based on the full amount of params,
|
|
127
|
+
// always target `modelPathParams`, not the "current" `pathParams`
|
|
128
|
+
pathParams = modelPathParams.slice(collectionLevelIndex, modelPathParams.length);
|
|
150
129
|
}
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
if (!fetchConfig.path) {
|
|
134
|
+
fetchConfig.path = `/api/${modelPath}`;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// determine if we need to append an "{:id}" hook
|
|
138
|
+
const pathLevels = (fetchConfig.path.match(/{:id}/g) || []).length;
|
|
139
|
+
// GET, PUT, PATCH, DELETE => append '/{:id}'
|
|
140
|
+
isCollectionItemFetch = !!endpointConfig.isCollection && pathParams.length > pathLevels;
|
|
141
|
+
// POST
|
|
142
|
+
isCollectionItemCreate = !!endpointConfig.isCollection && fetchConfig.method === 'POST';
|
|
143
|
+
isCollectionItemDelete = !!endpointConfig.isCollection && fetchConfig.method === 'DELETE';
|
|
144
|
+
|
|
145
|
+
// insert pathParam hooks into path and modelPath
|
|
146
|
+
// track collection item requests by id (update, delete) or guid (create)
|
|
147
|
+
if (isCollectionItemFetch && !isCollectionItemCreate) {
|
|
148
|
+
fetchConfig.path = `${fetchConfig.path}/{:id}`;
|
|
149
|
+
modelPath = `${modelPath}.{:id}`;
|
|
150
|
+
} else if (isCollectionItemCreate) {
|
|
151
|
+
modelPath = `${modelPath}.${modelFetchRequestAction.guid || (0, _uuid.v4)()}`;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
if (!fetchConfig.path) {
|
|
155
|
+
throw new Error("'fetchConfig.path' is required for non-collections");
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
// substitute any params in `modelPath`, e.g. `groups.{:id}`
|
|
159
|
+
if (/{:.+}/.test(modelPath)) {
|
|
160
|
+
let index = 0;
|
|
161
|
+
modelPath = modelPath.replace(/{:(.+?)}/g, () => {
|
|
162
|
+
const value = modelPathParams[index];
|
|
163
|
+
if (value === undefined || value === null) {
|
|
164
|
+
throw new Error(`Could not replace params in 'modelPath' using 'modelPathParams'`);
|
|
151
165
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
// substitute any params in `modelPath`, e.g. `groups.{:id}`
|
|
156
|
-
if (/{:.+}/.test(modelPath_1)) {
|
|
157
|
-
var index_1 = 0;
|
|
158
|
-
modelPath_1 = modelPath_1.replace(/{:(.+?)}/g, function () {
|
|
159
|
-
var value = modelPathParams_1[index_1];
|
|
160
|
-
if (value === undefined || value === null) {
|
|
161
|
-
throw new Error("Could not replace params in 'modelPath' using 'modelPathParams'");
|
|
162
|
-
}
|
|
163
|
-
index_1++;
|
|
164
|
-
return value;
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
// substitute any params in `fetchConfig.path`, e.g. `/api/group/{:id}`
|
|
168
|
-
if (!!fetchConfig_1.path && /{:.+}/.test(fetchConfig_1.path)) {
|
|
169
|
-
var index_2 = 0;
|
|
170
|
-
fetchConfig_1.path = fetchConfig_1.path.replace(/{:(.+?)}/g, function () {
|
|
171
|
-
var value = pathParams_1[index_2];
|
|
172
|
-
if (value === undefined || value === null) {
|
|
173
|
-
throw new Error("Could not replace params in 'fetchConfig.path' using 'pathParams'");
|
|
174
|
-
}
|
|
175
|
-
index_2++;
|
|
176
|
-
return value;
|
|
177
|
-
});
|
|
178
|
-
}
|
|
179
|
-
var result = {
|
|
180
|
-
endpointMapping: endpointMapping,
|
|
181
|
-
fetchConfig: fetchConfig_1,
|
|
182
|
-
endpointConfig: endpointConfig,
|
|
183
|
-
modelPath: modelPath_1,
|
|
184
|
-
isCollectionItemFetch: isCollectionItemFetch,
|
|
185
|
-
isCollectionItemCreate: isCollectionItemCreate,
|
|
186
|
-
isCollectionItemDelete: isCollectionItemDelete
|
|
187
|
-
};
|
|
188
|
-
return result;
|
|
166
|
+
index++;
|
|
167
|
+
return String(value);
|
|
168
|
+
});
|
|
189
169
|
}
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
170
|
+
|
|
171
|
+
// substitute any params in `fetchConfig.path`, e.g. `/api/group/{:id}`
|
|
172
|
+
if (!!fetchConfig.path && /{:.+}/.test(fetchConfig.path)) {
|
|
173
|
+
let index = 0;
|
|
174
|
+
fetchConfig.path = fetchConfig.path.replace(/{:(.+?)}/g, () => {
|
|
175
|
+
const value = pathParams[index];
|
|
176
|
+
if (value === undefined || value === null) {
|
|
177
|
+
throw new Error(`Could not replace params in 'fetchConfig.path' using 'pathParams'`);
|
|
178
|
+
}
|
|
179
|
+
index++;
|
|
180
|
+
return String(value);
|
|
181
|
+
});
|
|
193
182
|
}
|
|
183
|
+
const result = {
|
|
184
|
+
endpointMapping,
|
|
185
|
+
fetchConfig,
|
|
186
|
+
endpointConfig,
|
|
187
|
+
modelPath,
|
|
188
|
+
isCollectionItemFetch,
|
|
189
|
+
isCollectionItemCreate,
|
|
190
|
+
isCollectionItemDelete
|
|
191
|
+
};
|
|
192
|
+
return result;
|
|
193
|
+
} catch (error) {
|
|
194
|
+
const prepareFetchError = (0, _error.constructErrorFromCaughtError)(error, 'PrepareFetchError');
|
|
195
|
+
throw prepareFetchError;
|
|
196
|
+
}
|
|
194
197
|
}
|
|
195
|
-
exports.prepareFetch = prepareFetch;
|
|
198
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbG9kYXNoIiwicmVxdWlyZSIsIl91dWlkIiwiX2Vycm9yIiwiaXNGZXRjaEVycm9yRGF0YSIsInZhbHVlIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZXhwb3J0cyIsInByZXBhcmVGZXRjaCIsIm1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uIiwiZW5kcG9pbnRNYXBwaW5ncyIsIm1vZGVsTmFtZSIsIkVycm9yIiwiZW5kcG9pbnRNYXBwaW5nIiwiZ2V0IiwiZW5kcG9pbnRDb25maWciLCJtZXJnZSIsIl9jb25maWciLCJmZXRjaENvbmZpZyIsImZldGNoIiwiaGVhZGVycyIsInF1ZXJ5UGFyYW1zIiwibWV0aG9kIiwiYm9keSIsIkZvcm1EYXRhIiwiY29udGVudFR5cGUiLCJpc0FycmF5IiwidW5pb24iLCJtb2RlbFBhdGgiLCJpc0NvbGxlY3Rpb25JdGVtRmV0Y2giLCJpc0NvbGxlY3Rpb25JdGVtQ3JlYXRlIiwiaXNDb2xsZWN0aW9uSXRlbURlbGV0ZSIsInBhdGhQYXJhbXMiLCJtb2RlbFBhdGhQYXJhbXMiLCJtb2RlbFBhdGhMZXZlbHMiLCJzcGxpdCIsImxhc3RNb2RlbExldmVsIiwibW9kZWxMZXZlbHMiLCJtYXAiLCJsZXZlbE5hbWUiLCJtb2RlbExldmVsIiwiY29sbGVjdGlvbk1vZGVsTGV2ZWxzIiwiZmlsdGVyIiwibGV2ZWwiLCJpc0NvbGxlY3Rpb24iLCJpc0FueUxldmVsQ29sbGVjdGlvbiIsImxlbmd0aCIsImZvckVhY2giLCJpbmRleCIsImN1cnJlbnRNb2RlbENvbmZpZyIsImN1cnJlbnRGZXRjaENvbmZpZyIsImN1cnJlbnRQYXRoIiwiaXNVbmRlZmluZWQiLCJwYXRoIiwicHJldk1vZGVsQ29uZmlnIiwiZGl2aWRlciIsImluZGV4T2YiLCJjb2xsZWN0aW9uTGV2ZWxJbmRleCIsInNsaWNlIiwicGF0aExldmVscyIsIm1hdGNoIiwiZ3VpZCIsInV1aWR2NCIsInRlc3QiLCJyZXBsYWNlIiwidW5kZWZpbmVkIiwiU3RyaW5nIiwicmVzdWx0IiwiZXJyb3IiLCJwcmVwYXJlRmV0Y2hFcnJvciIsImNvbnN0cnVjdEVycm9yRnJvbUNhdWdodEVycm9yIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2ZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldCwgaXNBcnJheSwgaXNVbmRlZmluZWQsIG1lcmdlLCB1bmlvbiB9IGZyb20gJ2xvZGFzaCdcbmltcG9ydCB7IHY0IGFzIHV1aWR2NCB9IGZyb20gJ3V1aWQnXG5pbXBvcnQgeyBNb2RlbEZldGNoUmVxdWVzdEFjdGlvbiwgUGVyaW9kaWNNb2RlbEZldGNoUmVxdWVzdEFjdGlvbiB9IGZyb20gJy4uL3JlZHV4L2FjdGlvbnMvTW9kZWxBY3Rpb24nXG5pbXBvcnQgeyBFbmRwb2ludENvbmZpZywgRW5kcG9pbnRNYXBwaW5nLCBFbmRwb2ludE1hcHBpbmdzLCBGZXRjaENvbmZpZywgRmV0Y2hFcnJvckRhdGEgfSBmcm9tICcuLi90eXBlcydcbmltcG9ydCB7IGNvbnN0cnVjdEVycm9yRnJvbUNhdWdodEVycm9yIH0gZnJvbSAnLi9lcnJvcidcblxuLyoqXG4gKiBUeXBlIGNoZWNrIG1ldGhvZCB0byBjb25maXJtIGlmIGEgdmFsdWUgaXMgYEZldGNoRXJyb3JEYXRhYC5cbiAqXG4gKiBDaGVja3MgaWYgYHZhbHVlYCBpcyBhbiBvYmplY3QsIGFuZCBoYXMgYHN0YXR1c2AsIGB0aXRsZWAsIGFuZCBgZGV0YWlsYCBwcm9wZXJ0aWVzLlxuICovXG5leHBvcnQgY29uc3QgaXNGZXRjaEVycm9yRGF0YSA9ICh2YWx1ZTogYW55KTogdmFsdWUgaXMgRmV0Y2hFcnJvckRhdGEgPT5cblx0ISF2YWx1ZSAmJlxuXHR0eXBlb2YgdmFsdWUgPT09ICdvYmplY3QnICYmXG5cdE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbCh2YWx1ZSwgJ3N0YXR1cycpICYmXG5cdE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbCh2YWx1ZSwgJ3RpdGxlJykgJiZcblx0T2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHZhbHVlLCAnZGV0YWlsJylcblxuZXhwb3J0IGludGVyZmFjZSBQcmVwYXJlRmV0Y2hSZXN1bHQge1xuXHQvKiogVGhlIGVuZHBvaW50IG1hcHBpbmcgdGhhdCB3YXMgbWF0Y2hlZCB1c2luZyBhIGRhdGEgcmVxdWVzdCBhY3Rpb24ncyAnbW9kZWxOYW1lJy4gKi9cblx0ZW5kcG9pbnRNYXBwaW5nOiBFbmRwb2ludE1hcHBpbmdcblx0LyoqIFRoZSBlbmRwb2ludCBjb25maWcgZnJvbSB0aGUgZW5kcG9pbnQgbWFwcGluZy4gZGVmYXVsdHMgdG8gYW4gZW1wdHkgb2JqZWN0LiAqL1xuXHRlbmRwb2ludENvbmZpZzogRW5kcG9pbnRDb25maWdcblx0LyoqIFRoZSBmZXRjaCBjb25maWcgY29uc3RydWN0ZWQgZnJvbSB0aGUgZGF0YSByZXF1ZXN0IGFjdGlvbiBhbmQgZW5kcG9pbnQgbWFwcGluZy4gU2VudCB0byBgZG9GZXRjaGAuICovXG5cdGZldGNoQ29uZmlnOiBGZXRjaENvbmZpZ1xuXHQvKiogVGhlIGZpbmFsIG9iamVjdCBwYXRoIHVzZWQgdG8gc3RvcmUgdGhlIHJlc3VsdCBpbiB0aGUgcmVkdXggc3RvcmUuIEluY2x1ZGVzIGtleXMgYW5kIGlkcy4gKi9cblx0bW9kZWxQYXRoOiBzdHJpbmdcblx0aXNDb2xsZWN0aW9uSXRlbUZldGNoOiBib29sZWFuXG5cdGlzQ29sbGVjdGlvbkl0ZW1DcmVhdGU6IGJvb2xlYW5cblx0aXNDb2xsZWN0aW9uSXRlbURlbGV0ZTogYm9vbGVhblxufVxuXG4vKipcbiAqIFByZXBhcmUgZmV0Y2hDb25maWcgdG8gcGFzcyB0byBmZXRjaFNlcnZpY2UuIEFsc28gc2V0IHVwIHN0YXRlIHRvIGhhbmRsZSByZXNwb25zZSBjb3JyZWN0bHkuXG4gKlxuICogQHBhcmFtIG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uIFRoZSBhY3Rpb24gZGlzcGF0Y2hlZCBieSB0aGUgY2xpZW50XG4gKiBAcGFyYW0gZW5kcG9pbnRNYXBwaW5ncyBUaGUgRW5kcG9pbnRNYXBwaW5ncyBvYmplY3RcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByZXBhcmVGZXRjaChcblx0bW9kZWxGZXRjaFJlcXVlc3RBY3Rpb246IE1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uIHwgUGVyaW9kaWNNb2RlbEZldGNoUmVxdWVzdEFjdGlvbixcblx0ZW5kcG9pbnRNYXBwaW5nczogRW5kcG9pbnRNYXBwaW5ncyB8IHVuZGVmaW5lZFxuKSB7XG5cdHRyeSB7XG5cdFx0aWYgKCFtb2RlbEZldGNoUmVxdWVzdEFjdGlvbi5tb2RlbE5hbWUpIHtcblx0XHRcdHRocm93IG5ldyBFcnJvcihcIidtb2RlbEZldGNoUmVxdWVzdEFjdGlvbi5tb2RlbE5hbWUnIGlzIHJlcXVpcmVkXCIpXG5cdFx0fVxuXHRcdGlmICghZW5kcG9pbnRNYXBwaW5ncykge1xuXHRcdFx0dGhyb3cgbmV3IEVycm9yKFwiJ2VuZHBvaW50TWFwcGluZ3MnIGlzIHJlcXVpcmVkXCIpXG5cdFx0fVxuXG5cdFx0Ly8gR2V0IGZldGNoIHBhcmFtZXRlcnMgZnJvbSBnbG9iYWwgZmV0Y2ggZGljdGlvbmFyeSB1c2luZyB0aGUgbW9kZWxOYW1lIHBhc3NlZCBpbiB0byBsb2NhdGUgdGhlbVxuXHRcdC8vIENvbWJpbmUgcGFyYW1ldGVycyBmcm9tIGdsb2JhbCBkaWN0aW9uYXJ5IHdpdGggYW55IHBhc3NlZCBpbiAtIGxvY2FscyBvdmVycmlkZSBkaWN0aW9uYXJ5XG5cdFx0Y29uc3QgZW5kcG9pbnRNYXBwaW5nID0gZ2V0KGVuZHBvaW50TWFwcGluZ3MsIG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLm1vZGVsTmFtZSkgYXMgRW5kcG9pbnRNYXBwaW5nIHwgdW5kZWZpbmVkXG5cdFx0aWYgKCFlbmRwb2ludE1hcHBpbmcpIHtcblx0XHRcdHRocm93IG5ldyBFcnJvcihgQ2Fubm90IGZpbmQgJyR7bW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24ubW9kZWxOYW1lfScgaW4gJ2VuZHBvaW50TWFwcGluZ3MnYClcblx0XHR9XG5cblx0XHRjb25zdCBlbmRwb2ludENvbmZpZzogRW5kcG9pbnRDb25maWcgPSBtZXJnZSh7fSwgZW5kcG9pbnRNYXBwaW5nLl9jb25maWcpXG5cdFx0Y29uc3QgZmV0Y2hDb25maWc6IEZldGNoQ29uZmlnID0gbWVyZ2Uoe30sIGVuZHBvaW50Q29uZmlnLmZldGNoLCB7XG5cdFx0XHRoZWFkZXJzOiBtZXJnZSh7fSwgbW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24uaGVhZGVycyksXG5cdFx0XHRxdWVyeVBhcmFtczogbWVyZ2Uoe30sIG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLnF1ZXJ5UGFyYW1zKVxuXHRcdH0pXG5cblx0XHQvLyBzZXQgXCJtZXRob2RcIiBpZiBkZWZpbmVkXG5cdFx0aWYgKG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLm1ldGhvZCkge1xuXHRcdFx0ZmV0Y2hDb25maWcubWV0aG9kID0gbW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24ubWV0aG9kXG5cdFx0fVxuXG5cdFx0Ly8gc2V0IG9yIG1lcmdlIFwiYm9keVwiXG5cdFx0Ly8gSWYgdGhlIGJvZHkgaXMgYSBzdHJpbmcsIHdlIGFyZSBhc3N1bWluZyBpdCdzIGFuICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnXG5cdFx0aWYgKFxuXHRcdFx0bW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24uYm9keSAmJlxuXHRcdFx0KHR5cGVvZiBtb2RlbEZldGNoUmVxdWVzdEFjdGlvbi5ib2R5ID09PSAnc3RyaW5nJyB8fCBtb2RlbEZldGNoUmVxdWVzdEFjdGlvbi5ib2R5IGluc3RhbmNlb2YgRm9ybURhdGEpXG5cdFx0KSB7XG5cdFx0XHRmZXRjaENvbmZpZy5ib2R5ID0gbW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24uYm9keVxuXHRcdFx0ZmV0Y2hDb25maWcuY29udGVudFR5cGUgPSAnYXBwbGljYXRpb24veC13d3ctZm9ybS11cmxlbmNvZGVkJ1xuXHRcdH0gZWxzZSBpZiAoZmV0Y2hDb25maWcuYm9keSB8fCBtb2RlbEZldGNoUmVxdWVzdEFjdGlvbi5ib2R5KSB7XG5cdFx0XHQvLyBpZiB0aGUgYWN0aW9uIGJvZHkgaXMgYW4gYXJyYXksIGVuc3VyZSB0aGUgcmVxdWVzdCBib2R5IGlzIGFuIGFycmF5XG5cdFx0XHRpZiAoISFtb2RlbEZldGNoUmVxdWVzdEFjdGlvbi5ib2R5ICYmIGlzQXJyYXkobW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24uYm9keSkpIHtcblx0XHRcdFx0ZmV0Y2hDb25maWcuYm9keSA9IHVuaW9uKFxuXHRcdFx0XHRcdFtdLFxuXHRcdFx0XHRcdC8vIHVzZSB0aGUgZGVmYXVsdCBib2R5IGZyb20gdGhlIGNvbmZpZyBpZiBpdCBpcyBhbHNvIGFuIGFycmF5XG5cdFx0XHRcdFx0ISFmZXRjaENvbmZpZy5ib2R5ICYmIGlzQXJyYXkoZmV0Y2hDb25maWcuYm9keSkgPyBmZXRjaENvbmZpZy5ib2R5IDogW10sXG5cdFx0XHRcdFx0bW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24uYm9keVxuXHRcdFx0XHQpXG5cdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRmZXRjaENvbmZpZy5ib2R5ID0gbWVyZ2Uoe30sIGZldGNoQ29uZmlnLmJvZHksIG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLmJvZHkpXG5cdFx0XHR9XG5cdFx0fVxuXG5cdFx0Ly8gc2V0IFwiY29udGVudFR5cGVcIiBpZiBkZWZpbmVkLCBvdmVycmlkaW5nIHRoZSBkZWZhdWx0ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnXG5cdFx0Ly8gdGhhdCBtYXkgaGF2ZSBiZWVuIHNldCBwcmV2aW91c2x5XG5cdFx0aWYgKG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLmNvbnRlbnRUeXBlKSB7XG5cdFx0XHRmZXRjaENvbmZpZy5jb250ZW50VHlwZSA9IG1vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLmNvbnRlbnRUeXBlXG5cdFx0fVxuXG5cdFx0bGV0IG1vZGVsUGF0aDogc3RyaW5nID0gbW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24ubW9kZWxOYW1lXG5cdFx0bGV0IGlzQ29sbGVjdGlvbkl0ZW1GZXRjaCA9IGZhbHNlXG5cdFx0bGV0IGlzQ29sbGVjdGlvbkl0ZW1DcmVhdGUgPSBmYWxzZVxuXHRcdGxldCBpc0NvbGxlY3Rpb25JdGVtRGVsZXRlID0gZmFsc2Vcblx0XHQvLyBjb3B5IHBhdGhQYXJhbXMgaW50byB0d28gYXJyYXlzLCB0byBtYW5hZ2UgdGhlbSBzZXBhcmF0ZWx5XG5cdFx0bGV0IHBhdGhQYXJhbXMgPSBtZXJnZShbXSBhcyBBcnJheTxzdHJpbmcgfCBudW1iZXIgfCBudWxsIHwgdW5kZWZpbmVkPiwgbW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24ucGF0aFBhcmFtcylcblx0XHRjb25zdCBtb2RlbFBhdGhQYXJhbXMgPSBtZXJnZShcblx0XHRcdFtdIGFzIEFycmF5PHN0cmluZyB8IG51bWJlciB8IG51bGwgfCB1bmRlZmluZWQ+LFxuXHRcdFx0bW9kZWxGZXRjaFJlcXVlc3RBY3Rpb24ucGF0aFBhcmFtc1xuXHRcdClcblxuXHRcdC8vIGZpbmQgYWxsIHRoZSBtb2RlbCBsZXZlbHMgZnJvbSAnbW9kZWxQYXRoJ1xuXHRcdGNvbnN0IG1vZGVsUGF0aExldmVscyA9IG1vZGVsUGF0aC5zcGxpdCgnLicpXG5cdFx0bGV0IGxhc3RNb2RlbExldmVsOiBFbmRwb2ludE1hcHBpbmcgfCBFbmRwb2ludENvbmZpZyA9IGVuZHBvaW50TWFwcGluZ3Ncblx0XHRjb25zdCBtb2RlbExldmVscyA9IG1vZGVsUGF0aExldmVscy5tYXAobGV2ZWxOYW1lID0+IHtcblx0XHRcdGNvbnN0IG1vZGVsTGV2ZWwgPSBnZXQobGFzdE1vZGVsTGV2ZWwsIGxldmVsTmFtZSlcblx0XHRcdGxhc3RNb2RlbExldmVsID0gbW9kZWxMZXZlbFxuXHRcdFx0cmV0dXJuIG1vZGVsTGV2ZWxcblx0XHR9KVxuXG5cdFx0Ly8gZmluZCB0aGUgbGV2ZWxzIHRoYXQgYXJlIGNvbGxlY3Rpb25zXG5cdFx0Y29uc3QgY29sbGVjdGlvbk1vZGVsTGV2ZWxzID0gbW9kZWxMZXZlbHMuZmlsdGVyKGxldmVsID0+IGxldmVsLl9jb25maWcgJiYgbGV2ZWwuX2NvbmZpZy5pc0NvbGxlY3Rpb24pXG5cdFx0Y29uc3QgaXNBbnlMZXZlbENvbGxlY3Rpb24gPSBjb2xsZWN0aW9uTW9kZWxMZXZlbHMubGVuZ3RoID4gMFxuXG5cdFx0Ly8gaWYgYW55IGxldmVsIGlzIGEgY29sbGVjdGlvbiwgd2UgbmVlZCB0byBjb25jYXQgdGhlaXIgZmV0Y2ggcGF0aHMgYW5kIG1vZGVsTmFtZXNcblx0XHRpZiAoaXNBbnlMZXZlbENvbGxlY3Rpb24pIHtcblx0XHRcdGlmIChtb2RlbFBhdGhMZXZlbHMubGVuZ3RoID4gMSkge1xuXHRcdFx0XHRtb2RlbExldmVscy5mb3JFYWNoKChtb2RlbExldmVsLCBpbmRleCkgPT4ge1xuXHRcdFx0XHRcdGNvbnN0IGxldmVsTmFtZTogc3RyaW5nID0gbW9kZWxQYXRoTGV2ZWxzW2luZGV4XVxuXHRcdFx0XHRcdGNvbnN0IGN1cnJlbnRNb2RlbENvbmZpZyA9IG1lcmdlKHt9LCBtb2RlbExldmVsLl9jb25maWcpXG5cdFx0XHRcdFx0Y29uc3QgY3VycmVudEZldGNoQ29uZmlnID0gbWVyZ2Uoe30sIGN1cnJlbnRNb2RlbENvbmZpZy5mZXRjaClcblx0XHRcdFx0XHRjb25zdCBjdXJyZW50UGF0aCA9ICFpc1VuZGVmaW5lZChjdXJyZW50RmV0Y2hDb25maWcucGF0aClcblx0XHRcdFx0XHRcdD8gY3VycmVudEZldGNoQ29uZmlnLnBhdGhcblx0XHRcdFx0XHRcdDogaW5kZXggPT09IDBcblx0XHRcdFx0XHRcdFx0PyBgL2FwaS8ke2xldmVsTmFtZX1gXG5cdFx0XHRcdFx0XHRcdDogbGV2ZWxOYW1lXG5cblx0XHRcdFx0XHQvLyBmaXJzdCBsZXZlbCwganVzdCB1c2UgaXRzIHZhbHVlc1xuXHRcdFx0XHRcdGlmIChpbmRleCA9PT0gMCkge1xuXHRcdFx0XHRcdFx0ZmV0Y2hDb25maWcucGF0aCA9IGN1cnJlbnRQYXRoXG5cdFx0XHRcdFx0XHRtb2RlbFBhdGggPSBsZXZlbE5hbWVcblx0XHRcdFx0XHRcdHJldHVyblxuXHRcdFx0XHRcdH1cblxuXHRcdFx0XHRcdC8vIGlmIHByZXZpb3VzIGxldmVsIGlzQ29sbGVjdGlvbiwgd2UgbmVlZCB0byB1c2UgXCJ7OmlkfVwiIGhvb2tzIHdoZW4gYXBwZW5kaW5nIG5ldyBsZXZlbFxuXHRcdFx0XHRcdC8vIG90aGVyd2lzZSwganVzdCBhcHBlbmQgdXNpbmcgdGhlIGRpdmlkZXJcblx0XHRcdFx0XHRjb25zdCBwcmV2TW9kZWxDb25maWcgPSBtZXJnZSh7fSwgbW9kZWxMZXZlbHNbaW5kZXggLSAxXS5fY29uZmlnKVxuXHRcdFx0XHRcdGNvbnN0IGRpdmlkZXIgPVxuXHRcdFx0XHRcdFx0ISFmZXRjaENvbmZpZy5wYXRoICYmIGZldGNoQ29uZmlnLnBhdGgubGVuZ3RoID4gMCAmJiBjdXJyZW50UGF0aC5sZW5ndGggPiAwID8gJy8nIDogJydcblx0XHRcdFx0XHRpZiAocHJldk1vZGVsQ29uZmlnLmlzQ29sbGVjdGlvbikge1xuXHRcdFx0XHRcdFx0ZmV0Y2hDb25maWcucGF0aCA9IGAke2ZldGNoQ29uZmlnLnBhdGh9JHtkaXZpZGVyfXs6aWR9LyR7Y3VycmVudFBhdGh9YFxuXHRcdFx0XHRcdFx0bW9kZWxQYXRoID0gYCR7bW9kZWxQYXRofS57OmlkfS4ke2xldmVsTmFtZX1gXG5cdFx0XHRcdFx0fSBlbHNlIHtcblx0XHRcdFx0XHRcdGZldGNoQ29uZmlnLnBhdGggPSBgJHtmZXRjaENvbmZpZy5wYXRofSR7ZGl2aWRlcn0ke2N1cnJlbnRQYXRofWBcblx0XHRcdFx0XHRcdG1vZGVsUGF0aCA9IGAke21vZGVsUGF0aH0uJHtsZXZlbE5hbWV9YFxuXHRcdFx0XHRcdH1cblxuXHRcdFx0XHRcdC8vIGFuIGFic29sdXRlIHBhdGggcmVzZXRzIHRoZSBmZXRjaCBwYXRoLCBhbmQgaWdub3JlcyBwcmV2aW91cyBwYXRoUGFyYW1zIG1vdmluZyBmb3J3YXJkXG5cdFx0XHRcdFx0Ly8gaXQgZG9lcyBub3QgYWZmZWN0IG1vZGVsUGF0aCBwYXJhbXMgZm9yIHJlZHV4XG5cdFx0XHRcdFx0aWYgKGN1cnJlbnRQYXRoLmluZGV4T2YoJy8nKSA9PT0gMCkge1xuXHRcdFx0XHRcdFx0ZmV0Y2hDb25maWcucGF0aCA9IGN1cnJlbnRQYXRoXG5cdFx0XHRcdFx0XHRjb25zdCBjb2xsZWN0aW9uTGV2ZWxJbmRleCA9IGNvbGxlY3Rpb25Nb2RlbExldmVscy5pbmRleE9mKG1vZGVsTGV2ZWwpXG5cdFx0XHRcdFx0XHRpZiAoY29sbGVjdGlvbkxldmVsSW5kZXggPiAwKSB7XG5cdFx0XHRcdFx0XHRcdC8vIHNpbmNlIGBjb2xsZWN0aW9uTGV2ZWxJbmRleGAgaXMgYmFzZWQgb24gdGhlIGZ1bGwgYW1vdW50IG9mIHBhcmFtcyxcblx0XHRcdFx0XHRcdFx0Ly8gYWx3YXlzIHRhcmdldCBgbW9kZWxQYXRoUGFyYW1zYCwgbm90IHRoZSBcImN1cnJlbnRcIiBgcGF0aFBhcmFtc2Bcblx0XHRcdFx0XHRcdFx0cGF0aFBhcmFtcyA9IG1vZGVsUGF0aFBhcmFtcy5zbGljZShjb2xsZWN0aW9uTGV2ZWxJbmRleCwgbW9kZWxQYXRoUGFyYW1zLmxlbmd0aClcblx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHR9XG5cdFx0XHRcdH0pXG5cdFx0XHR9XG5cblx0XHRcdGlmICghZmV0Y2hDb25maWcucGF0aCkge1xuXHRcdFx0XHRmZXRjaENvbmZpZy5wYXRoID0gYC9hcGkvJHttb2RlbFBhdGh9YFxuXHRcdFx0fVxuXG5cdFx0XHQvLyBkZXRlcm1pbmUgaWYgd2UgbmVlZCB0byBhcHBlbmQgYW4gXCJ7OmlkfVwiIGhvb2tcblx0XHRcdGNvbnN0IHBhdGhMZXZlbHMgPSAoZmV0Y2hDb25maWcucGF0aC5tYXRjaCgvezppZH0vZykgfHwgW10pLmxlbmd0aFxuXHRcdFx0Ly8gR0VULCBQVVQsIFBBVENILCBERUxFVEUgPT4gYXBwZW5kICcvezppZH0nXG5cdFx0XHRpc0NvbGxlY3Rpb25JdGVtRmV0Y2ggPSAhIWVuZHBvaW50Q29uZmlnLmlzQ29sbGVjdGlvbiAmJiBwYXRoUGFyYW1zLmxlbmd0aCA+IHBhdGhMZXZlbHNcblx0XHRcdC8vIFBPU1Rcblx0XHRcdGlzQ29sbGVjdGlvbkl0ZW1DcmVhdGUgPSAhIWVuZHBvaW50Q29uZmlnLmlzQ29sbGVjdGlvbiAmJiBmZXRjaENvbmZpZy5tZXRob2QgPT09ICdQT1NUJ1xuXHRcdFx0aXNDb2xsZWN0aW9uSXRlbURlbGV0ZSA9ICEhZW5kcG9pbnRDb25maWcuaXNDb2xsZWN0aW9uICYmIGZldGNoQ29uZmlnLm1ldGhvZCA9PT0gJ0RFTEVURSdcblxuXHRcdFx0Ly8gaW5zZXJ0IHBhdGhQYXJhbSBob29rcyBpbnRvIHBhdGggYW5kIG1vZGVsUGF0aFxuXHRcdFx0Ly8gdHJhY2sgY29sbGVjdGlvbiBpdGVtIHJlcXVlc3RzIGJ5IGlkICh1cGRhdGUsIGRlbGV0ZSkgb3IgZ3VpZCAoY3JlYXRlKVxuXHRcdFx0aWYgKGlzQ29sbGVjdGlvbkl0ZW1GZXRjaCAmJiAhaXNDb2xsZWN0aW9uSXRlbUNyZWF0ZSkge1xuXHRcdFx0XHRmZXRjaENvbmZpZy5wYXRoID0gYCR7ZmV0Y2hDb25maWcucGF0aH0vezppZH1gXG5cdFx0XHRcdG1vZGVsUGF0aCA9IGAke21vZGVsUGF0aH0uezppZH1gXG5cdFx0XHR9IGVsc2UgaWYgKGlzQ29sbGVjdGlvbkl0ZW1DcmVhdGUpIHtcblx0XHRcdFx0bW9kZWxQYXRoID0gYCR7bW9kZWxQYXRofS4ke21vZGVsRmV0Y2hSZXF1ZXN0QWN0aW9uLmd1aWQgfHwgdXVpZHY0KCl9YFxuXHRcdFx0fVxuXHRcdH1cblxuXHRcdGlmICghZmV0Y2hDb25maWcucGF0aCkge1xuXHRcdFx0dGhyb3cgbmV3IEVycm9yKFwiJ2ZldGNoQ29uZmlnLnBhdGgnIGlzIHJlcXVpcmVkIGZvciBub24tY29sbGVjdGlvbnNcIilcblx0XHR9XG5cblx0XHQvLyBzdWJzdGl0dXRlIGFueSBwYXJhbXMgaW4gYG1vZGVsUGF0aGAsIGUuZy4gYGdyb3Vwcy57OmlkfWBcblx0XHRpZiAoL3s6Lit9Ly50ZXN0KG1vZGVsUGF0aCkpIHtcblx0XHRcdGxldCBpbmRleCA9IDBcblx0XHRcdG1vZGVsUGF0aCA9IG1vZGVsUGF0aC5yZXBsYWNlKC97OiguKz8pfS9nLCAoKSA9PiB7XG5cdFx0XHRcdGNvbnN0IHZhbHVlID0gbW9kZWxQYXRoUGFyYW1zW2luZGV4XVxuXHRcdFx0XHRpZiAodmFsdWUgPT09IHVuZGVmaW5lZCB8fCB2YWx1ZSA9PT0gbnVsbCkge1xuXHRcdFx0XHRcdHRocm93IG5ldyBFcnJvcihgQ291bGQgbm90IHJlcGxhY2UgcGFyYW1zIGluICdtb2RlbFBhdGgnIHVzaW5nICdtb2RlbFBhdGhQYXJhbXMnYClcblx0XHRcdFx0fVxuXHRcdFx0XHRpbmRleCsrXG5cdFx0XHRcdHJldHVybiBTdHJpbmcodmFsdWUpXG5cdFx0XHR9KVxuXHRcdH1cblxuXHRcdC8vIHN1YnN0aXR1dGUgYW55IHBhcmFtcyBpbiBgZmV0Y2hDb25maWcucGF0aGAsIGUuZy4gYC9hcGkvZ3JvdXAvezppZH1gXG5cdFx0aWYgKCEhZmV0Y2hDb25maWcucGF0aCAmJiAvezouK30vLnRlc3QoZmV0Y2hDb25maWcucGF0aCkpIHtcblx0XHRcdGxldCBpbmRleCA9IDBcblx0XHRcdGZldGNoQ29uZmlnLnBhdGggPSBmZXRjaENvbmZpZy5wYXRoLnJlcGxhY2UoL3s6KC4rPyl9L2csICgpID0+IHtcblx0XHRcdFx0Y29uc3QgdmFsdWUgPSBwYXRoUGFyYW1zW2luZGV4XVxuXHRcdFx0XHRpZiAodmFsdWUgPT09IHVuZGVmaW5lZCB8fCB2YWx1ZSA9PT0gbnVsbCkge1xuXHRcdFx0XHRcdHRocm93IG5ldyBFcnJvcihgQ291bGQgbm90IHJlcGxhY2UgcGFyYW1zIGluICdmZXRjaENvbmZpZy5wYXRoJyB1c2luZyAncGF0aFBhcmFtcydgKVxuXHRcdFx0XHR9XG5cdFx0XHRcdGluZGV4Kytcblx0XHRcdFx0cmV0dXJuIFN0cmluZyh2YWx1ZSlcblx0XHRcdH0pXG5cdFx0fVxuXG5cdFx0Y29uc3QgcmVzdWx0OiBQcmVwYXJlRmV0Y2hSZXN1bHQgPSB7XG5cdFx0XHRlbmRwb2ludE1hcHBpbmcsXG5cdFx0XHRmZXRjaENvbmZpZyxcblx0XHRcdGVuZHBvaW50Q29uZmlnLFxuXHRcdFx0bW9kZWxQYXRoLFxuXHRcdFx0aXNDb2xsZWN0aW9uSXRlbUZldGNoLFxuXHRcdFx0aXNDb2xsZWN0aW9uSXRlbUNyZWF0ZSxcblx0XHRcdGlzQ29sbGVjdGlvbkl0ZW1EZWxldGVcblx0XHR9XG5cblx0XHRyZXR1cm4gcmVzdWx0XG5cdH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG5cdFx0Y29uc3QgcHJlcGFyZUZldGNoRXJyb3IgPSBjb25zdHJ1Y3RFcnJvckZyb21DYXVnaHRFcnJvcihlcnJvciwgJ1ByZXBhcmVGZXRjaEVycm9yJylcblx0XHR0aHJvdyBwcmVwYXJlRmV0Y2hFcnJvclxuXHR9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxPQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxLQUFBLEdBQUFELE9BQUE7QUFHQSxJQUFBRSxNQUFBLEdBQUFGLE9BQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ08sTUFBTUcsZ0JBQWdCLEdBQUlDLEtBQVUsSUFDMUMsQ0FBQyxDQUFDQSxLQUFLLElBQ1AsT0FBT0EsS0FBSyxLQUFLLFFBQVEsSUFDekJDLE1BQU0sQ0FBQ0MsU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osS0FBSyxFQUFFLFFBQVEsQ0FBQyxJQUNyREMsTUFBTSxDQUFDQyxTQUFTLENBQUNDLGNBQWMsQ0FBQ0MsSUFBSSxDQUFDSixLQUFLLEVBQUUsT0FBTyxDQUFDLElBQ3BEQyxNQUFNLENBQUNDLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNKLEtBQUssRUFBRSxRQUFRLENBQUM7QUFBQUssT0FBQSxDQUFBTixnQkFBQSxHQUFBQSxnQkFBQTtBQWdCdEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ08sU0FBU08sWUFBWUEsQ0FDM0JDLHVCQUFrRixF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QzVDLFdBQVcsQ0FBQ21DLElBQUksRUFBRTtNQUN0QixNQUFNLElBQUl6QyxLQUFLLENBQUMsb0RBQW9ELENBQUM7SUFDdEU7O0lBRUE7SUFDQSxJQUFJLE9BQU8sQ0FBQ21ELElBQUksQ0FBQ25DLFNBQVMsQ0FBQyxFQUFFO01BQzVCLElBQUlvQixLQUFLLEdBQUcsQ0FBQztNQUNicEIsU0FBUyxHQUFHQSxTQUFTLENBQUNvQyxPQUFPLENBQUMsV0FBVyxFQUFFLE1BQU07UUFDaEQsTUFBTTlELEtBQUssR0FBRytCLGVBQWUsQ0FBQ2UsS0FBSyxDQUFDO1FBQ3BDLElBQUk5QyxLQUFLLEtBQUsrRCxTQUFTLElBQUkvRCxLQUFLLEtBQUssSUFBSSxFQUFFO1VBQzFDLE1BQU0sSUFBSVUsS0FBSyxDQUFDLGlFQUFpRSxDQUFDO1FBQ25GO1FBQ0FvQyxLQUFLLEVBQUU7UUFDUCxPQUFPa0IsTUFBTSxDQUFDaEUsS0FBSyxDQUFDO01BQ3JCLENBQUMsQ0FBQztJQUNIOztJQUVBO0lBQ0EsSUFBSSxDQUFDLENBQUNnQixXQUFXLENBQUNtQyxJQUFJLElBQUksT0FBTyxDQUFDVSxJQUFJLENBQUM3QyxXQUFXLENBQUNtQyxJQUFJLENBQUMsRUFBRTtNQUN6RCxJQUFJTCxLQUFLLEdBQUcsQ0FBQztNQUNiOUIsV0FBVyxDQUFDbUMsSUFBSSxHQUFHbkMsV0FBVyxDQUFDbUMsSUFBSSxDQUFDVyxPQUFPLENBQUMsV0FBVyxFQUFFLE1BQU07UUFDOUQsTUFBTTlELEtBQUssR0FBRzhCLFVBQVUsQ0FBQ2dCLEtBQUssQ0FBQztRQUMvQixJQUFJOUMsS0FBSyxLQUFLK0QsU0FBUyxJQUFJL0QsS0FBSyxLQUFLLElBQUksRUFBRTtVQUMxQyxNQUFNLElBQUlVLEtBQUssQ0FBQyxtRUFBbUUsQ0FBQztRQUNyRjtRQUNBb0MsS0FBSyxFQUFFO1FBQ1AsT0FBT2tCLE1BQU0sQ0FBQ2hFLEtBQUssQ0FBQztNQUNyQixDQUFDLENBQUM7SUFDSDtJQUVBLE1BQU1pRSxNQUEwQixHQUFHO01BQ2xDdEQsZUFBZTtNQUNmSyxXQUFXO01BQ1hILGNBQWM7TUFDZGEsU0FBUztNQUNUQyxxQkFBcUI7TUFDckJDLHNCQUFzQjtNQUN0QkM7SUFDRCxDQUFDO0lBRUQsT0FBT29DLE1BQU07RUFDZCxDQUFDLENBQUMsT0FBT0MsS0FBYyxFQUFFO0lBQ3hCLE1BQU1DLGlCQUFpQixHQUFHLElBQUFDLG9DQUE2QixFQUFDRixLQUFLLEVBQUUsbUJBQW1CLENBQUM7SUFDbkYsTUFBTUMsaUJBQWlCO0VBQ3hCO0FBQ0QiLCJpZ25vcmVMaXN0IjpbXX0=
|
package/lib/utils/group.js
CHANGED
|
@@ -1,15 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
3
6
|
exports.isInvalidForSave = exports.hasFormErrors = void 0;
|
|
4
|
-
var
|
|
7
|
+
var _date = require("./date");
|
|
5
8
|
// Not validating dates or external sections currently. Assumes data coming from back end has been validated
|
|
6
|
-
|
|
9
|
+
const hasFormErrors = formErrors => !!formErrors.name;
|
|
7
10
|
exports.hasFormErrors = hasFormErrors;
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
const isInvalidForSave = _ref => {
|
|
12
|
+
let {
|
|
13
|
+
externalTerm,
|
|
14
|
+
isUsingExternalTerm,
|
|
15
|
+
startDate,
|
|
16
|
+
endDate,
|
|
17
|
+
groupName,
|
|
18
|
+
formErrors
|
|
19
|
+
} = _ref;
|
|
20
|
+
return !groupName || hasFormErrors(formErrors) || !isUsingExternalTerm && (!startDate || !endDate || (0, _date.isNowEqualOrBeforeDate)(startDate, endDate)) || isUsingExternalTerm && !externalTerm;
|
|
14
21
|
};
|
|
15
22
|
exports.isInvalidForSave = isInvalidForSave;
|
|
23
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF0ZSIsInJlcXVpcmUiLCJoYXNGb3JtRXJyb3JzIiwiZm9ybUVycm9ycyIsIm5hbWUiLCJleHBvcnRzIiwiaXNJbnZhbGlkRm9yU2F2ZSIsIl9yZWYiLCJleHRlcm5hbFRlcm0iLCJpc1VzaW5nRXh0ZXJuYWxUZXJtIiwic3RhcnREYXRlIiwiZW5kRGF0ZSIsImdyb3VwTmFtZSIsImlzTm93RXF1YWxPckJlZm9yZURhdGUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvZ3JvdXAudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXh0ZXJuYWxUZXJtIH0gZnJvbSAnLi4vdHlwZXMnXG5pbXBvcnQgeyBpc05vd0VxdWFsT3JCZWZvcmVEYXRlIH0gZnJvbSAnLi9kYXRlJ1xuXG5pbnRlcmZhY2UgRm9ybUVycm9yIHtcblx0bmFtZT86IHN0cmluZ1xufVxuXG5pbnRlcmZhY2UgRm9ybURhdGEge1xuXHRleHRlcm5hbFRlcm0/OiBFeHRlcm5hbFRlcm1cblx0aXNVc2luZ0V4dGVybmFsVGVybTogYm9vbGVhblxuXHRzdGFydERhdGU/OiBzdHJpbmdcblx0ZW5kRGF0ZT86IHN0cmluZ1xuXHRncm91cE5hbWU6IHN0cmluZ1xuXHRmb3JtRXJyb3JzOiBGb3JtRXJyb3Jcbn1cblxuLy8gTm90IHZhbGlkYXRpbmcgZGF0ZXMgb3IgZXh0ZXJuYWwgc2VjdGlvbnMgY3VycmVudGx5LiBBc3N1bWVzIGRhdGEgY29taW5nIGZyb20gYmFjayBlbmQgaGFzIGJlZW4gdmFsaWRhdGVkXG5leHBvcnQgY29uc3QgaGFzRm9ybUVycm9ycyA9IChmb3JtRXJyb3JzOiBGb3JtRXJyb3IpID0+ICEhZm9ybUVycm9ycy5uYW1lXG5cbmV4cG9ydCBjb25zdCBpc0ludmFsaWRGb3JTYXZlID0gKHtcblx0ZXh0ZXJuYWxUZXJtLFxuXHRpc1VzaW5nRXh0ZXJuYWxUZXJtLFxuXHRzdGFydERhdGUsXG5cdGVuZERhdGUsXG5cdGdyb3VwTmFtZSxcblx0Zm9ybUVycm9yc1xufTogRm9ybURhdGEpID0+XG5cdCFncm91cE5hbWUgfHxcblx0aGFzRm9ybUVycm9ycyhmb3JtRXJyb3JzKSB8fFxuXHQoIWlzVXNpbmdFeHRlcm5hbFRlcm0gJiYgKCFzdGFydERhdGUgfHwgIWVuZERhdGUgfHwgaXNOb3dFcXVhbE9yQmVmb3JlRGF0ZShzdGFydERhdGUsIGVuZERhdGUpKSkgfHxcblx0KGlzVXNpbmdFeHRlcm5hbFRlcm0gJiYgIWV4dGVybmFsVGVybSlcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsSUFBQUEsS0FBQSxHQUFBQyxPQUFBO0FBZUE7QUFDTyxNQUFNQyxhQUFhLEdBQUlDLFVBQXFCLElBQUssQ0FBQyxDQUFDQSxVQUFVLENBQUNDLElBQUk7QUFBQUMsT0FBQSxDQUFBSCxhQUFBLEdBQUFBLGFBQUE7QUFFbEUsTUFBTUksZ0JBQWdCLEdBQUdDLElBQUE7RUFBQSxJQUFDO0lBQ2hDQyxZQUFZO0lBQ1pDLG1CQUFtQjtJQUNuQkMsU0FBUztJQUNUQyxPQUFPO0lBQ1BDLFNBQVM7SUFDVFQ7RUFDUyxDQUFDLEdBQUFJLElBQUE7RUFBQSxPQUNWLENBQUNLLFNBQVMsSUFDVlYsYUFBYSxDQUFDQyxVQUFVLENBQUMsSUFDeEIsQ0FBQ00sbUJBQW1CLEtBQUssQ0FBQ0MsU0FBUyxJQUFJLENBQUNDLE9BQU8sSUFBSSxJQUFBRSw0QkFBc0IsRUFBQ0gsU0FBUyxFQUFFQyxPQUFPLENBQUMsQ0FBRSxJQUMvRkYsbUJBQW1CLElBQUksQ0FBQ0QsWUFBYTtBQUFBO0FBQUFILE9BQUEsQ0FBQUMsZ0JBQUEsR0FBQUEsZ0JBQUEiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -3,5 +3,5 @@ export declare const getTerm: (externalTerms: ModelCollection<ExternalTerm>, gro
|
|
|
3
3
|
export declare const getTermOrDatesUIText: (externalTerms: ModelCollection<ExternalTerm>, group: Group) => string;
|
|
4
4
|
export declare const getEndDate: (externalTerms: ModelCollection<ExternalTerm>, group: Group) => string;
|
|
5
5
|
export declare const getStartDate: (externalTerms: ModelCollection<ExternalTerm>, group: Group) => string;
|
|
6
|
-
export declare const filterGroupsByEndDate: (groups: Group[], externalTerms: ModelCollection<ExternalTerm>, filterFunction: (dateTimeUtc?: string
|
|
6
|
+
export declare const filterGroupsByEndDate: (groups: Group[], externalTerms: ModelCollection<ExternalTerm>, filterFunction: (dateTimeUtc?: string, nowUtc?: string) => boolean) => Group[];
|
|
7
7
|
export declare const isGroupEnded: (externalTerms: ModelCollection<ExternalTerm>, group: Group) => boolean;
|