From 67e04cb1b3c00b5962ec8f4ecc4769d6d19288a2 Mon Sep 17 00:00:00 2001 From: Galen Charlton Date: Thu, 28 Jan 2016 12:44:37 -0500 Subject: [PATCH] webstaff: fix selection of stat cats in copy editor and templates Signed-off-by: Galen Charlton Signed-off-by: Kathy Lussier --- .../web/js/ui/default/staff/cat/volcopy/app.js | 30 ++++++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) diff --git a/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js b/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js index 94d3079aab..f52e88be96 100644 --- a/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js +++ b/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js @@ -750,6 +750,13 @@ function($scope , $q , $window , $routeParams , $location , $timeout , egCore , $scope.batch.prefix = $scope.defaults.prefix; $scope.batch.suffix = $scope.defaults.suffix; $scope.working.statcat_filter = $scope.defaults.statcat_filter; + if (typeof $scope.defaults.statcat_filter == 'object') { + // want fieldmapper object here... + $scope.defaults.statcat_filter = + egCore.idl.Clone($scope.defaults.statcat_filter); + // ... and ID here + $scope.working.statcat_filter = $scope.defaults.statcat_filter.id(); + } if ($scope.defaults.always_volumes) $scope.show_vols = true; if ($scope.defaults.barcode_checkdigit) itemSvc.barcode_checkdigit = true; if ($scope.defaults.auto_gen_barcode) itemSvc.auto_gen_barcode = true; @@ -758,6 +765,9 @@ function($scope , $q , $window , $routeParams , $location , $timeout , egCore , } $scope.fetchDefaults(); + $scope.$watch('defaults.statcat_filter', function() { + $scope.saveDefaults(); + }); $scope.$watch('defaults.auto_gen_barcode', function (n,o) { itemSvc.auto_gen_barcode = n }); @@ -1314,8 +1324,8 @@ function($scope , $q , $window , $routeParams , $location , $timeout , egCore , $scope.statcat_visible = function (sc_owner) { var visible = typeof $scope.working.statcat_filter === 'undefined' || !$scope.working.statcat_filter; - angular.forEach(egCore.org.ancestors(sc_owner), function (anscestor_org) { - if ($scope.working.statcat_filter == anscestor_org.id()) + angular.forEach(egCore.org.ancestors(sc_owner), function (ancestor_org) { + if ($scope.working.statcat_filter == ancestor_org.id()) visible = true; }); return visible; @@ -1548,6 +1558,13 @@ function($scope , $q , $window , $routeParams , $location , $timeout , egCore , if (t) { $scope.defaults = t; $scope.working.statcat_filter = $scope.defaults.statcat_filter; + if (typeof $scope.defaults.statcat_filter == 'object') { + // want fieldmapper object here... + $scope.defaults.statcat_filter = + egCore.idl.Clone($scope.defaults.statcat_filter); + // ... and ID here + $scope.working.statcat_filter = $scope.defaults.statcat_filter.id(); + } } }); } @@ -1685,6 +1702,15 @@ function($scope , $q , $window , $routeParams , $location , $timeout , egCore , statcat_filter: undefined }; + $scope.statcat_visible = function (sc_owner) { + var visible = typeof $scope.working.statcat_filter === 'undefined' || !$scope.working.statcat_filter; + angular.forEach(egCore.org.ancestors(sc_owner), function (ancestor_org) { + if ($scope.working.statcat_filter == ancestor_org.id()) + visible = true; + }); + return visible; + } + createStatcatUpdateWatcher = function (id) { return $scope.$watch('working.statcats[' + id + ']', function () { if ($scope.working.statcats) { -- 2.11.0