bigbuffet-rw/app/soapbox/utils/accounts.ts

57 lines
1.6 KiB
TypeScript
Raw Normal View History

import type { Account } from 'soapbox/schemas';
2022-03-21 11:09:01 -07:00
2023-06-19 14:49:42 -07:00
const getDomainFromURL = (account: Pick<Account, 'url'>): string => {
try {
2022-03-31 15:00:31 -07:00
const url = account.url;
return new URL(url).host;
} catch {
return '';
}
};
2023-06-19 14:49:42 -07:00
export const getDomain = (account: Pick<Account, 'acct' | 'url'>): string => {
2022-03-31 15:00:31 -07:00
const domain = account.acct.split('@')[1];
return domain ? domain : getDomainFromURL(account);
};
2023-06-19 14:49:42 -07:00
export const getBaseURL = (account: Pick<Account, 'url'>): string => {
try {
2022-04-24 12:28:07 -07:00
return new URL(account.url).origin;
} catch {
return '';
}
};
export const getAcct = (account: Pick<Account, 'fqn' | 'acct'>, displayFqn: boolean): string => (
2023-06-13 18:59:38 -07:00
displayFqn === true ? account.fqn : account.acct
);
2023-06-19 14:49:42 -07:00
export const isLocal = (account: Pick<Account, 'acct'>): boolean => {
const domain: string = account.acct.split('@')[1];
return domain === undefined ? true : false;
};
2023-06-19 14:49:42 -07:00
export const isRemote = (account: Pick<Account, 'acct'>): boolean => !isLocal(account);
/** Default header filenames from various backends */
const DEFAULT_HEADERS = [
'/headers/original/missing.png', // Mastodon
'/images/banner.png', // Pleroma
];
/** Check if the avatar is a default avatar */
export const isDefaultHeader = (url: string) => {
return DEFAULT_HEADERS.some(header => url.endsWith(header));
};
/** Default avatar filenames from various backends */
const DEFAULT_AVATARS = [
'/avatars/original/missing.png', // Mastodon
'/images/avi.png', // Pleroma
];
/** Check if the avatar is a default avatar */
export const isDefaultAvatar = (url: string) => {
return DEFAULT_AVATARS.some(avatar => url.endsWith(avatar));
};