This commit is contained in:
syuilo 2020-09-05 16:53:27 +09:00
parent 4c55cd6756
commit 5f3f9e2f8f
4 changed files with 19 additions and 23 deletions

View file

@ -3,7 +3,7 @@
<transition :name="$store.state.device.animation ? 'bg-fade' : ''" appear> <transition :name="$store.state.device.animation ? 'bg-fade' : ''" appear>
<div class="bg _modalBg" @click="onBgClick" v-if="!closing"></div> <div class="bg _modalBg" @click="onBgClick" v-if="!closing"></div>
</transition> </transition>
<transition :name="$store.state.device.animation ? 'dialog' : ''" appear @after-leave="$emit('closed')"> <transition :name="$store.state.device.animation ? 'dialog' : ''" appear @after-leave="$store.commit('removeDialog', id)">
<div class="main" v-if="!closing"> <div class="main" v-if="!closing">
<template v-if="type == 'signin'"> <template v-if="type == 'signin'">
<mk-signin/> <mk-signin/>
@ -59,8 +59,6 @@ import MkSignin from './signin.vue';
import parseAcct from '../../misc/acct/parse'; import parseAcct from '../../misc/acct/parse';
export default defineComponent({ export default defineComponent({
emits: ['done', 'closed'],
components: { components: {
MkButton, MkButton,
MkInput, MkInput,
@ -69,6 +67,9 @@ export default defineComponent({
}, },
props: { props: {
id: {
required: true
},
type: { type: {
type: String, type: String,
required: false, required: false,
@ -117,14 +118,11 @@ export default defineComponent({
type: Boolean, type: Boolean,
default: false default: false
}, },
closing: {
type: Boolean,
default: false
},
}, },
data() { data() {
return { return {
closing: false,
inputValue: this.input && this.input.default ? this.input.default : null, inputValue: this.input && this.input.default ? this.input.default : null,
userInputValue: null, userInputValue: null,
selectedValue: this.select ? this.select.default ? this.select.default : this.select.items ? this.select.items[0].value : this.select.groupedItems[0].items[0].value : null, selectedValue: this.select ? this.select.default ? this.select.default : this.select.items ? this.select.items[0].value : this.select.groupedItems[0].items[0].value : null,
@ -150,7 +148,7 @@ export default defineComponent({
if (this.autoClose) { if (this.autoClose) {
setTimeout(() => { setTimeout(() => {
this.$emit('done'); this.done(false);
}, 1000); }, 1000);
} }
@ -162,6 +160,11 @@ export default defineComponent({
}, },
methods: { methods: {
done(canceled, result?) {
this.closing = true;
this.$store.commit('dialogDone', { id: this.id, result: { canceled, result } });
},
async ok() { async ok() {
if (!this.canOk) return; if (!this.canOk) return;
if (!this.showOkButton) return; if (!this.showOkButton) return;
@ -169,19 +172,19 @@ export default defineComponent({
if (this.user) { if (this.user) {
const user = await this.$root.api('users/show', parseAcct(this.userInputValue)); const user = await this.$root.api('users/show', parseAcct(this.userInputValue));
if (user) { if (user) {
this.$emit('done', { canceled: false, result: user }); this.done(false, user);
} }
} else { } else {
const result = const result =
this.input ? this.inputValue : this.input ? this.inputValue :
this.select ? this.selectedValue : this.select ? this.selectedValue :
true; true;
this.$emit('done', { canceled: false, result }); this.done(false, result);
} }
}, },
cancel() { cancel() {
this.$emit('done', { canceled: true }); this.done(true);
}, },
onBgClick() { onBgClick() {

View file

@ -107,7 +107,7 @@ export default defineComponent({
.form-enter-active, .form-leave-active { .form-enter-active, .form-leave-active {
transition: opacity 0.3s, transform 0.3s !important; transition: opacity 0.3s, transform 0.3s !important;
} }
.form-enter, .form-leave-to { .form-enter-from, .form-leave-to {
opacity: 0; opacity: 0;
transform: scale(0.9); transform: scale(0.9);
} }
@ -115,7 +115,7 @@ export default defineComponent({
.form-fade-enter-active, .form-fade-leave-active { .form-fade-enter-active, .form-fade-leave-active {
transition: opacity 0.3s !important; transition: opacity 0.3s !important;
} }
.form-fade-enter, .form-fade-leave-to { .form-fade-enter-from, .form-fade-leave-to {
opacity: 0; opacity: 0;
} }

View file

@ -2,8 +2,10 @@
<DeckUI v-if="deckmode"/> <DeckUI v-if="deckmode"/>
<DefaultUI v-else/> <DefaultUI v-else/>
<XDialog v-if="dialog" v-bind="dialog" :key="dialog.id" <XPostFormDialog v-if="$store.state.postForm" v-bind="$store.state.postForm"
@done="onDialogDone" @closed="onDialogClosed"/> @done="onDialogDone" @closed="onDialogClosed"/>
<XDialog v-if="dialog" v-bind="dialog" :key="dialog.id"/>
</template> </template>
<script lang="ts"> <script lang="ts">
@ -56,14 +58,6 @@ export default defineComponent({
api(endpoint: string, data: Record<string, any> = {}, token?) { api(endpoint: string, data: Record<string, any> = {}, token?) {
return this.$store.dispatch('api', { endpoint, data, token }); return this.$store.dispatch('api', { endpoint, data, token });
}, },
onDialogDone(result) {
this.$store.commit('dialogDone', { id: this.dialog.id, result });
},
onDialogClosed() {
this.$store.commit('removeDialog', this.dialog.id);
}
} }
}); });
</script> </script>

View file

@ -270,7 +270,6 @@ export const store = createStore({
dialogDone(state, { id: dialogId, result }) { dialogDone(state, { id: dialogId, result }) {
const dialog = state.dialogs.find(d => d.id === dialogId); const dialog = state.dialogs.find(d => d.id === dialogId);
dialog.result = result; dialog.result = result;
dialog.closing = true;
}, },
removeDialog(state, dialogId) { removeDialog(state, dialogId) {