-
Notifications
You must be signed in to change notification settings - Fork 0
/
forms.js
78 lines (77 loc) · 2.56 KB
/
forms.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
angular.module('forms', [])
.directive('rebootInput', function () {
return {
restrict: 'E',
scope: {
name: '@',
caption: '@',
placeholder: '@',
ngModel: '='
},
templateUrl: 'templ/input.html'
}
})
.directive('rebootSelect', function () {
return {
restrict: 'E',
scope: {
name: '@',
caption: '@',
placeholder: '@',
optionSource: '@',
ngModel: '='
},
controller: function ($scope, $compile, $http) {
$http.get($scope.optionSource).then(function (articlesResponse) {
$scope.options = articlesResponse.data;
});
},
templateUrl: 'templ/select.html'
}
})
.directive('rebootDialog', function () {
return {
restrict: 'E',
transclude: true,
scope: false,
// {
// title: '@',
// desc: '@',
// name: '@',
// modalShow: "="
//TODO: Trennung reinbringen, 2 Dialoge parallel sonst nicht moeglich
// },
templateUrl: 'templ/dialog.html',
link: function (scope, element, attrs) {
scope.title = attrs.title;
scope.name = attrs.title;
}
}
}).
directive("modalShow", function ($parse) {
return {
restrict: "A",
link: function (scope, element, attrs) {
//Hide or show the modal
scope.showModal = function (visible, elem) {
if (!elem)
elem = element;
if (visible)
$(elem).modal("show");
else
$(elem).modal("hide");
};
//Watch for changes to the modal-visible attribute
scope.$watch(attrs.modalShow, function (newValue, oldValue) {
scope.showModal(newValue, attrs.$$element);
});
//Update the visible value when the dialog is closed through UI actions (Ok, cancel, etc.)
$(element).bind("hide.bs.modal", function () {
$parse(attrs.modalShow).assign(scope, false);
if (!scope.$$phase && !scope.$root.$$phase)
scope.$apply();
});
}
};
})
;