From 8a33dfd36fcfb1ecd40127055a01d85d46f889f0 Mon Sep 17 00:00:00 2001 From: Kitteh Date: Sat, 8 May 2021 03:36:26 +0100 Subject: [PATCH] Add typing to TransitEncrypt.ts --- .vscode/settings.json | 2 ++ src/allPages.ts | 2 +- .../{TransitEncrypt.js => TransitEncrypt.ts} | 30 +++++++++++-------- 3 files changed, 20 insertions(+), 14 deletions(-) create mode 100644 .vscode/settings.json rename src/pages/Transit/{TransitEncrypt.js => TransitEncrypt.ts} (78%) diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..7a73a41 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,2 @@ +{ +} \ No newline at end of file diff --git a/src/allPages.ts b/src/allPages.ts index 8b23b12..fa03bf7 100644 --- a/src/allPages.ts +++ b/src/allPages.ts @@ -14,7 +14,7 @@ import { SetLanguagePage } from "./pages/SetLanguage"; import { SetVaultURLPage } from "./pages/SetVaultURL"; import { TOTPViewPage } from "./pages/TOTP/TOTPView"; import { TransitDecryptPage } from "./pages/Transit/TransitDecrypt"; -import { TransitEncryptPage } from "./pages/Transit/TransitEncrypt.js"; +import { TransitEncryptPage } from "./pages/Transit/TransitEncrypt"; import { TransitViewPage } from "./pages/Transit/TransitView"; import { TransitViewSecretPage } from "./pages/Transit/TransitViewSecret"; import { UnsealPage } from "./pages/Unseal"; diff --git a/src/pages/Transit/TransitEncrypt.js b/src/pages/Transit/TransitEncrypt.ts similarity index 78% rename from src/pages/Transit/TransitEncrypt.js rename to src/pages/Transit/TransitEncrypt.ts index c456eb1..2bfaec1 100644 --- a/src/pages/Transit/TransitEncrypt.js +++ b/src/pages/Transit/TransitEncrypt.ts @@ -3,7 +3,7 @@ import { Margin } from "../../elements/Margin"; import { Page } from "../../types/Page"; import { changePage, setErrorText, setPageContent, setTitleElement } from "../../pageUtils"; import { makeElement } from "../../htmlUtils"; -import { pageState } from "../../globalPageState.ts"; +import { pageState } from "../../globalPageState"; import { transitEncrypt } from "../../api/transitEncrypt"; import UIkit from 'uikit/dist/js/uikit.min.js'; import i18next from "i18next"; @@ -13,10 +13,15 @@ export class TransitEncryptPage extends Page { constructor() { super(); } - goBack() { + + goBack(): void { changePage("TRANSIT_VIEW_SECRET"); } - async render() { + + transitEncryptForm: HTMLFormElement; + + + async render(): Promise { setTitleElement(pageState); setPageContent(makeElement({ tag: "div" @@ -65,7 +70,7 @@ export class TransitEncryptPage extends Page { } }) ] - }); + }) as HTMLFormElement; setPageContent(this.transitEncryptForm); this.transitEncryptForm.addEventListener("submit", function (e) { @@ -74,25 +79,24 @@ export class TransitEncryptPage extends Page { }.bind(this)); } - transitEncryptFormHandler() { - let formData = new FormData(this.transitEncryptForm); - let encodedData = - formData.get("base64Checkbox") == "on" ? formData.get("plaintext") : btoa(formData.get("plaintext")); + transitEncryptFormHandler(): void { + const formData = new FormData(this.transitEncryptForm); + const encodedData = + formData.get("base64Checkbox") as string == "on" ? formData.get("plaintext") as string : btoa(formData.get("plaintext") as string); transitEncrypt(pageState.currentBaseMount, pageState.currentSecret, encodedData).then(res => { - console.log(res); - let modal = CopyableModal(i18next.t("transit_encrypt_encryption_result_modal_title"), res.ciphertext); - pageContent.appendChild(modal); + const modal = CopyableModal(i18next.t("transit_encrypt_encryption_result_modal_title"), res.ciphertext); + document.body.querySelector("#pageContent").appendChild(modal); UIkit.modal(modal).show(); }).catch(e => { setErrorText(`API Error: ${e.message}`); }); } - get titleSuffix() { + get titleSuffix(): string { return i18next.t("transit_encrypt_suffix"); } - get name() { + get name(): string { return i18next.t("transit_encrypt_title"); } }