///
///
module Elements {
export var animationTime = 1000;
export var isMobile = /Mobi/i.test(navigator.userAgent); // This correctly lets Mobile users who requested the Desktop app or are on a sufficiently big tablet to get the right desktop version
export var screenWidth = document.body.clientWidth;
export var screenHeight = document.body.clientHeight;
export function getLinkElements (image? : boolean) {
if (CurrentTurnHandler == undefined) return [];
if (CurrentTurnHandler.isTurn() || image) {
return [CurrentTurnHandler.currentTurnTab];
} else {
return [HyperlinkHandler.linkedActionsTab, RoomHandler.currentRoomTab, HyperlinkHandler.commonActionsTab, CurrentTurnHandler.currentTurnTab, RoomHandler.currentRoomExits];
}
}
export function updateScreenSize () {
screenWidth = document.body.clientWidth;
screenHeight = document.body.clientHeight;
}
export var mainPage = document.getElementById("mainPage");
/**
* Adds the blur effect to the screen
*/
export function startTurn () {
mainPage.classList.add("turn");
}
/**
* Remove the blur effect from the screen
*/
export function endTurn () {
mainPage.classList.remove("turn");
}
/**
* Are we currently in a turn?
* @returns {boolean}
*/
export function isInTurn () {
return mainPage.classList.contains("turn");
}
let menuOutsideofTurn = false;
let menus = 0;
export function startMenu () {
if (!isInTurn()) {
menuOutsideofTurn = true;
startTurn();
}
mainPage.classList.add("mainmenu");
menus++;
Elements.CurrentTurnHandler.clear();
Controls.KeyHandler.reset();
}
export function endMenu () {
Elements.CurrentTurnHandler.clear();
if (--menus == 0) {
if (menuOutsideofTurn) {
endTurn();
}
resetMenus();
}
}
export function resetMenus () {
if (menus != 0) {
console.error("A menu wasn't finished properly. Please correct the dialogue.");
}
menus = 0;
menuOutsideofTurn = false;
mainPage.classList.remove("mainmenu");
}
export function clearMainScreen () {
Elements.CurrentTurnHandler.clear();
}
let loadingScreen = document.getElementById("loadingScreen");
export function stopLoading () {
document.body.removeChild(loadingScreen);
}
export async function waitForAnyKey () {
let say = new Say(Say.CENTERED, new SayBold("Press any key to continue."));
let elements = await say.getHTML("p", ["content"]);
Elements.CurrentTurnHandler.print(...elements);
await Controls.KeyHandler.getNextKey();
Elements.CurrentTurnHandler.unprint(...elements);
}
export async function waitForSpaceKey () {
let say = new Say(Say.CENTERED, new SayBold("Press Space to continue."));
let elements = await say.getHTML("p", ["content"]);
Elements.CurrentTurnHandler.print(...elements);
let lastKey = "notSpace";
while (lastKey != "Space" && lastKey != "Click") {
lastKey = (await Controls.KeyHandler.getNextKey()).evCode;
}
Elements.CurrentTurnHandler.unprint(...elements);
}
export function printObeliskLogo () {
let say = new Say(Say.CENTERED, new SayImage("introLogo"), Say.LINE_BREAK, new SayItalic("The Obelisk is a pornographic interactive fiction game set in a post-apocalyptic world ravaged by a magical structure."));
Elements.CurrentTurnHandler.printAsContent(say);
}
export function getStyle (name : string) {
try {
for (var i = 0; i < document.styleSheets.length; i++) {
var rules = document.styleSheets[i]['rules'] || document.styleSheets[i]['cssRules'];
for (var x in rules) {
if (typeof rules[x].selectorText == 'string' && rules[x].selectorText == name) {
return rules[x].style;
}
}
}
} catch (e) {
console.warn("Can't read CSS styles", e);
return {};
}
}
}
if (Elements.isMobile) {
Elements.mainPage.classList.add("mobile");
}
window.addEventListener("resize", function () {
Elements.updateScreenSize();
});
module MachineBegins {
export let HideLoadingDivRule = MachineBegins.rulebook.createAndAddRule({
name : "Hide loading div",
code : runner => {
Elements.stopLoading();
}
});
}
module TurnSequence {
export let LazilyFixMenus = TurnSequence.rulebook.createAndAddRule({
name : "Fix menus that were never closed because the dev is stupid",
firstPriority : Rule.PRIORITY_LOWEST,
priority : Rule.PRIORITY_LOWEST,
code : () => {
Elements.resetMenus();
}
})
}