From 4e354946b4876caf1eac015ba1a6896eb0383f81 Mon Sep 17 00:00:00 2001 From: "desislava.borisova" Date: Tue, 12 Nov 2024 11:19:55 +0200 Subject: [PATCH] GDB-10692 - edit styling and logic to reflect review notes. Known issue: main checkbox goes out of sync with list after indeterminate click --- src/css/import-resource-tree.css | 6 +- .../import-resource-tree.directive.js | 61 ++++++++----------- .../templates/import-resource-tree.html | 3 +- .../checkbox-control-resource-wrapper.js | 21 +++++++ 4 files changed, 53 insertions(+), 38 deletions(-) create mode 100644 src/js/angular/models/import/checkbox-control-resource-wrapper.js diff --git a/src/css/import-resource-tree.css b/src/css/import-resource-tree.css index b4c5ebd36..715be3139 100644 --- a/src/css/import-resource-tree.css +++ b/src/css/import-resource-tree.css @@ -100,10 +100,14 @@ .import-resource-tree .import-resources-actions .import-resource-status-dropdown { padding-left: 5px; gap: 5px; + margin-right: 10px; +} + +.import-resource-tree .import-resources-actions .import-resource-status-dropdown #importSelectCheckboxInput { + cursor: pointer; } .import-resource-tree .import-resources-actions .import-resource-status-dropdown .dropdown-toggle { - padding-left: 0.5rem; margin-right: 0; } diff --git a/src/js/angular/import/directives/import-resource-tree.directive.js b/src/js/angular/import/directives/import-resource-tree.directive.js index 061ac5c32..becf0c9dd 100644 --- a/src/js/angular/import/directives/import-resource-tree.directive.js +++ b/src/js/angular/import/directives/import-resource-tree.directive.js @@ -6,6 +6,7 @@ import {ImportResourceTreeElement} from "../../models/import/import-resource-tre import {TABS} from "../services/import-context.service"; import {ImportResourceTreeService} from "../services/import-resource-tree.service"; import {convertToBytes} from "../../utils/size-util"; +import {CheckboxControlModel} from "../../models/import/checkbox-control-resource-wrapper"; const TYPE_FILTER_OPTIONS = { 'FILE': 'FILE', @@ -64,11 +65,12 @@ function importResourceTreeDirective($timeout, ImportContextService) { // ========================= $scope.resources = new ImportResourceTreeElement(); $scope.displayResources = []; + $scope.checkboxControlModel = undefined; $scope.TYPE_FILTER_OPTIONS = TYPE_FILTER_OPTIONS; $scope.filterByType = TYPE_FILTER_OPTIONS.ALL; $scope.filterByFileName = ''; $scope.STATUS_OPTIONS = STATUS_OPTIONS; - $scope.selectedByStatus = undefined; + $scope.selectedByStatus = STATUS_OPTIONS.NONE; $scope.areAllDisplayedImportResourcesSelected = false; $scope.areAllDisplayedImportResourcesPartialSelected = false; $scope.ImportResourceStatus = ImportResourceStatus; @@ -104,7 +106,13 @@ function importResourceTreeDirective($timeout, ImportContextService) { } else if (STATUS_OPTIONS.IMPORTED === $scope.selectedByStatus) { $scope.resources.selectAllWithStatus([ImportResourceStatus.DONE]); } else if (STATUS_OPTIONS.NOT_IMPORTED === $scope.selectedByStatus) { - $scope.resources.selectAllWithStatus([ImportResourceStatus.IMPORTING, ImportResourceStatus.NONE, ImportResourceStatus.ERROR, ImportResourceStatus.PENDING, ImportResourceStatus.INTERRUPTING]); + $scope.resources.selectAllWithStatus([ + ImportResourceStatus.IMPORTING, + ImportResourceStatus.NONE, + ImportResourceStatus.ERROR, + ImportResourceStatus.PENDING, + ImportResourceStatus.INTERRUPTING + ]); } updateListedImportResources(); @@ -181,23 +189,24 @@ function importResourceTreeDirective($timeout, ImportContextService) { }; $scope.toggleSelectAll = () => { - const allSelected = $scope.displayResources.every((resource) => resource.selected); - const noneSelected = $scope.displayResources.every((resource) => !resource.selected); - const checkboxElement = document.getElementById('checkboxInput'); + const allSelected = $scope.checkboxControlModel.areAllSelected(); + const noneSelected = $scope.checkboxControlModel.areNoneSelected(); + const someSelected = $scope.checkboxControlModel.areMixedSelections(); - if (allSelected) { - toggleCheckboxes(checkboxElement, false); + if (someSelected || allSelected) { + $scope.resources.setSelection(false); + $scope.selectedByStatus = STATUS_OPTIONS.NONE; + $scope.areAllDisplayedImportResourcesSelected = false; } else if (noneSelected) { - toggleCheckboxes(checkboxElement, true); - } else { - toggleCheckboxes(checkboxElement, false); + $scope.resources.setSelection(true); + $scope.selectedByStatus = STATUS_OPTIONS.ALL; + $scope.areAllDisplayedImportResourcesSelected = true; } + $scope.areAllDisplayedImportResourcesPartialSelected = false; - updateSelectByStateDropdownModel(); - updateHasSelection(); + updateListedImportResources(); }; - // ========================= // Private functions // ========================= @@ -213,7 +222,8 @@ function importResourceTreeDirective($timeout, ImportContextService) { const updateListedImportResources = () => { $scope.resources.getRoot().updateSelectionState(); sortResources(); - $scope.displayResources = $scope.resources.toList() + $scope.checkboxControlModel = new CheckboxControlModel($scope.resources.toList()); + $scope.displayResources = $scope.checkboxControlModel.getResourcesList() .filter(filterByType) .filter(filterByName); @@ -228,27 +238,8 @@ function importResourceTreeDirective($timeout, ImportContextService) { }; const updateSelectByStateDropdownModel = () => { - const hasUnselectedDisplayedImportResource = $scope.displayResources.some((resource) => !resource.selected); - const hasSelectedDisplayedImportResource = $scope.displayResources.some((resource) => resource.selected); - $scope.areAllDisplayedImportResourcesSelected = hasSelectedDisplayedImportResource && !hasUnselectedDisplayedImportResource; - $scope.areAllDisplayedImportResourcesPartialSelected = hasSelectedDisplayedImportResource && hasUnselectedDisplayedImportResource; - - if ($scope.areAllDisplayedImportResourcesSelected) { - $scope.selectedByStatus = STATUS_OPTIONS.ALL; - } else if (!$scope.areAllDisplayedImportResourcesSelected && !$scope.areAllDisplayedImportResourcesPartialSelected) { - $scope.selectedByStatus = STATUS_OPTIONS.NONE; - } - }; - - const toggleCheckboxes = (checkboxElement, shouldSelect) => { - $scope.displayResources.forEach((resource) => resource.selected = shouldSelect); - $scope.selectedByStatus = shouldSelect ? STATUS_OPTIONS.ALL : STATUS_OPTIONS.NONE; - $scope.areAllDisplayedImportResourcesSelected = shouldSelect; - $scope.areAllDisplayedImportResourcesPartialSelected = false; - - if (checkboxElement) { - checkboxElement.checked = shouldSelect; - } + $scope.areAllDisplayedImportResourcesSelected = $scope.checkboxControlModel.areAllSelected(); + $scope.areAllDisplayedImportResourcesPartialSelected = $scope.checkboxControlModel.areMixedSelections(); }; const sortResources = () => { diff --git a/src/js/angular/import/templates/import-resource-tree.html b/src/js/angular/import/templates/import-resource-tree.html index 2a900528e..b496ca025 100644 --- a/src/js/angular/import/templates/import-resource-tree.html +++ b/src/js/angular/import/templates/import-resource-tree.html @@ -3,9 +3,8 @@
-