<template> <section id="Content" class="p-6 pb-24"> <!-- Breadcrumb --> <div id="ViewBreadcrumb" class="mb-8"> <h1 class="text-lg text-center font-light relative px-7"> <!-- Cancel --> <button @click="$router.go(-1)" class="text-lg text-center px-2 py-1 absolute -left-2 -top-1" > <fa icon="chevron-left" class="fa-fw"></fa> </button> Edit Identity </h1> </div> <input type="text" placeholder="Name" class="block w-full rounded border border-slate-400 mb-4 px-3 py-2" v-model="givenName" /> <div class="mt-8"> <button type="button" class="block w-full text-center text-lg font-bold uppercase bg-blue-600 text-white px-2 py-3 rounded-md mb-2" @click="onClickSaveChanges()" > Save Changes </button> <!-- SHOW ME instead while processing saving changes --> <button type="button" class="block w-full text-center text-md uppercase bg-slate-500 text-white px-1.5 py-2 rounded-md" @click="onClickCancel()" > Cancel </button> </div> </section> </template> <script lang="ts"> import { Component, Vue } from "vue-facing-decorator"; import { db } from "@/db/index"; import { MASTER_SETTINGS_KEY, Settings } from "@/db/tables/settings"; @Component({ components: {}, }) export default class NewEditAccountView extends Vue { givenName = ""; // 'created' hook runs when the Vue instance is first created async created() { await db.open(); const settings = (await db.settings.get(MASTER_SETTINGS_KEY)) as Settings; this.givenName = (settings?.firstName || "") + (settings?.lastName ? ` ${settings.lastName}` : ""); // deprecated, pre v 0.1.3 } onClickSaveChanges() { db.settings.update(MASTER_SETTINGS_KEY, { firstName: this.givenName, lastName: "", // deprecated, pre v 0.1.3 }); localStorage.setItem("firstName", this.givenName as string); localStorage.setItem("lastName", ""); // deprecated, pre v 0.1.3 this.$router.push({ name: "account" }); } onClickCancel() { this.$router.back(); } } </script>