frontend-rw #1
2 changed files with 34 additions and 7 deletions
|
@ -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);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue