diff options
| author | 2024-07-17 16:46:52 +0200 | |
|---|---|---|
| committer | 2024-07-17 16:46:52 +0200 | |
| commit | 0aadc2db2a42fc99538fbbb096b84b209b9ccd68 (patch) | |
| tree | 38c58d163004d43da80d33477a6e9f22547bdb15 /web/source/settings/lib | |
| parent | give read-only access to /dev for ffmpeg to access /dev/urandom (#3109) (diff) | |
| download | gotosocial-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')
| -rw-r--r-- | web/source/settings/lib/query/gts-api.ts | 1 | ||||
| -rw-r--r-- | web/source/settings/lib/query/user/index.ts | 37 | ||||
| -rw-r--r-- | web/source/settings/lib/types/account.ts | 11 | ||||
| -rw-r--r-- | web/source/settings/lib/types/interaction.ts | 63 | 
4 files changed, 111 insertions, 1 deletions
| diff --git a/web/source/settings/lib/query/gts-api.ts b/web/source/settings/lib/query/gts-api.ts index f96a55fda..d6741df3a 100644 --- a/web/source/settings/lib/query/gts-api.ts +++ b/web/source/settings/lib/query/gts-api.ts @@ -141,6 +141,7 @@ export const gtsApi = createApi({  		"InstanceRules",  		"HTTPHeaderAllows",  		"HTTPHeaderBlocks", +		"DefaultInteractionPolicies",  	],  	endpoints: (build) => ({  		instanceV1: build.query<InstanceV1, void>({ 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; diff --git a/web/source/settings/lib/types/account.ts b/web/source/settings/lib/types/account.ts index 8fd4e0356..590b2c98e 100644 --- a/web/source/settings/lib/types/account.ts +++ b/web/source/settings/lib/types/account.ts @@ -64,6 +64,17 @@ export interface Account {  	enable_rss: boolean,  	role: any,  	suspended?: boolean, +	source?: AccountSource; +} + +export interface AccountSource { +	fields: any[]; +	follow_requests_count: number; +	language: string; +	note: string; +	privacy: string; +	sensitive: boolean; +	status_content_type: string;  }  export interface SearchAccountParams { diff --git a/web/source/settings/lib/types/interaction.ts b/web/source/settings/lib/types/interaction.ts new file mode 100644 index 000000000..735a20ed2 --- /dev/null +++ b/web/source/settings/lib/types/interaction.ts @@ -0,0 +1,63 @@ +/* +	GoToSocial +	Copyright (C) GoToSocial Authors admin@gotosocial.org +	SPDX-License-Identifier: AGPL-3.0-or-later + +	This program is free software: you can redistribute it and/or modify +	it under the terms of the GNU Affero General Public License as published by +	the Free Software Foundation, either version 3 of the License, or +	(at your option) any later version. + +	This program is distributed in the hope that it will be useful, +	but WITHOUT ANY WARRANTY; without even the implied warranty of +	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +	GNU Affero General Public License for more details. + +	You should have received a copy of the GNU Affero General Public License +	along with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +export interface DefaultInteractionPolicies { +	direct: InteractionPolicy; +	private: InteractionPolicy; +	unlisted: InteractionPolicy; +	public: InteractionPolicy; +} + +export interface UpdateDefaultInteractionPolicies { +	direct: InteractionPolicy | null; +	private: InteractionPolicy | null; +	unlisted: InteractionPolicy | null; +	public: InteractionPolicy | null; +} + +export interface InteractionPolicy { +	can_favourite: InteractionPolicyEntry; +	can_reply: InteractionPolicyEntry; +	can_reblog: InteractionPolicyEntry; +} + +export interface InteractionPolicyEntry { +	always: InteractionPolicyValue[]; +	with_approval: InteractionPolicyValue[]; +} + +export type InteractionPolicyValue = string; + +const PolicyValuePublic: InteractionPolicyValue = "public"; +const PolicyValueFollowers: InteractionPolicyValue = "followers"; +const PolicyValueFollowing: InteractionPolicyValue = "following"; +const PolicyValueMutuals: InteractionPolicyValue = "mutuals"; +const PolicyValueMentioned: InteractionPolicyValue = "mentioned"; +const PolicyValueAuthor: InteractionPolicyValue = "author"; +const PolicyValueMe: InteractionPolicyValue = "me"; + +export { +	PolicyValuePublic, +	PolicyValueFollowers, +	PolicyValueFollowing, +	PolicyValueMutuals, +	PolicyValueMentioned, +	PolicyValueAuthor, +	PolicyValueMe, +}; | 
