-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmxSwitchbox.js
44 lines (41 loc) · 3.29 KB
/
mxSwitchbox.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
/*
|------------------------------------------------------------
| directive for AngularJS to have use a simple switchbox
|------------------------------------------------------------
|
how to use :
1 - load js in your html :
<script src="js/mx/mxSwitchbox.js"></script>
2 - add the 'mx' module to your application module
<script>
(function () {
var myApplication = angular.module('MyApplication', ['mx']);
}());
</script>
3 - use it in html
// for example you want to bind to the boolean value isShiny in your controller :
myApplication.controller('MyController', [function () {
this.isShiny = true;
}]);
// you can bind with switched attribute :
<div ng-controller="MyController as myCtrl">
<div mx-switchbox switched="myCtrl.isShiny"></div>
</div>
*/
angular.module('mx', []).directive('mxSwitchbox', [function () {
return {
template : '<div style="display:inline-block;vertical-align:middle;">'+
'<input type="checkbox" autocomplete="off" ng-model="switched" style="width:44px;height:20px;opacity:0;float:left;cursor:pointer;">'+
'<div style="width:44px;height:20px;background-position: {{switched == true && \'bottom\' || \'top\'}};background-repeat:no-repeat;background-image:url();"></div>'+
'</div>',
scope: {
switched:'='
},
link : function (scope, element, attrs) {
scope.$watch('switched', function (newVal, oldVal) {
scope.switched = (scope.switched == 1) ? true : false;
scope.inputCheckbox = (newVal === undefined || newVal == false) ? false : true;
});
}
};
}]);