Make it possible to abandon draft

This commit is contained in:
tusooa 2023-03-10 12:39:08 -05:00
parent 02e2e6b1bf
commit a245379f43
No known key found for this signature in database
GPG key ID: 42AEC43D48433C51
4 changed files with 77 additions and 13 deletions

View file

@ -1,8 +1,10 @@
import PostStatusForm from 'src/components/post_status_form/post_status_form.vue' import PostStatusForm from 'src/components/post_status_form/post_status_form.vue'
import ConfirmModal from 'src/components/confirm_modal/confirm_modal.vue'
const Draft = { const Draft = {
components: { components: {
PostStatusForm PostStatusForm,
ConfirmModal
}, },
props: { props: {
draft: { draft: {
@ -12,7 +14,8 @@ const Draft = {
}, },
data () { data () {
return { return {
editing: false editing: false,
showingConfirmDialog: false
} }
}, },
computed: { computed: {
@ -35,6 +38,23 @@ const Draft = {
methods: { methods: {
toggleEditing () { toggleEditing () {
this.editing = !this.editing this.editing = !this.editing
},
abandon () {
this.showingConfirmDialog = true
},
doAbandon () {
console.debug('abandoning')
this.$store.dispatch('abandonDraft', { id: this.draft.id })
.then(() => {
this.hideConfirmDialog()
})
},
hideConfirmDialog () {
this.showingConfirmDialog = false
},
handlePosted () {
console.debug('posted')
this.doAbandon()
} }
} }
} }

View file

@ -1,28 +1,48 @@
<template> <template>
<article class="Draft"> <article class="Draft">
<div>
{{ draft.id }}
</div>
<div v-if="draft.inReplyToStatusId"> <div v-if="draft.inReplyToStatusId">
{{ draft.inReplyToStatusId }} {{ draft.inReplyToStatusId }}
</div> </div>
<div <div class="actions">
class="draft-content"
>
{{ draft.status }}
</div>
<div>
<button <button
class="btn button-default" class="btn button-default"
:class="{ toggled: editing }"
:aria-expanded="editing" :aria-expanded="editing"
@click.prevent.stop="toggleEditing" @click.prevent.stop="toggleEditing"
> >
{{ $t('drafts.continue') }} {{ $t('drafts.continue') }}
</button> </button>
<button
class="btn button-default"
@click.prevent.stop="abandon"
>
{{ $t('drafts.abandon') }}
</button>
</div> </div>
<p
v-if="!editing"
class="draft-content"
>
{{ draft.status }}
</p>
<div v-if="editing"> <div v-if="editing">
<PostStatusForm v-bind="postStatusFormProps" /> <PostStatusForm
v-bind="postStatusFormProps"
@posted="handlePosted"
/>
</div> </div>
<teleport to="#modal">
<confirm-modal
v-if="showingConfirmDialog"
:title="$t('drafts.abandon_confirm_title')"
:confirm-text="$t('drafts.abandon_confirm_accept_button')"
:cancel-text="$t('drafts.abandon_confirm_cancel_button')"
@accepted="doAbandon"
@cancelled="hideConfirmDialog"
>
{{ $t('drafts.abandon_confirm') }}
</confirm-modal>
</teleport>
</article> </article>
</template> </template>
@ -31,5 +51,18 @@
<style lang="scss"> <style lang="scss">
.Draft { .Draft {
margin: 1em; margin: 1em;
.actions {
display: flex;
flex-direction: row;
justify-content: space-evenly;
.btn {
flex: 1;
margin-left: 1em;
margin-right: 1em;
max-width: 10em;
}
}
} }
</style> </style>

View file

@ -1405,6 +1405,11 @@
}, },
"drafts": { "drafts": {
"drafts": "Drafts", "drafts": "Drafts",
"continue": "Continue editing" "continue": "Continue editing",
"abandon": "Abandon draft",
"abandon_confirm_title": "Abandon confirmation",
"abandon_confirm": "Do you really want to abandon this draft?",
"abandon_confirm_accept_button": "Abandon",
"abandon_confirm_cancel_button": "Keep"
} }
} }

View file

@ -6,6 +6,9 @@ export const defaultState = {
export const mutations = { export const mutations = {
addOrSaveDraft (state, { draft }) { addOrSaveDraft (state, { draft }) {
state.drafts[draft.id] = draft state.drafts[draft.id] = draft
},
abandonDraft (state, { id }) {
delete state.drafts[id]
} }
} }
@ -14,6 +17,9 @@ export const actions = {
const id = draft.id || (new Date().getTime()).toString() const id = draft.id || (new Date().getTime()).toString()
store.commit('addOrSaveDraft', { draft: { ...draft, id } }) store.commit('addOrSaveDraft', { draft: { ...draft, id } })
return id return id
},
abandonDraft (store, { id }) {
store.commit('abandonDraft', { id })
} }
} }