summaryrefslogtreecommitdiff
path: root/web/source/settings/lib/query/user/index.ts
diff options
context:
space:
mode:
authorLibravatar tobi <31960611+tsmethurst@users.noreply.github.com>2024-07-17 16:46:52 +0200
committerLibravatar GitHub <noreply@github.com>2024-07-17 16:46:52 +0200
commit0aadc2db2a42fc99538fbbb096b84b209b9ccd68 (patch)
tree38c58d163004d43da80d33477a6e9f22547bdb15 /web/source/settings/lib/query/user/index.ts
parentgive read-only access to /dev for ffmpeg to access /dev/urandom (#3109) (diff)
downloadgotosocial-0aadc2db2a42fc99538fbbb096b84b209b9ccd68.tar.xz
[feature] Allow users to set default interaction policies per status visibility (#3108)
* [feature] Allow users to set default interaction policies * use vars for default policies * avoid some code repetition * unfuck form binding * avoid bonkers loop * beep boop * put policyValsToAPIPolicyVals in separate function * don't bother with slices.Grow * oops
Diffstat (limited to 'web/source/settings/lib/query/user/index.ts')
-rw-r--r--web/source/settings/lib/query/user/index.ts37
1 files changed, 36 insertions, 1 deletions
diff --git a/web/source/settings/lib/query/user/index.ts b/web/source/settings/lib/query/user/index.ts
index 1f9070bfb..0df926eb3 100644
--- a/web/source/settings/lib/query/user/index.ts
+++ b/web/source/settings/lib/query/user/index.ts
@@ -25,6 +25,7 @@ import type {
} from "../../types/migration";
import type { Theme } from "../../types/theme";
import { User } from "../../types/user";
+import { DefaultInteractionPolicies, UpdateDefaultInteractionPolicies } from "../../types/interaction";
const extended = gtsApi.injectEndpoints({
endpoints: (build) => ({
@@ -38,9 +39,11 @@ const extended = gtsApi.injectEndpoints({
}),
...replaceCacheOnMutation("verifyCredentials")
}),
+
user: build.query<User, void>({
query: () => ({url: `/api/v1/user`})
}),
+
passwordChange: build.mutation({
query: (data) => ({
method: "POST",
@@ -48,6 +51,7 @@ const extended = gtsApi.injectEndpoints({
body: data
})
}),
+
emailChange: build.mutation<User, { password: string, new_email: string }>({
query: (data) => ({
method: "POST",
@@ -56,6 +60,7 @@ const extended = gtsApi.injectEndpoints({
}),
...replaceCacheOnMutation("user")
}),
+
aliasAccount: build.mutation<any, UpdateAliasesFormData>({
async queryFn(formData, _api, _extraOpts, fetchWithBQ) {
// Pull entries out from the hooked form.
@@ -73,6 +78,7 @@ const extended = gtsApi.injectEndpoints({
});
}
}),
+
moveAccount: build.mutation<any, MoveAccountFormData>({
query: (data) => ({
method: "POST",
@@ -80,11 +86,37 @@ const extended = gtsApi.injectEndpoints({
body: data
})
}),
+
accountThemes: build.query<Theme[], void>({
query: () => ({
url: `/api/v1/accounts/themes`
})
- })
+ }),
+
+ defaultInteractionPolicies: build.query<DefaultInteractionPolicies, void>({
+ query: () => ({
+ url: `/api/v1/interaction_policies/defaults`
+ }),
+ providesTags: ["DefaultInteractionPolicies"]
+ }),
+
+ updateDefaultInteractionPolicies: build.mutation<DefaultInteractionPolicies, UpdateDefaultInteractionPolicies>({
+ query: (data) => ({
+ method: "PATCH",
+ url: `/api/v1/interaction_policies/defaults`,
+ body: data,
+ }),
+ ...replaceCacheOnMutation("defaultInteractionPolicies")
+ }),
+
+ resetDefaultInteractionPolicies: build.mutation<DefaultInteractionPolicies, void>({
+ query: () => ({
+ method: "PATCH",
+ url: `/api/v1/interaction_policies/defaults`,
+ body: {},
+ }),
+ invalidatesTags: ["DefaultInteractionPolicies"]
+ }),
})
});
@@ -96,4 +128,7 @@ export const {
useAliasAccountMutation,
useMoveAccountMutation,
useAccountThemesQuery,
+ useDefaultInteractionPoliciesQuery,
+ useUpdateDefaultInteractionPoliciesMutation,
+ useResetDefaultInteractionPoliciesMutation,
} = extended;