From 1aa0901471beb3f77feced1f2ac72726cb8aebfc Mon Sep 17 00:00:00 2001 From: tusooa Date: Fri, 10 Mar 2023 11:20:06 -0500 Subject: [PATCH] Add basic draft saving --- .../post_status_form/post_status_form.js | 54 +++++++++++++++++-- src/main.js | 2 + src/modules/drafts.js | 35 ++++++++++++ 3 files changed, 88 insertions(+), 3 deletions(-) create mode 100644 src/modules/drafts.js diff --git a/src/components/post_status_form/post_status_form.js b/src/components/post_status_form/post_status_form.js index 563dfb96..ccb1e2cc 100644 --- a/src/components/post_status_form/post_status_form.js +++ b/src/components/post_status_form/post_status_form.js @@ -55,6 +55,18 @@ const pxStringToNumber = (str) => { return Number(str.substring(0, str.length - 2)) } +const typeAndRefId = ({ replyTo, profileMention, statusId }) => { + if (replyTo) { + return ['reply', replyTo] + } else if (profileMention) { + return ['mention', profileMention] + } else if (statusId) { + return ['edit', statusId] + } else { + return ['new', ''] + } +} + const PostStatusForm = { props: [ 'statusId', @@ -88,7 +100,8 @@ const PostStatusForm = { 'submitOnEnter', 'emojiPickerPlacement', 'optimisticPosting', - 'profileMention' + 'profileMention', + 'draftId' ], emits: [ 'posted', @@ -126,7 +139,9 @@ const PostStatusForm = { const { scopeCopy } = this.$store.getters.mergedConfig - if (this.replyTo || this.profileMention) { + const [statusType, refId] = typeAndRefId({ replyTo: this.replyTo, profileMention: this.profileMention, statusId: this.statusId }) + + if (statusType === 'reply' || statusType === 'mention') { const currentUser = this.$store.state.users.currentUser statusText = buildMentionsString({ user: this.repliedUser, attentions: this.attentions }, currentUser) } @@ -138,6 +153,8 @@ const PostStatusForm = { const { postContentType: contentType, sensitiveByDefault } = this.$store.getters.mergedConfig let statusParams = { + type: statusType, + refId, spoilerText: this.subject || '', status: statusText, nsfw: !!sensitiveByDefault, @@ -148,9 +165,11 @@ const PostStatusForm = { contentType } - if (this.statusId) { + if (statusType === 'edit') { const statusContentType = this.statusContentType || contentType statusParams = { + type: statusType, + refId, spoilerText: this.subject || '', status: this.statusText || '', nsfw: this.statusIsSensitive || !!sensitiveByDefault, @@ -163,6 +182,21 @@ const PostStatusForm = { } } + console.debug('type and ref:', [statusType, refId]) + + const maybeDraft = this.$store.state.drafts.drafts[this.draftId] + if (this.draftId && maybeDraft) { + console.debug('current draft:', maybeDraft) + statusParams = maybeDraft + } else { + const existingDrafts = this.$store.getters.draftsByTypeAndRefId(statusType, refId) + + console.debug('existing drafts:', existingDrafts) + if (existingDrafts.length) { + statusParams = existingDrafts[0] + } + } + return { randomSeed: genRandomSeed(), dropFiles: [], @@ -293,6 +327,19 @@ const PostStatusForm = { return false }, + saveDraft () { + return debounce(() => { + if (this.newStatus.status) { + console.debug('Saving status', this.newStatus) + this.$store.dispatch('addOrSaveDraft', { draft: this.newStatus }) + .then(id => { + if (this.newStatus.id !== id) { + this.newStatus.id = id + } + }) + } + }, 3000) + }, ...mapGetters(['mergedConfig']), ...mapState({ mobileLayout: state => state.interface.mobileLayout @@ -310,6 +357,7 @@ const PostStatusForm = { statusChanged () { this.autoPreview() this.updateIdempotencyKey() + this.saveDraft() }, clearStatus () { const newStatus = this.newStatus diff --git a/src/main.js b/src/main.js index 85eb1f4c..a2af7b19 100644 --- a/src/main.js +++ b/src/main.js @@ -24,6 +24,7 @@ import pollsModule from './modules/polls.js' import postStatusModule from './modules/postStatus.js' import editStatusModule from './modules/editStatus.js' import statusHistoryModule from './modules/statusHistory.js' +import draftsModule from './modules/drafts.js' import chatsModule from './modules/chats.js' import announcementsModule from './modules/announcements.js' @@ -96,6 +97,7 @@ const persistedStateOptions = { postStatus: postStatusModule, editStatus: editStatusModule, statusHistory: statusHistoryModule, + drafts: draftsModule, chats: chatsModule, announcements: announcementsModule }, diff --git a/src/modules/drafts.js b/src/modules/drafts.js new file mode 100644 index 00000000..465c9aad --- /dev/null +++ b/src/modules/drafts.js @@ -0,0 +1,35 @@ + +export const defaultState = { + drafts: {} +} + +export const mutations = { + addOrSaveDraft (state, { draft }) { + state.drafts[draft.id] = draft + } +} + +export const actions = { + addOrSaveDraft (store, { draft }) { + const id = draft.id || (new Date().getTime()).toString() + store.commit('addOrSaveDraft', { draft: { ...draft, id } }) + return id + } +} + +export const getters = { + draftsByTypeAndRefId (state) { + return (type, refId) => { + return Object.values(state.drafts).filter(draft => draft.type === type && draft.refId === refId) + } + } +} + +const drafts = { + state: defaultState, + mutations, + getters, + actions +} + +export default drafts