frontend-rw #1

Merged
marcin merged 347 commits from frontend-rw into develop 2024-12-05 15:32:18 -08:00
2 changed files with 34 additions and 7 deletions
Showing only changes of commit 97576b0de1 - Show all commits

View file

@ -241,8 +241,23 @@ import type { PaginatedResponse } from './responses';
const GROUPED_TYPES = ['favourite', 'reblog', 'emoji_reaction', 'event_reminder', 'participation_accepted', 'participation_request']; const GROUPED_TYPES = ['favourite', 'reblog', 'emoji_reaction', 'event_reminder', 'participation_accepted', 'participation_request'];
interface PlApiClientConstructorOpts {
/** Instance object to use by default, to be populated eg. from cache */
instance?: Instance;
/** Fetch instance after constructing */
fetchInstance?: boolean;
/** Abort signal which can be used to cancel the callbacks */
fetchInstanceSignal?: AbortSignal;
/** Executed after the initial instance fetch */
onInstanceFetchSuccess?: (instance: Instance) => void;
/** Executed when the initial instance fetch failed */
onInstanceFetchError?: (error?: any) => void;
}
/** /**
* @category Clients * @category Clients
*
* Mastodon API client.
*/ */
class PlApiClient { class PlApiClient {
@ -259,17 +274,18 @@ class PlApiClient {
close: () => void; close: () => void;
}; };
/**
*
* @param baseURL Mastodon API-compatible server URL
* @param accessToken OAuth token for an authorized user
*/
constructor(baseURL: string, accessToken?: string, { constructor(baseURL: string, accessToken?: string, {
instance, instance,
fetchInstance, fetchInstance,
fetchInstanceSignal,
onInstanceFetchSuccess, onInstanceFetchSuccess,
onInstanceFetchError, onInstanceFetchError,
}: { }: PlApiClientConstructorOpts = {}) {
instance?: Instance;
fetchInstance?: boolean;
onInstanceFetchSuccess?: (instance: Instance) => void;
onInstanceFetchError?: (error?: any) => void;
} = {}) {
this.baseURL = baseURL; this.baseURL = baseURL;
this.#accessToken = accessToken; this.#accessToken = accessToken;
@ -277,7 +293,13 @@ class PlApiClient {
this.#setInstance(instance); this.#setInstance(instance);
} }
if (fetchInstance) { if (fetchInstance) {
this.instance.getInstance().then(onInstanceFetchSuccess).catch(onInstanceFetchError); this.instance.getInstance().then((instance) => {
if (fetchInstanceSignal?.aborted) return;
onInstanceFetchSuccess?.(instance);
}).catch((error) => {
if (fetchInstanceSignal?.aborted) return;
onInstanceFetchError?.(error);
});
} }
} }

View file

@ -22,6 +22,8 @@ interface Params {
/** /**
* @category Clients * @category Clients
*
* joinmastodon.org-compatible server directory client.
*/ */
class PlApiDirectoryClient { class PlApiDirectoryClient {
@ -33,6 +35,9 @@ class PlApiDirectoryClient {
baseURL: string; baseURL: string;
public request = request.bind(this) as typeof request; public request = request.bind(this) as typeof request;
/**
* @param baseURL Server directory URL. e.g. `https://joinmastodon.org`
*/
constructor(baseURL: string) { constructor(baseURL: string) {
this.baseURL = baseURL; this.baseURL = baseURL;
} }