pleroma/app/soapbox/queries/accounts.ts

60 lines
1.5 KiB
TypeScript
Raw Normal View History

import { useMutation } from '@tanstack/react-query';
import { patchMeSuccess } from 'soapbox/actions/me';
import snackbar from 'soapbox/actions/snackbar';
import { useApi, useAppDispatch, useOwnAccount } from 'soapbox/hooks';
2022-09-08 09:47:19 -07:00
export type IAccount = {
acct: string
avatar: string
avatar_static: string
bot: boolean
created_at: string
discoverable: boolean
display_name: string
followers_count: number
following_count: number
group: boolean
header: string
header_static: string
id: string
last_status_at: string
location: string
locked: boolean
note: string
statuses_count: number
url: string
username: string
verified: boolean
website: string
}
type UpdateCredentialsData = {
accepting_messages?: boolean
chats_onboarded?: boolean
}
const useUpdateCredentials = () => {
const account = useOwnAccount();
const api = useApi();
const dispatch = useAppDispatch();
return useMutation((data: UpdateCredentialsData) => api.patch('/api/v1/accounts/update_credentials', data), {
onMutate(variables) {
const cachedAccount = account?.toJS();
dispatch(patchMeSuccess({ ...cachedAccount, ...variables }));
return { cachedAccount };
},
onSuccess(response) {
dispatch(patchMeSuccess(response.data));
dispatch(snackbar.success('Chat Settings updated successfully'));
},
onError(_error, _variables, context: any) {
dispatch(snackbar.error('Chat Settings failed to update.'));
dispatch(patchMeSuccess(context.cachedAccount));
},
});
};
export { useUpdateCredentials };