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,66 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc service
|
3
|
-
* @name Bastion.content-views.factory:Filter
|
4
|
-
*
|
5
|
-
* @requires BastionResource
|
6
|
-
*
|
7
|
-
* @description
|
8
|
-
* Provides a BastionResource for interacting with content view filters.
|
9
|
-
*/
|
10
|
-
angular.module('Bastion.content-views').factory('Filter',
|
11
|
-
['BastionResource', function (BastionResource) {
|
12
|
-
|
13
|
-
return BastionResource('katello/api/v2/content_view_filters/:filterId/:action',
|
14
|
-
{filterId: '@id', 'content_view_id': '@content_view.id'},
|
15
|
-
{
|
16
|
-
autocomplete: {method: 'GET', isArray: true, params: {filterId: 'auto_complete_search'}},
|
17
|
-
update: {method: 'PUT'},
|
18
|
-
availableErrata: {
|
19
|
-
method: 'GET',
|
20
|
-
params: {action: 'errata', 'available_for': 'content_view_filter'}
|
21
|
-
},
|
22
|
-
rules: {method: 'GET', transformResponse: function (data) {
|
23
|
-
var response = angular.fromJson(data),
|
24
|
-
rules = response.rules || [];
|
25
|
-
|
26
|
-
function getType(rule) {
|
27
|
-
var typeId;
|
28
|
-
|
29
|
-
if (rule.version) {
|
30
|
-
typeId = 'equal';
|
31
|
-
} else if (rule['min_version'] && !rule['max_version']) {
|
32
|
-
typeId = 'greater';
|
33
|
-
} else if (!rule['min_version'] && rule['max_version']) {
|
34
|
-
typeId = 'less';
|
35
|
-
} else if (rule['min_version'] && rule['max_version']) {
|
36
|
-
typeId = 'range';
|
37
|
-
} else {
|
38
|
-
typeId = 'all';
|
39
|
-
}
|
40
|
-
|
41
|
-
return typeId;
|
42
|
-
}
|
43
|
-
|
44
|
-
angular.forEach(rules, function (rule) {
|
45
|
-
rule.type = getType(rule);
|
46
|
-
});
|
47
|
-
|
48
|
-
return {results: rules, subtotal: rules.length, total: rules.length};
|
49
|
-
}},
|
50
|
-
errata: {
|
51
|
-
method: 'GET',
|
52
|
-
params: {action: 'errata'}
|
53
|
-
},
|
54
|
-
availablePackageGroups: {
|
55
|
-
method: 'GET',
|
56
|
-
params: {action: 'package_groups', 'available_for': 'content_view_filter'}
|
57
|
-
},
|
58
|
-
packageGroups: {
|
59
|
-
method: 'GET',
|
60
|
-
params: {action: 'package_groups'}
|
61
|
-
}
|
62
|
-
}
|
63
|
-
);
|
64
|
-
|
65
|
-
}]
|
66
|
-
);
|
@@ -1,85 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc object
|
3
|
-
* @name Bastion.content-views.controller:FiltersController
|
4
|
-
*
|
5
|
-
* @requires $scope
|
6
|
-
* @requires translate
|
7
|
-
* @requires Filter
|
8
|
-
* @requires Nutupane
|
9
|
-
* @requires Notification
|
10
|
-
*
|
11
|
-
* @description
|
12
|
-
* Handles loading all filters for a content view.
|
13
|
-
*/
|
14
|
-
angular.module('Bastion.content-views').controller('FiltersController',
|
15
|
-
['$scope', 'translate', 'Filter', 'Nutupane', 'Notification', function ($scope, translate, Filter, Nutupane, Notification) {
|
16
|
-
var nutupane, filterTypes;
|
17
|
-
|
18
|
-
function removeFilter(id) {
|
19
|
-
var success, failure;
|
20
|
-
|
21
|
-
success = function () {
|
22
|
-
nutupane.removeRow(id);
|
23
|
-
Notification.setSuccessMessage(translate('Filters successfully removed.'));
|
24
|
-
};
|
25
|
-
|
26
|
-
failure = function (response) {
|
27
|
-
Notification.setErrorMessage(response.data.displayMessage);
|
28
|
-
};
|
29
|
-
|
30
|
-
Filter.delete({filterId: id}, success, failure);
|
31
|
-
}
|
32
|
-
|
33
|
-
if ($scope.stateIncludes('content-view.yum')) {
|
34
|
-
filterTypes = ['rpm', 'package_group', 'erratum', 'modulemd'];
|
35
|
-
} else {
|
36
|
-
filterTypes = ['docker'];
|
37
|
-
}
|
38
|
-
nutupane = new Nutupane(Filter, {
|
39
|
-
'content_view_id': $scope.$stateParams.contentViewId,
|
40
|
-
'types[]': filterTypes
|
41
|
-
});
|
42
|
-
|
43
|
-
$scope.table = nutupane.table;
|
44
|
-
|
45
|
-
$scope.$on('filter.created', function () {
|
46
|
-
nutupane.refresh();
|
47
|
-
});
|
48
|
-
|
49
|
-
$scope.$on('filter.updated', function () {
|
50
|
-
nutupane.refresh();
|
51
|
-
});
|
52
|
-
|
53
|
-
$scope.removeFilters = function () {
|
54
|
-
var filterIds = nutupane.getAllSelectedResults().included.ids;
|
55
|
-
|
56
|
-
angular.forEach(filterIds, removeFilter);
|
57
|
-
};
|
58
|
-
|
59
|
-
nutupane.table.closeItem = function () {};
|
60
|
-
|
61
|
-
$scope.getFilterState = function (filter) {
|
62
|
-
var state;
|
63
|
-
|
64
|
-
switch (filter.type) {
|
65
|
-
case "erratum":
|
66
|
-
state = "content-view.yum.filter.erratum.list({filterId: filter.id})";
|
67
|
-
if (filter.rules[0].types) {
|
68
|
-
state = "content-view.yum.filter.erratum.dateType({filterId: filter.id})";
|
69
|
-
}
|
70
|
-
break;
|
71
|
-
case "rpm":
|
72
|
-
state = "content-view.yum.filter.rpm({filterId: filter.id})";
|
73
|
-
break;
|
74
|
-
case "modulemd":
|
75
|
-
state = "content-view.yum.filter.module-stream.list({filterId: filter.id})";
|
76
|
-
break;
|
77
|
-
case "package_group":
|
78
|
-
state = "content-view.yum.filter.package_group.list({filterId: filter.id})";
|
79
|
-
break;
|
80
|
-
}
|
81
|
-
|
82
|
-
return state;
|
83
|
-
};
|
84
|
-
}]
|
85
|
-
);
|
@@ -1,73 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc object
|
3
|
-
* @name Bastion.content-views.controller:PackageFilterListController
|
4
|
-
*
|
5
|
-
* @requires $scope
|
6
|
-
* @requires translate
|
7
|
-
* @requires ModuleStream
|
8
|
-
* @requires Rule
|
9
|
-
* @requires Nutupane
|
10
|
-
* @requires Notification
|
11
|
-
*
|
12
|
-
* @description
|
13
|
-
* Handles loading module streams that have been added to the filter via filter rules
|
14
|
-
* and provides a method to remove them.
|
15
|
-
*/
|
16
|
-
angular.module('Bastion.content-views').controller('ModuleStreamFilterListController',
|
17
|
-
['$scope', 'translate', 'ModuleStream', 'Rule', 'Nutupane', 'Notification',
|
18
|
-
function ($scope, translate, ModuleStream, Rule, Nutupane, Notification) {
|
19
|
-
var nutupane;
|
20
|
-
|
21
|
-
function success(rule) {
|
22
|
-
nutupane.removeRow(rule['module_stream_id'], 'id');
|
23
|
-
$scope.filter.rules = _.reject($scope.filter.rules, function (filterRule) {
|
24
|
-
return rule.id === filterRule.id;
|
25
|
-
});
|
26
|
-
Notification.setSuccessMessage(translate('Module Stream successfully removed.'));
|
27
|
-
}
|
28
|
-
|
29
|
-
function failure(response) {
|
30
|
-
Notification.setErrorMessage(response.data.displayMessage);
|
31
|
-
}
|
32
|
-
|
33
|
-
function findRules(moduleStreamIds) {
|
34
|
-
var rules = [];
|
35
|
-
|
36
|
-
angular.forEach(moduleStreamIds, function (id) {
|
37
|
-
var found;
|
38
|
-
|
39
|
-
found = _.find($scope.filter.rules, function (rule) {
|
40
|
-
return (rule['module_stream_id'] === id);
|
41
|
-
});
|
42
|
-
|
43
|
-
if (found) {
|
44
|
-
rules.push(new Rule(found));
|
45
|
-
}
|
46
|
-
});
|
47
|
-
|
48
|
-
return rules;
|
49
|
-
}
|
50
|
-
|
51
|
-
nutupane = new Nutupane(ModuleStream, {
|
52
|
-
filterId: $scope.$stateParams.filterId,
|
53
|
-
'sort_order': 'ASC',
|
54
|
-
'sort_by': 'name'
|
55
|
-
},
|
56
|
-
'queryPaged'
|
57
|
-
);
|
58
|
-
|
59
|
-
$scope.table = nutupane.table;
|
60
|
-
nutupane.table.closeItem = function () {};
|
61
|
-
|
62
|
-
$scope.removeModuleStreams = function () {
|
63
|
-
var moduleStreamIds = nutupane.getAllSelectedResults().included.ids,
|
64
|
-
rules;
|
65
|
-
|
66
|
-
rules = findRules(moduleStreamIds);
|
67
|
-
|
68
|
-
angular.forEach(rules, function (rule) {
|
69
|
-
rule.$delete(success, failure);
|
70
|
-
});
|
71
|
-
};
|
72
|
-
}]
|
73
|
-
);
|
@@ -1,100 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc object
|
3
|
-
* @name Bastion.content-views.controller:NewFilterController
|
4
|
-
*
|
5
|
-
* @requires $scope
|
6
|
-
* @requires translate
|
7
|
-
* @requires Filter
|
8
|
-
* @requires Rule
|
9
|
-
* @requires Notification
|
10
|
-
*
|
11
|
-
* @description
|
12
|
-
*/
|
13
|
-
angular.module('Bastion.content-views').controller('NewFilterController',
|
14
|
-
['$scope', 'translate', 'Filter', 'Rule', 'Notification', function ($scope, translate, Filter, Rule, Notification) {
|
15
|
-
var filterType;
|
16
|
-
|
17
|
-
function transitionToDetails(filter) {
|
18
|
-
var state = '';
|
19
|
-
|
20
|
-
if (filterType === 'erratumId') {
|
21
|
-
state = 'content-view.yum.filter.erratum.available';
|
22
|
-
} else if (filterType === 'erratumDateType') {
|
23
|
-
state = 'content-view.yum.filter.erratum.dateType';
|
24
|
-
} else if (filterType === 'rpm') {
|
25
|
-
state = 'content-view.yum.filter.rpm.details';
|
26
|
-
} else if (filterType === 'package_group') {
|
27
|
-
state = 'content-view.yum.filter.package_group.available';
|
28
|
-
} else if (filterType === 'modulemd') {
|
29
|
-
state = 'content-view.yum.filter.module-stream.available';
|
30
|
-
} else if (filterType === 'docker') {
|
31
|
-
state = 'content-view.docker.filter.tag.details';
|
32
|
-
}
|
33
|
-
|
34
|
-
$scope.$emit('filter.created');
|
35
|
-
$scope.transitionTo(state, {filterId: filter.id, contentViewId: filter['content_view'].id});
|
36
|
-
}
|
37
|
-
|
38
|
-
function addErrataDateTypeRule(filter) {
|
39
|
-
var rule = new Rule({
|
40
|
-
types: ['security', 'enhancement', 'bugfix']
|
41
|
-
}),
|
42
|
-
addSuccess, error;
|
43
|
-
|
44
|
-
addSuccess = function () {
|
45
|
-
transitionToDetails(filter);
|
46
|
-
};
|
47
|
-
|
48
|
-
error = function (response) {
|
49
|
-
Notification.setErrorMessage(response.data.displayMessage);
|
50
|
-
};
|
51
|
-
|
52
|
-
rule.$save({filterId: filter.id}, addSuccess, error);
|
53
|
-
}
|
54
|
-
|
55
|
-
function success(filter) {
|
56
|
-
if (filterType === 'erratumDateType') {
|
57
|
-
addErrataDateTypeRule(filter);
|
58
|
-
} else {
|
59
|
-
transitionToDetails(filter);
|
60
|
-
}
|
61
|
-
}
|
62
|
-
|
63
|
-
function failure(response) {
|
64
|
-
$scope.working = false;
|
65
|
-
angular.forEach(response.data.errors, function (errors, field) {
|
66
|
-
$scope.filterForm[field].$setValidity('server', false);
|
67
|
-
$scope.filterForm[field].$error.messages = errors;
|
68
|
-
});
|
69
|
-
}
|
70
|
-
|
71
|
-
$scope.filter = new Filter();
|
72
|
-
$scope.working = false;
|
73
|
-
|
74
|
-
if ($scope.stateIncludes('content-view.yum')) {
|
75
|
-
$scope.filterChoices = [
|
76
|
-
{id: 'rpm', name: translate('Package')},
|
77
|
-
{id: 'package_group', name: translate('Package Group')},
|
78
|
-
{id: 'erratumId', name: translate('Erratum - by ID')},
|
79
|
-
{id: 'erratumDateType', name: translate('Erratum - Date and Type')},
|
80
|
-
{id: 'modulemd', name: translate('Module Stream')}
|
81
|
-
];
|
82
|
-
} else {
|
83
|
-
$scope.filter.type = "docker";
|
84
|
-
$scope.filterChoices = [
|
85
|
-
{id: 'docker', name: translate('Container Image Tag')}
|
86
|
-
];
|
87
|
-
}
|
88
|
-
|
89
|
-
$scope.save = function (filter, contentView) {
|
90
|
-
filterType = filter.type;
|
91
|
-
|
92
|
-
if (filter.type === 'erratumId' || filter.type === 'erratumDateType') {
|
93
|
-
filter.type = 'erratum';
|
94
|
-
}
|
95
|
-
|
96
|
-
filter.$save({'content_view_id': contentView.id}, success, failure);
|
97
|
-
};
|
98
|
-
|
99
|
-
}]
|
100
|
-
);
|
@@ -1,179 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc object
|
3
|
-
* @name Bastion.content-views.controller:PackageFilterController
|
4
|
-
*
|
5
|
-
* @requires $scope
|
6
|
-
* @requires $location
|
7
|
-
* @requires translate
|
8
|
-
* @requires Nutupane
|
9
|
-
* @requires CurrentOrganization
|
10
|
-
* @requires Filter
|
11
|
-
* @requires Rule
|
12
|
-
* @requires Package
|
13
|
-
* @requires Notification
|
14
|
-
* @requires $uibModal
|
15
|
-
*
|
16
|
-
* @description
|
17
|
-
* Handles package filter rules for a content view.
|
18
|
-
*/
|
19
|
-
angular.module('Bastion.content-views').controller('PackageFilterController',
|
20
|
-
['$scope', '$location', 'translate', 'Nutupane', 'CurrentOrganization', 'Filter', 'Rule', 'Package', 'Notification', '$uibModal',
|
21
|
-
function ($scope, $location, translate, Nutupane, CurrentOrganization, Filter, Rule, Package, Notification, $uibModal) {
|
22
|
-
var nutupane, params;
|
23
|
-
|
24
|
-
function failure(response) {
|
25
|
-
Notification.setErrorMessage(response.data.displayMessage);
|
26
|
-
}
|
27
|
-
|
28
|
-
function createRule(rule) {
|
29
|
-
var success;
|
30
|
-
|
31
|
-
success = function (result) {
|
32
|
-
rule.id = result.id;
|
33
|
-
rule.editMode = false;
|
34
|
-
rule.working = false;
|
35
|
-
|
36
|
-
Notification.setSuccessMessage(translate('Package successfully added.'));
|
37
|
-
};
|
38
|
-
|
39
|
-
if ($scope.valid(rule)) {
|
40
|
-
Rule.save({filterId: $scope.filter.id}, rule, success, failure);
|
41
|
-
}
|
42
|
-
}
|
43
|
-
|
44
|
-
function updateRule(rule) {
|
45
|
-
var updateParams = {filterId: $scope.filter.id, ruleId: rule.id},
|
46
|
-
success, error;
|
47
|
-
|
48
|
-
// Need access to the original rule
|
49
|
-
success = function () {
|
50
|
-
rule.previous = {};
|
51
|
-
rule.editMode = false;
|
52
|
-
rule.working = false;
|
53
|
-
Notification.setSuccessMessage(translate('Package successfully updated.'));
|
54
|
-
};
|
55
|
-
|
56
|
-
error = function () {
|
57
|
-
rule.working = false;
|
58
|
-
};
|
59
|
-
|
60
|
-
Rule.update(updateParams, rule, success, error);
|
61
|
-
}
|
62
|
-
|
63
|
-
function removeRule(rule) {
|
64
|
-
var success, ruleId = rule.id;
|
65
|
-
|
66
|
-
success = function () {
|
67
|
-
nutupane.removeRow(ruleId);
|
68
|
-
Notification.setSuccessMessage(translate('Package successfully removed.'));
|
69
|
-
};
|
70
|
-
|
71
|
-
Rule.delete({filterId: $scope.$stateParams.filterId, ruleId: ruleId}, success, failure);
|
72
|
-
}
|
73
|
-
|
74
|
-
params = {
|
75
|
-
filterId: $scope.$stateParams.filterId,
|
76
|
-
'organization_id': CurrentOrganization,
|
77
|
-
'search': $location.search().search || "",
|
78
|
-
'sort_by': 'name',
|
79
|
-
'sort_order': 'ASC',
|
80
|
-
'paged': true
|
81
|
-
};
|
82
|
-
|
83
|
-
nutupane = new Nutupane(Filter, params, 'rules');
|
84
|
-
$scope.table = nutupane.table;
|
85
|
-
|
86
|
-
$scope.addRule = function () {
|
87
|
-
var rule = new Rule();
|
88
|
-
rule.editMode = true;
|
89
|
-
$scope.table.addRow(rule);
|
90
|
-
};
|
91
|
-
|
92
|
-
$scope.saveRule = function (rule) {
|
93
|
-
if (rule.id) {
|
94
|
-
updateRule(rule);
|
95
|
-
} else {
|
96
|
-
createRule(rule);
|
97
|
-
}
|
98
|
-
};
|
99
|
-
|
100
|
-
$scope.valid = function (rule) {
|
101
|
-
var valid = rule.name ? true : false;
|
102
|
-
|
103
|
-
if (rule.type === 'equal') {
|
104
|
-
valid = valid && rule.version;
|
105
|
-
} else if (rule.type === 'less') {
|
106
|
-
valid = valid && rule['max_version'];
|
107
|
-
} else if (rule.type === 'greater') {
|
108
|
-
valid = valid && rule['min_version'];
|
109
|
-
} else if (rule.type === 'range') {
|
110
|
-
valid = valid && rule['min_version'] && rule['max_version'];
|
111
|
-
}
|
112
|
-
|
113
|
-
return valid;
|
114
|
-
};
|
115
|
-
|
116
|
-
$scope.clearValues = function (rule) {
|
117
|
-
rule.version = undefined;
|
118
|
-
rule['min_version'] = undefined;
|
119
|
-
rule['max_version'] = undefined;
|
120
|
-
};
|
121
|
-
|
122
|
-
$scope.backupPrevious = function (rule) {
|
123
|
-
rule.previous = {};
|
124
|
-
angular.copy(rule, rule.previous);
|
125
|
-
};
|
126
|
-
|
127
|
-
$scope.restorePrevious = function (rule) {
|
128
|
-
if (rule.id) {
|
129
|
-
angular.copy(rule.previous, rule);
|
130
|
-
} else {
|
131
|
-
$scope.table.rows.shift();
|
132
|
-
}
|
133
|
-
rule.previous = {};
|
134
|
-
};
|
135
|
-
|
136
|
-
$scope.removeRules = function () {
|
137
|
-
angular.forEach($scope.table.getSelected(), function (rule) {
|
138
|
-
removeRule(rule);
|
139
|
-
});
|
140
|
-
};
|
141
|
-
|
142
|
-
$scope.getMatchingContent = function (rule) {
|
143
|
-
$uibModal.open({
|
144
|
-
templateUrl: 'content-views/details/filters/views/filter-rule-matching-package-modal.html',
|
145
|
-
controller: 'FilterRuleMatchingPackageModal',
|
146
|
-
size: 'lg',
|
147
|
-
resolve: {
|
148
|
-
filterRuleId: rule.id
|
149
|
-
}
|
150
|
-
}).closed.then(function () {});
|
151
|
-
};
|
152
|
-
|
153
|
-
$scope.fetchAutocompleteName = function (term) {
|
154
|
-
var repositoryIds = $scope.contentView['repository_ids'],
|
155
|
-
promise;
|
156
|
-
|
157
|
-
promise = Package.autocompleteName({'repoids[]': repositoryIds, term: term, 'non_modular_only': true}).$promise;
|
158
|
-
|
159
|
-
return promise.then(function (data) {
|
160
|
-
return data.results;
|
161
|
-
});
|
162
|
-
};
|
163
|
-
|
164
|
-
$scope.fetchAutocompleteArch = function (term) {
|
165
|
-
var repositoryIds = $scope.contentView['repository_ids'],
|
166
|
-
promise;
|
167
|
-
|
168
|
-
promise = Package.autocompleteArch({'repoids[]': repositoryIds, term: term, 'non_modular_only': true}).$promise;
|
169
|
-
|
170
|
-
return promise.then(function (data) {
|
171
|
-
return data.results;
|
172
|
-
});
|
173
|
-
};
|
174
|
-
|
175
|
-
$scope.filterRepositoriesByType = function () {
|
176
|
-
return (_.filter($scope.filter.repositories, ["content_type", "yum"]));
|
177
|
-
};
|
178
|
-
}]
|
179
|
-
);
|
@@ -1,75 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc object
|
3
|
-
* @name Bastion.content-views.controller:PackageFilterListController
|
4
|
-
*
|
5
|
-
* @requires $scope
|
6
|
-
* @requires translate
|
7
|
-
* @requires Filter
|
8
|
-
* @requires Rule
|
9
|
-
* @requires Nutupane
|
10
|
-
* @requires Notification
|
11
|
-
*
|
12
|
-
* @description
|
13
|
-
* Handles loading package groups that have been added to the filter via filter rules
|
14
|
-
* and provides a method to remove them.
|
15
|
-
*/
|
16
|
-
angular.module('Bastion.content-views').controller('PackageGroupFilterListController',
|
17
|
-
['$scope', 'translate', 'PackageGroup', 'Rule', 'Nutupane', 'Notification',
|
18
|
-
function ($scope, translate, PackageGroup, Rule, Nutupane, Notification) {
|
19
|
-
var nutupane;
|
20
|
-
|
21
|
-
function success(rule) {
|
22
|
-
nutupane.removeRow(rule.uuid, 'uuid');
|
23
|
-
$scope.filter.rules = _.reject($scope.filter.rules, function (filterRule) {
|
24
|
-
return rule.id === filterRule.id;
|
25
|
-
});
|
26
|
-
Notification.setSuccessMessage(translate('Package Group successfully removed.'));
|
27
|
-
}
|
28
|
-
|
29
|
-
function failure(response) {
|
30
|
-
Notification.setErrorMessage(response.data.displayMessage);
|
31
|
-
}
|
32
|
-
|
33
|
-
function findRules(packageGroupIds) {
|
34
|
-
var rules = [];
|
35
|
-
|
36
|
-
angular.forEach(packageGroupIds, function (id) {
|
37
|
-
var found;
|
38
|
-
|
39
|
-
found = _.find($scope.filter.rules, function (rule) {
|
40
|
-
return (rule.uuid === id);
|
41
|
-
});
|
42
|
-
|
43
|
-
if (found) {
|
44
|
-
rules.push(new Rule(found));
|
45
|
-
}
|
46
|
-
});
|
47
|
-
|
48
|
-
return rules;
|
49
|
-
}
|
50
|
-
|
51
|
-
nutupane = new Nutupane(PackageGroup, {
|
52
|
-
filterId: $scope.$stateParams.filterId,
|
53
|
-
'sort_order': 'ASC',
|
54
|
-
'sort_by': 'name'
|
55
|
-
},
|
56
|
-
'queryUnpaged'
|
57
|
-
);
|
58
|
-
$scope.controllerName = 'katello_package_groups';
|
59
|
-
|
60
|
-
$scope.table = nutupane.table;
|
61
|
-
nutupane.table.closeItem = function () {};
|
62
|
-
|
63
|
-
$scope.removePackageGroups = function () {
|
64
|
-
var packageGroupIds = nutupane.getAllSelectedResults('uuid').included.ids,
|
65
|
-
rules;
|
66
|
-
|
67
|
-
rules = findRules(packageGroupIds);
|
68
|
-
|
69
|
-
angular.forEach(rules, function (rule) {
|
70
|
-
rule.$delete(success, failure);
|
71
|
-
});
|
72
|
-
};
|
73
|
-
|
74
|
-
}]
|
75
|
-
);
|
@@ -1,21 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* @ngdoc service
|
3
|
-
* @name Bastion.content-views.filters.factory:Filter
|
4
|
-
*
|
5
|
-
* @requires BastionResource
|
6
|
-
*
|
7
|
-
* @description
|
8
|
-
* Provides a BastionResource for interacting with content view filter rules.
|
9
|
-
*/
|
10
|
-
angular.module('Bastion.content-views').factory('Rule',
|
11
|
-
['BastionResource', function (BastionResource) {
|
12
|
-
|
13
|
-
return BastionResource('katello/api/v2/content_view_filters/:filterId/rules/:ruleId',
|
14
|
-
{ruleId: '@id', filterId: '@content_view_filter_id'},
|
15
|
-
{
|
16
|
-
update: {method: 'PUT'}
|
17
|
-
}
|
18
|
-
);
|
19
|
-
|
20
|
-
}]
|
21
|
-
);
|
@@ -1,9 +0,0 @@
|
|
1
|
-
<form name="errataForm" class="col-sm-5">
|
2
|
-
<div ng-include="'content-views/details/filters/views/date-type-errata.html'"></div>
|
3
|
-
|
4
|
-
<div bst-form-buttons
|
5
|
-
on-cancel="transitionTo('content-view.yum.filters', {contentViewId: contentView.id})"
|
6
|
-
on-save="save(rule, filter)"
|
7
|
-
working="rule.working">
|
8
|
-
</div>
|
9
|
-
</form>
|
@@ -1,75 +0,0 @@
|
|
1
|
-
<div bst-form-group label="{{ 'Errata Type' | translate }}">
|
2
|
-
|
3
|
-
<label class="checkbox-inline">
|
4
|
-
<input type="checkbox"
|
5
|
-
name="types"
|
6
|
-
value="{{ types.security }}"
|
7
|
-
ng-model="types.security"
|
8
|
-
ng-change="updateTypes(types)"
|
9
|
-
ng-disabled="onlySelected(types, 'security')"/>
|
10
|
-
<span translate>Security</span>
|
11
|
-
</label>
|
12
|
-
|
13
|
-
<label class="checkbox-inline">
|
14
|
-
<input type="checkbox"
|
15
|
-
name="types"
|
16
|
-
value="{{ types.enhancement }}"
|
17
|
-
ng-model="types.enhancement"
|
18
|
-
ng-change="updateTypes(types)"
|
19
|
-
ng-disabled="onlySelected(types, 'enhancement')"/>
|
20
|
-
<span translate>Enhancement</span>
|
21
|
-
</label>
|
22
|
-
|
23
|
-
<label class="checkbox-inline">
|
24
|
-
<input type="checkbox"
|
25
|
-
name="types"
|
26
|
-
value="{{ types.bugfix }}"
|
27
|
-
ng-model="types.bugfix"
|
28
|
-
ng-change="updateTypes(types)"
|
29
|
-
ng-disabled="onlySelected(types, 'bugfix')"/>
|
30
|
-
<span translate>Bugfix</span>
|
31
|
-
</label>
|
32
|
-
|
33
|
-
</div>
|
34
|
-
<div bst-form-group label="{{ 'Date Type' | translate }}">
|
35
|
-
<label class="radio-inline">
|
36
|
-
<input type="radio"
|
37
|
-
ng-model="rule.date_type"
|
38
|
-
ng-change="updateDateType()"
|
39
|
-
value="updated"/>
|
40
|
-
<span translate>Updated On</span>
|
41
|
-
</label>
|
42
|
-
<label class="radio-inline">
|
43
|
-
<input type="radio"
|
44
|
-
ng-model="rule.date_type"
|
45
|
-
ng-change="updateDateType()"
|
46
|
-
value="issued"/>
|
47
|
-
<span translate>Issued On</span>
|
48
|
-
</label>
|
49
|
-
</div>
|
50
|
-
|
51
|
-
<div bst-form-group label="{{ 'Start Date' | translate }}">
|
52
|
-
<div class="input-group">
|
53
|
-
<input type="date" class="form-control" uib-datepicker-popup
|
54
|
-
ng-model="rule.start_date" ng-model-options="{timezone: 'UTC'}"
|
55
|
-
is-open="date.startOpen" ng-click="openStartDate($event)"/>
|
56
|
-
<span class="input-group-btn">
|
57
|
-
<button class="btn btn-default" type="button" ng-click="openStartDate($event)">
|
58
|
-
<i class="fa fa-calendar inline-icon"></i>
|
59
|
-
</button>
|
60
|
-
</span>
|
61
|
-
</div>
|
62
|
-
</div>
|
63
|
-
|
64
|
-
<div bst-form-group label="{{ 'End Date' | translate }}">
|
65
|
-
<div class="input-group">
|
66
|
-
<input type="date" class="form-control" uib-datepicker-popup
|
67
|
-
ng-model="rule.end_date" ng-model-options="{timezone: 'UTC'}"
|
68
|
-
is-open="date.endOpen" ng-click="openEndDate($event)"/>
|
69
|
-
<span class="input-group-btn">
|
70
|
-
<button class="btn btn-default" type="button" ng-click="openEndDate($event)">
|
71
|
-
<i class="fa fa-calendar inline-icon"></i>
|
72
|
-
</button>
|
73
|
-
</span>
|
74
|
-
</div>
|
75
|
-
</div>
|