From 8f4443c52861b5844bfd9c5e171b25ca7b88aefa Mon Sep 17 00:00:00 2001 From: Gail Terman Date: Wed, 27 Jul 2022 19:41:46 -0400 Subject: [PATCH] PLAN-193 add confirmation on primary email change --- .../components/email_addresses_editor.vue | 43 +++++++++++++++---- 1 file changed, 34 insertions(+), 9 deletions(-) diff --git a/app/javascript/components/email_addresses_editor.vue b/app/javascript/components/email_addresses_editor.vue index b18f7ba89..ea1cac3cf 100644 --- a/app/javascript/components/email_addresses_editor.vue +++ b/app/javascript/components/email_addresses_editor.vue @@ -13,7 +13,7 @@ @@ -33,6 +33,10 @@ + +

You are about to change the primary email address associated with this profile. This will change the login email used for this account.

+

Are you sure you wish to make this change?

+
@@ -42,11 +46,13 @@ import EmailAddressEditor from './email_address_editor.vue' import emailAddressMixin from '../store/email_address.mixin' import {personSessionMixin} from '@/mixins'; import modelUtilsMixin from "@/store/model_utils.mixin"; +import PlanoModal from './plano_modal.vue'; export default { name: 'EmailAddressesEditor', components: { - EmailAddressEditor + EmailAddressEditor, + PlanoModal }, mixins: [ modelUtilsMixin, @@ -68,12 +74,11 @@ export default { default: 'email-addresses-editor' } }, - data() { - return { - emails: [], - additional: [] - } - }, + data: () => ({ + emails: [], + additional: [], + pendingPrimaryChange: null + }), computed: { primary: { get: function() { @@ -102,7 +107,27 @@ export default { ) } }, - onInput(arg) { + onConfirmCancel() { + this.setLists() + this.pendingPrimaryChange = null; + }, + onConfirmOk() { + this.saveEmail(this.pendingPrimaryChange).then( + () => { + this.setLists() + } + ).catch((err) => { + console.log("i caught an error", err) + this.setLists() + }); + this.pendingPrimaryChange = null; + }, + onInput(arg, isPrimary = false) { + if(isPrimary) { + this.$bvModal.show('primaryEmailConfirm') + this.pendingPrimaryChange = arg; + return; + } if (arg.id) { this.saveEmail(arg).then( () => {