code-server/packages/web/src/index.ts

44 lines
1.2 KiB
TypeScript
Raw Normal View History

2019-01-12 07:21:31 +07:00
import { logger, field, time } from "@coder/logger";
import { load } from "@coder/vscode";
2019-01-12 01:58:25 +07:00
import "./index.scss";
2019-01-12 07:21:31 +07:00
const loadTime = time(2500);
logger.info("Loading IDE...");
2019-01-12 07:11:34 +07:00
2019-01-12 00:50:54 +07:00
const overlay = document.getElementById("overlay");
const logo = document.getElementById("logo");
2019-01-12 07:21:31 +07:00
const msgElement = overlay
? overlay.querySelector(".message") as HTMLElement
: undefined;
2019-01-12 00:50:54 +07:00
if (overlay && logo) {
overlay.addEventListener("mousemove", (event) => {
const xPos = ((event.clientX - logo.offsetLeft) / 24).toFixed(2);
const yPos = ((logo.offsetTop - event.clientY) / 24).toFixed(2);
logo.style.transform = `perspective(200px) rotateX(${yPos}deg) rotateY(${xPos}deg)`;
});
}
2019-01-12 07:11:34 +07:00
2019-01-12 07:21:31 +07:00
load().then(() => {
if (overlay) {
overlay.style.opacity = "0";
overlay.addEventListener("transitionend", () => {
overlay.remove();
});
}
}).catch((error: Error) => {
logger.error(error.message);
if (overlay) {
overlay.classList.add("error");
}
if (msgElement) {
msgElement.innerText = `Failed to load: ${error.message}. Retrying in 3 seconds...`;
}
setTimeout(() => {
location.reload();
}, 3000);
}).finally(() => {
logger.info("Load completed", field("duration", loadTime));
});