diff --git a/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.controller.js b/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.controller.js index 7c8c1e64fbd7..1269a4c28b6d 100644 --- a/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.controller.js +++ b/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.controller.js @@ -44,14 +44,15 @@ function contentPickerController($scope, $q, $routeParams, $location, entityReso function validate() { if ($scope.contentPickerForm) { //Validate! - if ($scope.model.config && $scope.model.config.minNumber && parseInt($scope.model.config.minNumber) > $scope.renderModel.length) { + var hasItemsOrMandatory = $scope.renderModel.length !== 0 || ($scope.model.validation && $scope.model.validation.mandatory); + if (hasItemsOrMandatory && $scope.minNumberOfItems > $scope.renderModel.length) { $scope.contentPickerForm.minCount.$setValidity("minCount", false); } else { $scope.contentPickerForm.minCount.$setValidity("minCount", true); } - if ($scope.model.config && $scope.model.config.maxNumber && parseInt($scope.model.config.maxNumber) < $scope.renderModel.length) { + if ($scope.maxNumberOfItems < $scope.renderModel.length) { $scope.contentPickerForm.maxCount.$setValidity("maxCount", false); } else { @@ -145,6 +146,10 @@ function contentPickerController($scope, $q, $routeParams, $location, entityReso $scope.umbProperty.setPropertyActions(propertyActions); } + + // use these to avoid the nested property lookups/null-checks + $scope.minNumberOfItems = $scope.model.config.minNumber ? parseInt($scope.model.config.minNumber) : 0; + $scope.maxNumberOfItems = $scope.model.config.maxNumber ? parseInt($scope.model.config.maxNumber) : 0; } //Umbraco persists boolean for prevalues as "0" or "1" so we need to convert that! @@ -194,7 +199,7 @@ function contentPickerController($scope, $q, $routeParams, $location, entityReso dialogOptions.dataTypeKey = $scope.model.dataTypeKey; // if we can't pick more than one item, explicitly disable multiPicker in the dialog options - if ($scope.model.config.maxNumber && parseInt($scope.model.config.maxNumber) === 1) { + if ($scope.maxNumberOfItems === 1) { dialogOptions.multiPicker = false; } diff --git a/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.html b/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.html index 8ebbaae91f83..e93637c67142 100644 --- a/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.html +++ b/src/Umbraco.Web.UI.Client/src/views/propertyeditors/contentpicker/contentpicker.html @@ -19,7 +19,7 @@ - -
+
- - Add between {{model.config.minNumber}} and {{model.config.maxNumber}} items - - You can only have {{model.config.maxNumber}} items selected + + Add between {{minNumberOfItems}} and {{maxNumberOfItems}} items + + You can only have {{maxNumberOfItems}} items selected - - Add {{model.config.minNumber - renderModel.length}} item(s) - - You can only have {{model.config.maxNumber}} items selected + + Add {{minNumberOfItems - renderModel.length}} item(s) + + You can only have {{maxNumberOfItems}} items selected - - Add up to {{model.config.maxNumber}} items - - You can only have {{model.config.maxNumber}} items selected + + Add up to {{maxNumberOfItems}} items + + You can only have {{maxNumberOfItems}} items selected - - Add at least {{model.config.minNumber}} item(s) + + Add at least {{minNumberOfItems}} item(s)
@@ -70,12 +70,12 @@
- You need to add at least {{model.config.minNumber}} items + You need to add at least {{minNumberOfItems}} items
- You can only have {{model.config.maxNumber}} items selected + You can only have {{maxNumberOfItems}} items selected