@beinformed/ui 1.65.13 → 1.65.15
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/CHANGELOG.md +15 -0
- package/esm/hooks/useList.js +3 -1
- package/esm/hooks/useList.js.flow +11 -4
- package/esm/hooks/useList.js.map +1 -1
- package/esm/hooks/useModularUI.js +21 -26
- package/esm/hooks/useModularUI.js.flow +28 -34
- package/esm/hooks/useModularUI.js.map +1 -1
- package/esm/hooks/useModularUIBasic.js +8 -39
- package/esm/hooks/useModularUIBasic.js.flow +6 -42
- package/esm/hooks/useModularUIBasic.js.map +1 -1
- package/lib/hooks/useList.js +3 -1
- package/lib/hooks/useList.js.map +1 -1
- package/lib/hooks/useModularUI.js +20 -25
- package/lib/hooks/useModularUI.js.map +1 -1
- package/lib/hooks/useModularUIBasic.js +9 -39
- package/lib/hooks/useModularUIBasic.js.map +1 -1
- package/package.json +2 -3
- package/src/builder/__tests__/LayoutHintConfig.json +0 -20
- package/src/builder/__tests__/mergeLayoutHintConfigurations.spec.js +0 -71
- package/src/builder/__tests__/subdir/LayoutHintConfig.json +0 -20
- package/src/builder/index.js +0 -2
- package/src/builder/mergeLayoutHintConfigurations.js +0 -62
- package/src/constants/Constants.js +0 -196
- package/src/constants/LayoutHintConfig.js +0 -186
- package/src/constants/LayoutHints.js +0 -134
- package/src/constants/Settings.js +0 -267
- package/src/constants/index.js +0 -4
- package/src/exceptions/ConfigurationException.js +0 -13
- package/src/exceptions/FetchException.js +0 -101
- package/src/exceptions/IllegalArgumentException.js +0 -12
- package/src/exceptions/IllegalReturnException.js +0 -11
- package/src/exceptions/IllegalStateException.js +0 -12
- package/src/exceptions/JsonParseException.js +0 -12
- package/src/exceptions/MissingPropertyException.js +0 -13
- package/src/exceptions/NetworkException.js +0 -20
- package/src/exceptions/NotAllowedUriException.js +0 -12
- package/src/exceptions/NotFoundException.js +0 -20
- package/src/exceptions/ServerRequestException.js +0 -12
- package/src/exceptions/ThemePropertyException.js +0 -12
- package/src/exceptions/TimeoutException.js +0 -13
- package/src/exceptions/UnauthorizedException.js +0 -26
- package/src/exceptions/UnsupportedOperationException.js +0 -12
- package/src/exceptions/index.js +0 -16
- package/src/hooks/__tests__/UseModularUIModel.spec.js +0 -194
- package/src/hooks/__tests__/useAuthentication.spec.js +0 -166
- package/src/hooks/__tests__/useForm.spec.js +0 -300
- package/src/hooks/__tests__/useI18n.spec.js +0 -30
- package/src/hooks/__tests__/useModal.spec.js +0 -67
- package/src/hooks/__tests__/useModelCatalog.spec.js +0 -180
- package/src/hooks/__tests__/useModels.spec.js +0 -138
- package/src/hooks/__tests__/useModularUIBasic.spec.js +0 -126
- package/src/hooks/__tests__/useNotification.spec.js +0 -47
- package/src/hooks/__tests__/usePreference.spec.js +0 -72
- package/src/hooks/__tests__/useProgressIndicator.spec.js +0 -67
- package/src/hooks/index.js +0 -21
- package/src/hooks/useAllFormsOnModel.js +0 -92
- package/src/hooks/useAuthentication.js +0 -113
- package/src/hooks/useContent.js +0 -48
- package/src/hooks/useDeepCompareEffect.js +0 -50
- package/src/hooks/useForm.js +0 -156
- package/src/hooks/useI18n.js +0 -46
- package/src/hooks/useList.js +0 -221
- package/src/hooks/useLookup.js +0 -82
- package/src/hooks/useModal.js +0 -46
- package/src/hooks/useModelCatalog.js +0 -256
- package/src/hooks/useModels.js +0 -50
- package/src/hooks/useModularUI.js +0 -79
- package/src/hooks/useModularUIBasic.js +0 -152
- package/src/hooks/useModularUIKey.js +0 -14
- package/src/hooks/useModularUIModel.js +0 -86
- package/src/hooks/useModularUIRequest.js +0 -25
- package/src/hooks/useNotification.js +0 -48
- package/src/hooks/usePanel.js +0 -79
- package/src/hooks/usePreference.js +0 -27
- package/src/hooks/useProgressIndicator.js +0 -50
- package/src/hooks/useRouter.js +0 -70
- package/src/hooks/useSearch.js +0 -31
- package/src/i18n/Locale.js +0 -157
- package/src/i18n/Locales.js +0 -171
- package/src/i18n/Message.js +0 -66
- package/src/i18n/__tests__/Locale.spec.js +0 -108
- package/src/i18n/__tests__/Locales.spec.js +0 -137
- package/src/i18n/index.js +0 -12
- package/src/i18n/languages.js +0 -207
- package/src/i18n/translations/beinformed_error_messages_en.nl.js +0 -98
- package/src/i18n/translations/beinformed_error_messages_nl.nl.js +0 -98
- package/src/i18n/types.js +0 -23
- package/src/i18n/withMessage.js +0 -47
- package/src/index.js +0 -7
- package/src/models/__tests__/resolveModel.spec.js +0 -34
- package/src/models/actions/ActionCollection.js +0 -100
- package/src/models/actions/ActionModel.js +0 -207
- package/src/models/actions/__mock__/action.js +0 -35
- package/src/models/actions/__tests__/ActionCollection.spec.js +0 -98
- package/src/models/actions/__tests__/ActionModel.spec.js +0 -75
- package/src/models/application/ApplicationModel.js +0 -168
- package/src/models/application/__mock__/application.js +0 -14
- package/src/models/application/__mock__/contributions.json +0 -312
- package/src/models/application/__mock__/data.json +0 -263
- package/src/models/application/__tests__/Application.spec.js +0 -99
- package/src/models/application/__tests__/webapp.json +0 -42
- package/src/models/application/__tests__/webappContributions.json +0 -43
- package/src/models/attributes/AttributeCollection.js +0 -306
- package/src/models/attributes/AttributeContent.js +0 -233
- package/src/models/attributes/AttributeDataHelper.js +0 -323
- package/src/models/attributes/AttributeModel.js +0 -1021
- package/src/models/attributes/AttributeSetModel.js +0 -117
- package/src/models/attributes/BooleanAttributeModel.js +0 -319
- package/src/models/attributes/CaptchaAttributeModel.js +0 -51
- package/src/models/attributes/ChoiceAttributeModel.js +0 -520
- package/src/models/attributes/ChoiceAttributeOptionCollection.js +0 -372
- package/src/models/attributes/ChoiceAttributeOptionModel.js +0 -415
- package/src/models/attributes/CompositeAttributeChildCollection.js +0 -254
- package/src/models/attributes/CompositeAttributeModel.js +0 -439
- package/src/models/attributes/DatetimeAttributeModel.js +0 -566
- package/src/models/attributes/HelptextAttributeModel.js +0 -54
- package/src/models/attributes/LabelAttributeModel.js +0 -36
- package/src/models/attributes/MemoAttributeModel.js +0 -43
- package/src/models/attributes/MoneyAttributeModel.js +0 -45
- package/src/models/attributes/NumberAttributeModel.js +0 -255
- package/src/models/attributes/PasswordAttributeModel.js +0 -245
- package/src/models/attributes/StringAttributeModel.js +0 -314
- package/src/models/attributes/UploadAttributeModel.js +0 -261
- package/src/models/attributes/XMLAttributeModel.js +0 -51
- package/src/models/attributes/__mock__/_ActionFieldsContributions.json +0 -12
- package/src/models/attributes/__mock__/_ActionFieldsData.json +0 -7
- package/src/models/attributes/__mock__/_FormCollectionContribution.json +0 -419
- package/src/models/attributes/__mock__/_FormCollectionData.json +0 -122
- package/src/models/attributes/__mock__/_InstrumentQuestionContributions.json +0 -178
- package/src/models/attributes/__mock__/_ListAttributeContributions.json +0 -82
- package/src/models/attributes/__mock__/_ListAttributeData.json +0 -70
- package/src/models/attributes/__mock__/_ListDetailContributions.json +0 -75
- package/src/models/attributes/__mock__/_ListDetailData.json +0 -38
- package/src/models/attributes/__mock__/_TreeFormAttributeContribution.json +0 -117
- package/src/models/attributes/__mock__/_TreeFormAttributeData.json +0 -27
- package/src/models/attributes/__mock__/form.contributions.json +0 -410
- package/src/models/attributes/__mock__/form.data.json +0 -113
- package/src/models/attributes/__mock__/form.js +0 -6
- package/src/models/attributes/__mock__/list.contributions.json +0 -110
- package/src/models/attributes/__mock__/list.data.json +0 -84
- package/src/models/attributes/__mock__/list.js +0 -6
- package/src/models/attributes/__tests__/AttributeCollection.spec.js +0 -160
- package/src/models/attributes/__tests__/AttributeCollectionComposite.spec.js +0 -146
- package/src/models/attributes/__tests__/AttributeContent.spec.js +0 -225
- package/src/models/attributes/__tests__/AttributeDataHelper.spec.js +0 -634
- package/src/models/attributes/__tests__/AttributeModel.spec.js +0 -274
- package/src/models/attributes/__tests__/AttributeSetModel.spec.js +0 -39
- package/src/models/attributes/__tests__/BooleanAttributeModel.spec.js +0 -107
- package/src/models/attributes/__tests__/CaptchaAttributeModel.spec.js +0 -13
- package/src/models/attributes/__tests__/ChoiceAttributeModel.spec.js +0 -750
- package/src/models/attributes/__tests__/ChoiceAttributeOptionCollection.spec.js +0 -507
- package/src/models/attributes/__tests__/ChoiceAttributeOptionModel.spec.js +0 -107
- package/src/models/attributes/__tests__/CompositeAttributeModel.spec.js +0 -467
- package/src/models/attributes/__tests__/DateAttributeModel.spec.js +0 -134
- package/src/models/attributes/__tests__/DatetimeAttributeModel.spec.js +0 -206
- package/src/models/attributes/__tests__/DatetimeAttributeModel_offset.spec.js +0 -345
- package/src/models/attributes/__tests__/HelptextAttributeModel.spec.js +0 -64
- package/src/models/attributes/__tests__/LabelAttributeModel.spec.js +0 -13
- package/src/models/attributes/__tests__/LookupAttributeModel.spec.js +0 -47
- package/src/models/attributes/__tests__/MemoAttributeModel.spec.js +0 -28
- package/src/models/attributes/__tests__/MoneyAttributeModel.spec.js +0 -22
- package/src/models/attributes/__tests__/NumberAttributeModel.spec.js +0 -67
- package/src/models/attributes/__tests__/PasswordAttributeModel.spec.js +0 -49
- package/src/models/attributes/__tests__/StringAttributeModel.spec.js +0 -125
- package/src/models/attributes/__tests__/TimeAttributeModel.spec.js +0 -57
- package/src/models/attributes/__tests__/TimestampModel.spec.js +0 -43
- package/src/models/attributes/__tests__/UploadAttributeModel.spec.js +0 -67
- package/src/models/attributes/__tests__/XMLAttributeModel.spec.js +0 -17
- package/src/models/attributes/__tests__/_createAttribute.spec.js +0 -106
- package/src/models/attributes/__tests__/createAttributeComposite.spec.js +0 -151
- package/src/models/attributes/__tests__/createAttributeDynamicSchema.spec.js +0 -134
- package/src/models/attributes/_createAttribute.js +0 -147
- package/src/models/attributes/input-constraints/BSNConstraint.js +0 -80
- package/src/models/attributes/input-constraints/ConstraintCollection.js +0 -65
- package/src/models/attributes/input-constraints/ConstraintModel.js +0 -76
- package/src/models/attributes/input-constraints/DateBoundaryConstraint.js +0 -240
- package/src/models/attributes/input-constraints/DateTimeDateFormatConstraint.js +0 -72
- package/src/models/attributes/input-constraints/DateTimeTimeFormatConstraint.js +0 -72
- package/src/models/attributes/input-constraints/DatetimeFormatConstraint.js +0 -132
- package/src/models/attributes/input-constraints/FileExtensionConstraint.js +0 -60
- package/src/models/attributes/input-constraints/FileSizeConstraint.js +0 -101
- package/src/models/attributes/input-constraints/IBANConstraint.js +0 -46
- package/src/models/attributes/input-constraints/MandatoryConstraint.js +0 -54
- package/src/models/attributes/input-constraints/MandatoryRangeConstraint.js +0 -84
- package/src/models/attributes/input-constraints/NumberBoundaryConstraint.js +0 -213
- package/src/models/attributes/input-constraints/NumberFormatConstraint.js +0 -153
- package/src/models/attributes/input-constraints/NumberGroupingConstraint.js +0 -140
- package/src/models/attributes/input-constraints/PasswordConfirmConstraint.js +0 -68
- package/src/models/attributes/input-constraints/PasswordLowerAndUpperCaseConstraint.js +0 -44
- package/src/models/attributes/input-constraints/PasswordMinNumericCharactersConstraint.js +0 -60
- package/src/models/attributes/input-constraints/PasswordMinSpecialCharactersConstraint.js +0 -60
- package/src/models/attributes/input-constraints/PasswordThreeConsecutiveCharactersNotAllowedConstraint.js +0 -72
- package/src/models/attributes/input-constraints/RangeConstraint.js +0 -161
- package/src/models/attributes/input-constraints/RegexConstraint.js +0 -72
- package/src/models/attributes/input-constraints/StringLengthConstraint.js +0 -179
- package/src/models/attributes/input-constraints/XMLConstraint.js +0 -62
- package/src/models/attributes/input-constraints/__tests__/BSNConstraint.spec.js +0 -25
- package/src/models/attributes/input-constraints/__tests__/ConstraintCollection.spec.js +0 -9
- package/src/models/attributes/input-constraints/__tests__/ConstraintModel.spec.js +0 -35
- package/src/models/attributes/input-constraints/__tests__/DateBoundaryConstraint.spec.js +0 -117
- package/src/models/attributes/input-constraints/__tests__/DateTimeDateFormatConstraint.spec.js +0 -30
- package/src/models/attributes/input-constraints/__tests__/DateTimeTimeFormatConstraint.spec.js +0 -54
- package/src/models/attributes/input-constraints/__tests__/DatetimeFormatConstraint.spec.js +0 -79
- package/src/models/attributes/input-constraints/__tests__/FileExtensionConstraint.spec.js +0 -20
- package/src/models/attributes/input-constraints/__tests__/FileSizeConstraint.spec.js +0 -53
- package/src/models/attributes/input-constraints/__tests__/IBANConstraint.spec.js +0 -12
- package/src/models/attributes/input-constraints/__tests__/MandatoryConstraint.spec.js +0 -14
- package/src/models/attributes/input-constraints/__tests__/NumberBoundaryConstraint.spec.js +0 -46
- package/src/models/attributes/input-constraints/__tests__/NumberFormatConstraint.spec.js +0 -137
- package/src/models/attributes/input-constraints/__tests__/NumberGroupingConstraint.spec.js +0 -85
- package/src/models/attributes/input-constraints/__tests__/PasswordConfirmConstraint.spec.js +0 -21
- package/src/models/attributes/input-constraints/__tests__/PasswordLowerAndUpperCaseConstraint.spec.js +0 -14
- package/src/models/attributes/input-constraints/__tests__/PasswordMinNumericCharactersConstraint.spec.js +0 -11
- package/src/models/attributes/input-constraints/__tests__/PasswordMinSpecialCharactersConstraint.spec.js +0 -11
- package/src/models/attributes/input-constraints/__tests__/PasswordThreeConsecutiveCharactersNotAllowedConstraint.spec.js +0 -22
- package/src/models/attributes/input-constraints/__tests__/RegexConstraint.spec.js +0 -42
- package/src/models/attributes/input-constraints/__tests__/StringLengthConstraint.spec.js +0 -102
- package/src/models/attributes/input-constraints/__tests__/XMLConstraint.spec.js +0 -15
- package/src/models/attributes/layouthint-rules/BaseLayoutHintRule.js +0 -74
- package/src/models/attributes/layouthint-rules/DependentAttribute.js +0 -246
- package/src/models/attributes/layouthint-rules/LayoutHintRuleCollection.js +0 -101
- package/src/models/attributes/layouthint-rules/RemainingTotalUploadSize.js +0 -67
- package/src/models/attributes/layouthint-rules/__mock__/MockedCollectionFactory.js +0 -54
- package/src/models/attributes/layouthint-rules/__tests__/BaseLayoutHintRule.spec.js +0 -29
- package/src/models/attributes/layouthint-rules/__tests__/DependentAttribute.spec.js +0 -310
- package/src/models/attributes/layouthint-rules/__tests__/LayoutHintRuleCollection.spec.js +0 -58
- package/src/models/attributes/layouthint-rules/__tests__/RemainingTotalUploadSize.spec.js +0 -24
- package/src/models/base/BaseCollection.js +0 -191
- package/src/models/base/BaseModel.js +0 -155
- package/src/models/base/ResourceCollection.js +0 -42
- package/src/models/base/ResourceModel.js +0 -246
- package/src/models/base/__tests__/BaseCollection.spec.js +0 -108
- package/src/models/base/__tests__/BaseModel.spec.js +0 -85
- package/src/models/base/__tests__/ResourceCollection.spec.js +0 -51
- package/src/models/base/__tests__/ResourceModel.spec.js +0 -100
- package/src/models/base/__tests__/webapp.json +0 -52
- package/src/models/caseview/CaseViewModel.js +0 -188
- package/src/models/caseview/__mock__/caseview.js +0 -14
- package/src/models/caseview/__mock__/contributions.json +0 -146
- package/src/models/caseview/__mock__/data.json +0 -21
- package/src/models/caseview/__tests__/CaseViewModel.spec.js +0 -132
- package/src/models/caseview/__tests__/caseview.json +0 -49
- package/src/models/caseview/__tests__/caseviewContributions.json +0 -118
- package/src/models/caseview/__tests__/caseview_local_taskgroup.json +0 -57
- package/src/models/concepts/BusinessScenarioModel.js +0 -176
- package/src/models/concepts/ConceptDetailModel.js +0 -349
- package/src/models/concepts/ConceptIndexModel.js +0 -186
- package/src/models/concepts/ConceptLinkModel.js +0 -208
- package/src/models/concepts/ConceptRelationCollection.js +0 -95
- package/src/models/concepts/ConceptRelationModel.js +0 -129
- package/src/models/concepts/ConceptTypeDetailModel.js +0 -128
- package/src/models/concepts/SourceReferenceCollection.js +0 -40
- package/src/models/concepts/SourceReferenceModel.js +0 -126
- package/src/models/concepts/__mock__/business_scenario.js +0 -26
- package/src/models/concepts/__mock__/business_scenario_data.json +0 -234
- package/src/models/concepts/__mock__/business_scenario_step.json +0 -64
- package/src/models/concepts/__mock__/conceptdetail.js +0 -27
- package/src/models/concepts/__mock__/conceptdetail_contributions.json +0 -156
- package/src/models/concepts/__mock__/conceptdetail_data.json +0 -164
- package/src/models/concepts/__mock__/conceptindex.js +0 -15
- package/src/models/concepts/__mock__/conceptindex_contributions.json +0 -86
- package/src/models/concepts/__mock__/conceptindex_data.json +0 -329
- package/src/models/concepts/__mock__/concepttype.js +0 -13
- package/src/models/concepts/__mock__/concepttype_Calculation.json +0 -75
- package/src/models/concepts/__mock__/concepttype_contributions.json +0 -139
- package/src/models/concepts/__mock__/concepttype_data.json +0 -32
- package/src/models/concepts/__mock__/concepttype_hierarchy.js +0 -13
- package/src/models/concepts/__mock__/concepttype_hierarchy.json +0 -32
- package/src/models/concepts/__mock__/related_concepts.js +0 -12
- package/src/models/concepts/__mock__/related_concepts_contributions.json +0 -41
- package/src/models/concepts/__mock__/related_concepts_data.json +0 -2408
- package/src/models/concepts/__mock__/relation_with_props_and_tf_data.js +0 -27
- package/src/models/concepts/__mock__/relation_with_props_and_tf_data.json +0 -67
- package/src/models/concepts/__tests__/BusinessScenarioModel.spec.js +0 -28
- package/src/models/concepts/__tests__/ConceptDetailModel.spec.js +0 -65
- package/src/models/concepts/__tests__/ConceptIndexModel.spec.js +0 -42
- package/src/models/concepts/__tests__/ConceptLinkModel.spec.js +0 -9
- package/src/models/concepts/__tests__/ConceptRelationCollection.spec.js +0 -9
- package/src/models/concepts/__tests__/ConceptRelationModel.spec.js +0 -53
- package/src/models/concepts/__tests__/ConceptTypeDetailModel.spec.js +0 -31
- package/src/models/concepts/__tests__/RelatedConcepts.spec.js +0 -58
- package/src/models/concepts/__tests__/SourceReferenceCollection.spec.js +0 -9
- package/src/models/concepts/__tests__/SourceReferenceModel.spec.js +0 -108
- package/src/models/content/ContentIndexModel.js +0 -165
- package/src/models/content/ContentLinkModel.js +0 -308
- package/src/models/content/ContentModel.js +0 -227
- package/src/models/content/ContentTOCModel.js +0 -237
- package/src/models/content/ContentTypeModel.js +0 -71
- package/src/models/content/SectionModel.js +0 -236
- package/src/models/content/SubSectionModel.js +0 -181
- package/src/models/content/__tests__/ContentIndexModel.spec.js +0 -40
- package/src/models/content/__tests__/ContentLinkModel.spec.js +0 -129
- package/src/models/content/__tests__/ContentModel.spec.js +0 -241
- package/src/models/content/__tests__/Formalsource.spec.js +0 -133
- package/src/models/content/__tests__/content-index-contributions.json +0 -50
- package/src/models/content/__tests__/content-index.json +0 -164
- package/src/models/content/__tests__/content-with-childsections.json +0 -105
- package/src/models/content/__tests__/content-with-sections.json +0 -105
- package/src/models/content/__tests__/content-with-subsections.json +0 -119
- package/src/models/content/__tests__/content-with-subsections2.json +0 -79
- package/src/models/content/__tests__/content.json +0 -31
- package/src/models/content/__tests__/contributions.json +0 -84
- package/src/models/content/__tests__/formalsource-complete.json +0 -235
- package/src/models/content/__tests__/formalsource-contributions.json +0 -110
- package/src/models/content/__tests__/formalsource-section-contributions.json +0 -84
- package/src/models/content/__tests__/formalsource-section.json +0 -60
- package/src/models/content/__tests__/formalsource-toc.json +0 -122
- package/src/models/contentconfiguration/ContentConfiguration.js +0 -70
- package/src/models/contentconfiguration/ContentConfigurationElements.js +0 -152
- package/src/models/contentconfiguration/ContentConfigurationEndResults.js +0 -45
- package/src/models/contentconfiguration/ContentConfigurationQuestions.js +0 -60
- package/src/models/contentconfiguration/ContentConfigurationResults.js +0 -105
- package/src/models/contentconfiguration/__tests__/ContentConfigurationElements.spec.js +0 -29
- package/src/models/contentconfiguration/__tests__/ContentConfigurationResults.spec.js +0 -101
- package/src/models/detail/DetailModel.js +0 -241
- package/src/models/detail/__tests__/DetailModel.spec.js +0 -41
- package/src/models/detail/__tests__/detail.json +0 -37
- package/src/models/detail/__tests__/detailContributions.json +0 -124
- package/src/models/error/ErrorCollection.js +0 -127
- package/src/models/error/ErrorModel.js +0 -83
- package/src/models/error/ErrorResponse.js +0 -343
- package/src/models/error/__tests__/ErrorCollection.spec.js +0 -41
- package/src/models/error/__tests__/ErrorModel.spec.js +0 -24
- package/src/models/filters/AssignmentFilterModel.js +0 -218
- package/src/models/filters/BaseFilterModel.js +0 -146
- package/src/models/filters/ConceptIndexFilterModel.js +0 -43
- package/src/models/filters/FilterCollection.js +0 -227
- package/src/models/filters/FilterModel.js +0 -151
- package/src/models/filters/RangeFilterModel.js +0 -36
- package/src/models/filters/StringFilterModel.js +0 -167
- package/src/models/filters/__tests__/AssignmentFilterModel.spec.js +0 -140
- package/src/models/filters/__tests__/FilterCollection.spec.js +0 -68
- package/src/models/filters/__tests__/FilterModel.spec.js +0 -65
- package/src/models/filters/__tests__/RangeFilterModel.spec.js +0 -55
- package/src/models/filters/__tests__/ZipcodeFilter.spec.js +0 -145
- package/src/models/filters/__tests__/filters.json +0 -91
- package/src/models/filters/__tests__/filtersContributions.json +0 -110
- package/src/models/form/FormModel.js +0 -1280
- package/src/models/form/FormObjectModel.js +0 -590
- package/src/models/form/__mock__/contributions.json +0 -525
- package/src/models/form/__mock__/data.json +0 -78
- package/src/models/form/__mock__/form.js +0 -17
- package/src/models/form/__tests__/FormContributions.json +0 -495
- package/src/models/form/__tests__/FormContributionsUnknownRepeat.json +0 -67
- package/src/models/form/__tests__/FormInstrumentContributions.json +0 -183
- package/src/models/form/__tests__/FormModel.getters.spec.js +0 -149
- package/src/models/form/__tests__/FormModel.instrument.spec.js +0 -202
- package/src/models/form/__tests__/FormModel.repeating.spec.js +0 -65
- package/src/models/form/__tests__/FormModel.selfhref.spec.js +0 -84
- package/src/models/form/__tests__/FormModel.spec.js +0 -752
- package/src/models/form/__tests__/FormModel.unknown-repeat.spec.js +0 -52
- package/src/models/form/__tests__/FormObjectModel.spec.js +0 -180
- package/src/models/form/__tests__/FormResultData.spec.js +0 -86
- package/src/models/form/__tests__/FormValidation.spec.js +0 -79
- package/src/models/form/__tests__/FormValidationContributions.json +0 -45
- package/src/models/form/__tests__/FormValidationDataInitial.json +0 -33
- package/src/models/form/__tests__/FormValidationDataUpdate1.json +0 -25
- package/src/models/form/__tests__/FormValidationDataUpdate2.json +0 -33
- package/src/models/form/__tests__/FormWithContent.spec.js +0 -71
- package/src/models/form/__tests__/FormWithContentContributions.json +0 -242
- package/src/models/form/__tests__/FormWithContentData.json +0 -244
- package/src/models/grouping/GroupingModel.js +0 -232
- package/src/models/grouping/__tests__/GroupingModel.spec.js +0 -80
- package/src/models/href/Href.js +0 -592
- package/src/models/href/ListHref.js +0 -161
- package/src/models/href/__tests__/Href.spec.js +0 -184
- package/src/models/href/__tests__/ListHref.spec.js +0 -61
- package/src/models/href/__tests__/list.json +0 -2417
- package/src/models/href/__tests__/listContributions.json +0 -330
- package/src/models/index.js +0 -177
- package/src/models/layouthint/LayoutHintCollection.js +0 -116
- package/src/models/layouthint/__tests__/LayoutHintCollection.spec.js +0 -89
- package/src/models/links/LinkCollection.js +0 -169
- package/src/models/links/LinkModel.js +0 -246
- package/src/models/links/__tests__/LinkCollection.spec.js +0 -426
- package/src/models/links/__tests__/LinkModel.spec.js +0 -103
- package/src/models/links/__tests__/normalizeLinkJSON.spec.js +0 -212
- package/src/models/links/normalizeLinkJSON.js +0 -121
- package/src/models/list/ListDetailModel.js +0 -332
- package/src/models/list/ListHeaderModel.js +0 -96
- package/src/models/list/ListItemCollection.js +0 -80
- package/src/models/list/ListItemModel.js +0 -111
- package/src/models/list/ListModel.js +0 -485
- package/src/models/list/__mock__/caselist.contributions.json +0 -372
- package/src/models/list/__mock__/caselist.data.json +0 -519
- package/src/models/list/__mock__/caselist.js +0 -14
- package/src/models/list/__tests__/ListDetailModel.hierarchy.spec.js +0 -88
- package/src/models/list/__tests__/ListDetailModel.spec.js +0 -96
- package/src/models/list/__tests__/ListItemCollection.spec.js +0 -22
- package/src/models/list/__tests__/ListModel.spec.js +0 -152
- package/src/models/list/__tests__/ListResultDetail.spec.js +0 -37
- package/src/models/list/__tests__/caselist-34.contributions.json +0 -146
- package/src/models/list/__tests__/caselist-34.data.json +0 -21
- package/src/models/list/__tests__/hierarchy.json +0 -185
- package/src/models/list/__tests__/hierarchyContributions.json +0 -582
- package/src/models/list/__tests__/instrument-detail-contributions.json +0 -761
- package/src/models/list/__tests__/instrument-detail-data.json +0 -66
- package/src/models/list/__tests__/list.json +0 -2426
- package/src/models/list/__tests__/listContributions.json +0 -349
- package/src/models/list/__tests__/related-contributions.json +0 -42
- package/src/models/list/__tests__/related-data.json +0 -32
- package/src/models/lookup/LookupOptionCollection.js +0 -54
- package/src/models/lookup/LookupOptionsModel.js +0 -81
- package/src/models/lookup/__tests__/LookupOptionCollection.spec.js +0 -80
- package/src/models/lookup/__tests__/LookupOptionsModel.spec.js +0 -82
- package/src/models/lookup/__tests__/_LookupOptionsContributions.json +0 -29
- package/src/models/lookup/__tests__/_LookupOptionsData.json +0 -34
- package/src/models/lookup/__tests__/_LookupOptionsListContributions.json +0 -129
- package/src/models/lookup/__tests__/_LookupOptionsListData.json +0 -134
- package/src/models/lookup/__tests__/_TaxonomyAttributeData.json +0 -42
- package/src/models/modelcatalog/ModelCatalogModel.js +0 -73
- package/src/models/modelcatalog/ModelCategoryCollection.js +0 -22
- package/src/models/modelcatalog/ModelCategoryModel.js +0 -63
- package/src/models/modelcatalog/__mock__/contributions.json +0 -6
- package/src/models/modelcatalog/__mock__/data.json +0 -29
- package/src/models/modelcatalog/__mock__/modelcatalog.js +0 -14
- package/src/models/modelcatalog/__tests__/ModelCatalogModel.spec.js +0 -49
- package/src/models/paging/PagesizeModel.js +0 -50
- package/src/models/paging/PagingModel.js +0 -105
- package/src/models/paging/__tests__/PageSizeModel.spec.js +0 -31
- package/src/models/paging/__tests__/PagingModel.spec.js +0 -40
- package/src/models/paging/__tests__/list.json +0 -8
- package/src/models/paging/__tests__/listContributions.json +0 -7
- package/src/models/panels/GroupingPanelModel.js +0 -164
- package/src/models/panels/__tests__/GroupingPanelModel.spec.js +0 -142
- package/src/models/panels/__tests__/groupingPanel.json +0 -49
- package/src/models/panels/__tests__/groupingPanelContributions.json +0 -59
- package/src/models/parameter/Parameter.js +0 -117
- package/src/models/parameter/__tests__/Parameter.spec.js +0 -125
- package/src/models/process/ProcessStatusSettingsModel.js +0 -88
- package/src/models/process/__tests__/ProcessStatusSettingsModel.spec.js +0 -52
- package/src/models/resolveModel.js +0 -92
- package/src/models/search/CaseSearchModel.js +0 -46
- package/src/models/search/__tests__/CaseSearchModel.spec.js +0 -10
- package/src/models/sorting/SortOptionModel.js +0 -114
- package/src/models/sorting/SortingModel.js +0 -140
- package/src/models/sorting/__tests__/SortingModel.spec.js +0 -96
- package/src/models/tab/TabModel.js +0 -160
- package/src/models/tab/__mock__/contributions.json +0 -77
- package/src/models/tab/__mock__/data.json +0 -20
- package/src/models/tab/__mock__/personContributions.json +0 -35
- package/src/models/tab/__mock__/personData.json +0 -21
- package/src/models/tab/__mock__/tab.js +0 -14
- package/src/models/tab/__mock__/tabPerson.js +0 -14
- package/src/models/tab/__tests__/TabModel.spec.js +0 -72
- package/src/models/tab/__tests__/tab.json +0 -37
- package/src/models/tab/__tests__/tabContributions.json +0 -39
- package/src/models/taskgroup/TaskGroupCollection.js +0 -16
- package/src/models/taskgroup/TaskGroupModel.js +0 -102
- package/src/models/taskgroup/__mock__/contributions.json +0 -18
- package/src/models/taskgroup/__mock__/data.json +0 -21
- package/src/models/taskgroup/__mock__/taskgroup.js +0 -14
- package/src/models/taskgroup/__tests__/TaskGroupModel.spec.js +0 -26
- package/src/models/taskgroup/__tests__/taskgroup.json +0 -25
- package/src/models/taskgroup/__tests__/taskgroupContributions.json +0 -23
- package/src/models/types.js +0 -291
- package/src/models/user/UserModel.js +0 -57
- package/src/models/user/UserProfileModel.js +0 -54
- package/src/models/user/UserServicesModel.js +0 -136
- package/src/models/user/__mock__/contributions.json +0 -148
- package/src/models/user/__mock__/data.json +0 -22
- package/src/models/user/__tests__/UserModel.spec.js +0 -43
- package/src/models/user/__tests__/UserProfileModel.spec.js +0 -45
- package/src/models/user/__tests__/UserServicesModel.spec.js +0 -55
- package/src/modularui/Authenticate.js +0 -217
- package/src/modularui/CaptchaRequest.js +0 -104
- package/src/modularui/ModularUIError.js +0 -25
- package/src/modularui/ModularUIRequest.js +0 -872
- package/src/modularui/ModularUIResponse.js +0 -160
- package/src/modularui/UploadRequest.js +0 -151
- package/src/modularui/__tests__/CustomContextPath.spec.js +0 -61
- package/src/modularui/__tests__/ModularUIError.spec.js +0 -22
- package/src/modularui/__tests__/ModularUIRequest.spec.js +0 -495
- package/src/modularui/__tests__/contributions.json +0 -312
- package/src/modularui/__tests__/data.json +0 -263
- package/src/modularui/index.js +0 -6
- package/src/modularui/types.js +0 -4
- package/src/react/ErrorBoundary.js +0 -61
- package/src/react/ErrorBoundaryFallback.js +0 -46
- package/src/react/index.js +0 -3
- package/src/react/utils.js +0 -33
- package/src/react-client/Init.js +0 -46
- package/src/react-client/client.js +0 -309
- package/src/react-client/contextPath.js +0 -30
- package/src/react-client/index.js +0 -4
- package/src/react-client/rehydrate.js +0 -94
- package/src/react-server/__tests__/htmlpage.spec.js +0 -75
- package/src/react-server/__tests__/requestInformation.spec.js +0 -266
- package/src/react-server/__tests__/serverUtil.spec.js +0 -183
- package/src/react-server/contextPath.js +0 -8
- package/src/react-server/createSSRComplete.js +0 -63
- package/src/react-server/htmlpage.js +0 -55
- package/src/react-server/index.js +0 -13
- package/src/react-server/renderSSRComplete.js +0 -111
- package/src/react-server/renderSSRMinimal.js +0 -54
- package/src/react-server/requestInformation.js +0 -68
- package/src/react-server/serverNoSSR.js +0 -87
- package/src/react-server/serverSSR.js +0 -70
- package/src/react-server/serverUtil.js +0 -279
- package/src/react-theme/ThemeProvider.js +0 -25
- package/src/react-theme/__tests__/ThemeProvider.spec.js +0 -84
- package/src/react-theme/__tests__/createTheme.spec.js +0 -172
- package/src/react-theme/createTheme.js +0 -118
- package/src/react-theme/index.js +0 -15
- package/src/react-theme/types.js +0 -16
- package/src/react-theme/useTheme.js +0 -13
- package/src/react-theme/utils/__tests__/background.spec.js +0 -30
- package/src/react-theme/utils/__tests__/colors.spec.js +0 -30
- package/src/react-theme/utils/__tests__/contrast.spec.js +0 -44
- package/src/react-theme/utils/__tests__/corners.spec.js +0 -27
- package/src/react-theme/utils/__tests__/spacers.spec.js +0 -44
- package/src/react-theme/utils/__tests__/themeProps.spec.js +0 -72
- package/src/react-theme/utils/background.js +0 -20
- package/src/react-theme/utils/colors.js +0 -47
- package/src/react-theme/utils/contrast.js +0 -117
- package/src/react-theme/utils/corners.js +0 -37
- package/src/react-theme/utils/spacers.js +0 -65
- package/src/react-theme/utils/themeProps.js +0 -90
- package/src/redux/_i18n/I18nActions.js +0 -38
- package/src/redux/_i18n/I18nReducer.js +0 -91
- package/src/redux/_i18n/__tests__/actions.spec.js +0 -37
- package/src/redux/_i18n/__tests__/reducer.spec.js +0 -29
- package/src/redux/_i18n/index.js +0 -6
- package/src/redux/_i18n/types.js +0 -20
- package/src/redux/_modularui/ModularUIActions.js +0 -227
- package/src/redux/_modularui/ModularUIConnector.js +0 -157
- package/src/redux/_modularui/ModularUIMiddleware.js +0 -182
- package/src/redux/_modularui/ModularUIReducer.js +0 -169
- package/src/redux/_modularui/ModularUISelectors.js +0 -322
- package/src/redux/_modularui/ModularUIUtils.js +0 -96
- package/src/redux/_modularui/__tests__/actions.spec.js +0 -159
- package/src/redux/_modularui/__tests__/reducer.spec.js +0 -134
- package/src/redux/_modularui/__tests__/selectors.spec.js +0 -153
- package/src/redux/_modularui/index.js +0 -11
- package/src/redux/_modularui/types.js +0 -121
- package/src/redux/_modularui/withModularUI.js +0 -85
- package/src/redux/_router/RouterActions.js +0 -75
- package/src/redux/_router/RouterConnectors.js +0 -97
- package/src/redux/_router/RouterMiddleware.js +0 -37
- package/src/redux/_router/RouterReducer.js +0 -21
- package/src/redux/_router/__tests__/actions.spec.js +0 -109
- package/src/redux/_router/__tests__/hooks.spec.js +0 -98
- package/src/redux/_router/__tests__/middleware.spec.js +0 -62
- package/src/redux/_router/__tests__/reducer.spec.js +0 -26
- package/src/redux/_router/index.js +0 -8
- package/src/redux/_router/types.js +0 -43
- package/src/redux/actions/Application.js +0 -45
- package/src/redux/actions/Authorization.js +0 -65
- package/src/redux/actions/Error.js +0 -95
- package/src/redux/actions/Form.js +0 -42
- package/src/redux/actions/FormAttributeSet.js +0 -98
- package/src/redux/actions/FormAttributeSetRepeatable.js +0 -45
- package/src/redux/actions/FormAutosave.js +0 -73
- package/src/redux/actions/FormAutosubmit.js +0 -43
- package/src/redux/actions/FormAutoupdate.js +0 -47
- package/src/redux/actions/FormValidations.js +0 -71
- package/src/redux/actions/Modals.js +0 -16
- package/src/redux/actions/ModelCatalog.js +0 -12
- package/src/redux/actions/Notification.js +0 -101
- package/src/redux/actions/Preferences.js +0 -173
- package/src/redux/actions/ProgressIndicator.js +0 -39
- package/src/redux/actions/SignIn.js +0 -102
- package/src/redux/actions/SignOut.js +0 -29
- package/src/redux/actions/__tests__/Application.spec.js +0 -52
- package/src/redux/actions/__tests__/Authorization.spec.js +0 -121
- package/src/redux/actions/__tests__/CustomErrorResponseHandler.spec.js +0 -72
- package/src/redux/actions/__tests__/Error-server.spec.js +0 -134
- package/src/redux/actions/__tests__/Error.spec.js +0 -116
- package/src/redux/actions/__tests__/Form.spec.js +0 -39
- package/src/redux/actions/__tests__/Modals.spec.js +0 -34
- package/src/redux/actions/__tests__/Notification.spec.js +0 -94
- package/src/redux/actions/__tests__/Preferences.spec.js +0 -71
- package/src/redux/actions/__tests__/ProgressIndicator.spec.js +0 -53
- package/src/redux/actions/index.js +0 -17
- package/src/redux/connectors/Application.js +0 -14
- package/src/redux/connectors/Breadcrumb.js +0 -28
- package/src/redux/connectors/CaseView.js +0 -14
- package/src/redux/connectors/ConceptDetail.js +0 -12
- package/src/redux/connectors/ContentBrowser.js +0 -14
- package/src/redux/connectors/ContentDetail.js +0 -13
- package/src/redux/connectors/ContentDetailSection.js +0 -17
- package/src/redux/connectors/Form.js +0 -83
- package/src/redux/connectors/FormAttributeSet.js +0 -85
- package/src/redux/connectors/ListDetail.js +0 -16
- package/src/redux/connectors/Modal.js +0 -47
- package/src/redux/connectors/ModelCatalog.js +0 -14
- package/src/redux/connectors/Notification.js +0 -47
- package/src/redux/connectors/PanelRenderer.js +0 -29
- package/src/redux/connectors/Preferences.js +0 -53
- package/src/redux/connectors/Progress.js +0 -35
- package/src/redux/connectors/ProgressIndicator.js +0 -35
- package/src/redux/connectors/QuickSearch.js +0 -36
- package/src/redux/connectors/SignIn.js +0 -47
- package/src/redux/connectors/SignOut.js +0 -38
- package/src/redux/connectors/Tab.js +0 -14
- package/src/redux/connectors/index.js +0 -22
- package/src/redux/index.js +0 -27
- package/src/redux/reducers/AuthReducer.js +0 -56
- package/src/redux/reducers/ErrorReducer.js +0 -22
- package/src/redux/reducers/ModalsReducer.js +0 -58
- package/src/redux/reducers/ModelCatalogReducer.js +0 -34
- package/src/redux/reducers/NotificationReducer.js +0 -45
- package/src/redux/reducers/PreferencesReducer.js +0 -31
- package/src/redux/reducers/ProgressIndicatorReducer.js +0 -60
- package/src/redux/reducers/__tests__/AuthReducer.spec.js +0 -95
- package/src/redux/reducers/__tests__/ErrorReducer.spec.js +0 -17
- package/src/redux/reducers/__tests__/ModalsReducer.spec.js +0 -34
- package/src/redux/reducers/__tests__/ModelCatalogReducer.spec.js +0 -23
- package/src/redux/reducers/__tests__/NotificationReducer.spec.js +0 -53
- package/src/redux/reducers/__tests__/PreferencesReducer.spec.js +0 -31
- package/src/redux/reducers/__tests__/ProgressIndicatorReducer.spec.js +0 -82
- package/src/redux/reducers/createReducer.js +0 -55
- package/src/redux/reducers/index.js +0 -10
- package/src/redux/selectors/i18n.js +0 -15
- package/src/redux/selectors/index.js +0 -3
- package/src/redux/selectors/modelcatalog.js +0 -11
- package/src/redux/store/__tests__/beforeRenderHooks.spec.js +0 -13
- package/src/redux/store/beforeRenderHooks.js +0 -26
- package/src/redux/store/configureStore.js +0 -59
- package/src/redux/types.js +0 -241
- package/src/utils/browser/Cache.js +0 -157
- package/src/utils/browser/Cookies.js +0 -44
- package/src/utils/browser/__tests__/Cookies.spec.js +0 -51
- package/src/utils/datetime/DateTimeUtil.js +0 -858
- package/src/utils/datetime/__tests__/DateTime.spec.js +0 -873
- package/src/utils/datetime/__tests__/DateTimeFormat.spec.js +0 -146
- package/src/utils/fetch/__mocks__/applicationContributions.json +0 -323
- package/src/utils/fetch/__mocks__/applicationData.json +0 -216
- package/src/utils/fetch/__mocks__/formContributions.json +0 -527
- package/src/utils/fetch/__mocks__/formData.json +0 -21
- package/src/utils/fetch/__mocks__/universalFetch.js +0 -38
- package/src/utils/fetch/__tests__/xhr.spec.js +0 -281
- package/src/utils/fetch/serverFetch.js +0 -33
- package/src/utils/fetch/types.js +0 -46
- package/src/utils/fetch/universalFetch.js +0 -106
- package/src/utils/fetch/xhr.js +0 -409
- package/src/utils/helpers/__tests__/checkResource.spec.js +0 -60
- package/src/utils/helpers/__tests__/createHash.spec.js +0 -11
- package/src/utils/helpers/__tests__/createHref.spec.js +0 -39
- package/src/utils/helpers/__tests__/objects.spec.js +0 -50
- package/src/utils/helpers/__tests__/sanitizeHTML.spec.js +0 -69
- package/src/utils/helpers/checkResource.js +0 -43
- package/src/utils/helpers/createHash.js +0 -28
- package/src/utils/helpers/createHref.js +0 -117
- package/src/utils/helpers/createUUID.js +0 -13
- package/src/utils/helpers/index.js +0 -9
- package/src/utils/helpers/objects.js +0 -33
- package/src/utils/helpers/repositoryResource.js +0 -22
- package/src/utils/helpers/sanitizeHtml.js +0 -55
- package/src/utils/helpers/text.js +0 -23
- package/src/utils/index.js +0 -22
- package/src/utils/number/DecimalFormat.js +0 -410
- package/src/utils/number/__tests__/formatValue.spec.js +0 -36
- package/src/utils/number/__tests__/parseNumbers.spec.js +0 -50
- package/src/utils/number/formatValue.js +0 -60
- package/src/utils/number/parseNumbers.js +0 -94
package/src/utils/fetch/xhr.js
DELETED
|
@@ -1,409 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import { has, isPlainObject } from "../helpers/objects";
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
IllegalArgumentException,
|
|
6
|
-
UnauthorizedException,
|
|
7
|
-
FetchException,
|
|
8
|
-
TimeoutException,
|
|
9
|
-
NotFoundException,
|
|
10
|
-
JsonParseException,
|
|
11
|
-
NetworkException,
|
|
12
|
-
} from "../../exceptions";
|
|
13
|
-
|
|
14
|
-
import Cache from "../browser/Cache";
|
|
15
|
-
|
|
16
|
-
import { HTTP_METHODS } from "../../constants/Constants";
|
|
17
|
-
|
|
18
|
-
import { getSetting } from "../../constants/Settings";
|
|
19
|
-
|
|
20
|
-
import type { RequestOptions } from "./types";
|
|
21
|
-
|
|
22
|
-
const NETWORK_ERROR_CODE = 0;
|
|
23
|
-
const SUCCESS_CODE = 200;
|
|
24
|
-
const CLIENT_ERROR_CODE = 400;
|
|
25
|
-
const UNAUTHORIZED_CODE = 401;
|
|
26
|
-
const REDIRECTION_CODE = 300;
|
|
27
|
-
const NOT_FOUND_CODE = 404;
|
|
28
|
-
|
|
29
|
-
const JSON_TYPE = "application/json";
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* @private
|
|
33
|
-
*/
|
|
34
|
-
class XHR {
|
|
35
|
-
_options: RequestOptions;
|
|
36
|
-
_xmlhttp: XMLHttpRequest;
|
|
37
|
-
_attempts: number;
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
*/
|
|
41
|
-
constructor(options: RequestOptions) {
|
|
42
|
-
this._options = options;
|
|
43
|
-
this._attempts = 0;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
*/
|
|
48
|
-
get xmlhttp(): XMLHttpRequest {
|
|
49
|
-
return this._xmlhttp;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
*/
|
|
54
|
-
set xmlhttp(xmlhttp: XMLHttpRequest) {
|
|
55
|
-
this._xmlhttp = xmlhttp;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
*/
|
|
60
|
-
get options(): RequestOptions {
|
|
61
|
-
return this._options;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
*/
|
|
66
|
-
set options(options: RequestOptions) {
|
|
67
|
-
this._options = options;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
*/
|
|
72
|
-
get attempts(): number {
|
|
73
|
-
return this._attempts;
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
*/
|
|
78
|
-
set attempts(attempts: number) {
|
|
79
|
-
this._attempts = attempts;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Create and fix url when params or both querystring and params exist.
|
|
84
|
-
*/
|
|
85
|
-
get url(): string {
|
|
86
|
-
const { url } = this.options;
|
|
87
|
-
if (this.params !== "") {
|
|
88
|
-
if (url.includes("?")) {
|
|
89
|
-
const aUrl = url.split("?");
|
|
90
|
-
|
|
91
|
-
return `${aUrl[0]}?${aUrl[1]}&${this.params}`;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
return `${url}?${this.params}`;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
return url;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
*/
|
|
102
|
-
get params(): string {
|
|
103
|
-
return this.options.params || "";
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
*/
|
|
108
|
-
get data(): any | null {
|
|
109
|
-
return this.options.data || null;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
/**
|
|
113
|
-
*/
|
|
114
|
-
get method(): $Keys<typeof HTTP_METHODS> {
|
|
115
|
-
return this.options.method || HTTP_METHODS.GET;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
*/
|
|
120
|
-
get timeout(): number {
|
|
121
|
-
return this.options.timeout || getSetting("XHR_TIMEOUT_MS", 300000);
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
/**
|
|
125
|
-
*/
|
|
126
|
-
get responseType(): string {
|
|
127
|
-
return this.options.responseType || "json";
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
/**
|
|
131
|
-
*/
|
|
132
|
-
get onProgress(): ProgressEventHandler {
|
|
133
|
-
if (this.options.onProgress) {
|
|
134
|
-
return this.options.onProgress;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
return () => {
|
|
138
|
-
// do nothing
|
|
139
|
-
};
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
/**
|
|
143
|
-
*/
|
|
144
|
-
get events(): { [eventName: string]: () => void } {
|
|
145
|
-
return this.options.events || {};
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
/**
|
|
149
|
-
*/
|
|
150
|
-
getBaseLocale(): string {
|
|
151
|
-
if (typeof navigator !== "undefined" && navigator.language) {
|
|
152
|
-
return navigator.language.split("-")[0] || "en";
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
return "en";
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
/**
|
|
159
|
-
*/
|
|
160
|
-
get headers(): { [string]: string } {
|
|
161
|
-
const baseHeaders = {
|
|
162
|
-
Accept: JSON_TYPE,
|
|
163
|
-
"Content-Type": JSON_TYPE,
|
|
164
|
-
|
|
165
|
-
// needed for csrf, see: https://plaza.beinformed.com/amdoc/csrf-protection-in-modular-ui-services-40054554.html
|
|
166
|
-
"X-Requested-With": "XMLHttpRequest",
|
|
167
|
-
|
|
168
|
-
"Accept-Language": this.getBaseLocale(),
|
|
169
|
-
};
|
|
170
|
-
|
|
171
|
-
if (this.options.headers) {
|
|
172
|
-
// $FlowFixMe[cannot-spread-indexer]
|
|
173
|
-
return {
|
|
174
|
-
...baseHeaders,
|
|
175
|
-
...this.options.headers,
|
|
176
|
-
};
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
return baseHeaders;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
/**
|
|
183
|
-
*/
|
|
184
|
-
timeoutHandler(reject: Function): any {
|
|
185
|
-
return reject(new TimeoutException(this.url, this.method));
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
/**
|
|
189
|
-
*/
|
|
190
|
-
errorHandler(reject: Function, responseJSON: any = null): any {
|
|
191
|
-
const { status } = this.xmlhttp;
|
|
192
|
-
const { isReload } = this.options;
|
|
193
|
-
|
|
194
|
-
if (status === NETWORK_ERROR_CODE) {
|
|
195
|
-
return reject(new NetworkException(this.url, this.method));
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
if (status === NOT_FOUND_CODE) {
|
|
199
|
-
return reject(new NotFoundException(this.url, this.method, isReload));
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
if (status === UNAUTHORIZED_CODE) {
|
|
203
|
-
return reject(
|
|
204
|
-
new UnauthorizedException(this.url, this.method, responseJSON),
|
|
205
|
-
);
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
return reject(new FetchException(responseJSON, this.xmlhttp, this.options));
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
/**
|
|
212
|
-
*/
|
|
213
|
-
getResponse(): any {
|
|
214
|
-
const { responseType, response } = this.xmlhttp;
|
|
215
|
-
|
|
216
|
-
if (
|
|
217
|
-
(responseType === "" || responseType === "text") &&
|
|
218
|
-
this.getResponseHeader("Content-Type") === JSON_TYPE
|
|
219
|
-
) {
|
|
220
|
-
if (isPlainObject(response)) {
|
|
221
|
-
return response;
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
try {
|
|
225
|
-
return JSON.parse(response);
|
|
226
|
-
} catch (error) {
|
|
227
|
-
throw new JsonParseException(error);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
return response;
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
/**
|
|
235
|
-
*/
|
|
236
|
-
responseHandler(resolve: Function, reject: Function): any {
|
|
237
|
-
const { status } = this.xmlhttp;
|
|
238
|
-
|
|
239
|
-
let response = null;
|
|
240
|
-
try {
|
|
241
|
-
response = this.getResponse();
|
|
242
|
-
} catch (error) {
|
|
243
|
-
return reject(error);
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
if (
|
|
247
|
-
(status >= SUCCESS_CODE && status < REDIRECTION_CODE) ||
|
|
248
|
-
(status === CLIENT_ERROR_CODE && has(response, "formresponse"))
|
|
249
|
-
) {
|
|
250
|
-
return resolve(response);
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
return this.errorHandler(reject, response);
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
/**
|
|
257
|
-
*/
|
|
258
|
-
setEventListeners(resolve: Function, reject: Function) {
|
|
259
|
-
if (this.options.onProgress) {
|
|
260
|
-
["load", "loadend", "loadstart", "progress"].forEach((eventType) => {
|
|
261
|
-
this.xmlhttp.addEventListener(eventType, this.onProgress);
|
|
262
|
-
});
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
["abort", "error"].forEach((eventType) => {
|
|
266
|
-
this.xmlhttp.addEventListener(eventType, () => this.errorHandler(reject));
|
|
267
|
-
});
|
|
268
|
-
|
|
269
|
-
this.xmlhttp.addEventListener("timeout", () => this.timeoutHandler(reject));
|
|
270
|
-
|
|
271
|
-
this.xmlhttp.addEventListener("load", () =>
|
|
272
|
-
this.responseHandler(resolve, reject),
|
|
273
|
-
);
|
|
274
|
-
|
|
275
|
-
// Set custom events
|
|
276
|
-
Object.keys(this.events).forEach((eventName) => {
|
|
277
|
-
this.xmlhttp.addEventListener(eventName, this.events[eventName]);
|
|
278
|
-
});
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
/**
|
|
282
|
-
*/
|
|
283
|
-
openConnection() {
|
|
284
|
-
this.xmlhttp.open(this.method, this.url, true);
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
/**
|
|
288
|
-
*/
|
|
289
|
-
setBasicAuthentication() {
|
|
290
|
-
if (Cache.hasItem("basic")) {
|
|
291
|
-
const basicToken = Cache.getItem("basic");
|
|
292
|
-
|
|
293
|
-
if (typeof basicToken === "string") {
|
|
294
|
-
this.xmlhttp.setRequestHeader("Authorization", `Basic ${basicToken}`);
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
/**
|
|
300
|
-
*/
|
|
301
|
-
getResponseHeader(headerName: string): string | null {
|
|
302
|
-
return this.xmlhttp.getResponseHeader(headerName);
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
/**
|
|
306
|
-
*/
|
|
307
|
-
setCustomHeaders() {
|
|
308
|
-
Object.keys(this.headers).forEach((headerName) => {
|
|
309
|
-
this.xmlhttp.setRequestHeader(headerName, this.headers[headerName]);
|
|
310
|
-
});
|
|
311
|
-
}
|
|
312
|
-
|
|
313
|
-
/**
|
|
314
|
-
*/
|
|
315
|
-
setOtherOptions() {
|
|
316
|
-
if (
|
|
317
|
-
this.options.withCredentials ||
|
|
318
|
-
getSetting("XHR_ALWAYS_WITH_CREDENTIALS", Cache.hasItem("basic"))
|
|
319
|
-
) {
|
|
320
|
-
this.xmlhttp.withCredentials = true;
|
|
321
|
-
}
|
|
322
|
-
this.xmlhttp.responseType = this.responseType;
|
|
323
|
-
this.xmlhttp.timeout = this.timeout;
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
/**
|
|
327
|
-
*/
|
|
328
|
-
sendData() {
|
|
329
|
-
if (this.data == null) {
|
|
330
|
-
this.xmlhttp.send();
|
|
331
|
-
} else {
|
|
332
|
-
const stringData = isPlainObject(this.data)
|
|
333
|
-
? JSON.stringify(this.data)
|
|
334
|
-
: this.data;
|
|
335
|
-
this.xmlhttp.send(stringData);
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
/**
|
|
340
|
-
*/
|
|
341
|
-
setXMLHttpRequest(): Promise<any> {
|
|
342
|
-
return new Promise((resolve, reject) => {
|
|
343
|
-
this.xmlhttp = new XMLHttpRequest();
|
|
344
|
-
|
|
345
|
-
this.setEventListeners(resolve, reject);
|
|
346
|
-
|
|
347
|
-
this.openConnection();
|
|
348
|
-
|
|
349
|
-
this.setBasicAuthentication();
|
|
350
|
-
|
|
351
|
-
this.setCustomHeaders();
|
|
352
|
-
|
|
353
|
-
this.setOtherOptions();
|
|
354
|
-
|
|
355
|
-
this.sendData();
|
|
356
|
-
});
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
/**
|
|
360
|
-
*/
|
|
361
|
-
async fetch(): Promise<any> {
|
|
362
|
-
try {
|
|
363
|
-
return await this.setXMLHttpRequest();
|
|
364
|
-
} catch (err) {
|
|
365
|
-
if (err instanceof NetworkException && this.attempts < 2) {
|
|
366
|
-
this.attempts += 1;
|
|
367
|
-
return this.fetch();
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
throw err;
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
/**
|
|
376
|
-
*/
|
|
377
|
-
const validateInputArguments = (args: RequestOptions) => {
|
|
378
|
-
if (args == null) {
|
|
379
|
-
throw new IllegalArgumentException(
|
|
380
|
-
"Missing request options, expecting an object as argument for xhr",
|
|
381
|
-
);
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
if (!isPlainObject(args)) {
|
|
385
|
-
throw new IllegalArgumentException(
|
|
386
|
-
`Expecting an object as argument for xhr, but received: ${args.toString()}`,
|
|
387
|
-
);
|
|
388
|
-
}
|
|
389
|
-
|
|
390
|
-
if (!has(args, "url")) {
|
|
391
|
-
throw new IllegalArgumentException(
|
|
392
|
-
`No url property found in arguments of xhr, received: ${JSON.stringify(
|
|
393
|
-
args,
|
|
394
|
-
)}`,
|
|
395
|
-
);
|
|
396
|
-
}
|
|
397
|
-
|
|
398
|
-
return true;
|
|
399
|
-
};
|
|
400
|
-
|
|
401
|
-
/**
|
|
402
|
-
*/
|
|
403
|
-
const xhr = (args: RequestOptions): Promise<any> => {
|
|
404
|
-
validateInputArguments(args);
|
|
405
|
-
|
|
406
|
-
return new XHR(args).fetch();
|
|
407
|
-
};
|
|
408
|
-
|
|
409
|
-
export default xhr;
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
resourceExists,
|
|
3
|
-
resourceRedirectsToSecureLogin,
|
|
4
|
-
} from "../checkResource";
|
|
5
|
-
|
|
6
|
-
import Href from "../../../models/href/Href";
|
|
7
|
-
|
|
8
|
-
const mockXMLHttpRequest = () => {
|
|
9
|
-
const mock = {
|
|
10
|
-
open: jest.fn(),
|
|
11
|
-
addEventListener: jest.fn(),
|
|
12
|
-
setRequestHeader: jest.fn(),
|
|
13
|
-
send: jest.fn(),
|
|
14
|
-
getResponseHeader: jest.fn(),
|
|
15
|
-
|
|
16
|
-
upload: {
|
|
17
|
-
addEventListener: jest.fn(),
|
|
18
|
-
},
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
jest.spyOn(global, "XMLHttpRequest").mockImplementation(() => mock);
|
|
22
|
-
|
|
23
|
-
return mock;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
describe("checkResource", () => {
|
|
27
|
-
it("indicates a resource exists if it has a status code other then 404", () => {
|
|
28
|
-
const mock = mockXMLHttpRequest();
|
|
29
|
-
mock.status = 200;
|
|
30
|
-
|
|
31
|
-
const exists = resourceExists("/");
|
|
32
|
-
expect(exists).toBe(true);
|
|
33
|
-
|
|
34
|
-
const hrefExists = resourceExists(new Href("/caseview"));
|
|
35
|
-
expect(hrefExists).toBe(true);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it("indicates a resource does not exists if it has a status code of 404", () => {
|
|
39
|
-
const mock = mockXMLHttpRequest();
|
|
40
|
-
mock.status = 404;
|
|
41
|
-
|
|
42
|
-
const exists = resourceExists("/");
|
|
43
|
-
expect(exists).toBe(false);
|
|
44
|
-
|
|
45
|
-
const hrefExists = resourceExists(new Href("/caseview"));
|
|
46
|
-
expect(hrefExists).toBe(false);
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it("indicates resource request redirects to secureLogin", () => {
|
|
50
|
-
const mock = mockXMLHttpRequest();
|
|
51
|
-
mock.responseURL = "/BeInformed/secureLogin";
|
|
52
|
-
mock.status = 400;
|
|
53
|
-
|
|
54
|
-
const toLogin = resourceRedirectsToSecureLogin("/");
|
|
55
|
-
expect(toLogin).toBe(true);
|
|
56
|
-
|
|
57
|
-
const hrefToLogin = resourceExists(new Href("/caseview"));
|
|
58
|
-
expect(hrefToLogin).toBe(true);
|
|
59
|
-
});
|
|
60
|
-
});
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { createHash } from "../createHash";
|
|
2
|
-
|
|
3
|
-
describe("createHash", () => {
|
|
4
|
-
it("creates hash from string", () => {
|
|
5
|
-
expect(createHash("")).toBe(729279156);
|
|
6
|
-
expect(createHash("abcdefgh")).toBe(17595859189820);
|
|
7
|
-
expect(createHash(123455)).toBe(15900277965517);
|
|
8
|
-
expect(createHash(null)).toBe(711079339769);
|
|
9
|
-
expect(createHash()).toBe(4721361581144);
|
|
10
|
-
});
|
|
11
|
-
});
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { createHref } from "../createHref";
|
|
2
|
-
import Href from "../../../models/href/Href";
|
|
3
|
-
|
|
4
|
-
describe("createHref", () => {
|
|
5
|
-
it("can filter out qs parameters", () => {
|
|
6
|
-
const dynamicPart = "project/folder/model.bixml/ConceptId";
|
|
7
|
-
const location = {
|
|
8
|
-
search: "?entryDate=2024-03-08&index=C¬Allowed=true",
|
|
9
|
-
};
|
|
10
|
-
const expectedSearch = "?index=C¬Allowed=true&entryDate=2010-01-01";
|
|
11
|
-
|
|
12
|
-
expect(createHref("concepts", dynamicPart)).toEqual(
|
|
13
|
-
new Href("/concepts/" + dynamicPart),
|
|
14
|
-
);
|
|
15
|
-
expect(createHref("concepts", dynamicPart, "2010-01-01", location)).toEqual(
|
|
16
|
-
new Href("/concepts/" + dynamicPart + expectedSearch),
|
|
17
|
-
);
|
|
18
|
-
expect(
|
|
19
|
-
createHref("concepts", dynamicPart, "2010-01-01", location, ["index"]),
|
|
20
|
-
).toEqual(
|
|
21
|
-
new Href("/concepts/" + dynamicPart + "?index=C&entryDate=2010-01-01"),
|
|
22
|
-
);
|
|
23
|
-
expect(
|
|
24
|
-
createHref(
|
|
25
|
-
"concepts",
|
|
26
|
-
dynamicPart + location.search,
|
|
27
|
-
"2010-01-01",
|
|
28
|
-
location,
|
|
29
|
-
["index"],
|
|
30
|
-
),
|
|
31
|
-
).toEqual(
|
|
32
|
-
new Href("/concepts/" + dynamicPart + "?index=C&entryDate=2010-01-01"),
|
|
33
|
-
);
|
|
34
|
-
|
|
35
|
-
expect(createHref("concepts", dynamicPart + "#hash")).toEqual(
|
|
36
|
-
new Href("/concepts/" + dynamicPart + "#hash"),
|
|
37
|
-
);
|
|
38
|
-
});
|
|
39
|
-
});
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { get, has, isPlainObject } from "../objects";
|
|
2
|
-
|
|
3
|
-
describe("objects", () => {
|
|
4
|
-
it("can get stuff or return default", () => {
|
|
5
|
-
const obj = {
|
|
6
|
-
a: {
|
|
7
|
-
b: {
|
|
8
|
-
c: 42,
|
|
9
|
-
},
|
|
10
|
-
},
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
expect(get(obj, "a.b.c", "fortytwo")).toBe(42);
|
|
14
|
-
expect(get(obj, "a.b.d", "fortytwo")).toBe("fortytwo");
|
|
15
|
-
expect(get(obj, "non-existing")).toBeUndefined();
|
|
16
|
-
expect(get(obj, "a.b")).toStrictEqual({ c: 42 });
|
|
17
|
-
expect(get("string", "a.b")).toBeUndefined();
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it("can check path on object", () => {
|
|
21
|
-
const obj = {
|
|
22
|
-
a: {
|
|
23
|
-
b: {
|
|
24
|
-
c: 42,
|
|
25
|
-
},
|
|
26
|
-
},
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
expect(has(obj, "a.b.c")).toBe(true);
|
|
30
|
-
expect(has(obj, "a.b.d")).toBe(false);
|
|
31
|
-
expect(has(obj, "non-existing")).toBe(false);
|
|
32
|
-
expect(has(obj, "a.b")).toBe(true);
|
|
33
|
-
expect(has("string", "a.b")).toBe(false);
|
|
34
|
-
expect(has(null, "a")).toBe(false);
|
|
35
|
-
expect(has(undefined, "a")).toBe(false);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it("can check for plain objects", () => {
|
|
39
|
-
expect(isPlainObject({})).toBe(true);
|
|
40
|
-
expect(isPlainObject({ param: "value" })).toBe(true);
|
|
41
|
-
expect(isPlainObject("string")).toBe(false);
|
|
42
|
-
expect(isPlainObject(["a", "b", "c"])).toBe(false);
|
|
43
|
-
expect(isPlainObject(new Set([1, 2, 3]))).toBe(false);
|
|
44
|
-
expect(isPlainObject(new Date())).toBe(false);
|
|
45
|
-
expect(isPlainObject(new File([""], "filename"))).toBe(false);
|
|
46
|
-
expect(isPlainObject(undefined)).toBe(false);
|
|
47
|
-
expect(isPlainObject(null)).toBe(false);
|
|
48
|
-
expect(isPlainObject(1)).toBe(false);
|
|
49
|
-
});
|
|
50
|
-
});
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { removeUnwantedHtml } from "../sanitizeHtml";
|
|
2
|
-
|
|
3
|
-
describe("sanitizeHTML", () => {
|
|
4
|
-
it("remove unwanted html", () => {
|
|
5
|
-
expect(removeUnwantedHtml("String without HTML")).toBe(
|
|
6
|
-
"String without HTML",
|
|
7
|
-
);
|
|
8
|
-
|
|
9
|
-
expect(
|
|
10
|
-
removeUnwantedHtml("<p>String with <b>allowed <i>html</i></b></p>"),
|
|
11
|
-
).toBe("<p>String with <b>allowed <i>html</i></b></p>");
|
|
12
|
-
|
|
13
|
-
expect(
|
|
14
|
-
removeUnwantedHtml(
|
|
15
|
-
"<p>String with <b>allowed <i>html</i></b><br /> and <blink>NOT</blink> allowed html</p>",
|
|
16
|
-
),
|
|
17
|
-
).toBe(
|
|
18
|
-
"<p>String with <b>allowed <i>html</i></b><br /> and NOT allowed html</p>",
|
|
19
|
-
);
|
|
20
|
-
|
|
21
|
-
expect(
|
|
22
|
-
removeUnwantedHtml("String<p><br /> with <u>allowed</u></p> html"),
|
|
23
|
-
).toBe("String<p><br /> with <u>allowed</u></p> html");
|
|
24
|
-
|
|
25
|
-
expect(
|
|
26
|
-
removeUnwantedHtml(
|
|
27
|
-
'<p>String <b style="font-weight: 400" id="bold">not allowed attribute</b> string</p>',
|
|
28
|
-
),
|
|
29
|
-
).toBe("<p>String <b>not allowed attribute</b> string</p>");
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
it("Should keep escaped html", () => {
|
|
33
|
-
expect(
|
|
34
|
-
removeUnwantedHtml(
|
|
35
|
-
"<p>Keep <cite>cite tag</cite> and remove <cite>real cite tag</cite>",
|
|
36
|
-
),
|
|
37
|
-
).toBe(
|
|
38
|
-
"<p>Keep <cite>cite tag</cite> and remove real cite tag",
|
|
39
|
-
);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it("Can encode special characters to numerical characters", () => {
|
|
43
|
-
expect(removeUnwantedHtml("<p>foo © bar ≠ baz 𝌆 qux bla</p>")).toBe(
|
|
44
|
-
"<p>foo © bar ≠ baz 𝌆 qux bla</p>",
|
|
45
|
-
);
|
|
46
|
-
|
|
47
|
-
expect(
|
|
48
|
-
removeUnwantedHtml(
|
|
49
|
-
"<p>foo © bar ≠ baz 𝌆 qux   bla</p>",
|
|
50
|
-
),
|
|
51
|
-
).toBe("<p>foo © bar ≠ baz 𝌆 qux   bla</p>");
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it("Keeps brackets", () => {
|
|
55
|
-
expect(
|
|
56
|
-
removeUnwantedHtml(
|
|
57
|
-
"The list of children [ Peter, Steven, Susan ] is up to date.",
|
|
58
|
-
),
|
|
59
|
-
).toBe("The list of children [ Peter, Steven, Susan ] is up to date.");
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it("Keeps curly brackets", () => {
|
|
63
|
-
expect(
|
|
64
|
-
removeUnwantedHtml(
|
|
65
|
-
"The list of children { Peter, Steven, Susan } is up to date.",
|
|
66
|
-
),
|
|
67
|
-
).toBe("The list of children { Peter, Steven, Susan } is up to date.");
|
|
68
|
-
});
|
|
69
|
-
});
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import Href from "../../models/href/Href";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Checks if a given url to a modular ui resource exists using a HEAD request to the resource (synchronous)
|
|
6
|
-
* When the resource returns a 404, the resource does not exists and the method returns false
|
|
7
|
-
*
|
|
8
|
-
* @param url
|
|
9
|
-
* @returns {boolean}
|
|
10
|
-
*/
|
|
11
|
-
export const resourceExists = (url: string | Href): boolean => {
|
|
12
|
-
const fullUrl = new Href(url).absolutehref;
|
|
13
|
-
|
|
14
|
-
const xhr = new XMLHttpRequest();
|
|
15
|
-
xhr.open("HEAD", fullUrl, false);
|
|
16
|
-
xhr.setRequestHeader("Accept", "application/json");
|
|
17
|
-
xhr.setRequestHeader("Content-Type", "application/json");
|
|
18
|
-
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
|
|
19
|
-
|
|
20
|
-
xhr.send();
|
|
21
|
-
|
|
22
|
-
return xhr.status !== 404;
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* Indicates if a request to the given url resuls in a redirect to /secureRedirect
|
|
27
|
-
* @param url
|
|
28
|
-
* @returns {boolean}
|
|
29
|
-
*/
|
|
30
|
-
export const resourceRedirectsToSecureLogin = (url: string | Href): boolean => {
|
|
31
|
-
const fullUrl = new Href(url).absolutehref;
|
|
32
|
-
|
|
33
|
-
const xhr = new XMLHttpRequest();
|
|
34
|
-
xhr.open("HEAD", fullUrl, false);
|
|
35
|
-
xhr.setRequestHeader("Accept", "application/json");
|
|
36
|
-
xhr.setRequestHeader("Content-Type", "application/json");
|
|
37
|
-
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
|
|
38
|
-
xhr.send();
|
|
39
|
-
|
|
40
|
-
const responseURL = xhr.responseURL ?? "";
|
|
41
|
-
|
|
42
|
-
return xhr.status === 400 && responseURL.endsWith("/secureLogin");
|
|
43
|
-
};
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import { hash } from "hash-it";
|
|
3
|
-
|
|
4
|
-
import type Href from "../../models/href/Href";
|
|
5
|
-
import type { SectionFragment } from "../../models";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* https://werxltd.com/wp/2010/05/13/javascript-implementation-of-javas-string-hashcode-method/
|
|
9
|
-
*/
|
|
10
|
-
const createHash = (str: string): number => {
|
|
11
|
-
return hash(str);
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
*/
|
|
16
|
-
const createHashFromHref = (href: Href, fragment?: SectionFragment): number => {
|
|
17
|
-
const hrefString = href.hash
|
|
18
|
-
? [href.toString(), href.hash].join("#")
|
|
19
|
-
: href.toString();
|
|
20
|
-
|
|
21
|
-
if (fragment) {
|
|
22
|
-
return hash({ hrefString, fragment });
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
return hash(hrefString);
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
export { createHash, createHashFromHref };
|