katello 4.5.1 → 4.6.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +10 -0
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +7 -0
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +52 -22
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +2 -0
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
- data/app/controllers/katello/api/v2/debs_controller.rb +42 -10
- data/app/controllers/katello/api/v2/host_collections_controller.rb +5 -1
- data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -0
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +9 -1
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +8 -1
- data/app/controllers/katello/api/v2/organizations_controller.rb +3 -1
- data/app/controllers/katello/api/v2/simple_content_access_controller.rb +8 -0
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +34 -11
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +7 -16
- data/app/lib/actions/katello/alternate_content_source/alternate_content_source_common.rb +16 -0
- data/app/lib/actions/katello/alternate_content_source/create.rb +11 -5
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +3 -4
- data/app/lib/actions/katello/alternate_content_source/refresh.rb +3 -5
- data/app/lib/actions/katello/alternate_content_source/update.rb +57 -13
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +2 -2
- data/app/lib/actions/katello/organization/manifest_refresh.rb +8 -4
- data/app/lib/actions/katello/organization/simple_content_access/toggle.rb +1 -9
- data/app/lib/actions/katello/repository/create.rb +9 -0
- data/app/lib/actions/katello/repository/destroy.rb +21 -0
- data/app/lib/actions/katello/repository/errata_mail.rb +3 -3
- data/app/lib/actions/katello/repository/refresh_repository.rb +3 -0
- data/app/lib/actions/katello/repository/update.rb +33 -0
- data/app/lib/actions/katello/repository/update_redhat_repository.rb +1 -1
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/refresh.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +5 -5
- data/app/lib/actions/pulp3/capsule_content/reclaim_space.rb +1 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +6 -7
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +2 -2
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh_remote.rb +18 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +1 -1
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +1 -1
- data/app/lib/katello/errors.rb +1 -1
- data/app/lib/katello/resources/candlepin/owner.rb +9 -2
- data/app/lib/katello/validators/alternate_content_source_products_validator.rb +17 -0
- data/app/models/katello/alternate_content_source.rb +39 -8
- data/app/models/katello/alternate_content_source_product.rb +13 -0
- data/app/models/katello/concerns/host_managed_extensions.rb +12 -2
- data/app/models/katello/concerns/pulp_database_unit.rb +2 -2
- data/app/models/katello/concerns/smart_proxy_extensions.rb +5 -6
- data/app/models/katello/content_view.rb +4 -0
- data/app/models/katello/content_view_deb_filter.rb +51 -0
- data/app/models/katello/content_view_deb_filter_rule.rb +24 -0
- data/app/models/katello/content_view_filter.rb +10 -3
- data/app/models/katello/glue/candlepin/owner.rb +0 -1
- data/app/models/katello/installed_package.rb +1 -0
- data/app/models/katello/product.rb +3 -0
- data/app/models/katello/repository.rb +2 -0
- data/app/models/katello/smart_proxy_alternate_content_source.rb +6 -0
- data/app/services/cert/certs.rb +8 -16
- data/app/services/katello/content_unit_indexer.rb +2 -1
- data/app/services/katello/organization_creator.rb +4 -4
- data/app/services/katello/pulp/server.rb +2 -2
- data/app/services/katello/pulp3/alternate_content_source.rb +22 -4
- data/app/services/katello/pulp3/api/apt.rb +12 -0
- data/app/services/katello/pulp3/erratum.rb +1 -4
- data/app/services/katello/pulp3/repository/apt.rb +186 -2
- data/app/services/katello/pulp3/repository.rb +4 -3
- data/app/services/katello/pulp3/service_common.rb +1 -1
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +1 -1
- data/app/views/foreman/smart_proxies/show.html.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +18 -3
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +20 -0
- data/app/views/katello/api/v2/ansible_collections/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/content_view_filters/base.json.rabl +5 -0
- data/app/views/katello/api/v2/module_streams/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +4 -0
- data/app/views/katello/layouts/foreman_with_bastion.html.erb +1 -1
- data/app/views/katello/layouts/react.html.erb +1 -1
- data/app/views/overrides/organizations/_edit_override.html.erb +5 -8
- data/app/views/overrides/organizations/_index_row_override.html.erb +1 -1
- data/app/views/overrides/organizations/_step_1_override.html.erb +5 -0
- data/ca/redhat-uep.pem +18 -23
- data/config/katello.yaml.example +0 -2
- data/config/routes/api/v2.rb +2 -0
- data/config/routes/overrides.rb +1 -0
- data/db/migrate/20201116161820_create_content_view_deb_filter_rules.rb +17 -0
- data/db/migrate/20220524132259_remove_last_refreshed_from_katello_alternate_content_sources.rb +5 -0
- data/db/migrate/20220601163911_add_vendor_to_katello_installed_packages.rb +5 -0
- data/db/migrate/20220610165621_add_repositories_and_products_to_acs.rb +23 -0
- data/db/seeds.d/102-organizations.rb +1 -1
- data/engines/bastion/app/views/bastion/layouts/application.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/application_ie.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment-content.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-content-views.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +4 -5
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +0 -1
- data/lib/katello/engine.rb +1 -2
- data/lib/katello/permission_creator.rb +2 -2
- data/lib/katello/permissions/host_permissions.rb +1 -0
- data/lib/katello/plugin.rb +6 -12
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +49 -46
- data/locale/bn/katello.po +361 -53
- data/{webpack/scenes/AnsibleCollections/AnsibleCollectionsTables.scss → locale/bn/katello.po.time_stamp} +0 -0
- data/locale/cs/katello.po +361 -53
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/de/katello.po +366 -58
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/en/katello.po +361 -53
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/es/katello.po +364 -56
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/fr/katello.po +376 -68
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gu/katello.po +361 -53
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/hi/katello.po +361 -53
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/it/katello.po +361 -53
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/katello.po +374 -66
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/katello.pot +1626 -1079
- data/locale/kn/katello.po +361 -53
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/katello.po +361 -53
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/mr/katello.po +361 -53
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/or/katello.po +361 -53
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/katello.po +361 -53
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pt/katello.po +361 -53
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/katello.po +364 -56
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ru/katello.po +361 -53
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/ta/katello.po +361 -53
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/te/katello.po +361 -53
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/zh_CN/katello.po +374 -66
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/katello.po +361 -53
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/package.json +0 -3
- data/webpack/components/EditableTextInput/EditableTextInput.js +3 -16
- data/webpack/components/EditableTextInput/PencilEditButton.js +33 -0
- data/webpack/components/Errata/index.js +18 -3
- data/webpack/components/Loading.js +1 -1
- data/webpack/components/RoutedTabs/index.js +1 -17
- data/webpack/components/Search/Search.js +0 -1
- data/webpack/components/Search/__tests__/search.test.js +1 -2
- data/webpack/components/SelectAllCheckbox/index.js +7 -4
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +1 -0
- data/webpack/components/Table/EmptyStateMessage.js +77 -2
- data/webpack/components/Table/MainTable.js +46 -4
- data/webpack/components/Table/TableHooks.js +9 -6
- data/webpack/components/Table/TableWrapper.js +14 -8
- data/webpack/components/TypeAhead/TypeAhead.js +26 -11
- data/webpack/components/TypeAhead/pf3Search/TypeAheadItems.js +1 -1
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +1 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +2 -1
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +9 -4
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeActions.js +37 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +173 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeConstants.js +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +301 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeSelectors.js +25 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +108 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +161 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +12 -12
- data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +100 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +26 -4
- data/webpack/components/extensions/HostDetails/HostDetailsConstants.js +3 -1
- data/webpack/components/extensions/HostDetails/HostDetailsReducer.js +14 -0
- data/webpack/components/extensions/HostDetails/HostDetailsSelectors.js +8 -2
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +8 -12
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +23 -2
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +5 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +57 -7
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +2 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +3 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +4 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +1 -10
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +1 -1
- data/webpack/components/extensions/RegistrationCommands/index.js +49 -17
- data/webpack/containers/Application/config.js +5 -10
- data/webpack/global_index.js +19 -7
- data/webpack/global_test_setup.js +14 -2
- data/webpack/ouia_id_check.js +95 -0
- data/webpack/redux/actions/RedHatRepositories/helpers.js +2 -0
- data/webpack/redux/reducers/index.js +2 -4
- data/webpack/scenes/AlternateContentSources/ACSActions.js +36 -3
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +3 -0
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +15 -6
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +73 -42
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +26 -10
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSProducts.js +44 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +59 -45
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +2 -1
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +0 -1
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +35 -19
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +120 -13
- data/webpack/scenes/AlternateContentSources/Create/__tests__/products.fixtures.json +92 -0
- data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +459 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +354 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +104 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditProducts.js +120 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +118 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +118 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +242 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +106 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsDetails.fixtures.json +49 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsProducts.fixtures.json +95 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/simplifiedAcsDetails.fixtures.json +39 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +215 -87
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.scss +3 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +1 -2
- data/webpack/scenes/Content/__tests__/contentTable.test.js +1 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +15 -4
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +2 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +113 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +89 -0
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +32 -9
- data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +13 -3
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +39 -27
- data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +236 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +10 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +3 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +3 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +17 -4
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +34 -22
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVDebMatchContentModal.js +97 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +128 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +56 -3
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +62 -8
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +1 -5
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +32 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVContainerImageFilterContent.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVPackageFilterRules.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyContentViewFilters.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +5 -1
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.js +143 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareConfig.js +314 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +186 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareTable.js +74 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/AnsibleCollectionsCompareAllContentData.fixtures.json +63 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionCompare.test.js +657 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionEmptyContentCompareData.fixtures.json +14 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ContainerTagsCompareAllContentData.fixtures.json +95 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/DebPackagesCompareAllContentData.fixtures.json +87 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareAllContentData.fixtures.json +319 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareThreeContentTypesData.fixtures.json +131 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareThreeContentTypesData.fixtures.json +48 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ModuleStreamsCompareAllContentData.fixtures.json +239 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PackageGroupsCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PythonPackagesCompareAllContentData.fixtures.json +315 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareAllContentData.fixtures.json +470 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareThreeContentTypesData.fixtures.json +475 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewDetails.fixtures.json +160 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionOneDetials.fixtures.json +161 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionThreeDetails.fixtures.json +154 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionTwoDetails.fixtures.json +211 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersions.fixtures.json +1013 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionOneDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionTwoDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +102 -36
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +4 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +113 -40
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +96 -81
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +1 -2
- data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +7 -2
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +1 -1
- data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +0 -30
- data/webpack/test-utils/nockWrapper.js +7 -0
- metadata +100 -145
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -751
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-deletion.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-confirm.controller.js +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +0 -82
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-environments.controller.js +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion.controller.js +0 -160
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/content-view-deletion.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-activation-keys.html +0 -94
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-confirm.html +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-content-hosts.html +0 -88
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-environments.html +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-component.factory.js +0 -32
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-available-content-views.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-content-views-list.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite.html +0 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-deb-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-docker-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-file-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-ostree-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-repositories.controller.js +0 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-deb-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-docker-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-file-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-ostree-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-promotion.controller.js +0 -129
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-publish.controller.js +0 -46
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories-list.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories.service.js +0 -91
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-versions.controller.js +0 -240
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-errata-filter.controller.js +0 -115
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-module-stream-filter.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-package-group-filter.controller.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/date-type-errata-filter.controller.js +0 -77
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/docker-tag-filter.controller.js +0 -137
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/edit-filter.controller.js +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter-list.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter.controller.js +0 -74
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-content-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-details.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-helper.service.js +0 -30
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-repositories.controller.js +0 -86
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-rule-matching-package-modal.controller.js +0 -37
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter.factory.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filters.controller.js +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/module-stream-list-filter.controller.js +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/new-filter.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-filter.controller.js +0 -179
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-group-list-filter.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/rule.factory.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata-filter.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata.html +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-tag-filter-details.html +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/edit-filter.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter-details.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter.html +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-details.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-repositories.html +0 -121
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-rule-matching-package-modal.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filters.html +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter-details.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/new-filter.html +0 -62
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +0 -182
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter-details.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/partials/filter-repositories-count.html +0 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.controller.js +0 -47
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.factory.js +0 -22
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/views/content-view-history.html +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-copy.html +0 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-deb-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details-tasks.html +0 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +0 -144
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-docker-repositories.html +0 -114
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-file-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-ostree-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-promotion.html +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-repositories.html +0 -116
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -126
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/content-view-new.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/views/content-view-new.html +0 -127
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +0 -138
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version.controller.js +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-apt.html +0 -25
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-components.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-deb.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-details.html +0 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-docker.html +0 -23
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-errata.html +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-file.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-module-streams.html +0 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-package-groups.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-packages.html +0 -27
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-yum.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -83
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +0 -74
- data/webpack/components/Table/__test__/useBulkSelect.test.js +0 -99
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsActions.js +0 -30
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsPage.js +0 -80
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsReducer.js +0 -39
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +0 -60
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetails.js +0 -94
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsActions.js +0 -23
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsReducer.js +0 -30
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionsSchema.js +0 -35
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailInfo.test.js +0 -16
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.fixtures.js +0 -25
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.test.js +0 -27
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js +0 -41
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsReducer.test.js +0 -33
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailInfo.test.js.snap +0 -83
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetails.test.js.snap +0 -190
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsActions.test.js.snap +0 -58
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsReducer.test.js.snap +0 -50
- data/webpack/scenes/AnsibleCollections/Details/index.js +0 -17
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionPage.test.js +0 -23
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollections.fixtures.js +0 -52
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsActions.test.js +0 -48
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsReducer.test.js +0 -46
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsTable.test.js +0 -25
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionPage.test.js.snap +0 -73
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionsTable.test.js.snap +0 -81
- data/webpack/scenes/AnsibleCollections/index.js +0 -17
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManageManifestModal.test.js +0 -123
@@ -1,26 +1,140 @@
|
|
1
|
-
import React, {
|
2
|
-
import {
|
1
|
+
import React, { useCallback, useEffect, useRef, useState } from 'react';
|
2
|
+
import { useHistory, useLocation } from 'react-router-dom';
|
3
|
+
import { useDispatch, useSelector } from 'react-redux';
|
3
4
|
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
-
import {
|
5
|
-
import {
|
5
|
+
import { STATUS } from 'foremanReact/constants';
|
6
|
+
import {
|
7
|
+
Button,
|
8
|
+
Drawer,
|
9
|
+
DrawerActions,
|
10
|
+
DrawerCloseButton,
|
11
|
+
DrawerContent,
|
12
|
+
DrawerContentBody,
|
13
|
+
DrawerHead,
|
14
|
+
DrawerPanelContent,
|
15
|
+
Text,
|
16
|
+
TextContent,
|
17
|
+
TextList,
|
18
|
+
TextListItem,
|
19
|
+
TextListItemVariants,
|
20
|
+
TextListVariants,
|
21
|
+
TextVariants,
|
22
|
+
} from '@patternfly/react-core';
|
23
|
+
import { TableVariant, Tbody, Td, Th, Thead, Tr } from '@patternfly/react-table';
|
6
24
|
import TableWrapper from '../../../components/Table/TableWrapper';
|
7
25
|
import {
|
8
|
-
selectAlternateContentSources,
|
26
|
+
selectAlternateContentSources,
|
27
|
+
selectAlternateContentSourcesError,
|
9
28
|
selectAlternateContentSourcesStatus,
|
10
29
|
} from '../ACSSelectors';
|
11
30
|
import { useTableSort } from '../../../components/Table/TableHooks';
|
12
|
-
import getAlternateContentSources, { deleteACS, refreshACS } from '../ACSActions';
|
31
|
+
import getAlternateContentSources, { deleteACS, getACSDetails, refreshACS } from '../ACSActions';
|
13
32
|
import ACSCreateWizard from '../Create/ACSCreateWizard';
|
14
33
|
import LastSync from '../../ContentViews/Details/Repositories/LastSync';
|
34
|
+
import ACSExpandableDetails from '../Details/ACSExpandableDetails';
|
35
|
+
import './ACSTable.scss';
|
15
36
|
|
16
37
|
const ACSTable = () => {
|
17
38
|
const response = useSelector(selectAlternateContentSources);
|
18
39
|
const status = useSelector(selectAlternateContentSourcesStatus);
|
19
40
|
const error = useSelector(selectAlternateContentSourcesError);
|
41
|
+
const resolved = status === STATUS.RESOLVED;
|
20
42
|
const [searchQuery, updateSearchQuery] = useState('');
|
21
43
|
const [isCreateWizardOpen, setIsCreateWizardOpen] = useState(false);
|
22
44
|
const dispatch = useDispatch();
|
23
45
|
const { results, ...metadata } = response;
|
46
|
+
const { pathname } = useLocation();
|
47
|
+
const { push } = useHistory();
|
48
|
+
const acsId = pathname.split('/')[3];
|
49
|
+
const [expandedId, setExpandedId] = useState(acsId);
|
50
|
+
const [isExpanded, setIsExpanded] = useState(false);
|
51
|
+
const drawerRef = useRef(null);
|
52
|
+
|
53
|
+
useEffect(() => {
|
54
|
+
if (acsId) {
|
55
|
+
dispatch(getACSDetails(acsId));
|
56
|
+
setIsExpanded(true);
|
57
|
+
}
|
58
|
+
}, [dispatch, acsId]);
|
59
|
+
|
60
|
+
const onExpand = () => {
|
61
|
+
if (drawerRef.current) drawerRef.current.focus();
|
62
|
+
};
|
63
|
+
|
64
|
+
const onDelete = (id) => {
|
65
|
+
dispatch(deleteACS(id, () =>
|
66
|
+
dispatch(getAlternateContentSources())));
|
67
|
+
};
|
68
|
+
|
69
|
+
const onRefresh = (id) => {
|
70
|
+
dispatch(refreshACS(id, () =>
|
71
|
+
dispatch(getAlternateContentSources())));
|
72
|
+
};
|
73
|
+
|
74
|
+
const createButtonOnclick = () => {
|
75
|
+
setIsCreateWizardOpen(true);
|
76
|
+
};
|
77
|
+
|
78
|
+
const onClick = (id) => {
|
79
|
+
setExpandedId(id);
|
80
|
+
};
|
81
|
+
|
82
|
+
const onCloseClick = () => {
|
83
|
+
setExpandedId(null);
|
84
|
+
push('/labs/alternate_content_sources');
|
85
|
+
setIsExpanded(false);
|
86
|
+
};
|
87
|
+
|
88
|
+
const PanelContent = () => {
|
89
|
+
if (!resolved) return <></>;
|
90
|
+
const acs = results?.find(source => source?.id === Number(expandedId));
|
91
|
+
const { last_refresh: lastTask } = acs ?? {};
|
92
|
+
const { last_refresh_words: lastRefreshWords, started_at: startedAt } = lastTask ?? {};
|
93
|
+
return (
|
94
|
+
<DrawerPanelContent defaultSize="50%">
|
95
|
+
<DrawerHead>
|
96
|
+
{results && isExpanded &&
|
97
|
+
<span ref={drawerRef}>
|
98
|
+
<TextContent>
|
99
|
+
<Text component={TextVariants.h1}>
|
100
|
+
{acs?.name}
|
101
|
+
</Text>
|
102
|
+
<TextList component={TextListVariants.dl}>
|
103
|
+
<TextListItem component={TextListItemVariants.dt}>
|
104
|
+
{__('Last refresh :')}
|
105
|
+
</TextListItem>
|
106
|
+
<TextListItem
|
107
|
+
aria-label="name_text_value"
|
108
|
+
component={TextListItemVariants.dd}
|
109
|
+
>
|
110
|
+
<LastSync
|
111
|
+
startedAt={startedAt}
|
112
|
+
lastSync={lastTask}
|
113
|
+
lastSyncWords={lastRefreshWords}
|
114
|
+
emptyMessage="N/A"
|
115
|
+
/>
|
116
|
+
</TextListItem>
|
117
|
+
</TextList>
|
118
|
+
</TextContent>
|
119
|
+
<ACSExpandableDetails />
|
120
|
+
</span>}
|
121
|
+
<DrawerActions>
|
122
|
+
<Button
|
123
|
+
ouiaId="refresh-acs"
|
124
|
+
onClick={() => onRefresh(acs?.id)}
|
125
|
+
variant="secondary"
|
126
|
+
isSmall
|
127
|
+
aria-label="refresh_acs"
|
128
|
+
>
|
129
|
+
{__('Refresh source')}
|
130
|
+
</Button>
|
131
|
+
<DrawerCloseButton onClick={onCloseClick} />
|
132
|
+
</DrawerActions>
|
133
|
+
</DrawerHead>
|
134
|
+
</DrawerPanelContent>
|
135
|
+
);
|
136
|
+
};
|
137
|
+
|
24
138
|
const columnHeaders = [
|
25
139
|
__('Name'),
|
26
140
|
__('Type'),
|
@@ -50,20 +164,6 @@ const ACSTable = () => {
|
|
50
164
|
[apiSortParams],
|
51
165
|
);
|
52
166
|
|
53
|
-
const onDelete = (id) => {
|
54
|
-
dispatch(deleteACS(id, () =>
|
55
|
-
dispatch(getAlternateContentSources())));
|
56
|
-
};
|
57
|
-
|
58
|
-
const onRefresh = (id) => {
|
59
|
-
dispatch(refreshACS(id, () =>
|
60
|
-
dispatch(getAlternateContentSources())));
|
61
|
-
};
|
62
|
-
|
63
|
-
const createButtonOnclick = () => {
|
64
|
-
setIsCreateWizardOpen(true);
|
65
|
-
};
|
66
|
-
|
67
167
|
const rowDropdownItems = ({ id }) => [
|
68
168
|
{
|
69
169
|
title: __('Delete'),
|
@@ -86,74 +186,102 @@ const ACSTable = () => {
|
|
86
186
|
const emptySearchTitle = __('No matching alternate content sources found');
|
87
187
|
const emptySearchBody = __('Try changing your search settings.');
|
88
188
|
/* eslint-disable react/no-array-index-key */
|
189
|
+
|
89
190
|
return (
|
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
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
191
|
+
<Drawer isExpanded={isExpanded} isInline onExpand={onExpand}>
|
192
|
+
<DrawerContent panelContent={<PanelContent />}>
|
193
|
+
<DrawerContentBody style={{ paddingBottom: '5%' }}>
|
194
|
+
<TableWrapper
|
195
|
+
{...{
|
196
|
+
metadata,
|
197
|
+
emptyContentTitle,
|
198
|
+
emptyContentBody,
|
199
|
+
emptySearchTitle,
|
200
|
+
emptySearchBody,
|
201
|
+
searchQuery,
|
202
|
+
updateSearchQuery,
|
203
|
+
error,
|
204
|
+
status,
|
205
|
+
fetchItems,
|
206
|
+
}}
|
207
|
+
ouiaId="alternate-content-sources-table"
|
208
|
+
variant={TableVariant.compact}
|
209
|
+
additionalListeners={[activeSortColumn, activeSortDirection]}
|
210
|
+
autocompleteEndpoint="/alternate_content_sources/auto_complete_search"
|
211
|
+
actionButtons={
|
212
|
+
<>
|
213
|
+
<Button
|
214
|
+
ouiaId="create-acs"
|
215
|
+
onClick={createButtonOnclick}
|
216
|
+
variant="primary"
|
217
|
+
aria-label="create_acs"
|
218
|
+
>
|
219
|
+
{__('Add source')}
|
220
|
+
</Button>
|
221
|
+
{isCreateWizardOpen &&
|
222
|
+
<ACSCreateWizard
|
223
|
+
show={isCreateWizardOpen}
|
224
|
+
setIsOpen={setIsCreateWizardOpen}
|
225
|
+
/>
|
226
|
+
}
|
227
|
+
</>
|
228
|
+
}
|
229
|
+
>
|
230
|
+
<Thead>
|
231
|
+
<Tr>
|
232
|
+
{columnHeaders.map(col => (
|
233
|
+
<Th
|
234
|
+
key={col}
|
235
|
+
sort={COLUMNS_TO_SORT_PARAMS[col] ? pfSortParams(col) : undefined}
|
236
|
+
>
|
237
|
+
{col}
|
238
|
+
</Th>
|
239
|
+
))}
|
240
|
+
</Tr>
|
241
|
+
</Thead>
|
242
|
+
<Tbody>
|
243
|
+
{results?.map((acs, index) => {
|
244
|
+
const {
|
245
|
+
name,
|
246
|
+
id,
|
247
|
+
alternate_content_source_type: acsType,
|
248
|
+
last_refresh: lastTask,
|
249
|
+
} = acs;
|
250
|
+
const {
|
251
|
+
last_refresh_words: lastRefreshWords,
|
252
|
+
started_at: startedAt,
|
253
|
+
} = lastTask ?? {};
|
254
|
+
return (
|
255
|
+
<Tr key={index}>
|
256
|
+
<Td onClick={() => {
|
257
|
+
onClick(id);
|
258
|
+
push(`/labs/alternate_content_sources/${id}/details`);
|
259
|
+
}}
|
260
|
+
>
|
261
|
+
<Text component="a">{name}</Text>
|
262
|
+
</Td>
|
263
|
+
<Td>{acsType}</Td>
|
264
|
+
<Td><LastSync
|
265
|
+
startedAt={startedAt}
|
266
|
+
lastSync={lastTask}
|
267
|
+
lastSyncWords={lastRefreshWords}
|
268
|
+
emptyMessage="N/A"
|
269
|
+
/>
|
270
|
+
</Td>
|
271
|
+
<Td
|
272
|
+
actions={{
|
273
|
+
items: rowDropdownItems(acs),
|
274
|
+
}}
|
275
|
+
/>
|
276
|
+
</Tr>
|
277
|
+
);
|
278
|
+
})
|
279
|
+
}
|
280
|
+
</Tbody>
|
281
|
+
</TableWrapper>
|
282
|
+
</DrawerContentBody>
|
283
|
+
</DrawerContent>
|
284
|
+
</Drawer>
|
157
285
|
);
|
158
286
|
/* eslint-enable react/no-array-index-key */
|
159
287
|
};
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { renderWithRedux, patientlyWaitFor } from 'react-testing-lib-wrapper';
|
3
3
|
|
4
|
-
import
|
4
|
+
import { nockInstance, assertNockRequest, mockAutocomplete, mockSetting } from '../../../../test-utils/nockWrapper';
|
5
5
|
import api from '../../../../services/api';
|
6
6
|
import ACSTable from '../ACSTable';
|
7
7
|
import acsData from './acsIndex.fixtures.json';
|
@@ -21,7 +21,6 @@ beforeEach(() => {
|
|
21
21
|
});
|
22
22
|
|
23
23
|
afterEach(() => {
|
24
|
-
nock.cleanAll();
|
25
24
|
assertNockRequest(searchDelayScope);
|
26
25
|
assertNockRequest(autoSearchScope);
|
27
26
|
});
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { renderWithRedux, patientlyWaitFor } from 'react-testing-lib-wrapper';
|
3
|
-
import
|
3
|
+
import { nockInstance, assertNockRequest, mockAutocomplete, mockSetting } from '../../../test-utils/nockWrapper';
|
4
4
|
import api from '../../../services/api';
|
5
5
|
import ContentPage from '../ContentPage';
|
6
6
|
import ansibleCollectionsResponse from './ansibleCollections.fixtures';
|
@@ -21,7 +21,6 @@ beforeEach(() => {
|
|
21
21
|
});
|
22
22
|
|
23
23
|
afterEach(() => {
|
24
|
-
nock.cleanAll();
|
25
24
|
assertNockRequest(autoSearchScope);
|
26
25
|
assertNockRequest(searchDelayScope);
|
27
26
|
});
|
@@ -2,6 +2,13 @@ import { translate as __ } from 'foremanReact/common/I18n';
|
|
2
2
|
import { toUpper } from 'lodash';
|
3
3
|
|
4
4
|
const CONTENT_VIEWS_KEY = 'CONTENT_VIEWS';
|
5
|
+
const PACKAGES_KEY = 'PACKAGES';
|
6
|
+
const PACKAGE_GROUPS_KEY = 'PACKAGE_GROUPS';
|
7
|
+
const ERRATA_KEY = 'ERRATA';
|
8
|
+
const MODULE_STREAMS_KEY = 'MODULE_STREAMS';
|
9
|
+
const DEB_PACKAGES_KEY = 'DEB_PACKAGES';
|
10
|
+
const DOCKER_TAGS_KEY = 'DOCKER_TAGS';
|
11
|
+
const FILES_KEY = 'FILES';
|
5
12
|
export const CREATE_CONTENT_VIEW_KEY = 'CONTENT_VIEW_CREATE';
|
6
13
|
export const COPY_CONTENT_VIEW_KEY = 'CONTENT_VIEW_COPY';
|
7
14
|
export const CREATE_CONTENT_VIEW_FILTER_KEY = 'CONTENT_VIEW_FILTER_CREATE';
|
@@ -51,12 +58,16 @@ export const cvVersionPublishKey = (cvId, versionCount) => `${PUBLISH_CONTENT_VI
|
|
51
58
|
export const cvVersionTaskPollingKey = cvId => `CONTENT_VIEW_VERSION_POLLING_${cvId}`;
|
52
59
|
export const cvAddComponentKey = cvId => `${CONTENT_VIEWS_KEY}_ADD_COMPONENT_${cvId}`;
|
53
60
|
export const cvRemoveComponentKey = cvId => `${CONTENT_VIEWS_KEY}_REMOVE_COMPONENT_${cvId}`;
|
54
|
-
|
55
61
|
export const removeComponentSuccessMessage = size => (size === 1 ? __('Removed component from content view') : __('Removed components from content view'));
|
56
|
-
|
57
62
|
export const addComponentSuccessMessage = component => (component ? __('Updated component details') : __('Added component to content view'));
|
58
|
-
|
59
|
-
|
63
|
+
export const genericContentCompareKey = (pluralLabel, versionOne, versionTwo, viewBy) => `${toUpper(pluralLabel)}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
64
|
+
export const cvPackageGroupsCompareKey = (versionOne, versionTwo, viewBy) => `${PACKAGE_GROUPS_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
65
|
+
export const cvRPMPackagesCompareKey = (versionOne, versionTwo, viewBy) => `${PACKAGES_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
66
|
+
export const cvErrataCompareKey = (versionOne, versionTwo, viewBy) => `${ERRATA_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
67
|
+
export const cvModuleStreamsCompareKey = (versionOne, versionTwo, viewBy) => `${MODULE_STREAMS_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
68
|
+
export const cvDebPackagesCompareKey = (versionOne, versionTwo, viewBy) => `${DEB_PACKAGES_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
69
|
+
export const cvDockerTagsCompareKey = (versionOne, versionTwo, viewBy) => `${DOCKER_TAGS_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
70
|
+
export const filesCompareKey = (versionOne, versionTwo, viewBy) => `${FILES_KEY}_COMPARE_${versionOne}_${versionTwo}_VIEW_BY_${toUpper(viewBy)}`;
|
60
71
|
// Repo added to content view status display and key
|
61
72
|
export const ADDED = __('Added');
|
62
73
|
export const NOT_ADDED = __('Not added');
|
@@ -2,7 +2,7 @@
|
|
2
2
|
import React from 'react';
|
3
3
|
import { renderWithRedux, patientlyWaitFor, fireEvent, act } from 'react-testing-lib-wrapper';
|
4
4
|
import api, { foremanApi } from '../../../../services/api';
|
5
|
-
import
|
5
|
+
import {
|
6
6
|
nockInstance, assertNockRequest, mockAutocomplete, mockSetting, mockForemanAutocomplete,
|
7
7
|
} from '../../../../test-utils/nockWrapper';
|
8
8
|
import CONTENT_VIEWS_KEY from '../../ContentViewsConstants';
|
@@ -53,7 +53,6 @@ beforeEach(() => {
|
|
53
53
|
});
|
54
54
|
|
55
55
|
afterEach(() => {
|
56
|
-
nock.cleanAll();
|
57
56
|
assertNockRequest(searchDelayScope);
|
58
57
|
assertNockRequest(autoSearchScope);
|
59
58
|
});
|
@@ -58,6 +58,7 @@ const ContentViewComponents = ({ cvId, details }) => {
|
|
58
58
|
const [bulkAdding, setBulkAdding] = useState(false);
|
59
59
|
const [bulkActionOpen, setBulkActionOpen] = useState(false);
|
60
60
|
const dispatch = useDispatch();
|
61
|
+
const resetFilters = () => setStatusSelected(ALL_STATUSES);
|
61
62
|
|
62
63
|
const columnHeaders = [
|
63
64
|
{ title: __('Type'), transforms: [fitContent] },
|
@@ -244,6 +245,7 @@ const ContentViewComponents = ({ cvId, details }) => {
|
|
244
245
|
status,
|
245
246
|
activeFilters,
|
246
247
|
defaultFilters,
|
248
|
+
resetFilters,
|
247
249
|
}}
|
248
250
|
ouiaId="content-view-components-table"
|
249
251
|
actionResolver={hasPermission(permissions, 'edit_content_views') ? actionResolver : null}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
|
3
|
-
import
|
3
|
+
import { nockInstance, assertNockRequest, mockAutocomplete, mockSetting } from '../../../../../test-utils/nockWrapper';
|
4
4
|
import api from '../../../../../services/api';
|
5
5
|
import CONTENT_VIEWS_KEY from '../../../ContentViewsConstants';
|
6
6
|
import ContentViewComponents from '../ContentViewComponents';
|
@@ -30,7 +30,6 @@ beforeEach(() => {
|
|
30
30
|
});
|
31
31
|
|
32
32
|
afterEach(() => {
|
33
|
-
nock.cleanAll();
|
34
33
|
assertNockRequest(searchDelayScope);
|
35
34
|
assertNockRequest(autoSearchScope);
|
36
35
|
});
|
@@ -49,6 +49,14 @@ import {
|
|
49
49
|
generatedContentKey,
|
50
50
|
STATUS_TRANSLATIONS_ENUM,
|
51
51
|
bulkRemoveVersionKey,
|
52
|
+
cvRPMPackagesCompareKey,
|
53
|
+
cvPackageGroupsCompareKey,
|
54
|
+
cvErrataCompareKey,
|
55
|
+
cvModuleStreamsCompareKey,
|
56
|
+
cvDockerTagsCompareKey,
|
57
|
+
cvDebPackagesCompareKey,
|
58
|
+
filesCompareKey,
|
59
|
+
genericContentCompareKey,
|
52
60
|
} from '../ContentViewsConstants';
|
53
61
|
import api, { foremanApi, orgId } from '../../../services/api';
|
54
62
|
import { getResponseErrorMsgs } from '../../../utils/helpers';
|
@@ -78,6 +86,111 @@ export const getRPMPackages = params => get({
|
|
78
86
|
errorToast: error => __(`Something went wrong while fetching rpm packages! ${getResponseErrorMsgs(error.response)}`),
|
79
87
|
});
|
80
88
|
|
89
|
+
export const getRPMPackagesComparison = (versionOne, versionTwo, viewBy, params) => {
|
90
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
91
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
92
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
93
|
+
const apiUrl = '/packages/compare';
|
94
|
+
return get({
|
95
|
+
key: cvRPMPackagesCompareKey(versionOne, versionTwo, viewBy),
|
96
|
+
params: apiParams,
|
97
|
+
errorToast: error => __(`Something went wrong while retrieving the packages! ${getResponseErrorMsgs(error.response)}`),
|
98
|
+
url: api.getApiUrl(apiUrl),
|
99
|
+
});
|
100
|
+
};
|
101
|
+
|
102
|
+
export const getPackageGroupsComparison = (versionOne, versionTwo, viewBy, params) => {
|
103
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
104
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
105
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
106
|
+
const apiUrl = '/package_groups/compare';
|
107
|
+
return get({
|
108
|
+
key: cvPackageGroupsCompareKey(versionOne, versionTwo, viewBy),
|
109
|
+
params: apiParams,
|
110
|
+
errorToast: error => __(`Something went wrong while retrieving the package groups! ${getResponseErrorMsgs(error.response)}`),
|
111
|
+
url: api.getApiUrl(apiUrl),
|
112
|
+
});
|
113
|
+
};
|
114
|
+
|
115
|
+
export const getErrataComparison = (versionOne, versionTwo, viewBy, params) => {
|
116
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
117
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
118
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
119
|
+
const apiUrl = '/errata/compare';
|
120
|
+
return get({
|
121
|
+
key: cvErrataCompareKey(versionOne, versionTwo, viewBy),
|
122
|
+
params: apiParams,
|
123
|
+
errorToast: error => __(`Something went wrong while retrieving the errata! ${getResponseErrorMsgs(error.response)}`),
|
124
|
+
url: api.getApiUrl(apiUrl),
|
125
|
+
});
|
126
|
+
};
|
127
|
+
|
128
|
+
export const getModuleStreamsComparison = (versionOne, versionTwo, viewBy, params) => {
|
129
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
130
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
131
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
132
|
+
const apiUrl = '/module_streams/compare';
|
133
|
+
return get({
|
134
|
+
key: cvModuleStreamsCompareKey(versionOne, versionTwo, viewBy),
|
135
|
+
params: apiParams,
|
136
|
+
errorToast: error => __(`Something went wrong while retrieving the module streams! ${getResponseErrorMsgs(error.response)}`),
|
137
|
+
url: api.getApiUrl(apiUrl),
|
138
|
+
});
|
139
|
+
};
|
140
|
+
|
141
|
+
export const getDebPackagesComparison = (versionOne, versionTwo, viewBy, params) => {
|
142
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
143
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
144
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
145
|
+
const apiUrl = '/debs/compare';
|
146
|
+
return get({
|
147
|
+
key: cvDebPackagesCompareKey(versionOne, versionTwo, viewBy),
|
148
|
+
params: apiParams,
|
149
|
+
errorToast: error => __(`Something went wrong while retrieving the deb packages! ${getResponseErrorMsgs(error.response)}`),
|
150
|
+
url: api.getApiUrl(apiUrl),
|
151
|
+
});
|
152
|
+
};
|
153
|
+
|
154
|
+
export const getDockerTagsComparison = (versionOne, versionTwo, viewBy, params) => {
|
155
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
156
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
157
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
158
|
+
const apiUrl = '/docker_tags/compare';
|
159
|
+
return get({
|
160
|
+
key: cvDockerTagsCompareKey(versionOne, versionTwo, viewBy),
|
161
|
+
params: apiParams,
|
162
|
+
errorToast: error => __(`Something went wrong while retrieving the container tags! ${getResponseErrorMsgs(error.response)}`),
|
163
|
+
url: api.getApiUrl(apiUrl),
|
164
|
+
});
|
165
|
+
};
|
166
|
+
|
167
|
+
export const getFilesComparison = (versionOne, versionTwo, viewBy, params) => {
|
168
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
169
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
170
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
171
|
+
const apiUrl = '/files/compare';
|
172
|
+
return get({
|
173
|
+
key: filesCompareKey(versionOne, versionTwo, viewBy),
|
174
|
+
params: apiParams,
|
175
|
+
errorToast: error => __(`Something went wrong while retrieving the files! ${getResponseErrorMsgs(error.response)}`),
|
176
|
+
url: api.getApiUrl(apiUrl),
|
177
|
+
});
|
178
|
+
};
|
179
|
+
|
180
|
+
export const getGenericContentComparison =
|
181
|
+
(pluralLabel, versionOne, versionTwo, viewBy, params) => {
|
182
|
+
const versions = { content_view_version_ids: [versionOne, versionTwo] };
|
183
|
+
const restrictComparison = { restrict_comparison: viewBy };
|
184
|
+
const apiParams = { ...versions, ...restrictComparison, ...params };
|
185
|
+
const apiUrl = `/${pluralLabel}/compare`;
|
186
|
+
return get({
|
187
|
+
key: genericContentCompareKey(pluralLabel, versionOne, versionTwo, viewBy),
|
188
|
+
params: apiParams,
|
189
|
+
errorToast: error => __(`Something went wrong while retrieving the content! ${getResponseErrorMsgs(error.response)}`),
|
190
|
+
url: api.getApiUrl(apiUrl),
|
191
|
+
});
|
192
|
+
};
|
193
|
+
|
81
194
|
export const getFiles = params => get({
|
82
195
|
type: API_OPERATIONS.GET,
|
83
196
|
key: FILE_CONTENT,
|