Add basic draft saving

This commit is contained in:
tusooa 2023-03-10 11:20:06 -05:00
parent 83189d9d41
commit 1aa0901471
No known key found for this signature in database
GPG key ID: 42AEC43D48433C51
3 changed files with 88 additions and 3 deletions

View file

@ -55,6 +55,18 @@ const pxStringToNumber = (str) => {
return Number(str.substring(0, str.length - 2)) 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 = { const PostStatusForm = {
props: [ props: [
'statusId', 'statusId',
@ -88,7 +100,8 @@ const PostStatusForm = {
'submitOnEnter', 'submitOnEnter',
'emojiPickerPlacement', 'emojiPickerPlacement',
'optimisticPosting', 'optimisticPosting',
'profileMention' 'profileMention',
'draftId'
], ],
emits: [ emits: [
'posted', 'posted',
@ -126,7 +139,9 @@ const PostStatusForm = {
const { scopeCopy } = this.$store.getters.mergedConfig 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 const currentUser = this.$store.state.users.currentUser
statusText = buildMentionsString({ user: this.repliedUser, attentions: this.attentions }, currentUser) statusText = buildMentionsString({ user: this.repliedUser, attentions: this.attentions }, currentUser)
} }
@ -138,6 +153,8 @@ const PostStatusForm = {
const { postContentType: contentType, sensitiveByDefault } = this.$store.getters.mergedConfig const { postContentType: contentType, sensitiveByDefault } = this.$store.getters.mergedConfig
let statusParams = { let statusParams = {
type: statusType,
refId,
spoilerText: this.subject || '', spoilerText: this.subject || '',
status: statusText, status: statusText,
nsfw: !!sensitiveByDefault, nsfw: !!sensitiveByDefault,
@ -148,9 +165,11 @@ const PostStatusForm = {
contentType contentType
} }
if (this.statusId) { if (statusType === 'edit') {
const statusContentType = this.statusContentType || contentType const statusContentType = this.statusContentType || contentType
statusParams = { statusParams = {
type: statusType,
refId,
spoilerText: this.subject || '', spoilerText: this.subject || '',
status: this.statusText || '', status: this.statusText || '',
nsfw: this.statusIsSensitive || !!sensitiveByDefault, 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 { return {
randomSeed: genRandomSeed(), randomSeed: genRandomSeed(),
dropFiles: [], dropFiles: [],
@ -293,6 +327,19 @@ const PostStatusForm = {
return false 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']), ...mapGetters(['mergedConfig']),
...mapState({ ...mapState({
mobileLayout: state => state.interface.mobileLayout mobileLayout: state => state.interface.mobileLayout
@ -310,6 +357,7 @@ const PostStatusForm = {
statusChanged () { statusChanged () {
this.autoPreview() this.autoPreview()
this.updateIdempotencyKey() this.updateIdempotencyKey()
this.saveDraft()
}, },
clearStatus () { clearStatus () {
const newStatus = this.newStatus const newStatus = this.newStatus

View file

@ -24,6 +24,7 @@ import pollsModule from './modules/polls.js'
import postStatusModule from './modules/postStatus.js' import postStatusModule from './modules/postStatus.js'
import editStatusModule from './modules/editStatus.js' import editStatusModule from './modules/editStatus.js'
import statusHistoryModule from './modules/statusHistory.js' import statusHistoryModule from './modules/statusHistory.js'
import draftsModule from './modules/drafts.js'
import chatsModule from './modules/chats.js' import chatsModule from './modules/chats.js'
import announcementsModule from './modules/announcements.js' import announcementsModule from './modules/announcements.js'
@ -96,6 +97,7 @@ const persistedStateOptions = {
postStatus: postStatusModule, postStatus: postStatusModule,
editStatus: editStatusModule, editStatus: editStatusModule,
statusHistory: statusHistoryModule, statusHistory: statusHistoryModule,
drafts: draftsModule,
chats: chatsModule, chats: chatsModule,
announcements: announcementsModule announcements: announcementsModule
}, },

35
src/modules/drafts.js Normal file
View file

@ -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