You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
devdocs/assets/javascripts/views/layout/mobile.js

212 lines
5.7 KiB

// TODO: This file was created by bulk-decaffeinate.
// Sanity-check the conversion and remove this comment.
/*
* decaffeinate suggestions:
* DS002: Fix invalid constructor
* DS102: Remove unnecessary code created because of implicit returns
* DS206: Consider reworking classes to avoid initClass
* DS207: Consider shorter variations of null checks
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/main/docs/suggestions.md
*/
const Cls = (app.views.Mobile = class Mobile extends app.View {
static initClass() {
1 year ago
this.className = "_mobile";
this.elements = {
1 year ago
body: "body",
content: "._container",
sidebar: "._sidebar",
docPicker: "._settings ._sidebar",
};
1 year ago
this.shortcuts = { escape: "onEscape" };
this.routes = { after: "afterRoute" };
}
static detect() {
1 year ago
if (Cookies.get("override-mobile-detect") != null) {
return JSON.parse(Cookies.get("override-mobile-detect"));
}
try {
1 year ago
return (
window.matchMedia("(max-width: 480px)").matches ||
window.matchMedia("(max-width: 767px)").matches ||
window.matchMedia("(max-height: 767px) and (max-width: 1024px)")
.matches ||
// Need to sniff the user agent because some Android and Windows Phone devices don't take
// resolution (dpi) into account when reporting device width/height.
(navigator.userAgent.indexOf("Android") !== -1 &&
navigator.userAgent.indexOf("Mobile") !== -1) ||
navigator.userAgent.indexOf("IEMobile") !== -1
);
} catch (error) {
return false;
}
}
static detectAndroidWebview() {
try {
return /(Android).*( Version\/.\.. ).*(Chrome)/.test(navigator.userAgent);
} catch (error) {
return false;
}
}
constructor() {
this.showSidebar = this.showSidebar.bind(this);
this.hideSidebar = this.hideSidebar.bind(this);
this.onClickBack = this.onClickBack.bind(this);
this.onClickForward = this.onClickForward.bind(this);
this.onClickToggleSidebar = this.onClickToggleSidebar.bind(this);
this.onClickDocPickerTab = this.onClickDocPickerTab.bind(this);
this.onClickSettingsTab = this.onClickSettingsTab.bind(this);
this.onTapSearch = this.onTapSearch.bind(this);
this.onEscape = this.onEscape.bind(this);
this.afterRoute = this.afterRoute.bind(this);
this.el = document.documentElement;
super(...arguments);
}
init() {
1 year ago
$.on($("._search"), "touchend", this.onTapSearch);
1 year ago
this.toggleSidebar = $("button[data-toggle-sidebar]");
this.toggleSidebar.removeAttribute("hidden");
$.on(this.toggleSidebar, "click", this.onClickToggleSidebar);
1 year ago
this.back = $("button[data-back]");
this.back.removeAttribute("hidden");
$.on(this.back, "click", this.onClickBack);
1 year ago
this.forward = $("button[data-forward]");
this.forward.removeAttribute("hidden");
$.on(this.forward, "click", this.onClickForward);
this.docPickerTab = $('button[data-tab="doc-picker"]');
1 year ago
this.docPickerTab.removeAttribute("hidden");
$.on(this.docPickerTab, "click", this.onClickDocPickerTab);
this.settingsTab = $('button[data-tab="settings"]');
1 year ago
this.settingsTab.removeAttribute("hidden");
$.on(this.settingsTab, "click", this.onClickSettingsTab);
1 year ago
app.document.sidebar.search.on("searching", this.showSidebar);
this.activate();
}
showSidebar() {
let selection;
if (this.isSidebarShown()) {
window.scrollTo(0, 0);
return;
}
this.contentTop = window.scrollY;
1 year ago
this.content.style.display = "none";
this.sidebar.style.display = "block";
if ((selection = this.findByClass(app.views.ListSelect.activeClass))) {
const scrollContainer =
window.scrollY === this.body.scrollTop
? this.body
: document.documentElement;
$.scrollTo(selection, scrollContainer, "center");
} else {
1 year ago
window.scrollTo(
0,
(this.findByClass(app.views.ListFold.activeClass) && this.sidebarTop) ||
0,
);
}
}
hideSidebar() {
1 year ago
if (!this.isSidebarShown()) {
return;
}
this.sidebarTop = window.scrollY;
1 year ago
this.sidebar.style.display = "none";
this.content.style.display = "block";
window.scrollTo(0, this.contentTop || 0);
}
isSidebarShown() {
1 year ago
return this.sidebar.style.display !== "none";
}
onClickBack() {
return history.back();
}
onClickForward() {
return history.forward();
}
onClickToggleSidebar() {
1 year ago
if (this.isSidebarShown()) {
this.hideSidebar();
} else {
this.showSidebar();
}
}
onClickDocPickerTab(event) {
$.stopEvent(event);
this.showDocPicker();
}
onClickSettingsTab(event) {
$.stopEvent(event);
this.showSettings();
}
showDocPicker() {
window.scrollTo(0, 0);
1 year ago
this.docPickerTab.classList.add("active");
this.settingsTab.classList.remove("active");
this.docPicker.style.display = "block";
this.content.style.display = "none";
}
showSettings() {
window.scrollTo(0, 0);
1 year ago
this.docPickerTab.classList.remove("active");
this.settingsTab.classList.add("active");
this.docPicker.style.display = "none";
this.content.style.display = "block";
}
onTapSearch() {
return window.scrollTo(0, 0);
}
onEscape() {
return this.hideSidebar();
}
afterRoute(route) {
this.hideSidebar();
1 year ago
if (route === "settings") {
this.showDocPicker();
} else {
1 year ago
this.content.style.display = "block";
}
if (page.canGoBack()) {
1 year ago
this.back.removeAttribute("disabled");
} else {
1 year ago
this.back.setAttribute("disabled", "disabled");
}
if (page.canGoForward()) {
1 year ago
this.forward.removeAttribute("disabled");
} else {
1 year ago
this.forward.setAttribute("disabled", "disabled");
}
}
});
Cls.initClass();