forked from muicss/mui
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathripple.js
More file actions
104 lines (81 loc) · 2.35 KB
/
ripple.js
File metadata and controls
104 lines (81 loc) · 2.35 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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/**
* MUI CSS/JS ripple module
* @module ripple
*/
'use strict';
var jqLite = require('./lib/jqLite'),
util = require('./lib/util'),
btnClass = 'mui-btn',
btnFABClass = 'mui-btn--fab',
rippleClass = 'mui-ripple-effect',
animationName = 'mui-btn-inserted';
/**
* Add ripple effects to button element.
* @param {Element} buttonEl - The button element.
*/
function initialize(buttonEl) {
// check flag
if (buttonEl._muiRipple === true) return;
else buttonEl._muiRipple = true;
// exit if element is INPUT (doesn't support absolute positioned children)
if (buttonEl.tagName === 'INPUT') return;
// attach event handler
jqLite.on(buttonEl, 'touchstart', eventHandler);
jqLite.on(buttonEl, 'mousedown', eventHandler);
}
/**
* Event handler
* @param {Event} ev - The DOM event
*/
function eventHandler(ev) {
// only left clicks
if (ev.button !== 0) return;
var buttonEl = this;
// exit if button is disabled
if (buttonEl.disabled === true) return;
// de-dupe touchstart and mousedown with 100msec flag
if (buttonEl.touchFlag === true) {
return;
} else {
buttonEl.touchFlag = true;
setTimeout(function() {
buttonEl.touchFlag = false;
}, 100);
}
var rippleEl = document.createElement('div');
rippleEl.className = rippleClass;
var offset = jqLite.offset(buttonEl),
xPos = ev.pageX - offset.left,
yPos = ev.pageY - offset.top,
diameter,
radius;
// get height
if (jqLite.hasClass(buttonEl, btnFABClass)) diameter = offset.height / 2;
else diameter = offset.height;
radius = diameter / 2;
jqLite.css(rippleEl, {
height: diameter + 'px',
width: diameter + 'px',
top: yPos - radius + 'px',
left: xPos - radius + 'px'
});
buttonEl.appendChild(rippleEl);
window.setTimeout(function() {
var parentNode = rippleEl.parentNode;
if (parentNode) parentNode.removeChild(rippleEl);
}, 2000);
}
/** Define module API */
module.exports = {
/** Initialize module listeners */
initListeners: function() {
var doc = document;
// markup elements available when method is called
var elList = doc.getElementsByClassName(btnClass);
for (var i=elList.length - 1; i >= 0; i--) initialize(elList[i]);
// listen for new elements
util.onNodeInserted(function(el) {
if (jqLite.hasClass(el, btnClass)) initialize(el);
});
}
};