78 lines
1.9 KiB
JavaScript
78 lines
1.9 KiB
JavaScript
import deprecated from "discourse-common/lib/deprecated";
|
|
import ENV from "discourse-common/config/environment";
|
|
|
|
let mobileForced = false;
|
|
|
|
// An object that is responsible for logic related to mobile devices.
|
|
const Mobile = {
|
|
isMobileDevice: false,
|
|
mobileView: false,
|
|
|
|
init() {
|
|
const $html = $("html");
|
|
this.isMobileDevice = mobileForced || $html.hasClass("mobile-device");
|
|
this.mobileView = mobileForced || $html.hasClass("mobile-view");
|
|
|
|
if (ENV.environment === "test" || mobileForced) {
|
|
return;
|
|
}
|
|
|
|
try {
|
|
if (window.location.search.match(/mobile_view=1/)) {
|
|
localStorage.mobileView = true;
|
|
}
|
|
if (window.location.search.match(/mobile_view=0/)) {
|
|
localStorage.mobileView = false;
|
|
}
|
|
if (window.location.search.match(/mobile_view=auto/)) {
|
|
localStorage.removeItem("mobileView");
|
|
}
|
|
if (localStorage.mobileView) {
|
|
var savedValue = localStorage.mobileView === "true";
|
|
if (savedValue !== this.mobileView) {
|
|
this.reloadPage(savedValue);
|
|
}
|
|
}
|
|
} catch (err) {
|
|
// localStorage may be disabled, just skip this
|
|
// you get security errors if it is disabled
|
|
}
|
|
},
|
|
|
|
toggleMobileView() {
|
|
try {
|
|
if (localStorage) {
|
|
localStorage.mobileView = !this.mobileView;
|
|
}
|
|
} catch (err) {
|
|
// localStorage may be disabled, skip
|
|
}
|
|
this.reloadPage(!this.mobileView);
|
|
},
|
|
|
|
reloadPage(mobile) {
|
|
window.location.assign(
|
|
window.location.pathname + "?mobile_view=" + (mobile ? "1" : "0")
|
|
);
|
|
}
|
|
};
|
|
|
|
export function forceMobile() {
|
|
mobileForced = true;
|
|
}
|
|
|
|
export function resetMobile() {
|
|
mobileForced = false;
|
|
}
|
|
|
|
Object.defineProperty(Discourse, "Mobile", {
|
|
get() {
|
|
deprecated(
|
|
"`Discourse.Mobile` is deprecated, use `this.site.mobileView` instead"
|
|
);
|
|
return Mobile;
|
|
}
|
|
});
|
|
|
|
export default Mobile;
|