* DRY up video service auth code * throw error if over upload limits * use token * xmark on toast * errors with nice translatable error messages * Update src/state/queries/video/video.ts --------- Co-authored-by: Hailey <me@haileyok.com>
150 lines
4.4 KiB
TypeScript
150 lines
4.4 KiB
TypeScript
import {Insets, Platform} from 'react-native'
|
|
import {AppBskyActorDefs} from '@atproto/api'
|
|
|
|
export const LOCAL_DEV_SERVICE =
|
|
Platform.OS === 'android' ? 'http://10.0.2.2:2583' : 'http://localhost:2583'
|
|
export const STAGING_SERVICE = 'https://staging.bsky.dev'
|
|
export const BSKY_SERVICE = 'https://bsky.social'
|
|
export const PUBLIC_BSKY_SERVICE = 'https://public.api.bsky.app'
|
|
export const DEFAULT_SERVICE = BSKY_SERVICE
|
|
const HELP_DESK_LANG = 'en-us'
|
|
export const HELP_DESK_URL = `https://blueskyweb.zendesk.com/hc/${HELP_DESK_LANG}`
|
|
export const EMBED_SERVICE = 'https://embed.bsky.app'
|
|
export const EMBED_SCRIPT = `${EMBED_SERVICE}/static/embed.js`
|
|
export const BSKY_DOWNLOAD_URL = 'https://bsky.app/download'
|
|
export const STARTER_PACK_MAX_SIZE = 150
|
|
|
|
// HACK
|
|
// Yes, this is exactly what it looks like. It's a hard-coded constant
|
|
// reflecting the number of new users in the last week. We don't have
|
|
// time to add a route to the servers for this so we're just going to hard
|
|
// code and update this number with each release until we can get the
|
|
// server route done.
|
|
// -prf
|
|
export const JOINED_THIS_WEEK = 3060000 // estimate as of 9/6/24
|
|
|
|
const BASE_FEEDBACK_FORM_URL = `${HELP_DESK_URL}/requests/new`
|
|
export function FEEDBACK_FORM_URL({
|
|
email,
|
|
handle,
|
|
}: {
|
|
email?: string
|
|
handle?: string
|
|
}): string {
|
|
let str = BASE_FEEDBACK_FORM_URL
|
|
if (email) {
|
|
str += `?tf_anonymous_requester_email=${encodeURIComponent(email)}`
|
|
if (handle) {
|
|
str += `&tf_17205412673421=${encodeURIComponent(handle)}`
|
|
}
|
|
}
|
|
return str
|
|
}
|
|
|
|
export const MAX_DISPLAY_NAME = 64
|
|
export const MAX_DESCRIPTION = 256
|
|
|
|
export const MAX_GRAPHEME_LENGTH = 300
|
|
|
|
export const MAX_DM_GRAPHEME_LENGTH = 1000
|
|
|
|
// Recommended is 100 per: https://www.w3.org/WAI/GL/WCAG20/tests/test3.html
|
|
// but increasing limit per user feedback
|
|
export const MAX_ALT_TEXT = 1000
|
|
|
|
export function IS_TEST_USER(handle?: string) {
|
|
return handle && handle?.endsWith('.test')
|
|
}
|
|
|
|
export function IS_PROD_SERVICE(url?: string) {
|
|
return url && url !== STAGING_SERVICE && !url.startsWith(LOCAL_DEV_SERVICE)
|
|
}
|
|
|
|
export const PROD_DEFAULT_FEED = (rkey: string) =>
|
|
`at://did:plc:z72i7hdynmk6r22z27h6tvur/app.bsky.feed.generator/${rkey}`
|
|
|
|
export const POST_IMG_MAX = {
|
|
width: 2000,
|
|
height: 2000,
|
|
size: 1000000,
|
|
}
|
|
|
|
export const STAGING_LINK_META_PROXY =
|
|
'https://cardyb.staging.bsky.dev/v1/extract?url='
|
|
|
|
export const PROD_LINK_META_PROXY = 'https://cardyb.bsky.app/v1/extract?url='
|
|
|
|
export function LINK_META_PROXY(serviceUrl: string) {
|
|
if (IS_PROD_SERVICE(serviceUrl)) {
|
|
return PROD_LINK_META_PROXY
|
|
}
|
|
|
|
return STAGING_LINK_META_PROXY
|
|
}
|
|
|
|
export const STATUS_PAGE_URL = 'https://status.bsky.app/'
|
|
|
|
// Hitslop constants
|
|
export const createHitslop = (size: number): Insets => ({
|
|
top: size,
|
|
left: size,
|
|
bottom: size,
|
|
right: size,
|
|
})
|
|
export const HITSLOP_10 = createHitslop(10)
|
|
export const HITSLOP_20 = createHitslop(20)
|
|
export const HITSLOP_30 = createHitslop(30)
|
|
export const POST_CTRL_HITSLOP = {top: 5, bottom: 10, left: 10, right: 10}
|
|
export const BACK_HITSLOP = HITSLOP_30
|
|
export const MAX_POST_LINES = 25
|
|
|
|
export const BSKY_APP_ACCOUNT_DID = 'did:plc:z72i7hdynmk6r22z27h6tvur'
|
|
|
|
export const BSKY_FEED_OWNER_DIDS = [
|
|
BSKY_APP_ACCOUNT_DID,
|
|
'did:plc:vpkhqolt662uhesyj6nxm7ys',
|
|
'did:plc:q6gjnaw2blty4crticxkmujt',
|
|
]
|
|
|
|
export const DISCOVER_FEED_URI =
|
|
'at://did:plc:z72i7hdynmk6r22z27h6tvur/app.bsky.feed.generator/whats-hot'
|
|
export const DISCOVER_SAVED_FEED = {
|
|
type: 'feed',
|
|
value: DISCOVER_FEED_URI,
|
|
pinned: true,
|
|
}
|
|
export const TIMELINE_SAVED_FEED = {
|
|
type: 'timeline',
|
|
value: 'following',
|
|
pinned: true,
|
|
}
|
|
|
|
export const RECOMMENDED_SAVED_FEEDS: Pick<
|
|
AppBskyActorDefs.SavedFeed,
|
|
'type' | 'value' | 'pinned'
|
|
>[] = [DISCOVER_SAVED_FEED, TIMELINE_SAVED_FEED]
|
|
|
|
export const KNOWN_SHUTDOWN_FEEDS = [
|
|
'at://did:plc:wqowuobffl66jv3kpsvo7ak4/app.bsky.feed.generator/the-algorithm', // for you by skygaze
|
|
]
|
|
|
|
export const GIF_SERVICE = 'https://gifs.bsky.app'
|
|
|
|
export const GIF_SEARCH = (params: string) =>
|
|
`${GIF_SERVICE}/tenor/v2/search?${params}`
|
|
export const GIF_FEATURED = (params: string) =>
|
|
`${GIF_SERVICE}/tenor/v2/featured?${params}`
|
|
|
|
export const MAX_LABELERS = 20
|
|
|
|
export const VIDEO_SERVICE = 'https://video.bsky.app'
|
|
export const VIDEO_SERVICE_DID = 'did:web:video.bsky.app'
|
|
|
|
export const SUPPORTED_MIME_TYPES = [
|
|
'video/mp4',
|
|
'video/mpeg',
|
|
'video/webm',
|
|
'video/quicktime',
|
|
] as const
|
|
|
|
export type SupportedMimeTypes = (typeof SUPPORTED_MIME_TYPES)[number]
|