2021-01-01 23:10:47 +01:00
|
|
|
import { ComposeAction, ComposeState } from './types'
|
2020-12-30 00:56:25 +01:00
|
|
|
|
|
|
|
const composeReducer = (
|
|
|
|
state: ComposeState,
|
|
|
|
action: ComposeAction
|
|
|
|
): ComposeState => {
|
|
|
|
switch (action.type) {
|
2021-01-14 22:53:01 +01:00
|
|
|
case 'posting':
|
|
|
|
return { ...state, posting: action.payload }
|
2020-12-30 00:56:25 +01:00
|
|
|
case 'spoiler':
|
|
|
|
return { ...state, spoiler: { ...state.spoiler, ...action.payload } }
|
|
|
|
case 'text':
|
|
|
|
return { ...state, text: { ...state.text, ...action.payload } }
|
|
|
|
case 'tag':
|
|
|
|
return { ...state, tag: action.payload }
|
|
|
|
case 'emoji':
|
|
|
|
return { ...state, emoji: action.payload }
|
|
|
|
case 'poll':
|
|
|
|
return { ...state, poll: { ...state.poll, ...action.payload } }
|
|
|
|
case 'attachments/sensitive':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
attachments: { ...state.attachments, ...action.payload }
|
|
|
|
}
|
|
|
|
case 'attachment/upload/start':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
attachments: {
|
|
|
|
...state.attachments,
|
|
|
|
uploads: state.attachments.uploads.concat([action.payload])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case 'attachment/upload/end':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
attachments: {
|
|
|
|
...state.attachments,
|
|
|
|
uploads: state.attachments.uploads.map(upload =>
|
|
|
|
upload.local?.uri === action.payload.local?.uri
|
|
|
|
? { ...upload, remote: action.payload.remote, uploading: false }
|
|
|
|
: upload
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2021-01-04 14:55:34 +01:00
|
|
|
case 'attachment/upload/fail':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
attachments: {
|
|
|
|
...state.attachments,
|
|
|
|
uploads: state.attachments.uploads.filter(
|
|
|
|
upload => upload.local.hash !== action.payload
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2020-12-30 00:56:25 +01:00
|
|
|
case 'attachment/delete':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
attachments: {
|
|
|
|
...state.attachments,
|
|
|
|
uploads: state.attachments.uploads.filter(
|
|
|
|
upload => upload.remote!.id !== action.payload
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case 'attachment/edit':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
attachments: {
|
|
|
|
...state.attachments,
|
|
|
|
uploads: state.attachments.uploads.map(upload =>
|
|
|
|
upload.remote!.id === action.payload!.id
|
|
|
|
? { ...upload, remote: action.payload }
|
|
|
|
: upload
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case 'visibility':
|
|
|
|
return { ...state, visibility: action.payload }
|
|
|
|
case 'textInputFocus':
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
textInputFocus: { ...state.textInputFocus, ...action.payload }
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
throw new Error('Unexpected action')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default composeReducer
|