diff --git a/src/tags-input.js b/src/tags-input.js index 33e3beff..f06c4ec7 100644 --- a/src/tags-input.js +++ b/src/tags-input.js @@ -229,6 +229,10 @@ tagsInput.directive('tagsInput', function($timeout, $document, $window, tagsInpu ngModelCtrl.$setValidity('leftoverText', scope.hasFocus || options.allowLeftoverText ? true : !scope.newTag.text); }; + ngModelCtrl.$isEmpty = function(value) { + return !value || !value.length; + }; + scope.newTag = { text: '', invalid: null, diff --git a/test/tags-input.spec.js b/test/tags-input.spec.js index a7440c87..fbc89fa5 100644 --- a/test/tags-input.spec.js +++ b/test/tags-input.spec.js @@ -1676,6 +1676,36 @@ describe('tags-input directive', function() { }); }); + describe('ng-required support', function() { + it('sets the required validation key when there is no tags', function() { + // Arrange/Act + compileWithForm('name="tags"', 'ng-required="true"'); + + // Assert + expect($scope.form.tags.$invalid).toBe(true); + expect($scope.form.tags.$error.required).toBe(true); + }); + + it('doesn\'t set the required validation key when there is any tags', function() { + // Arrange/Act + $scope.tags = ['Tag']; + compileWithForm('name="tags"', 'ng-required="true"'); + + // Assert + expect($scope.form.tags.$invalid).toBe(false); + expect($scope.form.tags.$error.required).toBe(false); + }); + + it('doesn\'t set the required validation key when ng-required is false', function() { + // Arrange/Act + compileWithForm('name="tags"', 'ng-required="false"'); + + // Assert + expect($scope.form.tags.$invalid).toBe(false); + expect($scope.form.tags.$error.required).toBe(false); + }); + }); + describe('autocomplete registration', function() { var autocompleteObj;