diff options
Diffstat (limited to 'web/source/settings/lib')
| -rw-r--r-- | web/source/settings/lib/query/admin/index.ts | 13 | ||||
| -rw-r--r-- | web/source/settings/lib/query/gts-api.ts | 6 | ||||
| -rw-r--r-- | web/source/settings/lib/types/account.ts | 6 | 
3 files changed, 20 insertions, 5 deletions
| diff --git a/web/source/settings/lib/query/admin/index.ts b/web/source/settings/lib/query/admin/index.ts index cbe66705b..3e7b1a0a0 100644 --- a/web/source/settings/lib/query/admin/index.ts +++ b/web/source/settings/lib/query/admin/index.ts @@ -20,8 +20,9 @@  import { replaceCacheOnMutation, removeFromCacheOnMutation } from "../query-modifiers";  import { gtsApi } from "../gts-api";  import { listToKeyedObject } from "../transforms"; -import { AdminAccount, HandleSignupParams, SearchAccountParams } from "../../types/account"; +import { AdminAccount, HandleSignupParams, SearchAccountParams, SearchAccountResp } from "../../types/account";  import { InstanceRule, MappedRules } from "../../types/rules"; +import parse from "parse-link-header";  const extended = gtsApi.injectEndpoints({  	endpoints: (build) => ({ @@ -65,7 +66,7 @@ const extended = gtsApi.injectEndpoints({  			],  		}), -		searchAccounts: build.query<AdminAccount[], SearchAccountParams>({ +		searchAccounts: build.query<SearchAccountResp, SearchAccountParams>({  			query: (form) => {  				const params = new(URLSearchParams);  				Object.entries(form).forEach(([k, v]) => { @@ -83,10 +84,16 @@ const extended = gtsApi.injectEndpoints({  					url: `/api/v2/admin/accounts${query}`  				};  			}, +			transformResponse: (apiResp: AdminAccount[], meta) => { +				const accounts = apiResp; +				const linksStr = meta?.response?.headers.get("Link"); +				const links = parse(linksStr); +				return { accounts, links }; +			},  			providesTags: (res) =>  				res  					? [ -						...res.map(({ id }) => ({ type: 'Account' as const, id })), +						...res.accounts.map(({ id }) => ({ type: 'Account' as const, id })),  						{ type: 'Account', id: 'LIST' },  					  ]  					: [{ type: 'Account', id: 'LIST' }], diff --git a/web/source/settings/lib/query/gts-api.ts b/web/source/settings/lib/query/gts-api.ts index a07f5ff1e..6e5eafeab 100644 --- a/web/source/settings/lib/query/gts-api.ts +++ b/web/source/settings/lib/query/gts-api.ts @@ -24,7 +24,7 @@ import type {  	FetchBaseQueryError,  } from '@reduxjs/toolkit/query/react';  import { serialize as serializeForm } from "object-to-formdata"; - +import type { FetchBaseQueryMeta } from "@reduxjs/toolkit/dist/query/fetchBaseQuery";  import type { RootState } from '../../redux/store';  import { InstanceV1 } from '../types/instance'; @@ -65,7 +65,9 @@ export interface GTSFetchArgs extends FetchArgs {  const gtsBaseQuery: BaseQueryFn<  	string | GTSFetchArgs,  	any, -	FetchBaseQueryError +	FetchBaseQueryError, +	{}, +	FetchBaseQueryMeta  > = async (args, api, extraOptions) => {  	// Retrieve state at the moment  	// this function was called. diff --git a/web/source/settings/lib/types/account.ts b/web/source/settings/lib/types/account.ts index 3e7e9640d..db97001ac 100644 --- a/web/source/settings/lib/types/account.ts +++ b/web/source/settings/lib/types/account.ts @@ -17,6 +17,7 @@  	along with this program.  If not, see <http://www.gnu.org/licenses/>.  */ +import { Links } from "parse-link-header";  import { CustomEmoji } from "./custom-emoji";  export interface AdminAccount { @@ -79,6 +80,11 @@ export interface SearchAccountParams {  	limit?: number,  } +export interface SearchAccountResp { +	accounts: AdminAccount[]; +	links: Links | null; +} +  export interface HandleSignupParams {  	id: string,  	approve_or_reject: "approve" | "reject", | 
