forked from marcelomazza/caniuse-chrome-extension
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpopup.js
113 lines (84 loc) · 2.47 KB
/
popup.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
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
105
106
107
108
109
110
111
112
113
var canIUse = (function () {
var my = {};
var features,
featureTitles = {},
browserList = [],
disabledBrowsers = {
"and_chr": true,
"and_ff": true,
"and_uc": true,
"opera": true,
"op_mob": true,
"ie_mob": true,
"bb": true,
"samsung": true,
},
mostUsedPercentage = 0.4;
$.getJSON('features.json', function(data) {
features = data;
autocomplete(features.data);
});
function autocomplete(data) {
$('#autocomplete').autocomplete({
source: $.map(data, function(value, key) {
return {
label: value.title,
value: key
}
}),
delay: 0,
minLength: 0,
autoFocus: true,
select: function(e, ui) {
e.preventDefault();
$('#autocomplete').val(ui.item.label);
listBrowsers(ui.item.value);
}
});
};
function listBrowsers(feature) {
var featureInfo = features.data[feature];
$('#browserSupport').empty();
$('.js-toggle').hide();
$.each(featureInfo.stats, function(browser, versions) {
if (disabledBrowsers[browser]) {
return;
}
browserList.push('<li class="browser-icon ' + browser + '" title="' + browser + '">' + browser + '</li>');
listVersions(browser, versions);
var list = $('<ul/>', {
class: 'browser-list',
html: browserList.join('')
});
list.appendTo('#browserSupport', document);
browserList = [];
$('#moreInfo').attr('href', 'http://caniuse.com/#feat=' + feature).text('"' + featureInfo.title + '" on caniuse.com');
$('.js-toggle').fadeIn();
});
};
function listVersions(browser, versions) {
var isMostUsed, support;
for (var version in versions) {
isMostUsed = features.agents[browser].usage_global[version] > mostUsedPercentage;
support = versions[version];
if (isMostUsed) {
browserList.push('<li class="' + support + '">' + version + '</li>');
}
}
};
my.features = function() {
return features;
};
return my;
})();
$('#aboutIcon').on('click', function() {
$('#about').slideToggle();
});
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-35317319-1']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = 'https://ssl.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
})();