<template> <div v-if="visible" class="dialog-overlay"> <div class="dialog"> <h1 class="text-xl font-bold text-center mb-4">Invitation & Notes</h1> These are optional notes for your use; they are comments to help you recall who it is when they accept it. These notes are sent to the server. If you want to store your own way, the invitation ID is: {{ inviteIdentifier }} <input type="text" placeholder="Notes" class="block w-full rounded border border-slate-400 mb-4 px-3 py-2" v-model="text" /> <!-- Add date selection element --> Expiration <input type="date" class="block rounded border border-slate-400 mb-4 px-3 py-2" v-model="expiresAt" /> <div class="mt-8"> <div class="grid grid-cols-1 sm:grid-cols-2 gap-2"> <button type="button" class="block w-full text-center text-lg font-bold uppercase bg-gradient-to-b from-blue-400 to-blue-700 shadow-[inset_0_-1px_0_0_rgba(0,0,0,0.5)] text-white px-2 py-3 rounded-md mb-2" @click="onClickSaveChanges()" > Save </button> <!-- SHOW ME instead while processing saving changes --> <button type="button" class="block w-full text-center text-md uppercase bg-gradient-to-b from-slate-400 to-slate-700 shadow-[inset_0_-1px_0_0_rgba(0,0,0,0.5)] text-white px-2 py-3 rounded-md mb-2" @click="onClickCancel()" > Cancel </button> </div> </div> </div> </div> </template> <script lang="ts"> import { Vue, Component } from "vue-facing-decorator"; import { NotificationIface } from "../constants/app"; @Component export default class InviteDialog extends Vue { $notify!: (notification: NotificationIface, timeout?: number) => void; callback: (text: string, expiresAt: string) => void = () => {}; inviteIdentifier = ""; text = ""; visible = false; expiresAt = new Date(Date.now() + 1000 * 60 * 60 * 24 * 7) .toISOString() .substring(0, 10); async open( inviteIdentifier: string, aCallback: (text: string, expiresAt: string) => void, ) { this.callback = aCallback; this.inviteIdentifier = inviteIdentifier; this.visible = true; } async onClickSaveChanges() { if (!this.expiresAt) { this.$notify( { group: "alert", type: "warning", title: "Needs Expiration", text: "You must select an expiration date.", }, 5000, ); } else { this.callback(this.text, this.expiresAt); this.visible = false; } } onClickCancel() { this.visible = false; } } </script> <style> .dialog-overlay { z-index: 50; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.5); display: flex; justify-content: center; align-items: center; padding: 1.5rem; } .dialog { background-color: white; padding: 1rem; border-radius: 0.5rem; width: 100%; max-width: 500px; } </style>