Prevent modal close when settings have changed

This commit is contained in:
Samuel Elliott 2018-02-14 18:14:46 +00:00
parent bea87f5be8
commit c9d9feb63f
No known key found for this signature in database
GPG Key ID: 8420C7CDE43DC4D6
2 changed files with 19 additions and 14 deletions

View File

@ -10,7 +10,7 @@
<template> <template>
<div class="bd-settings-modal" :class="{'bd-edited': changed}"> <div class="bd-settings-modal" :class="{'bd-edited': changed}">
<Modal :headerText="modal.headertext" :close="attemptToClose" :class="{'bd-modal-out': modal.closing}"> <Modal :headerText="modal.headertext" :close="modal.close" :class="{'bd-modal-out': modal.closing}">
<SettingsPanel :settings="configCache" :schemes="modal.schemes" :change="settingChange" slot="body" class="bd-settings-modal-body" /> <SettingsPanel :settings="configCache" :schemes="modal.schemes" :change="settingChange" slot="body" class="bd-settings-modal-body" />
<div slot="footer" class="bd-footer-alert" :class="{'bd-active': changed, 'bd-warn': warnclose}"> <div slot="footer" class="bd-footer-alert" :class="{'bd-active': changed, 'bd-warn': warnclose}">
<div class="bd-footer-alert-text">Unsaved changes</div> <div class="bd-footer-alert-text">Unsaved changes</div>
@ -91,19 +91,15 @@
this.configCache = JSON.parse(JSON.stringify(this.modal.settings)); this.configCache = JSON.parse(JSON.stringify(this.modal.settings));
this.changed = false; this.changed = false;
this.$forceUpdate(); this.$forceUpdate();
},
attemptToClose(e) {
if (!this.changed) {
this.closing = true;
setTimeout(() => {
this.modal.close();
}, 200);
return;
} }
},
created() {
this.modal.beforeClose = () => {
if (this.changed) {
this.warnclose = true; this.warnclose = true;
setTimeout(() => { setTimeout(() => this.warnclose = false, 400);
this.warnclose = false; return true;
}, 400); }
} }
}, },
beforeMount() { beforeMount() {

View File

@ -32,7 +32,16 @@ export default class {
} }
static close(modal) { static close(modal) {
return new Promise((resolve, reject) => { return new Promise(async (resolve, reject) => {
if (modal.beforeClose) {
let beforeCloseResult = modal.beforeClose();
if (beforeCloseResult instanceof Promise)
beforeCloseResult = await beforeCloseResult;
if (beforeCloseResult)
return reject(beforeCloseResult);
}
modal.closing = true; modal.closing = true;
setTimeout(() => { setTimeout(() => {
this._stack = this.stack.filter(m => m !== modal); this._stack = this.stack.filter(m => m !== modal);