From 0e38e0fb30ed3b3f017f9b34c2a62c4b3b566ebe Mon Sep 17 00:00:00 2001 From: Kitteh Date: Sat, 8 May 2021 03:28:37 +0100 Subject: [PATCH] Add typing to main.ts. --- src/{main.js => main.ts} | 16 ++++++++++------ tsconfig.json | 2 +- webpack.config.js | 2 +- 3 files changed, 12 insertions(+), 8 deletions(-) rename src/{main.js => main.ts} (89%) diff --git a/src/main.js b/src/main.ts similarity index 89% rename from src/main.js rename to src/main.ts index 0e67bfd..eca03b9 100644 --- a/src/main.js +++ b/src/main.ts @@ -8,8 +8,8 @@ import UIkit from 'uikit/dist/js/uikit.min.js'; UIkit.use(Icons); /* eslint-disable */ -import Prism from "prismjs"; import "prismjs/components/prism-json"; +import Prism from "prismjs"; Prism.highlightAll(); /* eslint-enable */ @@ -19,11 +19,14 @@ import { } from "./pageUtils"; import { getSealStatus } from "./api/getSealStatus"; import { makeElement } from "./htmlUtils"; -import { pageState } from "./globalPageState.ts"; +import { pageState } from "./globalPageState"; +import { playground } from "./playground"; // Translations +import { Page } from "./types/Page"; import { formatDistance } from './formatDistance'; import i18next from 'i18next'; +// @ts-ignore import translations from './translations/index.mjs' function ListItem(children) { @@ -54,7 +57,7 @@ async function onLoad() { ListItem(makeElement({ tag: "a", text: i18next.t("back_btn"), - onclick: _ => { pageState.currentPage.goBack(); } + onclick: _ => { (pageState.currentPage as Page).goBack(); } })), ListItem(makeElement({ tag: "a", @@ -102,10 +105,10 @@ async function onLoad() { }) })); - window.pageContent = document.querySelector("#pageContent"); + (window as any).pageContent = document.querySelector("#pageContent"); if (process.env.NODE_ENV == "development") { - await (await import("./playground.ts")).playground(); + await playground(); } renderPage(); @@ -113,7 +116,7 @@ async function onLoad() { setInterval(async () => { if (pageState.currentPageString != "UNSEAL") { if (pageState.apiURL.length != 0) { return; } - let sealStatus = await getSealStatus(); + const sealStatus = await getSealStatus(); if (sealStatus.sealed) { changePage("UNSEAL"); return; @@ -127,6 +130,7 @@ document.addEventListener('DOMContentLoaded', async function () { lng: pageState.language, fallbackLng: 'en', debug: true, + // @ts-ignore resources: Object.fromEntries(Object.entries(translations).map(([k, v]) => [k, { translation: v }])), interpolation: { format: function (value, format, _) { diff --git a/tsconfig.json b/tsconfig.json index 5e15dbd..e4b2ba9 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -4,7 +4,7 @@ "noImplicitAny": false, "allowSyntheticDefaultImports": true, "module": "es6", - "target": "es2015", + "target": "es2019", "jsx": "react", "allowJs": true, "moduleResolution": "node", diff --git a/webpack.config.js b/webpack.config.js index 30ec592..493e575 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -10,7 +10,7 @@ const DEBUG = MODE != "production"; module.exports = { mode: MODE, cache: DEBUG, - entry: './src/main.js', + entry: './src/main.ts', output: { path: path.resolve(__dirname, 'dist'), filename: 'bundle.js',