-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathngFormFixes.directive.js
90 lines (75 loc) · 2.45 KB
/
ngFormFixes.directive.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
'use strict';
(function() {
angular
.module('ngFormFixes', [])
.directive('ngForm', ['$parse', '$timeout', function($parse, $timeout) {
return {
link: linkFunction
};
function linkFunction($scope, $element, $attrs) {
var submitButton = findSubmitButton();
// bind Enter key
$element.bind('keydown', function(e) {
var keyCode = e.keyCode || e.which;
if (keyCode === 13) {
var nodeType = e.target.nodeName.toLowerCase();
if (nodeType === 'input') {
if ($attrs.ngSubmit) {
$parse($attrs.ngSubmit)($scope, {
$event: e
});
e.stopPropagation();
e.preventDefault();
} else if (submitButton) {
submitButton.click();
e.stopPropagation();
e.preventDefault();
}
}
}
});
// bind Submit click to run itself or ngSubmit
angular.element(submitButton).bind('click', function(e) {
if ($attrs.ngSubmit && angular.element(this).attr('ng-click') === undefined) {
$parse($attrs.ngSubmit)($scope, {
$event: e
});
e.stopPropagation();
e.preventDefault();
$timeout(function() {
if ($scope[$attrs.ngForm || $attrs.name]) {
$scope[$attrs.ngForm || $attrs.name].$submitted = true;
}
$element.addClass('ng-submitted');
});
}
});
// internal
function findSubmitButton() {
var $buttons = [$element.find('button'), $element.find('input')];
for (var i = 0; i < $buttons.length; i++) {
for (var n = 0; n < $buttons[i].length; n++) {
var $current = $buttons[i][n];
if ($current.getAttribute('type') && $current.getAttribute('type').toLowerCase() === 'submit') {
return $current;
}
}
}
}
}
}])
.directive('onEnter', ['$parse', function($parse) {
return {
link: function($scope, $element, $attrs) {
$element.bind('keyup', function(e) {
var keyCode = e.keyCode || e.which;
if (keyCode === 13 && $attrs.onEnter) {
$parse($attrs.onEnter)($scope, {
$event: e
});
}
});
}
};
}]);
})();