diff --git a/src/pages/SetVaultURL.ts b/src/pages/SetVaultURL.ts deleted file mode 100644 index 0ae1d56..0000000 --- a/src/pages/SetVaultURL.ts +++ /dev/null @@ -1,52 +0,0 @@ -import { Form } from "../elements/Form"; -import { Page } from "../types/Page"; -import { makeElement } from "z-makeelement"; - -export class SetVaultURLPage extends Page { - constructor() { - super(); - } - async render(): Promise { - await this.router.setPageContent( - Form( - [ - makeElement({ - tag: "div", - class: "uk-margin", - children: makeElement({ - tag: "input", - class: ["uk-input", "uk-form-width-medium"], - attributes: { - required: "true", - type: "text", - placeholder: "Vault URL", - name: "vaultURL", - }, - }), - }), - makeElement({ - tag: "p", - id: "errorText", - class: "uk-text-danger", - }), - makeElement({ - tag: "button", - class: ["uk-button", "uk-button-primary"], - text: "Set", - attributes: { - type: "submit", - }, - }), - ], - async (form: HTMLFormElement) => { - const formData = new FormData(form); - this.state.apiURL = formData.get("vaultURL") as string; - await this.router.changePage("HOME"); - }, - ), - ); - } - get name(): string { - return "Set Vault URL"; - } -} diff --git a/src/pages/SetVaultURL.tsx b/src/pages/SetVaultURL.tsx new file mode 100644 index 0000000..6384910 --- /dev/null +++ b/src/pages/SetVaultURL.tsx @@ -0,0 +1,42 @@ +import { Form } from "../elements/ReactForm"; +import { Margin } from "../elements/ReactMargin"; +import { Page } from "../types/Page"; +import { render } from "preact"; + +export class SetVaultURLPage extends Page { + constructor() { + super(); + } + async render(): Promise { + render( +
this.onSubmit(data)}> + + + +

+ + + +

, + + this.router.pageContentElement, + ); + } + + async onSubmit(data: FormData): Promise { + this.state.apiURL = data.get("vaultURL") as string; + await this.router.changePage("HOME"); + } + + get name(): string { + return "Set Vault URL"; + } +}