Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: static/js/index.js

Issue 29727563: Fixes #35 - Progressively enhance install button with appropriate links and text (Closed) Base URL: https://hg.adblockplus.org/web.adblockplus.org
Patch Set: Addressed comments #7 Created April 5, 2018, 2:31 p.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: static/js/index.js
===================================================================
new file mode 100644
--- /dev/null
+++ b/static/js/index.js
@@ -0,0 +1,75 @@
+"use strict";
+
+(function()
+{
+ var supportedPlatforms = {
+
+ // Desktop browsers
+ "chrome": {
+ installer: "https://chrome.google.com/webstore/detail/cfhdojbkjhnklbpkdaibdccddilifddb",
+ label: "Chrome"
juliandoucette 2018/04/06 12:35:23 Are these labels still being used?
ire 2018/04/06 13:21:49 Good catch, forgot about that! Removed.
+ },
+ "opera": {
+ installer: "https://addons.opera.com/extensions/details/opera-adblock/?display=en-US",
+ label: "Opera"
+ },
+ "yandexbrowser": {
+ installer: "https://chrome.google.com/webstore/detail/cfhdojbkjhnklbpkdaibdccddilifddb",
+ label: "Yandex Browser"
+ },
+ "msie": {
+ installer: "https://update.adblockplus.org/latest/adblockplusie.exe",
+ label: "Internet Explorer"
+ },
+ "msedge": {
+ installer: "https://www.microsoft.com/store/p/adblock-plus/9nblggh4r9nz",
+ label: "Micrsoft Edge"
+ },
+ "firefox": {
+ installer: "https://update.adblockplus.org/latest/adblockplusfirefox.xpi",
+ label: "Firefox"
+ },
+ "safari": {
+ installer: "https://update.adblockplus.org/latest/adblockplussafari.safariextz",
+ label: "Safari"
+ },
+ "maxthon": "",
+
+ // Mobile platforms
+ "ios": {
+ installer: "https://eyeo.to/adblockbrowser/ios/abp-website",
+ label: "iOS",
+ },
+ "android": {
+ installer: "https://eyeo.to/adblockbrowser/android/abp-website",
+ label: "Android"
+ }
+ };
+
+ function setupHeroDownloadButton()
+ {
+ var detectedPlatform = Object.keys(supportedPlatforms).find(hasOwnProperty.bind(bowser));
juliandoucette 2018/04/06 12:35:23 NIT: Line is too long?
ire 2018/04/06 13:21:49 Done.
+
+ if (!detectedPlatform) return;
+
+ document.body.classList.add(detectedPlatform);
+
+ if (detectedPlatform === "maxthon") return;
juliandoucette 2018/04/06 12:35:23 NIT: Code style says we should use == :(
ire 2018/04/06 13:21:49 I can't seem to find where it says that? (Done an
juliandoucette 2018/04/06 16:29:16 It's kindof obscure: ABP Coding style > General >
ire 2018/04/09 09:24:01 Acknowledged.
+
+ var heroDownloadButton = document.getElementById("hero-download-button");
+ heroDownloadButton.href = supportedPlatforms[detectedPlatform].installer;
+ heroDownloadButton.innerHTML = document
+ .getElementById("hero-download-button-template")
+ .innerHTML;
+
+ heroDownloadButton.addEventListener("click", function(event)
+ {
+ if (!chrome) return;
juliandoucette 2018/04/06 12:35:23 It's possible for chrome to exist without webstore
ire 2018/04/06 13:21:49 Agreed.
+ event.preventDefault();
+ chrome.webstore.install();
+ });
+ }
+
+ if (bowser) setupHeroDownloadButton();
+
+}());
« globals/browsers.py ('K') | « static/css/index.css ('k') | static/js/vendor/bowser.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld