forked from muicss/mui
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbutton.js
More file actions
88 lines (75 loc) · 2.61 KB
/
button.js
File metadata and controls
88 lines (75 loc) · 2.61 KB
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
var jqLite = require('../js/lib/jqLite');
module.exports = angular.module('mui.button', [])
.directive('muiButton', function() {
return {
restrict: 'AE',
scope: {},
replace: true,
template: '<button class="mui-btn" ripple ng-transclude></button>',
transclude: true,
link: function(scope, element, attrs) {
var btnClass = 'mui-btn',
styles = {
variant: 1, //['default', 'flat', 'raised', 'fab']
color: 1, //['default', 'primary', 'danger', 'dark','accent']
size: 1 //['default', 'small', 'large']
};
scope.type = scope.type || 'button';
//如果仅存在disabled 属性而没有 ngDisabled 设置ngDisabled = true
if (!angular.isUndefined(attrs.disabled) && angular.isUndefined(attrs.ngDisabled)) {
element.prop('disabled', true);
}
//change btn-style by attrs
var _renderBtn = function() {
element.removeAttr('class').addClass(btnClass);
angular.forEach(styles, function(value, style) {
element.addClass(attrs[style] ? 'mui-btn--' + attrs[style] : '');
});
};
//observe each attr and rerender button
angular.forEach(styles, function(value, style) {
attrs.$observe(style, function() {
_renderBtn();
});
});
}
};
})
.directive('ripple', function($timeout) {
return {
restrict: 'A',
link: function(scope, element, attrs) {
var rippleClass = 'mui-ripple-effect';
/**
* onmousedown ripple effect
* @param {event} mousedown event
*/
element.on('mousedown', function(event) {
if (element.prop('disabled')) return;
var offset = jqLite.offset(element[0]),
xPos = event.pageX - offset.left,
yPos = event.pageY - offset.top,
diameter,
radius;
diameter = offset.height;
if (element.hasClass('mui-btn--fab')) diameter = offset.height / 2;
radius = diameter / 2;
// ripple Dom position
var rippleStyle = {
height: diameter + 'px',
width: diameter + 'px',
top: (yPos - radius) + 'px',
left: (xPos - radius) + 'px'
};
var ripple = angular.element('<div></div>').addClass(rippleClass);
for (var style in rippleStyle) {
ripple.css(style, rippleStyle[style]);
}
element.append(ripple);
$timeout(function() {
ripple.remove();
}, 2000);
});
}
};
});