improve the visual of the cowebsite

This commit is contained in:
kharhamel 2021-03-17 11:52:41 +01:00
parent 3f6c61633a
commit 272be3eba0
4 changed files with 73 additions and 38 deletions

View File

@ -66,6 +66,11 @@
</div> </div>
</div> </div>
<div id="cowebsite" class="cowebsite hidden"> <div id="cowebsite" class="cowebsite hidden">
<aside id="cowebsite-aside">
<img src="/static/images/menu.svg" alt="hold to resize"/>
</aside>
<main id="cowebsite-main">
</main>
<button class="close-btn" id="cowebsite-close"> <button class="close-btn" id="cowebsite-close">
<img src="resources/logos/close.svg"/> <img src="resources/logos/close.svg"/>
</button> </button>

View File

@ -330,10 +330,7 @@ body {
top: 0; top: 0;
width: 50%; width: 50%;
height: 100vh; height: 100vh;
cursor: ew-resize; display: flex;
}
#cowebsite iframe {
margin-left: 30px;
} }
#cowebsite.loading { #cowebsite.loading {
transform: translateX(90%); transform: translateX(90%);
@ -342,6 +339,25 @@ body {
transform: translateX(100%); transform: translateX(100%);
} }
#cowebsite main {
width: 100%;
}
#cowebsite aside {
width: 30px;
background: gray;
align-items: center;
display: flex;
cursor: ew-resize;
}
#cowebsite aside img {
cursor: ew-resize;
margin: 3px;
transform: rotate(90deg);
pointer-events: none;
}
#cowebsite .close-btn{ #cowebsite .close-btn{
position: absolute; position: absolute;
top: 10px; top: 10px;
@ -415,7 +431,7 @@ body {
background-color: gray; background-color: gray;
} }
#cowebsite > iframe { #cowebsite main iframe {
width: 100%; width: 100%;
height: 100%; height: 100%;
} }

View File

@ -1,6 +1,5 @@
import {HtmlUtils} from "./HtmlUtils"; import {HtmlUtils} from "./HtmlUtils";
import {Subject} from "rxjs";
export type CoWebsiteStateChangedCallback = () => void;
enum iframeStates { enum iframeStates {
closed = 1, closed = 1,
@ -8,14 +7,18 @@ enum iframeStates {
opened, opened,
} }
const cowebsiteDivId = "cowebsite"; // the id of the parent div of the iframe. const cowebsiteDivId = 'cowebsite'; // the id of the whole container.
const cowebsiteMainDomId = 'cowebsite-main'; // the id of the parent div of the iframe.
const cowebsiteAsideDomId = 'cowebsite-aside'; // the id of the parent div of the iframe.
const cowebsiteCloseButtonId = 'cowebsite-close';
const animationTime = 500; //time used by the css transitions, in ms. const animationTime = 500; //time used by the css transitions, in ms.
class CoWebsiteManager { class CoWebsiteManager {
private opened: iframeStates = iframeStates.closed; private opened: iframeStates = iframeStates.closed;
private observers = new Array<CoWebsiteStateChangedCallback>(); private _onStateChange: Subject<void> = new Subject();
public onStateChange = this._onStateChange.asObservable();
/** /**
* Quickly going in and out of an iframe trigger can create conflicts between the iframe states. * Quickly going in and out of an iframe trigger can create conflicts between the iframe states.
* So we use this promise to queue up every cowebsite state transition * So we use this promise to queue up every cowebsite state transition
@ -23,16 +26,38 @@ class CoWebsiteManager {
private currentOperationPromise: Promise<void> = Promise.resolve(); private currentOperationPromise: Promise<void> = Promise.resolve();
private cowebsiteDiv: HTMLDivElement; private cowebsiteDiv: HTMLDivElement;
private resizing: boolean = false; private resizing: boolean = false;
private currentWidth: number = 0;
private cowebsiteMainDom: HTMLDivElement;
private cowebsiteAsideDom: HTMLDivElement;
get width(): number {
return this.cowebsiteDiv.clientWidth;
}
set width(width: number) {
this.cowebsiteDiv.style.width = width+'px';
}
constructor() { constructor() {
this.cowebsiteDiv = HtmlUtils.getElementByIdOrFail<HTMLDivElement>(cowebsiteDivId); this.cowebsiteDiv = HtmlUtils.getElementByIdOrFail<HTMLDivElement>(cowebsiteDivId);
this.cowebsiteMainDom = HtmlUtils.getElementByIdOrFail<HTMLDivElement>(cowebsiteMainDomId);
this.cowebsiteDiv.addEventListener('mousedown', (event) => { this.cowebsiteAsideDom = HtmlUtils.getElementByIdOrFail<HTMLDivElement>(cowebsiteAsideDomId);
this.initResizeListeners();
HtmlUtils.getElementByIdOrFail(cowebsiteCloseButtonId).addEventListener('click', () => {
this.closeCoWebsite();
});
}
private initResizeListeners() {
this.cowebsiteAsideDom.addEventListener('mousedown', (event) => {
this.resizing = true; this.resizing = true;
this.getIframeDom().style.display = 'none'; this.getIframeDom().style.display = 'none';
document.onmousemove = (event) => { document.onmousemove = (event) => {
this.cowebsiteDiv.style.width = (this.cowebsiteDiv.clientWidth - event.movementX) + 'px'; this.width = this.width - event.movementX;
this.fire();
} }
}); });
@ -43,7 +68,7 @@ class CoWebsiteManager {
this.resizing = false; this.resizing = false;
}); });
} }
private close(): void { private close(): void {
this.cowebsiteDiv.classList.remove('loaded'); //edit the css class to trigger the transition this.cowebsiteDiv.classList.remove('loaded'); //edit the css class to trigger the transition
this.cowebsiteDiv.classList.add('hidden'); this.cowebsiteDiv.classList.add('hidden');
@ -57,8 +82,13 @@ class CoWebsiteManager {
private open(): void { private open(): void {
this.cowebsiteDiv.classList.remove('loading', 'hidden'); //edit the css class to trigger the transition this.cowebsiteDiv.classList.remove('loading', 'hidden'); //edit the css class to trigger the transition
this.opened = iframeStates.opened; this.opened = iframeStates.opened;
this.resetWidth();
} }
private resetWidth() {
this.width = window.innerWidth / 2;
}
private getIframeDom(): HTMLIFrameElement { private getIframeDom(): HTMLIFrameElement {
const iframe = HtmlUtils.getElementByIdOrFail<HTMLDivElement>(cowebsiteDivId).querySelector('iframe'); const iframe = HtmlUtils.getElementByIdOrFail<HTMLDivElement>(cowebsiteDivId).querySelector('iframe');
if (!iframe) throw new Error('Could not find iframe!'); if (!iframe) throw new Error('Could not find iframe!');
@ -67,14 +97,7 @@ class CoWebsiteManager {
public loadCoWebsite(url: string, base: string, allowPolicy?: string): void { public loadCoWebsite(url: string, base: string, allowPolicy?: string): void {
this.load(); this.load();
this.cowebsiteDiv.innerHTML = `<button class="close-btn" id="cowebsite-close"> this.cowebsiteMainDom.innerHTML = ``;
<img src="resources/logos/close.svg">
</button>`;
setTimeout(() => {
HtmlUtils.getElementByIdOrFail('cowebsite-close').addEventListener('click', () => {
this.closeCoWebsite();
});
}, 100);
const iframe = document.createElement('iframe'); const iframe = document.createElement('iframe');
iframe.id = 'cowebsite-iframe'; iframe.id = 'cowebsite-iframe';
@ -85,7 +108,7 @@ class CoWebsiteManager {
const onloadPromise = new Promise((resolve) => { const onloadPromise = new Promise((resolve) => {
iframe.onload = () => resolve(); iframe.onload = () => resolve();
}); });
this.cowebsiteDiv.appendChild(iframe); this.cowebsiteMainDom.appendChild(iframe);
const onTimeoutPromise = new Promise((resolve) => { const onTimeoutPromise = new Promise((resolve) => {
setTimeout(() => resolve(), 2000); setTimeout(() => resolve(), 2000);
}); });
@ -116,9 +139,7 @@ class CoWebsiteManager {
this.close(); this.close();
this.fire(); this.fire();
setTimeout(() => { setTimeout(() => {
this.cowebsiteDiv.innerHTML = `<button class="close-btn" id="cowebsite-close"> this.cowebsiteMainDom.innerHTML = ``;
<img src="resources/logos/close.svg">
</button>`;
resolve(); resolve();
}, animationTime) }, animationTime)
})); }));
@ -134,7 +155,7 @@ class CoWebsiteManager {
} }
if (window.innerWidth >= window.innerHeight) { if (window.innerWidth >= window.innerHeight) {
return { return {
width: window.innerWidth / 2, width: window.innerWidth - this.width,
height: window.innerHeight height: window.innerHeight
} }
} else { } else {
@ -144,16 +165,9 @@ class CoWebsiteManager {
} }
} }
} }
//todo: is it still useful to allow any kind of observers?
public onStateChange(observer: CoWebsiteStateChangedCallback) {
this.observers.push(observer);
}
private fire(): void { private fire(): void {
for (const callback of this.observers) { this._onStateChange.next();
callback();
}
} }
} }

View File

@ -118,7 +118,7 @@ window.addEventListener('resize', function (event) {
} }
}); });
coWebsiteManager.onStateChange(() => { coWebsiteManager.onStateChange.subscribe(() => {
const {width, height} = coWebsiteManager.getGameSize(); const {width, height} = coWebsiteManager.getGameSize();
game.scale.resize(width / RESOLUTION, height / RESOLUTION); game.scale.resize(width / RESOLUTION, height / RESOLUTION);
}); });