2021-02-28 00:35:35 +01:00
|
|
|
import * as common from "../common";
|
|
|
|
|
2019-01-14 20:26:32 +01:00
|
|
|
export function detect_user_os() {
|
2020-10-07 12:37:15 +02:00
|
|
|
if (/android/i.test(navigator.userAgent)) {
|
2018-09-15 21:09:35 +02:00
|
|
|
return "android";
|
|
|
|
}
|
2020-10-07 12:37:15 +02:00
|
|
|
if (/iphone|ipad|ipod/i.test(navigator.userAgent)) {
|
2018-09-15 21:09:35 +02:00
|
|
|
return "ios";
|
|
|
|
}
|
2019-06-10 09:09:04 +02:00
|
|
|
if (common.has_mac_keyboard()) {
|
2018-09-15 21:09:35 +02:00
|
|
|
return "mac";
|
|
|
|
}
|
2020-10-07 12:37:15 +02:00
|
|
|
if (/win/i.test(navigator.userAgent)) {
|
2018-09-15 21:09:35 +02:00
|
|
|
return "windows";
|
|
|
|
}
|
2020-10-07 12:37:15 +02:00
|
|
|
if (/linux/i.test(navigator.userAgent)) {
|
2018-09-15 21:09:35 +02:00
|
|
|
return "linux";
|
|
|
|
}
|
|
|
|
return "mac"; // if unable to determine OS return Mac by default
|
|
|
|
}
|
|
|
|
|
2019-01-14 20:26:32 +01:00
|
|
|
export function activate_correct_tab($codeSection) {
|
2019-11-02 00:06:25 +01:00
|
|
|
const user_os = detect_user_os();
|
2020-10-07 10:45:28 +02:00
|
|
|
const desktop_os = new Set(["mac", "linux", "windows"]);
|
2018-09-15 21:09:35 +02:00
|
|
|
const $li = $codeSection.find("ul.nav li");
|
|
|
|
const $blocks = $codeSection.find(".blocks div");
|
|
|
|
|
|
|
|
$li.each(function () {
|
|
|
|
const language = this.dataset.language;
|
|
|
|
$(this).removeClass("active");
|
|
|
|
if (language === user_os) {
|
|
|
|
$(this).addClass("active");
|
|
|
|
}
|
|
|
|
|
2020-10-07 10:45:28 +02:00
|
|
|
if (desktop_os.has(user_os) && language === "desktop-web") {
|
2018-09-15 21:09:35 +02:00
|
|
|
$(this).addClass("active");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$blocks.each(function () {
|
|
|
|
const language = this.dataset.language;
|
|
|
|
$(this).removeClass("active");
|
|
|
|
if (language === user_os) {
|
|
|
|
$(this).addClass("active");
|
|
|
|
}
|
|
|
|
|
2020-10-07 10:45:28 +02:00
|
|
|
if (desktop_os.has(user_os) && language === "desktop-web") {
|
2018-09-15 21:09:35 +02:00
|
|
|
$(this).addClass("active");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// if no tab was activated, just activate the first one
|
2019-11-02 00:06:25 +01:00
|
|
|
const active_list_items = $li.filter(".active");
|
2018-09-15 21:09:35 +02:00
|
|
|
if (!active_list_items.length) {
|
|
|
|
$li.first().addClass("active");
|
2019-11-02 00:06:25 +01:00
|
|
|
const language = $li.first()[0].dataset.language;
|
2018-09-15 21:09:35 +02:00
|
|
|
$blocks.filter("[data-language=" + language + "]").addClass("active");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$(".code-section").each(function () {
|
|
|
|
activate_correct_tab($(this));
|
|
|
|
});
|