1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 | 'use strict';
|
12 |
|
13 | var ExecutionEnvironment = require('fbjs/lib/ExecutionEnvironment');
|
14 |
|
15 |
|
16 |
|
17 |
|
18 |
|
19 |
|
20 |
|
21 |
|
22 | function makePrefixMap(styleProp, eventName) {
|
23 | var prefixes = {};
|
24 |
|
25 | prefixes[styleProp.toLowerCase()] = eventName.toLowerCase();
|
26 | prefixes['Webkit' + styleProp] = 'webkit' + eventName;
|
27 | prefixes['Moz' + styleProp] = 'moz' + eventName;
|
28 | prefixes['ms' + styleProp] = 'MS' + eventName;
|
29 | prefixes['O' + styleProp] = 'o' + eventName.toLowerCase();
|
30 |
|
31 | return prefixes;
|
32 | }
|
33 |
|
34 |
|
35 |
|
36 |
|
37 | var vendorPrefixes = {
|
38 | animationend: makePrefixMap('Animation', 'AnimationEnd'),
|
39 | animationiteration: makePrefixMap('Animation', 'AnimationIteration'),
|
40 | animationstart: makePrefixMap('Animation', 'AnimationStart'),
|
41 | transitionend: makePrefixMap('Transition', 'TransitionEnd')
|
42 | };
|
43 |
|
44 |
|
45 |
|
46 |
|
47 | var prefixedEventNames = {};
|
48 |
|
49 |
|
50 |
|
51 |
|
52 | var style = {};
|
53 |
|
54 |
|
55 |
|
56 |
|
57 | if (ExecutionEnvironment.canUseDOM) {
|
58 | style = document.createElement('div').style;
|
59 |
|
60 |
|
61 |
|
62 |
|
63 |
|
64 | if (!('AnimationEvent' in window)) {
|
65 | delete vendorPrefixes.animationend.animation;
|
66 | delete vendorPrefixes.animationiteration.animation;
|
67 | delete vendorPrefixes.animationstart.animation;
|
68 | }
|
69 |
|
70 |
|
71 | if (!('TransitionEvent' in window)) {
|
72 | delete vendorPrefixes.transitionend.transition;
|
73 | }
|
74 | }
|
75 |
|
76 |
|
77 |
|
78 |
|
79 |
|
80 |
|
81 |
|
82 | function getVendorPrefixedEventName(eventName) {
|
83 | if (prefixedEventNames[eventName]) {
|
84 | return prefixedEventNames[eventName];
|
85 | } else if (!vendorPrefixes[eventName]) {
|
86 | return eventName;
|
87 | }
|
88 |
|
89 | var prefixMap = vendorPrefixes[eventName];
|
90 |
|
91 | for (var styleProp in prefixMap) {
|
92 | if (prefixMap.hasOwnProperty(styleProp) && styleProp in style) {
|
93 | return prefixedEventNames[eventName] = prefixMap[styleProp];
|
94 | }
|
95 | }
|
96 |
|
97 | return '';
|
98 | }
|
99 |
|
100 | module.exports = getVendorPrefixedEventName; |
\ | No newline at end of file |