'use strict'; import "./scss/main.scss"; import UIkit from 'uikit/dist/js/uikit.min.js'; import Icons from 'uikit/dist/js/uikit-icons.min.js'; UIkit.use(Icons); import Prism from "prismjs"; import "prismjs/components/prism-json"; Prism.highlightAll(); import { changePage, renderPage, } from "./pageUtils.js"; import { PageState } from "./PageState.js"; import { makeElement } from "./htmlUtils.js"; import { HomePage, TOTPViewPage, NewTOTPPage, LoginPage, SetVaultURLPage, UnsealPage, TransitViewPage, TransitViewSecretPage, TransitEncryptPage, TransitDecryptPage, KeyValueViewPage, KeyValueSecretsPage, KeyValueVersionsPage, KeyValueNewPage, KeyValueDeletePage, KeyValueSecretsEditPage, PwGenPage, } from "./pages"; import { getSealStatus } from './api.js'; const pages = { HOME: new HomePage(), TOTP: new TOTPViewPage(), NEW_TOTP: new NewTOTPPage(), LOGIN: new LoginPage(), SET_VAULT_URL: new SetVaultURLPage(), UNSEAL: new UnsealPage(), TRANSIT_VIEW: new TransitViewPage(), TRANSIT_VIEW_SECRET: new TransitViewSecretPage(), TRANSIT_ENCRYPT: new TransitEncryptPage(), TRANSIT_DECRYPT: new TransitDecryptPage(), KEY_VALUE_VIEW: new KeyValueViewPage(), KEY_VALUE_SECRETS: new KeyValueSecretsPage(), KEY_VALUE_VERSIONS: new KeyValueVersionsPage(), KEY_VALUE_NEW_SECRET: new KeyValueNewPage(), KEY_VALUE_DELETE: new KeyValueDeletePage(), KEY_VALUE_SECRETS_EDIT: new KeyValueSecretsEditPage(), PW_GEN: new PwGenPage(), }; var pageState = new PageState(); window.pageState = pageState; window.pages = pages; window.changePage = changePage; function ListItem(children) { return makeElement({ tag: "li", children: children }); } document.addEventListener('DOMContentLoaded', function () { document.body.innerHTML = ""; document.body.appendChild(makeElement({ tag: "nav", class: ["uk-navbar", "uk-navbar-container"], children: makeElement({ tag: "div", class: "uk-navbar-left", children: makeElement({ tag: "ul", class: "uk-navbar-nav", children: [ ListItem(makeElement({ tag: "a", text: "Home", onclick: _ => { changePage(pages.HOME); } })), ListItem(makeElement({ tag: "a", text: "Back", onclick: _ => { pageState.currentPage.goBack(); } })), ListItem(makeElement({ tag: "a", text: "Refresh", onclick: _ => { changePage(pageState.currentPage); } })), ] }) }) })); document.body.appendChild(makeElement({ tag: "div", class: ["uk-container", "uk-container-medium", "uk-align-center"], children: makeElement({ tag: "div", class: ["uk-card", "uk-card-body"], children: [ makeElement({ tag: "h3", class: "uk-card-title", id: "pageTitle", text: "Title" }), makeElement({ tag: "div", id: "pageContent" }) ] }) })); window.pageContent = document.querySelector("#pageContent"); renderPage(); setInterval(async () => { if (pageState.currentPage != pages.UNSEAL) { let sealStatus = await getSealStatus(); if (sealStatus.sealed) { changePage(pages.UNSEAL); return; } } }, 5000); }, false);