296ef9214b
SHA256:17ea8854a3504752a8ae4540ecb09e62f6f8aa260221d3619fda46f66b2ec43f
1 line
721 KiB
Plaintext
1 line
721 KiB
Plaintext
{"version":3,"file":"main-O03IOhxZ.js","sources":["../../src/utils/usePageVisibility.js","../../src/components/background-service.jsx","../../src/components/compose-button.jsx","../../src/components/keyboard-shortcuts-help.jsx","../../src/pages/accounts.jsx","../../src/assets/logo.svg","../../src/utils/push-notifications.js","../../src/pages/settings.jsx","../../src/utils/focus-deck.jsx","../../src/utils/useLocationChange.js","../../src/components/list-add-edit.jsx","../../src/components/account-info.jsx","../../src/components/account-sheet.jsx","../../src/components/drafts.jsx","../../src/utils/relationships.js","../../src/components/generic-accounts.jsx","../../src/components/media-alt-modal.jsx","../../src/utils/color-utils.js","../../src/components/media-modal.jsx","../../src/assets/floating-button.svg","../../src/assets/multi-column.svg","../../src/assets/tab-menu-bar.svg","../../src/utils/followed-tags.js","../../src/components/AsyncText.jsx","../../src/components/shortcuts-settings.jsx","../../src/components/modals.jsx","../../src/components/follow-request-buttons.jsx","../../src/components/notification.jsx","../../src/components/notification-service.jsx","../../src/components/search-form.jsx","../../src/components/search-command.jsx","../../src/components/shortcuts.jsx","../../src/utils/timeline-utils.jsx","../../src/utils/useScroll.js","../../src/utils/useScrollFn.js","../../src/components/media-post.jsx","../../src/components/nav-menu.jsx","../../src/components/timeline.jsx","../../src/pages/account-statuses.jsx","../../src/pages/bookmarks.jsx","../../src/pages/favourites.jsx","../../src/pages/followed-hashtags.jsx","../../src/pages/following.jsx","../../src/pages/hashtag.jsx","../../src/pages/list.jsx","../../src/pages/mentions.jsx","../../src/utils/group-notifications.jsx","../../src/pages/notifications.jsx","../../src/pages/public.jsx","../../src/pages/search.jsx","../../src/pages/trending.jsx","../../src/components/columns.jsx","../../src/pages/home.jsx","../../src/utils/get-instance-status-url.js","../../src/pages/http-route.jsx","../../src/pages/lists.jsx","../../src/data/instances.json?url","../../src/utils/auth.js","../../src/pages/login.jsx","../../src/pages/status.jsx","../../src/pages/status-route.jsx","../../src/assets/features/boosts-carousel.jpg","../../src/assets/features/grouped-notifications.jpg","../../src/assets/features/multi-column.jpg","../../src/assets/features/multi-hashtag-timeline.jpg","../../src/assets/features/nested-comments-thread.jpg","../../src/assets/logo-text.svg","../../src/pages/welcome.jsx","../../src/utils/toast-alert.js","../../src/app.jsx","../../src/main.jsx"],"sourcesContent":["import { useEffect, useRef } from 'preact/hooks';\n\nexport default function usePageVisibility(fn = () => {}, deps = []) {\n const savedCallback = useRef(fn);\n useEffect(() => {\n savedCallback.current = fn;\n }, [deps]);\n\n useEffect(() => {\n const handleVisibilityChange = () => {\n const hidden = document.hidden || document.visibilityState === 'hidden';\n console.log('👀 Page visibility changed', hidden ? 'hidden' : 'visible');\n savedCallback.current(!hidden);\n };\n\n document.addEventListener('visibilitychange', handleVisibilityChange);\n return () =>\n document.removeEventListener('visibilitychange', handleVisibilityChange);\n }, []);\n}\n","import { memo } from 'preact/compat';\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\n\nimport { api } from '../utils/api';\nimport showToast from '../utils/show-toast';\nimport states, { saveStatus } from '../utils/states';\nimport useInterval from '../utils/useInterval';\nimport usePageVisibility from '../utils/usePageVisibility';\n\nconst STREAMING_TIMEOUT = 1000 * 3; // 3 seconds\nconst POLL_INTERVAL = 15_000; // 15 seconds\n\nexport default memo(function BackgroundService({ isLoggedIn }) {\n // Notifications service\n // - WebSocket to receive notifications when page is visible\n const [visible, setVisible] = useState(true);\n usePageVisibility(setVisible);\n const checkLatestNotification = async (masto, instance, skipCheckMarkers) => {\n if (states.notificationsLast) {\n const notificationsIterator = masto.v1.notifications.list({\n limit: 1,\n sinceId: states.notificationsLast.id,\n });\n const { value: notifications } = await notificationsIterator.next();\n if (notifications?.length) {\n if (skipCheckMarkers) {\n states.notificationsShowNew = true;\n } else {\n let lastReadId;\n try {\n const markers = await masto.v1.markers.fetch({\n timeline: 'notifications',\n });\n lastReadId = markers?.notifications?.lastReadId;\n } catch (e) {}\n if (lastReadId) {\n states.notificationsShowNew = notifications[0].id !== lastReadId;\n } else {\n states.notificationsShowNew = true;\n }\n }\n }\n }\n };\n\n useEffect(() => {\n let sub;\n let pollNotifications;\n if (isLoggedIn && visible) {\n const { masto, streaming, instance } = api();\n (async () => {\n // 1. Get the latest notification\n await checkLatestNotification(masto, instance);\n\n let hasStreaming = false;\n // 2. Start streaming\n if (streaming) {\n pollNotifications = setTimeout(() => {\n (async () => {\n try {\n hasStreaming = true;\n sub = streaming.user.notification.subscribe();\n console.log('🎏 Streaming notification', sub);\n for await (const entry of sub) {\n if (!sub) break;\n if (!visible) break;\n console.log('🔔🔔 Notification entry', entry);\n if (entry.event === 'notification') {\n console.log('🔔🔔 Notification', entry);\n saveStatus(entry.payload, instance, {\n skipThreading: true,\n });\n }\n states.notificationsShowNew = true;\n }\n console.log('💥 Streaming notification loop STOPPED');\n } catch (e) {\n hasStreaming = false;\n console.error(e);\n }\n\n if (!hasStreaming) {\n console.log('🎏 Streaming failed, fallback to polling');\n pollNotifications = setInterval(() => {\n checkLatestNotification(masto, instance, true);\n }, POLL_INTERVAL);\n }\n })();\n }, STREAMING_TIMEOUT);\n }\n })();\n }\n return () => {\n sub?.unsubscribe?.();\n sub = null;\n clearTimeout(pollNotifications);\n clearInterval(pollNotifications);\n };\n }, [visible, isLoggedIn]);\n\n // Check for updates service\n const lastCheckDate = useRef();\n const checkForUpdates = () => {\n lastCheckDate.current = Date.now();\n console.log('✨ Check app update');\n fetch('./version.json')\n .then((r) => r.json())\n .then((info) => {\n if (info) states.appVersion = info;\n })\n .catch((e) => {\n console.error(e);\n });\n };\n useInterval(checkForUpdates, visible && 1000 * 60 * 30); // 30 minutes\n usePageVisibility((visible) => {\n if (visible) {\n if (!lastCheckDate.current) {\n checkForUpdates();\n } else {\n const diff = Date.now() - lastCheckDate.current;\n if (diff > 1000 * 60 * 60) {\n // 1 hour\n checkForUpdates();\n }\n }\n }\n });\n\n // Global keyboard shortcuts \"service\"\n useHotkeys('shift+alt+k', () => {\n const currentCloakMode = states.settings.cloakMode;\n states.settings.cloakMode = !currentCloakMode;\n showToast({\n text: `Cloak mode ${currentCloakMode ? 'disabled' : 'enabled'}`,\n });\n });\n\n return null;\n});\n","import { useHotkeys } from 'react-hotkeys-hook';\n\nimport openCompose from '../utils/open-compose';\nimport states from '../utils/states';\n\nimport Icon from './icon';\n\nexport default function ComposeButton() {\n function handleButton(e) {\n if (e.shiftKey) {\n const newWin = openCompose();\n\n if (!newWin) {\n states.showCompose = true;\n }\n } else {\n states.showCompose = true;\n }\n }\n\n useHotkeys('c, shift+c', handleButton, {\n ignoreEventWhen: (e) => {\n const hasModal = !!document.querySelector('#modal-container > *');\n return hasModal;\n },\n });\n\n return (\n <button type=\"button\" id=\"compose-button\" onClick={handleButton}>\n <Icon icon=\"quill\" size=\"xl\" alt=\"Compose\" />\n </button>\n );\n}\n","import './keyboard-shortcuts-help.css';\n\nimport { memo } from 'preact/compat';\nimport { useHotkeys } from 'react-hotkeys-hook';\nimport { useSnapshot } from 'valtio';\n\nimport states from '../utils/states';\n\nimport Icon from './icon';\nimport Modal from './modal';\n\nexport default memo(function KeyboardShortcutsHelp() {\n const snapStates = useSnapshot(states);\n\n function onClose() {\n states.showKeyboardShortcutsHelp = false;\n }\n\n useHotkeys(\n '?, shift+?',\n (e) => {\n console.log('help');\n states.showKeyboardShortcutsHelp = true;\n },\n {\n ignoreEventWhen: (e) => {\n const hasModal = !!document.querySelector('#modal-container > *');\n return hasModal;\n },\n },\n );\n\n return (\n !!snapStates.showKeyboardShortcutsHelp && (\n <Modal class=\"light\" onClose={onClose}>\n <div id=\"keyboard-shortcuts-help-container\" class=\"sheet\" tabindex=\"-1\">\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n <header>\n <h2>Keyboard shortcuts</h2>\n </header>\n <main>\n <table>\n {[\n {\n action: 'Keyboard shortcuts help',\n keys: <kbd>?</kbd>,\n },\n {\n action: 'Next post',\n keys: <kbd>j</kbd>,\n },\n {\n action: 'Previous post',\n keys: <kbd>k</kbd>,\n },\n {\n action: 'Skip carousel to next post',\n keys: (\n <>\n <kbd>Shift</kbd> + <kbd>j</kbd>\n </>\n ),\n },\n {\n action: 'Skip carousel to previous post',\n keys: (\n <>\n <kbd>Shift</kbd> + <kbd>k</kbd>\n </>\n ),\n },\n {\n action: 'Open post details',\n keys: (\n <>\n <kbd>Enter</kbd> or <kbd>o</kbd>\n </>\n ),\n },\n {\n action: (\n <>\n Expand content warning or\n <br />\n toggle expanded/collapsed thread\n </>\n ),\n keys: <kbd>x</kbd>,\n },\n {\n action: 'Close post or dialogs',\n keys: (\n <>\n <kbd>Esc</kbd> or <kbd>Backspace</kbd>\n </>\n ),\n },\n {\n action: 'Focus column in multi-column mode',\n keys: (\n <>\n <kbd>1</kbd> to <kbd>9</kbd>\n </>\n ),\n },\n {\n action: 'Compose new post',\n keys: <kbd>c</kbd>,\n },\n {\n action: 'Compose new post (new window)',\n className: 'insignificant',\n keys: (\n <>\n <kbd>Shift</kbd> + <kbd>c</kbd>\n </>\n ),\n },\n {\n action: 'Send post',\n keys: (\n <>\n <kbd>Ctrl</kbd> + <kbd>Enter</kbd> or <kbd>⌘</kbd> +{' '}\n <kbd>Enter</kbd>\n </>\n ),\n },\n {\n action: 'Search',\n keys: <kbd>/</kbd>,\n },\n {\n action: 'Reply',\n keys: <kbd>r</kbd>,\n },\n {\n action: 'Reply (new window)',\n className: 'insignificant',\n keys: (\n <>\n <kbd>Shift</kbd> + <kbd>r</kbd>\n </>\n ),\n },\n {\n action: 'Like (favourite)',\n keys: (\n <>\n <kbd>l</kbd> or <kbd>f</kbd>\n </>\n ),\n },\n {\n action: 'Boost',\n keys: (\n <>\n <kbd>Shift</kbd> + <kbd>b</kbd>\n </>\n ),\n },\n {\n action: 'Bookmark',\n keys: <kbd>d</kbd>,\n },\n {\n action: 'Toggle Cloak mode',\n keys: (\n <>\n <kbd>Shift</kbd> + <kbd>Alt</kbd> + <kbd>k</kbd>\n </>\n ),\n },\n ].map(({ action, className, keys }) => (\n <tr key={action}>\n <th class={className}>{action}</th>\n <td>{keys}</td>\n </tr>\n ))}\n </table>\n </main>\n </div>\n </Modal>\n )\n );\n});\n","import './accounts.css';\n\nimport { useAutoAnimate } from '@formkit/auto-animate/preact';\nimport { Menu, MenuDivider, MenuItem } from '@szhsin/react-menu';\nimport { useReducer } from 'preact/hooks';\n\nimport Avatar from '../components/avatar';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Menu2 from '../components/menu2';\nimport MenuConfirm from '../components/menu-confirm';\nimport NameText from '../components/name-text';\nimport { api } from '../utils/api';\nimport states from '../utils/states';\nimport store from '../utils/store';\n\nfunction Accounts({ onClose }) {\n const { masto } = api();\n // Accounts\n const accounts = store.local.getJSON('accounts');\n const currentAccount = store.session.get('currentAccount');\n const moreThanOneAccount = accounts.length > 1;\n\n const [_, reload] = useReducer((x) => x + 1, 0);\n const [accountsListParent] = useAutoAnimate();\n\n return (\n <div id=\"accounts-container\" class=\"sheet\" tabIndex=\"-1\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header class=\"header-grid\">\n <h2>Accounts</h2>\n </header>\n <main>\n <section>\n <ul class=\"accounts-list\" ref={accountsListParent}>\n {accounts.map((account, i) => {\n const isCurrent = account.info.id === currentAccount;\n const isDefault = i === 0; // first account is always default\n return (\n <li key={account.info.id}>\n <div>\n {moreThanOneAccount && (\n <span class={`current ${isCurrent ? 'is-current' : ''}`}>\n <Icon icon=\"check-circle\" alt=\"Current\" />\n </span>\n )}\n <Avatar\n url={account.info.avatarStatic}\n size=\"xxl\"\n onDblClick={async () => {\n if (isCurrent) {\n try {\n const info = await masto.v1.accounts\n .$select(account.info.id)\n .fetch();\n console.log('fetched account info', info);\n account.info = info;\n store.local.setJSON('accounts', accounts);\n reload();\n } catch (e) {}\n }\n }}\n />\n <NameText\n account={\n moreThanOneAccount\n ? {\n ...account.info,\n acct: /@/.test(account.info.acct)\n ? account.info.acct\n : `${account.info.acct}@${account.instanceURL}`,\n }\n : account.info\n }\n showAcct\n onClick={() => {\n if (isCurrent) {\n states.showAccount = `${account.info.username}@${account.instanceURL}`;\n } else {\n store.session.set('currentAccount', account.info.id);\n location.reload();\n }\n }}\n />\n </div>\n <div class=\"actions\">\n {isDefault && moreThanOneAccount && (\n <>\n <span class=\"tag\">Default</span>{' '}\n </>\n )}\n <Menu2\n align=\"end\"\n menuButton={\n <button\n type=\"button\"\n title=\"More\"\n class=\"plain more-button\"\n >\n <Icon icon=\"more\" size=\"l\" alt=\"More\" />\n </button>\n }\n >\n <MenuItem\n onClick={() => {\n states.showAccount = `${account.info.username}@${account.instanceURL}`;\n }}\n >\n <Icon icon=\"user\" />\n <span>View profile…</span>\n </MenuItem>\n <MenuDivider />\n {moreThanOneAccount && (\n <MenuItem\n disabled={isDefault}\n onClick={() => {\n // Move account to the top of the list\n accounts.splice(i, 1);\n accounts.unshift(account);\n store.local.setJSON('accounts', accounts);\n reload();\n }}\n >\n <Icon icon=\"check-circle\" />\n <span>Set as default</span>\n </MenuItem>\n )}\n <MenuConfirm\n subMenu\n confirmLabel={\n <>\n <Icon icon=\"exit\" />\n <span>Log out @{account.info.acct}?</span>\n </>\n }\n disabled={!isCurrent}\n menuItemClassName=\"danger\"\n onClick={() => {\n // const yes = confirm('Log out?');\n // if (!yes) return;\n accounts.splice(i, 1);\n store.local.setJSON('accounts', accounts);\n // location.reload();\n location.href = location.pathname || '/';\n }}\n >\n <Icon icon=\"exit\" />\n <span>Log out…</span>\n </MenuConfirm>\n </Menu2>\n </div>\n </li>\n );\n })}\n </ul>\n <p>\n <Link to=\"/login\" class=\"button plain2\" onClick={onClose}>\n <Icon icon=\"plus\" /> <span>Add an existing account</span>\n </Link>\n </p>\n {moreThanOneAccount && (\n <p>\n <small>\n Note: <i>Default</i> account will always be used for first load.\n Switched accounts will persist during the session.\n </small>\n </p>\n )}\n </section>\n </main>\n </div>\n );\n}\n\nexport default Accounts;\n","export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xml:space='preserve'%20fill-rule='evenodd'%20stroke-linejoin='round'%20stroke-miterlimit='2'%20clip-rule='evenodd'%20viewBox='0%200%2064%2064'%3e%3cpath%20fill='none'%20d='M0%200h63.994v63.994H0z'/%3e%3cpath%20fill='%23a4bff7'%20d='M37.774%2011.471c14.639%203.752%2019.034%2016.557%2015.889%2031.304-.696%203.261-2.563%206.661-6.356%208.693-3.204%201.717-8.07%202.537-15.338.55l-9.634-2.404C11.651%2046.992%208.378%2038.733%2010.027%2031.823c3.627-15.201%2015.543-23.48%2027.747-20.352Z'/%3e%3cpath%20fill='%23d8e7fe'%20d='M36.76%2015.429c12.289%203.15%2015.547%2014.114%2012.907%2026.493-.947%204.44-4.937%209.365-16.664%206.143l-9.684-2.417c-7.854-1.923-10.53-7.8-9.318-12.877%203.016-12.639%2012.611-19.943%2022.759-17.342Z'/%3e%3cpath%20fill='%236081e6'%20d='M27.471%2024.991c-1.457-.698-7.229%203.213-7.663%208.926-.182%202.39%204.55%203.237%205.071-.169.725-4.743%203.715-8.218%202.592-8.757Zm10.746%202.005c-2.083.327-.382%205.901-.595%2010.727-.123%202.8%204.388%203.464%204.703%202.011%201.098-5.073-2.066-13.058-4.108-12.738Z'/%3e%3c/svg%3e\"","// Utils for push notifications\nimport { api } from './api';\nimport { getCurrentAccount } from './store-utils';\n\n// Subscription is an object with the following structure:\n// {\n// data: {\n// alerts: {\n// admin: {\n// report: boolean,\n// signUp: boolean,\n// },\n// favourite: boolean,\n// follow: boolean,\n// mention: boolean,\n// poll: boolean,\n// reblog: boolean,\n// status: boolean,\n// update: boolean,\n// }\n// },\n// policy: \"all\" | \"followed\" | \"follower\" | \"none\",\n// subscription: {\n// endpoint: string,\n// keys: {\n// auth: string,\n// p256dh: string,\n// },\n// },\n// }\n\n// Back-end CRUD\n// =============\n\nfunction createBackendPushSubscription(subscription) {\n const { masto } = api();\n return masto.v1.push.subscription.create(subscription);\n}\n\nfunction fetchBackendPushSubscription() {\n const { masto } = api();\n return masto.v1.push.subscription.fetch();\n}\n\nfunction updateBackendPushSubscription(subscription) {\n const { masto } = api();\n return masto.v1.push.subscription.update(subscription);\n}\n\nfunction removeBackendPushSubscription() {\n const { masto } = api();\n return masto.v1.push.subscription.remove();\n}\n\n// Front-end\n// =========\n\nexport function isPushSupported() {\n return 'serviceWorker' in navigator && 'PushManager' in window;\n}\n\nexport function getRegistration() {\n // return navigator.serviceWorker.ready;\n return navigator.serviceWorker.getRegistration();\n}\n\nasync function getSubscription() {\n const registration = await getRegistration();\n const subscription = registration\n ? await registration.pushManager.getSubscription()\n : undefined;\n return { registration, subscription };\n}\n\nfunction urlBase64ToUint8Array(base64String) {\n const padding = '='.repeat((4 - (base64String.length % 4)) % 4);\n const base64 = `${base64String}${padding}`\n .replace(/-/g, '+')\n .replace(/_/g, '/');\n\n const rawData = window.atob(base64);\n const outputArray = new Uint8Array(rawData.length);\n\n for (let i = 0; i < rawData.length; ++i) {\n outputArray[i] = rawData.charCodeAt(i);\n }\n\n return outputArray;\n}\n\n// Front-end <-> back-end\n// ======================\n\nexport async function initSubscription() {\n if (!isPushSupported()) return;\n const { subscription } = await getSubscription();\n let backendSubscription = null;\n try {\n backendSubscription = await fetchBackendPushSubscription();\n } catch (err) {\n if (/(not found|unknown)/i.test(err.message)) {\n // No subscription found\n } else {\n // Other error\n throw err;\n }\n }\n console.log('INIT subscription', {\n subscription,\n backendSubscription,\n });\n\n // Check if the subscription changed\n if (backendSubscription && subscription) {\n const sameEndpoint = backendSubscription.endpoint === subscription.endpoint;\n const { vapidKey } = getCurrentAccount();\n const sameKey = backendSubscription.serverKey === vapidKey;\n if (!sameEndpoint) {\n throw new Error('Backend subscription endpoint changed');\n }\n if (sameKey) {\n // Subscription didn't change\n } else {\n // Subscription changed\n console.error('🔔 Subscription changed', {\n sameEndpoint,\n serverKey: backendSubscription.serverKey,\n vapIdKey: vapidKey,\n endpoint1: backendSubscription.endpoint,\n endpoint2: subscription.endpoint,\n sameKey,\n key1: backendSubscription.serverKey,\n key2: vapidKey,\n });\n throw new Error('Backend subscription key and vapid key changed');\n // Only unsubscribe from backend, not from browser\n // await removeBackendPushSubscription();\n // // Now let's resubscribe\n // // NOTE: I have no idea if this works\n // return await updateSubscription({\n // data: backendSubscription.data,\n // policy: backendSubscription.policy,\n // });\n }\n }\n\n if (subscription && !backendSubscription) {\n // check if account's vapidKey is same as subscription's applicationServerKey\n const { vapidKey } = getCurrentAccount();\n const { applicationServerKey } = subscription.options;\n const vapidKeyStr = urlBase64ToUint8Array(vapidKey).toString();\n const applicationServerKeyStr = new Uint8Array(\n applicationServerKey,\n ).toString();\n const sameKey = vapidKeyStr === applicationServerKeyStr;\n if (sameKey) {\n // Subscription didn't change\n } else {\n // Subscription changed\n console.error('🔔 Subscription changed', {\n vapidKeyStr,\n applicationServerKeyStr,\n sameKey,\n });\n // Unsubscribe since backend doesn't have a subscription\n await subscription.unsubscribe();\n throw new Error('Subscription key and vapid key changed');\n }\n }\n\n // Check if backend subscription returns 404\n // if (subscription && !backendSubscription) {\n // // Re-subscribe to backend\n // backendSubscription = await createBackendPushSubscription({\n // subscription,\n // data: {},\n // policy: 'all',\n // });\n // }\n\n return { subscription, backendSubscription };\n}\n\nexport async function updateSubscription({ data, policy }) {\n console.log('🔔 Updating subscription', { data, policy });\n if (!isPushSupported()) return;\n let { registration, subscription } = await getSubscription();\n let backendSubscription = null;\n\n if (subscription) {\n try {\n backendSubscription = await updateBackendPushSubscription({\n data,\n policy,\n });\n // TODO: save subscription in user settings\n } catch (error) {\n // Backend doesn't have a subscription for this user\n // Create a new one\n backendSubscription = await createBackendPushSubscription({\n subscription,\n data,\n policy,\n });\n // TODO: save subscription in user settings\n }\n } else {\n // User is not subscribed\n const { vapidKey } = getCurrentAccount();\n if (!vapidKey) throw new Error('No server key found');\n subscription = await registration.pushManager.subscribe({\n userVisibleOnly: true,\n applicationServerKey: urlBase64ToUint8Array(vapidKey),\n });\n backendSubscription = await createBackendPushSubscription({\n subscription,\n data,\n policy,\n });\n // TODO: save subscription in user settings\n }\n\n return { subscription, backendSubscription };\n}\n\nexport async function removeSubscription() {\n if (!isPushSupported()) return;\n const { subscription } = await getSubscription();\n if (subscription) {\n await removeBackendPushSubscription();\n await subscription.unsubscribe();\n }\n}\n","import './settings.css';\n\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport logo from '../assets/logo.svg';\n\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport RelativeTime from '../components/relative-time';\nimport targetLanguages from '../data/lingva-target-languages';\nimport { api } from '../utils/api';\nimport getTranslateTargetLanguage from '../utils/get-translate-target-language';\nimport localeCode2Text from '../utils/localeCode2Text';\nimport {\n initSubscription,\n isPushSupported,\n removeSubscription,\n updateSubscription,\n} from '../utils/push-notifications';\nimport showToast from '../utils/show-toast';\nimport states from '../utils/states';\nimport store from '../utils/store';\n\nconst DEFAULT_TEXT_SIZE = 16;\nconst TEXT_SIZES = [15, 16, 17, 18, 19, 20];\nconst {\n PHANPY_WEBSITE: WEBSITE,\n PHANPY_PRIVACY_POLICY_URL: PRIVACY_POLICY_URL,\n PHANPY_IMG_ALT_API_URL: IMG_ALT_API_URL,\n} = import.meta.env;\n\nfunction Settings({ onClose }) {\n const snapStates = useSnapshot(states);\n const currentTheme = store.local.get('theme') || 'auto';\n const themeFormRef = useRef();\n const targetLanguage =\n snapStates.settings.contentTranslationTargetLanguage || null;\n const systemTargetLanguage = getTranslateTargetLanguage();\n const systemTargetLanguageText = localeCode2Text(systemTargetLanguage);\n const currentTextSize = store.local.get('textSize') || DEFAULT_TEXT_SIZE;\n\n const [prefs, setPrefs] = useState(store.account.get('preferences') || {});\n const { masto, authenticated, instance } = api();\n // Get preferences every time Settings is opened\n // NOTE: Disabled for now because I don't expect this to change often. Also for some reason, the /api/v1/preferences endpoint is cached for a while and return old prefs if refresh immediately after changing them.\n // useEffect(() => {\n // const { masto } = api();\n // (async () => {\n // try {\n // const preferences = await masto.v1.preferences.fetch();\n // setPrefs(preferences);\n // store.account.set('preferences', preferences);\n // } catch (e) {\n // // Silently fail\n // console.error(e);\n // }\n // })();\n // }, []);\n\n return (\n <div id=\"settings-container\" class=\"sheet\" tabIndex=\"-1\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>Settings</h2>\n </header>\n <main>\n <section>\n <ul>\n <li>\n <div>\n <label>Appearance</label>\n </div>\n <div>\n <form\n ref={themeFormRef}\n onInput={(e) => {\n console.log(e);\n e.preventDefault();\n const formData = new FormData(themeFormRef.current);\n const theme = formData.get('theme');\n const html = document.documentElement;\n\n if (theme === 'auto') {\n html.classList.remove('is-light', 'is-dark');\n\n // Disable manual theme <meta>\n const $manualMeta = document.querySelector(\n 'meta[data-theme-setting=\"manual\"]',\n );\n if ($manualMeta) {\n $manualMeta.name = '';\n }\n // Enable auto theme <meta>s\n const $autoMetas = document.querySelectorAll(\n 'meta[data-theme-setting=\"auto\"]',\n );\n $autoMetas.forEach((m) => {\n m.name = 'theme-color';\n });\n } else {\n html.classList.toggle('is-light', theme === 'light');\n html.classList.toggle('is-dark', theme === 'dark');\n\n // Enable manual theme <meta>\n const $manualMeta = document.querySelector(\n 'meta[data-theme-setting=\"manual\"]',\n );\n if ($manualMeta) {\n $manualMeta.name = 'theme-color';\n $manualMeta.content =\n theme === 'light'\n ? $manualMeta.dataset.themeLightColor\n : $manualMeta.dataset.themeDarkColor;\n }\n // Disable auto theme <meta>s\n const $autoMetas = document.querySelectorAll(\n 'meta[data-theme-setting=\"auto\"]',\n );\n $autoMetas.forEach((m) => {\n m.name = '';\n });\n }\n document\n .querySelector('meta[name=\"color-scheme\"]')\n .setAttribute(\n 'content',\n theme === 'auto' ? 'dark light' : theme,\n );\n\n if (theme === 'auto') {\n store.local.del('theme');\n } else {\n store.local.set('theme', theme);\n }\n }}\n >\n <div class=\"radio-group\">\n <label>\n <input\n type=\"radio\"\n name=\"theme\"\n value=\"light\"\n defaultChecked={currentTheme === 'light'}\n />\n <span>Light</span>\n </label>\n <label>\n <input\n type=\"radio\"\n name=\"theme\"\n value=\"dark\"\n defaultChecked={currentTheme === 'dark'}\n />\n <span>Dark</span>\n </label>\n <label>\n <input\n type=\"radio\"\n name=\"theme\"\n value=\"auto\"\n defaultChecked={\n currentTheme !== 'light' && currentTheme !== 'dark'\n }\n />\n <span>Auto</span>\n </label>\n </div>\n </form>\n </div>\n </li>\n <li>\n <div>\n <label>Text size</label>\n </div>\n <div class=\"range-group\">\n <span style={{ fontSize: TEXT_SIZES[0] }}>A</span>{' '}\n <input\n type=\"range\"\n min={TEXT_SIZES[0]}\n max={TEXT_SIZES[TEXT_SIZES.length - 1]}\n step=\"1\"\n value={currentTextSize}\n list=\"sizes\"\n onChange={(e) => {\n const value = parseInt(e.target.value, 10);\n const html = document.documentElement;\n // set CSS variable\n html.style.setProperty('--text-size', `${value}px`);\n // save to local storage\n if (value === DEFAULT_TEXT_SIZE) {\n store.local.del('textSize');\n } else {\n store.local.set('textSize', e.target.value);\n }\n }}\n />{' '}\n <span style={{ fontSize: TEXT_SIZES[TEXT_SIZES.length - 1] }}>\n A\n </span>\n <datalist id=\"sizes\">\n {TEXT_SIZES.map((size) => (\n <option value={size} />\n ))}\n </datalist>\n </div>\n </li>\n </ul>\n </section>\n {authenticated && (\n <>\n <h3>Posting</h3>\n <section>\n <ul>\n <li>\n <div>\n <label for=\"posting-privacy-field\">\n Default visibility{' '}\n <Icon icon=\"cloud\" alt=\"Synced\" class=\"synced-icon\" />\n </label>\n </div>\n <div>\n <select\n id=\"posting-privacy-field\"\n value={prefs['posting:default:visibility'] || 'public'}\n onChange={(e) => {\n const { value } = e.target;\n (async () => {\n try {\n await masto.v1.accounts.updateCredentials({\n source: {\n privacy: value,\n },\n });\n setPrefs({\n ...prefs,\n 'posting:default:visibility': value,\n });\n store.account.set('preferences', {\n ...prefs,\n 'posting:default:visibility': value,\n });\n } catch (e) {\n alert('Failed to update posting privacy');\n console.error(e);\n }\n })();\n }}\n >\n <option value=\"public\">Public</option>\n <option value=\"unlisted\">Unlisted</option>\n <option value=\"private\">Followers only</option>\n </select>\n </div>\n </li>\n </ul>\n </section>\n <p class=\"section-postnote\">\n <Icon icon=\"cloud\" alt=\"Synced\" class=\"synced-icon\" />{' '}\n <small>\n Synced to your instance server's settings.{' '}\n <a\n href={`https://${instance}/`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Go to your instance ({instance}) for more settings.\n </a>\n </small>\n </p>\n </>\n )}\n <h3>Experiments</h3>\n <section>\n <ul>\n <li>\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.autoRefresh}\n onChange={(e) => {\n states.settings.autoRefresh = e.target.checked;\n }}\n />{' '}\n Auto refresh timeline posts\n </label>\n </li>\n <li>\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.boostsCarousel}\n onChange={(e) => {\n states.settings.boostsCarousel = e.target.checked;\n }}\n />{' '}\n Boosts carousel\n </label>\n </li>\n <li>\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.contentTranslation}\n onChange={(e) => {\n const { checked } = e.target;\n states.settings.contentTranslation = checked;\n if (!checked) {\n states.settings.contentTranslationTargetLanguage = null;\n }\n }}\n />{' '}\n Post translation\n </label>\n <div\n class={`sub-section ${\n !snapStates.settings.contentTranslation\n ? 'more-insignificant'\n : ''\n }`}\n >\n <div>\n <label>\n Translate to{' '}\n <select\n value={targetLanguage || ''}\n disabled={!snapStates.settings.contentTranslation}\n onChange={(e) => {\n states.settings.contentTranslationTargetLanguage =\n e.target.value || null;\n }}\n >\n <option value=\"\">\n System language ({systemTargetLanguageText})\n </option>\n <option disabled>──────────</option>\n {targetLanguages.map((lang) => (\n <option value={lang.code}>{lang.name}</option>\n ))}\n </select>\n </label>\n </div>\n <hr />\n <p class=\"checkbox-fieldset\">\n Hide \"Translate\" button for\n {snapStates.settings.contentTranslationHideLanguages.length >\n 0 && (\n <>\n {' '}\n (\n {\n snapStates.settings.contentTranslationHideLanguages\n .length\n }\n )\n </>\n )}\n :\n <div class=\"checkbox-fields\">\n {targetLanguages.map((lang) => (\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.contentTranslationHideLanguages.includes(\n lang.code,\n )}\n onChange={(e) => {\n const { checked } = e.target;\n if (checked) {\n states.settings.contentTranslationHideLanguages.push(\n lang.code,\n );\n } else {\n states.settings.contentTranslationHideLanguages =\n snapStates.settings.contentTranslationHideLanguages.filter(\n (code) => code !== lang.code,\n );\n }\n }}\n />{' '}\n {lang.name}\n </label>\n ))}\n </div>\n </p>\n <p class=\"insignificant\">\n <small>\n Note: This feature uses external translation services,\n powered by{' '}\n <a\n href=\"https://github.com/cheeaun/lingva-api\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Lingva API\n </a>{' '}\n &{' '}\n <a\n href=\"https://github.com/thedaviddelta/lingva-translate\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Lingva Translate\n </a>\n .\n </small>\n </p>\n <hr />\n <div>\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.contentTranslationAutoInline}\n disabled={!snapStates.settings.contentTranslation}\n onChange={(e) => {\n states.settings.contentTranslationAutoInline =\n e.target.checked;\n }}\n />{' '}\n Auto inline translation\n </label>\n <p class=\"insignificant\">\n <small>\n Automatically show translation for posts in timeline. Only\n works for <b>short</b> posts without content warning,\n media and poll.\n </small>\n </p>\n </div>\n </div>\n </li>\n {!!IMG_ALT_API_URL && (\n <li>\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.mediaAltGenerator}\n onChange={(e) => {\n states.settings.mediaAltGenerator = e.target.checked;\n }}\n />{' '}\n Image description generator{' '}\n <Icon icon=\"sparkles2\" class=\"more-insignificant\" />\n </label>\n <div class=\"sub-section insignificant\">\n <small>Only for new images while composing new posts.</small>\n </div>\n <div class=\"sub-section insignificant\">\n <small>\n Note: This feature uses external AI service, powered by{' '}\n <a\n href=\"https://github.com/cheeaun/img-alt-api\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n img-alt-api\n </a>\n . May not work well. Only for images and in English.\n </small>\n </div>\n </li>\n )}\n <li>\n <label>\n <input\n type=\"checkbox\"\n checked={snapStates.settings.cloakMode}\n onChange={(e) => {\n states.settings.cloakMode = e.target.checked;\n }}\n />{' '}\n Cloak mode{' '}\n <span class=\"insignificant\">\n (<samp>Text</samp> → <samp>████</samp>)\n </span>\n </label>\n <div class=\"sub-section insignificant\">\n <small>\n Replace text as blocks, useful when taking screenshots, for\n privacy reasons.\n </small>\n </div>\n </li>\n {authenticated && (\n <li>\n <button\n type=\"button\"\n class=\"light\"\n onClick={() => {\n states.showDrafts = true;\n states.showSettings = false;\n }}\n >\n Unsent drafts\n </button>\n </li>\n )}\n </ul>\n </section>\n {authenticated && <PushNotificationsSection onClose={onClose} />}\n <h3>About</h3>\n <section>\n <div\n style={{\n display: 'flex',\n flexWrap: 'wrap',\n gap: 8,\n lineHeight: 1.25,\n alignItems: 'center',\n marginTop: 8,\n }}\n >\n <img\n src={logo}\n alt=\"\"\n width=\"64\"\n height=\"64\"\n style={{\n aspectRatio: '1/1',\n verticalAlign: 'middle',\n background: '#b7cdf9',\n borderRadius: 12,\n }}\n />\n <div>\n <b>Phanpy</b>{' '}\n <a\n href=\"https://hachyderm.io/@phanpy\"\n // target=\"_blank\"\n rel=\"noopener noreferrer\"\n onClick={(e) => {\n e.preventDefault();\n states.showAccount = 'phanpy@hachyderm.io';\n }}\n >\n @phanpy\n </a>\n <br />\n <a\n href=\"https://github.com/cheeaun/phanpy\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Built\n </a>{' '}\n by{' '}\n <a\n href=\"https://mastodon.social/@cheeaun\"\n // target=\"_blank\"\n rel=\"noopener noreferrer\"\n onClick={(e) => {\n e.preventDefault();\n states.showAccount = 'cheeaun@mastodon.social';\n }}\n >\n @cheeaun\n </a>\n </div>\n </div>\n <p>\n <a\n href=\"https://github.com/sponsors/cheeaun\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Sponsor\n </a>{' '}\n ·{' '}\n <a\n href=\"https://www.buymeacoffee.com/cheeaun\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Donate\n </a>{' '}\n ·{' '}\n <a\n href={PRIVACY_POLICY_URL}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Privacy Policy\n </a>\n </p>\n {__BUILD_TIME__ && (\n <p>\n {WEBSITE && (\n <>\n <span class=\"insignificant\">Site:</span>{' '}\n {WEBSITE.replace(/https?:\\/\\//g, '').replace(/\\/$/, '')}\n <br />\n </>\n )}\n <span class=\"insignificant\">Version:</span>{' '}\n <input\n type=\"text\"\n class=\"version-string\"\n readOnly\n size=\"18\" // Manually calculated here\n value={`${__BUILD_TIME__.slice(0, 10).replace(/-/g, '.')}${\n __COMMIT_HASH__ ? `.${__COMMIT_HASH__}` : ''\n }`}\n onClick={(e) => {\n e.target.select();\n // Copy to clipboard\n try {\n navigator.clipboard.writeText(e.target.value);\n showToast('Version string copied');\n } catch (e) {\n console.warn(e);\n showToast('Unable to copy version string');\n }\n }}\n />{' '}\n {!__FAKE_COMMIT_HASH__ && (\n <span class=\"ib insignificant\">\n (\n <a\n href={`https://github.com/cheeaun/phanpy/commit/${__COMMIT_HASH__}`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <RelativeTime datetime={new Date(__BUILD_TIME__)} />\n </a>\n )\n </span>\n )}\n </p>\n )}\n </section>\n </main>\n </div>\n );\n}\n\nfunction PushNotificationsSection({ onClose }) {\n if (!isPushSupported()) return null;\n\n const { instance } = api();\n const [uiState, setUIState] = useState('default');\n const pushFormRef = useRef();\n const [allowNofitications, setAllowNotifications] = useState(false);\n const [needRelogin, setNeedRelogin] = useState(false);\n const previousPolicyRef = useRef();\n useEffect(() => {\n (async () => {\n setUIState('loading');\n try {\n const { subscription, backendSubscription } = await initSubscription();\n if (\n backendSubscription?.policy &&\n backendSubscription.policy !== 'none'\n ) {\n setAllowNotifications(true);\n const { alerts, policy } = backendSubscription;\n previousPolicyRef.current = policy;\n const { elements } = pushFormRef.current;\n const policyEl = elements.namedItem(policy);\n if (policyEl) policyEl.value = policy;\n // alerts is {}, iterate it\n Object.keys(alerts).forEach((alert) => {\n const el = elements.namedItem(alert);\n if (el?.type === 'checkbox') {\n el.checked = true;\n }\n });\n }\n setUIState('default');\n } catch (err) {\n console.warn(err);\n if (/outside.*authorized/i.test(err.message)) {\n setNeedRelogin(true);\n } else {\n alert(err?.message || err);\n }\n setUIState('error');\n }\n })();\n }, []);\n\n const isLoading = uiState === 'loading';\n\n return (\n <form\n ref={pushFormRef}\n onChange={() => {\n const values = Object.fromEntries(new FormData(pushFormRef.current));\n const allowNofitications = !!values['policy-allow'];\n const params = {\n policy: values.policy,\n data: {\n alerts: {\n mention: !!values.mention,\n favourite: !!values.favourite,\n reblog: !!values.reblog,\n follow: !!values.follow,\n follow_request: !!values.followRequest,\n poll: !!values.poll,\n update: !!values.update,\n status: !!values.status,\n },\n },\n };\n\n let alertsCount = 0;\n // Remove false values from data.alerts\n // API defaults to false anyway\n Object.keys(params.data.alerts).forEach((key) => {\n if (!params.data.alerts[key]) {\n delete params.data.alerts[key];\n } else {\n alertsCount++;\n }\n });\n const policyChanged = previousPolicyRef.current !== params.policy;\n\n console.log('PN Form', { values, allowNofitications, params });\n\n if (allowNofitications && alertsCount > 0) {\n if (policyChanged) {\n console.debug('Policy changed.');\n removeSubscription()\n .then(() => {\n updateSubscription(params);\n })\n .catch((err) => {\n console.warn(err);\n alert('Failed to update subscription. Please try again.');\n });\n } else {\n updateSubscription(params).catch((err) => {\n console.warn(err);\n alert('Failed to update subscription. Please try again.');\n });\n }\n } else {\n removeSubscription().catch((err) => {\n console.warn(err);\n alert('Failed to remove subscription. Please try again.');\n });\n }\n }}\n >\n <h3>Push Notifications (beta)</h3>\n <section>\n <ul>\n <li>\n <label>\n <input\n type=\"checkbox\"\n disabled={isLoading || needRelogin}\n name=\"policy-allow\"\n checked={allowNofitications}\n onChange={async (e) => {\n const { checked } = e.target;\n if (checked) {\n // Request permission\n const permission = await Notification.requestPermission();\n if (permission === 'granted') {\n setAllowNotifications(true);\n } else {\n setAllowNotifications(false);\n if (permission === 'denied') {\n alert(\n 'Push notifications are blocked. Please enable them in your browser settings.',\n );\n }\n }\n } else {\n setAllowNotifications(false);\n }\n }}\n />{' '}\n Allow from{' '}\n <select\n name=\"policy\"\n disabled={isLoading || needRelogin || !allowNofitications}\n >\n {[\n {\n value: 'all',\n label: 'anyone',\n },\n {\n value: 'followed',\n label: 'people I follow',\n },\n {\n value: 'follower',\n label: 'followers',\n },\n ].map((type) => (\n <option value={type.value}>{type.label}</option>\n ))}\n </select>\n </label>\n <div\n class=\"shazam-container no-animation\"\n style={{\n width: '100%',\n }}\n hidden={!allowNofitications}\n >\n <div class=\"shazam-container-inner\">\n <div class=\"sub-section\">\n <ul>\n {[\n {\n value: 'mention',\n label: 'Mentions',\n },\n {\n value: 'favourite',\n label: 'Likes',\n },\n {\n value: 'reblog',\n label: 'Boosts',\n },\n {\n value: 'follow',\n label: 'Follows',\n },\n {\n value: 'followRequest',\n label: 'Follow requests',\n },\n {\n value: 'poll',\n label: 'Polls',\n },\n {\n value: 'update',\n label: 'Post edits',\n },\n {\n value: 'status',\n label: 'New posts',\n },\n ].map((alert) => (\n <li>\n <label>\n <input type=\"checkbox\" name={alert.value} />{' '}\n {alert.label}\n </label>\n </li>\n ))}\n </ul>\n </div>\n </div>\n </div>\n {needRelogin && (\n <div class=\"sub-section\">\n <p>\n Push permission was not granted since your last login. You'll\n need to{' '}\n <Link to={`/login?instance=${instance}`} onClick={onClose}>\n <b>log in</b> again to grant push permission\n </Link>\n .\n </p>\n </div>\n )}\n </li>\n </ul>\n </section>\n <p class=\"section-postnote\">\n <small>\n NOTE: Push notifications only work for <b>one account</b>.\n </small>\n </p>\n </form>\n );\n}\n\nexport default Settings;\n","const focusDeck = () => {\n let timer = setTimeout(() => {\n const columns = document.getElementById('columns');\n if (columns) {\n // Focus first column\n // columns.querySelector('.deck-container')?.focus?.();\n } else {\n const modals = document.querySelectorAll('#modal-container > *');\n if (modals?.length) {\n // Focus last modal\n const modal = modals[modals.length - 1]; // last one\n const modalFocusElement =\n modal.querySelector('[tabindex=\"-1\"]') || modal;\n if (modalFocusElement) {\n modalFocusElement.focus();\n return;\n }\n }\n const backDrop = document.querySelector('.deck-backdrop');\n if (backDrop) return;\n // Focus last deck\n const pages = document.querySelectorAll('.deck-container');\n const page = pages[pages.length - 1]; // last one\n if (page && page.tabIndex === -1) {\n console.log('FOCUS', page);\n page.focus();\n }\n }\n }, 100);\n return () => clearTimeout(timer);\n};\n\nexport default focusDeck;\n","import { useEffect, useRef } from 'preact/hooks';\nimport { useLocation } from 'react-router-dom';\n\n// Hook that runs a callback when the location changes\n// Won't run on the first render\n\nexport default function useLocationChange(fn) {\n if (!fn) return;\n const location = useLocation();\n const currentLocationRef = useRef(location.pathname);\n useEffect(() => {\n // console.log('location', {\n // current: currentLocationRef.current,\n // next: location.pathname,\n // });\n if (\n currentLocationRef.current &&\n location.pathname !== currentLocationRef.current\n ) {\n fn?.();\n }\n }, [location.pathname, fn]);\n}\n","import { useEffect, useRef, useState } from 'preact/hooks';\n\nimport { api } from '../utils/api';\nimport supports from '../utils/supports';\n\nimport Icon from './icon';\nimport MenuConfirm from './menu-confirm';\n\nfunction ListAddEdit({ list, onClose }) {\n const { masto } = api();\n const [uiState, setUIState] = useState('default');\n const editMode = !!list;\n const nameFieldRef = useRef();\n const repliesPolicyFieldRef = useRef();\n const exclusiveFieldRef = useRef();\n useEffect(() => {\n if (editMode) {\n nameFieldRef.current.value = list.title;\n repliesPolicyFieldRef.current.value = list.repliesPolicy;\n if (exclusiveFieldRef.current) {\n exclusiveFieldRef.current.checked = list.exclusive;\n }\n }\n }, [editMode]);\n const supportsExclusive = supports('@mastodon/list-exclusive');\n\n return (\n <div class=\"sheet\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}{' '}\n <header>\n <h2>{editMode ? 'Edit list' : 'New list'}</h2>\n </header>\n <main>\n <form\n class=\"list-form\"\n onSubmit={(e) => {\n e.preventDefault(); // Get form values\n\n const formData = new FormData(e.target);\n const title = formData.get('title');\n const repliesPolicy = formData.get('replies_policy');\n const exclusive = formData.get('exclusive') === 'on';\n console.log({\n title,\n repliesPolicy,\n exclusive,\n });\n setUIState('loading');\n\n (async () => {\n try {\n let listResult;\n\n if (editMode) {\n listResult = await masto.v1.lists.$select(list.id).update({\n title,\n replies_policy: repliesPolicy,\n exclusive,\n });\n } else {\n listResult = await masto.v1.lists.create({\n title,\n replies_policy: repliesPolicy,\n exclusive,\n });\n }\n\n console.log(listResult);\n setUIState('default');\n onClose?.({\n state: 'success',\n list: listResult,\n });\n } catch (e) {\n console.error(e);\n setUIState('error');\n alert(\n editMode ? 'Unable to edit list.' : 'Unable to create list.',\n );\n }\n })();\n }}\n >\n <div class=\"list-form-row\">\n <label for=\"list-title\">\n Name{' '}\n <input\n ref={nameFieldRef}\n type=\"text\"\n id=\"list-title\"\n name=\"title\"\n required\n disabled={uiState === 'loading'}\n dir=\"auto\"\n />\n </label>\n </div>\n <div class=\"list-form-row\">\n <select\n ref={repliesPolicyFieldRef}\n name=\"replies_policy\"\n required\n disabled={uiState === 'loading'}\n >\n <option value=\"list\">Show replies to list members</option>\n <option value=\"followed\">Show replies to people I follow</option>\n <option value=\"none\">Don't show replies</option>\n </select>\n </div>\n {supportsExclusive && (\n <div class=\"list-form-row\">\n <label class=\"label-block\">\n <input\n ref={exclusiveFieldRef}\n type=\"checkbox\"\n name=\"exclusive\"\n disabled={uiState === 'loading'}\n />{' '}\n Hide posts on this list from Home/Following\n </label>\n </div>\n )}\n <div class=\"list-form-footer\">\n <button type=\"submit\" disabled={uiState === 'loading'}>\n {editMode ? 'Save' : 'Create'}\n </button>\n {editMode && (\n <MenuConfirm\n disabled={uiState === 'loading'}\n align=\"end\"\n menuItemClassName=\"danger\"\n confirmLabel=\"Delete this list?\"\n onClick={() => {\n // const yes = confirm('Delete this list?');\n // if (!yes) return;\n setUIState('loading');\n\n (async () => {\n try {\n await masto.v1.lists.$select(list.id).remove();\n setUIState('default');\n onClose?.({\n state: 'deleted',\n });\n } catch (e) {\n console.error(e);\n setUIState('error');\n alert('Unable to delete list.');\n }\n })();\n }}\n >\n <button\n type=\"button\"\n class=\"light danger\"\n disabled={uiState === 'loading'}\n >\n Delete…\n </button>\n </MenuConfirm>\n )}\n </div>\n </form>\n </main>\n </div>\n );\n}\n\nexport default ListAddEdit;\n","import './account-info.css';\n\nimport { Menu, MenuDivider, MenuItem, SubMenu } from '@szhsin/react-menu';\nimport {\n useCallback,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from 'preact/hooks';\n\nimport { api } from '../utils/api';\nimport enhanceContent from '../utils/enhance-content';\nimport getHTMLText from '../utils/getHTMLText';\nimport handleContentLinks from '../utils/handle-content-links';\nimport niceDateTime from '../utils/nice-date-time';\nimport pmem from '../utils/pmem';\nimport shortenNumber from '../utils/shorten-number';\nimport showToast from '../utils/show-toast';\nimport states, { hideAllModals } from '../utils/states';\nimport store from '../utils/store';\nimport { updateAccount } from '../utils/store-utils';\n\nimport AccountBlock from './account-block';\nimport Avatar from './avatar';\nimport EmojiText from './emoji-text';\nimport Icon from './icon';\nimport Link from './link';\nimport ListAddEdit from './list-add-edit';\nimport Loader from './loader';\nimport Menu2 from './menu2';\nimport MenuConfirm from './menu-confirm';\nimport Modal from './modal';\nimport TranslationBlock from './translation-block';\n\nconst MUTE_DURATIONS = [\n 60 * 5, // 5 minutes\n 60 * 30, // 30 minutes\n 60 * 60, // 1 hour\n 60 * 60 * 6, // 6 hours\n 60 * 60 * 24, // 1 day\n 60 * 60 * 24 * 3, // 3 days\n 60 * 60 * 24 * 7, // 1 week\n 0, // forever\n];\nconst MUTE_DURATIONS_LABELS = {\n 0: 'Forever',\n 300: '5 minutes',\n 1_800: '30 minutes',\n 3_600: '1 hour',\n 21_600: '6 hours',\n 86_400: '1 day',\n 259_200: '3 days',\n 604_800: '1 week',\n};\n\nconst LIMIT = 80;\n\nconst ACCOUNT_INFO_MAX_AGE = 1000 * 60 * 10; // 10 mins\n\nfunction fetchFamiliarFollowers(currentID, masto) {\n return masto.v1.accounts.familiarFollowers.fetch({\n id: [currentID],\n });\n}\nconst memFetchFamiliarFollowers = pmem(fetchFamiliarFollowers, {\n maxAge: ACCOUNT_INFO_MAX_AGE,\n});\n\nasync function fetchPostingStats(accountID, masto) {\n const fetchStatuses = masto.v1.accounts\n .$select(accountID)\n .statuses.list({\n limit: 20,\n })\n .next();\n\n const { value: statuses } = await fetchStatuses;\n console.log('fetched statuses', statuses);\n const stats = {\n total: statuses.length,\n originals: 0,\n replies: 0,\n boosts: 0,\n };\n // Categories statuses by type\n // - Original posts (not replies to others)\n // - Threads (self-replies + 1st original post)\n // - Boosts (reblogs)\n // - Replies (not-self replies)\n statuses.forEach((status) => {\n if (status.reblog) {\n stats.boosts++;\n } else if (\n !!status.inReplyToId &&\n status.inReplyToAccountId !== status.account.id // Not self-reply\n ) {\n stats.replies++;\n } else {\n stats.originals++;\n }\n });\n\n // Count days since last post\n if (statuses.length) {\n stats.daysSinceLastPost = Math.ceil(\n (Date.now() - new Date(statuses[statuses.length - 1].createdAt)) /\n 86400000,\n );\n }\n\n console.log('posting stats', stats);\n return stats;\n}\nconst memFetchPostingStats = pmem(fetchPostingStats, {\n maxAge: ACCOUNT_INFO_MAX_AGE,\n});\n\nfunction AccountInfo({\n account,\n fetchAccount = () => {},\n standalone,\n instance,\n authenticated,\n}) {\n const { masto } = api({\n instance,\n });\n const { masto: currentMasto, instance: currentInstance } = api();\n const [uiState, setUIState] = useState('default');\n const isString = typeof account === 'string';\n const [info, setInfo] = useState(isString ? null : account);\n\n const sameCurrentInstance = useMemo(\n () => instance === currentInstance,\n [instance, currentInstance],\n );\n\n useEffect(() => {\n if (!isString) {\n setInfo(account);\n return;\n }\n setUIState('loading');\n (async () => {\n try {\n const info = await fetchAccount();\n states.accounts[`${info.id}@${instance}`] = info;\n setInfo(info);\n setUIState('default');\n } catch (e) {\n console.error(e);\n setInfo(null);\n setUIState('error');\n }\n })();\n }, [isString, account, fetchAccount]);\n\n const {\n acct,\n avatar,\n avatarStatic,\n bot,\n createdAt,\n displayName,\n emojis,\n fields,\n followersCount,\n followingCount,\n group,\n // header,\n // headerStatic,\n id,\n lastStatusAt,\n locked,\n note,\n statusesCount,\n url,\n username,\n memorial,\n moved,\n roles,\n } = info || {};\n let headerIsAvatar = false;\n let { header, headerStatic } = info || {};\n if (!header || /missing\\.png$/.test(header)) {\n if (avatar && !/missing\\.png$/.test(avatar)) {\n header = avatar;\n headerIsAvatar = true;\n if (avatarStatic && !/missing\\.png$/.test(avatarStatic)) {\n headerStatic = avatarStatic;\n }\n }\n }\n\n const isSelf = useMemo(\n () => id === store.session.get('currentAccount'),\n [id],\n );\n\n useEffect(() => {\n const infoHasEssentials = !!(\n info?.id &&\n info?.username &&\n info?.acct &&\n info?.avatar &&\n info?.avatarStatic &&\n info?.displayName &&\n info?.url\n );\n if (isSelf && instance && infoHasEssentials) {\n const accounts = store.local.getJSON('accounts');\n let updated = false;\n accounts.forEach((account) => {\n if (account.info.id === info.id && account.instanceURL === instance) {\n account.info = info;\n updated = true;\n }\n });\n if (updated) {\n console.log('Updated account info', info);\n store.local.setJSON('accounts', accounts);\n }\n }\n }, [isSelf, info, instance]);\n\n const accountInstance = useMemo(() => {\n if (!url) return null;\n const domain = new URL(url).hostname;\n return domain;\n }, [url]);\n\n const [headerCornerColors, setHeaderCornerColors] = useState([]);\n\n const followersIterator = useRef();\n const familiarFollowersCache = useRef([]);\n async function fetchFollowers(firstLoad) {\n if (firstLoad || !followersIterator.current) {\n followersIterator.current = masto.v1.accounts.$select(id).followers.list({\n limit: LIMIT,\n });\n }\n const results = await followersIterator.current.next();\n if (isSelf) return results;\n if (!sameCurrentInstance) return results;\n\n const { value } = results;\n let newValue = [];\n // On first load, fetch familiar followers, merge to top of results' `value`\n // Remove dups on every fetch\n if (firstLoad) {\n const familiarFollowers = await masto.v1.accounts.familiarFollowers.fetch(\n {\n id: [id],\n },\n );\n familiarFollowersCache.current = familiarFollowers[0].accounts;\n newValue = [\n ...familiarFollowersCache.current,\n ...value.filter(\n (account) =>\n !familiarFollowersCache.current.some(\n (familiar) => familiar.id === account.id,\n ),\n ),\n ];\n } else if (value?.length) {\n newValue = value.filter(\n (account) =>\n !familiarFollowersCache.current.some(\n (familiar) => familiar.id === account.id,\n ),\n );\n }\n\n return {\n ...results,\n value: newValue,\n };\n }\n\n const followingIterator = useRef();\n async function fetchFollowing(firstLoad) {\n if (firstLoad || !followingIterator.current) {\n followingIterator.current = masto.v1.accounts.$select(id).following.list({\n limit: LIMIT,\n });\n }\n const results = await followingIterator.current.next();\n return results;\n }\n\n const LinkOrDiv = standalone ? 'div' : Link;\n const accountLink = instance ? `/${instance}/a/${id}` : `/a/${id}`;\n\n const [familiarFollowers, setFamiliarFollowers] = useState([]);\n const [postingStats, setPostingStats] = useState();\n const [postingStatsUIState, setPostingStatsUIState] = useState('default');\n const hasPostingStats = !!postingStats?.total;\n\n const renderFamiliarFollowers = async (currentID) => {\n try {\n const followers = await memFetchFamiliarFollowers(\n currentID,\n currentMasto,\n );\n console.log('fetched familiar followers', followers);\n setFamiliarFollowers(\n followers[0].accounts.slice(0, FAMILIAR_FOLLOWERS_LIMIT),\n );\n } catch (e) {\n console.error(e);\n }\n };\n\n const renderPostingStats = async () => {\n if (!id) return;\n setPostingStatsUIState('loading');\n try {\n const stats = await memFetchPostingStats(id, masto);\n setPostingStats(stats);\n setPostingStatsUIState('default');\n } catch (e) {\n console.error(e);\n setPostingStatsUIState('error');\n }\n };\n\n const onRelationshipChange = useCallback(\n ({ relationship, currentID }) => {\n if (!relationship.following) {\n renderFamiliarFollowers(currentID);\n if (!standalone && statusesCount > 0) {\n // Only render posting stats if not standalone and has posts\n renderPostingStats();\n }\n }\n },\n [standalone, id, statusesCount],\n );\n\n return (\n <div\n tabIndex=\"-1\"\n class={`account-container ${uiState === 'loading' ? 'skeleton' : ''}`}\n style={{\n '--header-color-1': headerCornerColors[0],\n '--header-color-2': headerCornerColors[1],\n '--header-color-3': headerCornerColors[2],\n '--header-color-4': headerCornerColors[3],\n }}\n >\n {uiState === 'error' && (\n <div class=\"ui-state\">\n <p>Unable to load account.</p>\n <p>\n <a\n href={isString ? account : url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n Go to account page <Icon icon=\"external\" />\n </a>\n </p>\n </div>\n )}\n {uiState === 'loading' ? (\n <>\n <header>\n <AccountBlock avatarSize=\"xxxl\" skeleton />\n </header>\n <main>\n <div class=\"note\">\n <p>███████ ████ ████</p>\n <p>████ ████████ ██████ █████████ ████ ██</p>\n </div>\n <div class=\"account-metadata-box\">\n <div class=\"profile-metadata\">\n <div class=\"profile-field\">\n <b class=\"more-insignificant\">███</b>\n <p>██████</p>\n </div>\n <div class=\"profile-field\">\n <b class=\"more-insignificant\">████</b>\n <p>███████████</p>\n </div>\n </div>\n <div class=\"stats\">\n <div>\n <span>██</span> Followers\n </div>\n <div>\n <span>██</span> Following\n </div>\n <div>\n <span>██</span> Posts\n </div>\n </div>\n </div>\n <div class=\"actions\">\n <span />\n <span class=\"buttons\">\n <button type=\"button\" title=\"More\" class=\"plain\" disabled>\n <Icon icon=\"more\" size=\"l\" alt=\"More\" />\n </button>\n </span>\n </div>\n </main>\n </>\n ) : (\n info && (\n <>\n {!!moved && (\n <div class=\"account-moved\">\n <p>\n <b>{displayName}</b> has indicated that their new account is\n now:\n </p>\n <AccountBlock\n account={moved}\n instance={instance}\n onClick={(e) => {\n e.stopPropagation();\n states.showAccount = moved;\n }}\n />\n </div>\n )}\n {!!header && !/missing\\.png$/.test(header) && (\n <img\n src={header}\n alt=\"\"\n class={`header-banner ${\n headerIsAvatar ? 'header-is-avatar' : ''\n }`}\n onError={(e) => {\n if (e.target.crossOrigin) {\n if (e.target.src !== headerStatic) {\n e.target.src = headerStatic;\n } else {\n e.target.removeAttribute('crossorigin');\n e.target.src = header;\n }\n } else if (e.target.src !== headerStatic) {\n e.target.src = headerStatic;\n } else {\n e.target.remove();\n }\n }}\n crossOrigin=\"anonymous\"\n onLoad={(e) => {\n e.target.classList.add('loaded');\n try {\n // Get color from four corners of image\n const canvas = document.createElement('canvas');\n const ctx = canvas.getContext('2d', {\n willReadFrequently: true,\n });\n canvas.width = e.target.width;\n canvas.height = e.target.height;\n ctx.drawImage(e.target, 0, 0);\n // const colors = [\n // ctx.getImageData(0, 0, 1, 1).data,\n // ctx.getImageData(e.target.width - 1, 0, 1, 1).data,\n // ctx.getImageData(0, e.target.height - 1, 1, 1).data,\n // ctx.getImageData(\n // e.target.width - 1,\n // e.target.height - 1,\n // 1,\n // 1,\n // ).data,\n // ];\n // Get 10x10 pixels from corners, get average color from each\n const pixelDimension = 10;\n const colors = [\n ctx.getImageData(0, 0, pixelDimension, pixelDimension)\n .data,\n ctx.getImageData(\n e.target.width - pixelDimension,\n 0,\n pixelDimension,\n pixelDimension,\n ).data,\n ctx.getImageData(\n 0,\n e.target.height - pixelDimension,\n pixelDimension,\n pixelDimension,\n ).data,\n ctx.getImageData(\n e.target.width - pixelDimension,\n e.target.height - pixelDimension,\n pixelDimension,\n pixelDimension,\n ).data,\n ].map((data) => {\n let r = 0;\n let g = 0;\n let b = 0;\n let a = 0;\n for (let i = 0; i < data.length; i += 4) {\n r += data[i];\n g += data[i + 1];\n b += data[i + 2];\n a += data[i + 3];\n }\n const dataLength = data.length / 4;\n return [\n r / dataLength,\n g / dataLength,\n b / dataLength,\n a / dataLength,\n ];\n });\n const rgbColors = colors.map((color) => {\n const [r, g, b, a] = lightenRGB(color);\n return `rgba(${r}, ${g}, ${b}, ${a})`;\n });\n setHeaderCornerColors(rgbColors);\n console.log({ colors, rgbColors });\n } catch (e) {\n // Silently fail\n }\n }}\n />\n )}\n <header>\n <AccountBlock\n account={info}\n instance={instance}\n avatarSize=\"xxxl\"\n external={standalone}\n internal={!standalone}\n />\n </header>\n <div class=\"faux-header-bg\" aria-hidden=\"true\" />\n <main>\n {!!memorial && <span class=\"tag\">In Memoriam</span>}\n {!!bot && (\n <span class=\"tag\">\n <Icon icon=\"bot\" /> Automated\n </span>\n )}\n {!!group && (\n <span class=\"tag\">\n <Icon icon=\"group\" /> Group\n </span>\n )}\n {roles?.map((role) => (\n <span class=\"tag\">\n {role.name}\n {!!accountInstance && (\n <>\n {' '}\n <span class=\"more-insignificant\">{accountInstance}</span>\n </>\n )}\n </span>\n ))}\n <div\n class=\"note\"\n dir=\"auto\"\n onClick={handleContentLinks({\n instance: currentInstance,\n })}\n dangerouslySetInnerHTML={{\n __html: enhanceContent(note, { emojis }),\n }}\n />\n <div class=\"account-metadata-box\">\n {fields?.length > 0 && (\n <div class=\"profile-metadata\">\n {fields.map(({ name, value, verifiedAt }, i) => (\n <div\n class={`profile-field ${\n verifiedAt ? 'profile-verified' : ''\n }`}\n key={name + i}\n dir=\"auto\"\n >\n <b>\n <EmojiText text={name} emojis={emojis} />{' '}\n {!!verifiedAt && (\n <Icon icon=\"check-circle\" size=\"s\" />\n )}\n </b>\n <p\n dangerouslySetInnerHTML={{\n __html: enhanceContent(value, { emojis }),\n }}\n />\n </div>\n ))}\n </div>\n )}\n <div class=\"stats\">\n <LinkOrDiv\n tabIndex={0}\n to={accountLink}\n onClick={() => {\n // states.showAccount = false;\n setTimeout(() => {\n states.showGenericAccounts = {\n heading: 'Followers',\n fetchAccounts: fetchFollowers,\n instance,\n excludeRelationshipAttrs: isSelf\n ? ['followedBy']\n : [],\n };\n }, 0);\n }}\n >\n {!!familiarFollowers.length && (\n <span class=\"shazam-container-horizontal\">\n <span class=\"shazam-container-inner stats-avatars-bunch\">\n {familiarFollowers.map((follower) => (\n <Avatar\n url={follower.avatarStatic}\n size=\"s\"\n alt={`${follower.displayName} @${follower.acct}`}\n squircle={follower?.bot}\n />\n ))}\n </span>\n </span>\n )}\n <span title={followersCount}>\n {shortenNumber(followersCount)}\n </span>{' '}\n Followers\n </LinkOrDiv>\n <LinkOrDiv\n class=\"insignificant\"\n tabIndex={0}\n to={accountLink}\n onClick={() => {\n // states.showAccount = false;\n setTimeout(() => {\n states.showGenericAccounts = {\n heading: 'Following',\n fetchAccounts: fetchFollowing,\n instance,\n excludeRelationshipAttrs: isSelf ? ['following'] : [],\n };\n }, 0);\n }}\n >\n <span title={followingCount}>\n {shortenNumber(followingCount)}\n </span>{' '}\n Following\n <br />\n </LinkOrDiv>\n <LinkOrDiv\n class=\"insignificant\"\n to={accountLink}\n // onClick={\n // standalone\n // ? undefined\n // : () => {\n // hideAllModals();\n // }\n // }\n >\n <span title={statusesCount}>\n {shortenNumber(statusesCount)}\n </span>{' '}\n Posts\n </LinkOrDiv>\n {!!createdAt && (\n <div class=\"insignificant\">\n Joined{' '}\n <time datetime={createdAt}>\n {niceDateTime(createdAt, {\n hideTime: true,\n })}\n </time>\n </div>\n )}\n </div>\n </div>\n {!!postingStats && (\n <LinkOrDiv\n to={accountLink}\n class=\"account-metadata-box\"\n // onClick={() => {\n // states.showAccount = false;\n // }}\n >\n <div class=\"shazam-container\">\n <div class=\"shazam-container-inner\">\n {hasPostingStats ? (\n <div\n class=\"posting-stats\"\n title={`${Math.round(\n (postingStats.originals / postingStats.total) * 100,\n )}% original posts, ${Math.round(\n (postingStats.replies / postingStats.total) * 100,\n )}% replies, ${Math.round(\n (postingStats.boosts / postingStats.total) * 100,\n )}% boosts`}\n >\n <div>\n {postingStats.daysSinceLastPost < 365\n ? `Last ${postingStats.total} post${\n postingStats.total > 1 ? 's' : ''\n } in the past \n ${postingStats.daysSinceLastPost} day${\n postingStats.daysSinceLastPost > 1 ? 's' : ''\n }`\n : `\n Last ${postingStats.total} posts in the past year(s)\n `}\n </div>\n <div\n class=\"posting-stats-bar\"\n style={{\n // [originals | replies | boosts]\n '--originals-percentage': `${\n (postingStats.originals / postingStats.total) *\n 100\n }%`,\n '--replies-percentage': `${\n ((postingStats.originals +\n postingStats.replies) /\n postingStats.total) *\n 100\n }%`,\n }}\n />\n <div class=\"posting-stats-legends\">\n <span class=\"ib\">\n <span class=\"posting-stats-legend-item posting-stats-legend-item-originals\" />{' '}\n Original\n </span>{' '}\n <span class=\"ib\">\n <span class=\"posting-stats-legend-item posting-stats-legend-item-replies\" />{' '}\n Replies\n </span>{' '}\n <span class=\"ib\">\n <span class=\"posting-stats-legend-item posting-stats-legend-item-boosts\" />{' '}\n Boosts\n </span>\n </div>\n </div>\n ) : (\n <div class=\"posting-stats\">Post stats unavailable.</div>\n )}\n </div>\n </div>\n </LinkOrDiv>\n )}\n <div class=\"account-metadata-box\">\n <div\n class=\"shazam-container no-animation\"\n hidden={!!postingStats}\n >\n <div class=\"shazam-container-inner\">\n <button\n type=\"button\"\n class=\"posting-stats-button\"\n disabled={postingStatsUIState === 'loading'}\n onClick={() => {\n renderPostingStats();\n }}\n >\n <div\n class={`posting-stats-bar posting-stats-icon ${\n postingStatsUIState === 'loading' ? 'loading' : ''\n }`}\n style={{\n '--originals-percentage': '33%',\n '--replies-percentage': '66%',\n }}\n />\n View post stats{' '}\n {/* <Loader\n abrupt\n hidden={postingStatsUIState !== 'loading'}\n /> */}\n </button>\n </div>\n </div>\n </div>\n </main>\n <footer>\n <RelatedActions\n info={info}\n instance={instance}\n authenticated={authenticated}\n onRelationshipChange={onRelationshipChange}\n />\n </footer>\n </>\n )\n )}\n </div>\n );\n}\n\nconst FAMILIAR_FOLLOWERS_LIMIT = 3;\n\nfunction RelatedActions({\n info,\n instance,\n authenticated,\n onRelationshipChange = () => {},\n}) {\n if (!info) return null;\n const {\n masto: currentMasto,\n instance: currentInstance,\n authenticated: currentAuthenticated,\n } = api();\n const sameInstance = instance === currentInstance;\n\n const [relationshipUIState, setRelationshipUIState] = useState('default');\n const [relationship, setRelationship] = useState(null);\n\n const { id, acct, url, username, locked, lastStatusAt, note, fields, moved } =\n info;\n const accountID = useRef(id);\n\n const {\n following,\n showingReblogs,\n notifying,\n followedBy,\n blocking,\n blockedBy,\n muting,\n mutingNotifications,\n requested,\n domainBlocking,\n endorsed,\n note: privateNote,\n } = relationship || {};\n\n const [currentInfo, setCurrentInfo] = useState(null);\n const [isSelf, setIsSelf] = useState(false);\n\n useEffect(() => {\n if (info) {\n const currentAccount = store.session.get('currentAccount');\n let currentID;\n (async () => {\n if (sameInstance && authenticated) {\n currentID = id;\n } else if (!sameInstance && currentAuthenticated) {\n // Grab this account from my logged-in instance\n const acctHasInstance = info.acct.includes('@');\n try {\n const results = await currentMasto.v2.search.fetch({\n q: acctHasInstance ? info.acct : `${info.username}@${instance}`,\n type: 'accounts',\n limit: 1,\n resolve: true,\n });\n console.log('🥏 Fetched account from logged-in instance', results);\n if (results.accounts.length) {\n currentID = results.accounts[0].id;\n setCurrentInfo(results.accounts[0]);\n }\n } catch (e) {\n console.error(e);\n }\n }\n\n if (!currentID) return;\n\n if (currentAccount === currentID) {\n // It's myself!\n setIsSelf(true);\n return;\n }\n\n accountID.current = currentID;\n\n if (moved) return;\n\n setRelationshipUIState('loading');\n\n const fetchRelationships = currentMasto.v1.accounts.relationships.fetch(\n {\n id: [currentID],\n },\n );\n\n try {\n const relationships = await fetchRelationships;\n console.log('fetched relationship', relationships);\n setRelationshipUIState('default');\n\n if (relationships.length) {\n const relationship = relationships[0];\n setRelationship(relationship);\n onRelationshipChange({ relationship, currentID });\n }\n } catch (e) {\n console.error(e);\n setRelationshipUIState('error');\n }\n })();\n }\n }, [info, authenticated]);\n\n useEffect(() => {\n if (info && isSelf) {\n updateAccount(info);\n }\n }, [info, isSelf]);\n\n const loading = relationshipUIState === 'loading';\n\n const [showTranslatedBio, setShowTranslatedBio] = useState(false);\n const [showAddRemoveLists, setShowAddRemoveLists] = useState(false);\n const [showPrivateNoteModal, setShowPrivateNoteModal] = useState(false);\n\n return (\n <>\n <div class=\"actions\">\n <span>\n {followedBy ? (\n <span class=\"tag\">Follows you</span>\n ) : !!lastStatusAt ? (\n <small class=\"insignificant\">\n Last post:{' '}\n <span class=\"ib\">\n {niceDateTime(lastStatusAt, {\n hideTime: true,\n })}\n </span>\n </small>\n ) : (\n <span />\n )}\n {muting && <span class=\"tag danger\">Muted</span>}\n {blocking && <span class=\"tag danger\">Blocked</span>}\n </span>{' '}\n <span class=\"buttons\">\n {!!privateNote && (\n <button\n type=\"button\"\n class=\"private-note-tag\"\n title=\"Private note\"\n onClick={() => {\n setShowPrivateNoteModal(true);\n }}\n dir=\"auto\"\n >\n <span>{privateNote}</span>\n </button>\n )}\n <Menu2\n portal={{\n target: document.body,\n }}\n containerProps={{\n style: {\n // Higher than the backdrop\n zIndex: 1001,\n },\n }}\n align=\"center\"\n position=\"anchor\"\n overflow=\"auto\"\n menuButton={\n <button\n type=\"button\"\n title=\"More\"\n class=\"plain\"\n disabled={loading}\n >\n <Icon icon=\"more\" size=\"l\" alt=\"More\" />\n </button>\n }\n >\n {currentAuthenticated && !isSelf && (\n <>\n <MenuItem\n onClick={() => {\n states.showCompose = {\n draftStatus: {\n status: `@${currentInfo?.acct || acct} `,\n },\n };\n }}\n >\n <Icon icon=\"at\" />\n <span>Mention @{username}</span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n setShowTranslatedBio(true);\n }}\n >\n <Icon icon=\"translate\" />\n <span>Translate bio</span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n setShowPrivateNoteModal(true);\n }}\n >\n <Icon icon=\"pencil\" />\n <span>\n {privateNote ? 'Edit private note' : 'Add private note'}\n </span>\n </MenuItem>\n {/* Add/remove from lists is only possible if following the account */}\n {following && (\n <MenuItem\n onClick={() => {\n setShowAddRemoveLists(true);\n }}\n >\n <Icon icon=\"list\" />\n <span>Add/remove from Lists</span>\n </MenuItem>\n )}\n <MenuDivider />\n </>\n )}\n <MenuItem href={url} target=\"_blank\">\n <Icon icon=\"external\" />\n <small class=\"menu-double-lines\">{niceAccountURL(url)}</small>\n </MenuItem>\n <div class=\"menu-horizontal\">\n <MenuItem\n onClick={() => {\n // Copy url to clipboard\n try {\n navigator.clipboard.writeText(url);\n showToast('Link copied');\n } catch (e) {\n console.error(e);\n showToast('Unable to copy link');\n }\n }}\n >\n <Icon icon=\"link\" />\n <span>Copy</span>\n </MenuItem>\n {navigator?.share &&\n navigator?.canShare?.({\n url,\n }) && (\n <MenuItem\n onClick={() => {\n try {\n navigator.share({\n url,\n });\n } catch (e) {\n console.error(e);\n alert(\"Sharing doesn't seem to work.\");\n }\n }}\n >\n <Icon icon=\"share\" />\n <span>Share…</span>\n </MenuItem>\n )}\n </div>\n {!!relationship && (\n <>\n <MenuDivider />\n {muting ? (\n <MenuItem\n onClick={() => {\n setRelationshipUIState('loading');\n (async () => {\n try {\n const newRelationship = await currentMasto.v1.accounts\n .$select(currentInfo?.id || id)\n .unmute();\n console.log('unmuting', newRelationship);\n setRelationship(newRelationship);\n setRelationshipUIState('default');\n showToast(`Unmuted @${username}`);\n states.reloadGenericAccounts.id = 'mute';\n states.reloadGenericAccounts.counter++;\n } catch (e) {\n console.error(e);\n setRelationshipUIState('error');\n }\n })();\n }}\n >\n <Icon icon=\"unmute\" />\n <span>Unmute @{username}</span>\n </MenuItem>\n ) : (\n <SubMenu\n openTrigger=\"clickOnly\"\n direction=\"bottom\"\n overflow=\"auto\"\n shift={16}\n label={\n <>\n <Icon icon=\"mute\" />\n <span class=\"menu-grow\">Mute @{username}…</span>\n <span\n style={{\n textOverflow: 'clip',\n }}\n >\n <Icon icon=\"time\" />\n <Icon icon=\"chevron-right\" />\n </span>\n </>\n }\n >\n <div class=\"menu-wrap\">\n {MUTE_DURATIONS.map((duration) => (\n <MenuItem\n onClick={() => {\n setRelationshipUIState('loading');\n (async () => {\n try {\n const newRelationship =\n await currentMasto.v1.accounts\n .$select(currentInfo?.id || id)\n .mute({\n duration,\n });\n console.log('muting', newRelationship);\n setRelationship(newRelationship);\n setRelationshipUIState('default');\n showToast(\n `Muted @${username} for ${MUTE_DURATIONS_LABELS[duration]}`,\n );\n states.reloadGenericAccounts.id = 'mute';\n states.reloadGenericAccounts.counter++;\n } catch (e) {\n console.error(e);\n setRelationshipUIState('error');\n showToast(`Unable to mute @${username}`);\n }\n })();\n }}\n >\n {MUTE_DURATIONS_LABELS[duration]}\n </MenuItem>\n ))}\n </div>\n </SubMenu>\n )}\n <MenuConfirm\n subMenu\n confirm={!blocking}\n confirmLabel={\n <>\n <Icon icon=\"block\" />\n <span>Block @{username}?</span>\n </>\n }\n menuItemClassName=\"danger\"\n onClick={() => {\n // if (!blocking && !confirm(`Block @${username}?`)) {\n // return;\n // }\n setRelationshipUIState('loading');\n (async () => {\n try {\n if (blocking) {\n const newRelationship = await currentMasto.v1.accounts\n .$select(currentInfo?.id || id)\n .unblock();\n console.log('unblocking', newRelationship);\n setRelationship(newRelationship);\n setRelationshipUIState('default');\n showToast(`Unblocked @${username}`);\n } else {\n const newRelationship = await currentMasto.v1.accounts\n .$select(currentInfo?.id || id)\n .block();\n console.log('blocking', newRelationship);\n setRelationship(newRelationship);\n setRelationshipUIState('default');\n showToast(`Blocked @${username}`);\n }\n states.reloadGenericAccounts.id = 'block';\n states.reloadGenericAccounts.counter++;\n } catch (e) {\n console.error(e);\n setRelationshipUIState('error');\n if (blocking) {\n showToast(`Unable to unblock @${username}`);\n } else {\n showToast(`Unable to block @${username}`);\n }\n }\n })();\n }}\n >\n {blocking ? (\n <>\n <Icon icon=\"unblock\" />\n <span>Unblock @{username}</span>\n </>\n ) : (\n <>\n <Icon icon=\"block\" />\n <span>Block @{username}…</span>\n </>\n )}\n </MenuConfirm>\n {/* <MenuItem>\n <Icon icon=\"flag\" />\n <span>Report @{username}…</span>\n </MenuItem> */}\n </>\n )}\n </Menu2>\n {!relationship && relationshipUIState === 'loading' && (\n <Loader abrupt />\n )}\n {!!relationship && (\n <MenuConfirm\n confirm={following || requested}\n confirmLabel={\n <span>\n {requested\n ? 'Withdraw follow request?'\n : `Unfollow @${info.acct || info.username}?`}\n </span>\n }\n menuItemClassName=\"danger\"\n align=\"end\"\n disabled={loading}\n onClick={() => {\n setRelationshipUIState('loading');\n (async () => {\n try {\n let newRelationship;\n\n if (following || requested) {\n // const yes = confirm(\n // requested\n // ? 'Withdraw follow request?'\n // : `Unfollow @${info.acct || info.username}?`,\n // );\n\n // if (yes) {\n newRelationship = await currentMasto.v1.accounts\n .$select(accountID.current)\n .unfollow();\n // }\n } else {\n newRelationship = await currentMasto.v1.accounts\n .$select(accountID.current)\n .follow();\n }\n\n if (newRelationship) setRelationship(newRelationship);\n setRelationshipUIState('default');\n } catch (e) {\n alert(e);\n setRelationshipUIState('error');\n }\n })();\n }}\n >\n <button\n type=\"button\"\n class={`${following || requested ? 'light swap' : ''}`}\n data-swap-state={following || requested ? 'danger' : ''}\n disabled={loading}\n >\n {following ? (\n <>\n <span>Following</span>\n <span>Unfollow…</span>\n </>\n ) : requested ? (\n <>\n <span>Requested</span>\n <span>Withdraw…</span>\n </>\n ) : locked ? (\n <>\n <Icon icon=\"lock\" /> <span>Follow</span>\n </>\n ) : (\n 'Follow'\n )}\n </button>\n </MenuConfirm>\n )}\n </span>\n </div>\n {!!showTranslatedBio && (\n <Modal\n class=\"light\"\n onClose={() => {\n setShowTranslatedBio(false);\n }}\n >\n <TranslatedBioSheet\n note={note}\n fields={fields}\n onClose={() => setShowTranslatedBio(false)}\n />\n </Modal>\n )}\n {!!showAddRemoveLists && (\n <Modal\n class=\"light\"\n onClose={() => {\n setShowAddRemoveLists(false);\n }}\n >\n <AddRemoveListsSheet\n accountID={accountID.current}\n onClose={() => setShowAddRemoveLists(false)}\n />\n </Modal>\n )}\n {!!showPrivateNoteModal && (\n <Modal\n class=\"light\"\n onClose={() => {\n setShowPrivateNoteModal(false);\n }}\n >\n <PrivateNoteSheet\n account={info}\n note={privateNote}\n onRelationshipChange={(relationship) => {\n setRelationship(relationship);\n // onRelationshipChange({ relationship, currentID: accountID.current });\n }}\n onClose={() => setShowPrivateNoteModal(false)}\n />\n </Modal>\n )}\n </>\n );\n}\n\n// Apply more alpha if high luminence\nfunction lightenRGB([r, g, b]) {\n const luminence = 0.2126 * r + 0.7152 * g + 0.0722 * b;\n console.log('luminence', luminence);\n let alpha;\n if (luminence >= 220) {\n alpha = 1;\n } else if (luminence <= 50) {\n alpha = 0.1;\n } else {\n alpha = luminence / 255;\n }\n alpha = Math.min(1, alpha);\n return [r, g, b, alpha];\n}\n\nfunction niceAccountURL(url) {\n if (!url) return;\n const urlObj = new URL(url);\n const { host, pathname } = urlObj;\n const path = pathname.replace(/\\/$/, '').replace(/^\\//, '');\n return (\n <>\n <span class=\"more-insignificant\">{host}/</span>\n <wbr />\n <span>{path}</span>\n </>\n );\n}\n\nfunction TranslatedBioSheet({ note, fields, onClose }) {\n const fieldsText =\n fields\n ?.map(({ name, value }) => `${name}\\n${getHTMLText(value)}`)\n .join('\\n\\n') || '';\n\n const text = getHTMLText(note) + (fieldsText ? `\\n\\n${fieldsText}` : '');\n\n return (\n <div class=\"sheet\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>Translated Bio</h2>\n </header>\n <main>\n <p\n style={{\n whiteSpace: 'pre-wrap',\n }}\n >\n {text}\n </p>\n <TranslationBlock forceTranslate text={text} />\n </main>\n </div>\n );\n}\n\nfunction AddRemoveListsSheet({ accountID, onClose }) {\n const { masto } = api();\n const [uiState, setUIState] = useState('default');\n const [lists, setLists] = useState([]);\n const [listsContainingAccount, setListsContainingAccount] = useState([]);\n const [reloadCount, reload] = useReducer((c) => c + 1, 0);\n\n useEffect(() => {\n setUIState('loading');\n (async () => {\n try {\n const lists = await masto.v1.lists.list();\n lists.sort((a, b) => a.title.localeCompare(b.title));\n const listsContainingAccount = await masto.v1.accounts\n .$select(accountID)\n .lists.list();\n console.log({ lists, listsContainingAccount });\n setLists(lists);\n setListsContainingAccount(listsContainingAccount);\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n }, [reloadCount]);\n\n const [showListAddEditModal, setShowListAddEditModal] = useState(false);\n\n return (\n <div class=\"sheet\" id=\"list-add-remove-container\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>Add/Remove from Lists</h2>\n </header>\n <main>\n {lists.length > 0 ? (\n <ul class=\"list-add-remove\">\n {lists.map((list) => {\n const inList = listsContainingAccount.some(\n (l) => l.id === list.id,\n );\n return (\n <li>\n <button\n type=\"button\"\n class={`light ${inList ? 'checked' : ''}`}\n disabled={uiState === 'loading'}\n onClick={() => {\n setUIState('loading');\n (async () => {\n try {\n if (inList) {\n await masto.v1.lists\n .$select(list.id)\n .accounts.remove({\n accountIds: [accountID],\n });\n } else {\n await masto.v1.lists\n .$select(list.id)\n .accounts.create({\n accountIds: [accountID],\n });\n }\n // setUIState('default');\n reload();\n } catch (e) {\n console.error(e);\n setUIState('error');\n alert(\n inList\n ? 'Unable to remove from list.'\n : 'Unable to add to list.',\n );\n }\n })();\n }}\n >\n <Icon icon=\"check-circle\" />\n <span>{list.title}</span>\n </button>\n </li>\n );\n })}\n </ul>\n ) : uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : uiState === 'error' ? (\n <p class=\"ui-state\">Unable to load lists.</p>\n ) : (\n <p class=\"ui-state\">No lists.</p>\n )}\n <button\n type=\"button\"\n class=\"plain2\"\n onClick={() => setShowListAddEditModal(true)}\n disabled={uiState !== 'default'}\n >\n <Icon icon=\"plus\" size=\"l\" /> <span>New list</span>\n </button>\n </main>\n {showListAddEditModal && (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n setShowListAddEditModal(false);\n }\n }}\n >\n <ListAddEdit\n list={showListAddEditModal?.list}\n onClose={(result) => {\n if (result.state === 'success') {\n reload();\n }\n setShowListAddEditModal(false);\n }}\n />\n </Modal>\n )}\n </div>\n );\n}\n\nfunction PrivateNoteSheet({\n account,\n note: initialNote,\n onRelationshipChange = () => {},\n onClose = () => {},\n}) {\n const { masto } = api();\n const [uiState, setUIState] = useState('default');\n const textareaRef = useRef(null);\n\n useEffect(() => {\n let timer;\n if (textareaRef.current && !initialNote) {\n timer = setTimeout(() => {\n textareaRef.current.focus?.();\n }, 100);\n }\n return () => {\n clearTimeout(timer);\n };\n }, []);\n\n return (\n <div class=\"sheet\" id=\"private-note-container\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <b>Private note about @{account?.username || account?.acct}</b>\n </header>\n <main>\n <form\n onSubmit={(e) => {\n e.preventDefault();\n const formData = new FormData(e.target);\n const note = formData.get('note');\n if (note?.trim() !== initialNote?.trim()) {\n setUIState('loading');\n (async () => {\n try {\n const newRelationship = await masto.v1.accounts\n .$select(account?.id)\n .note.create({\n comment: note,\n });\n console.log('updated relationship', newRelationship);\n setUIState('default');\n onRelationshipChange(newRelationship);\n onClose();\n } catch (e) {\n console.error(e);\n setUIState('error');\n alert(e?.message || 'Unable to update private note.');\n }\n })();\n }\n }}\n >\n <textarea\n ref={textareaRef}\n name=\"note\"\n disabled={uiState === 'loading'}\n >\n {initialNote}\n </textarea>\n <footer>\n <button\n type=\"button\"\n class=\"light\"\n disabled={uiState === 'loading'}\n onClick={() => {\n onClose?.();\n }}\n >\n Cancel\n </button>\n <span>\n <Loader abrupt hidden={uiState !== 'loading'} />\n <button disabled={uiState === 'loading'} type=\"submit\">\n Save & close\n </button>\n </span>\n </footer>\n </form>\n </main>\n </div>\n );\n}\n\nexport default AccountInfo;\n","import { useEffect } from 'preact/hooks';\n\nimport { api } from '../utils/api';\nimport states from '../utils/states';\nimport useLocationChange from '../utils/useLocationChange';\n\nimport AccountInfo from './account-info';\nimport Icon from './icon';\n\nfunction AccountSheet({ account, instance: propInstance, onClose }) {\n const { masto, instance, authenticated } = api({ instance: propInstance });\n const isString = typeof account === 'string';\n\n useEffect(() => {\n if (!isString) {\n states.accounts[`${account.id}@${instance}`] = account;\n }\n }, [account]);\n\n useLocationChange(onClose);\n\n return (\n <div\n class=\"sheet\"\n // onClick={(e) => {\n // const accountBlock = e.target.closest('.account-block');\n // if (accountBlock) {\n // onClose({\n // destination: 'account-statuses',\n // });\n // }\n // }}\n >\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close outer\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <AccountInfo\n instance={instance}\n authenticated={authenticated}\n account={account}\n fetchAccount={async () => {\n if (isString) {\n try {\n const info = await masto.v1.accounts.lookup({\n acct: account,\n skip_webfinger: false,\n });\n return info;\n } catch (e) {\n const result = await masto.v2.search.fetch({\n q: account,\n type: 'accounts',\n limit: 1,\n resolve: authenticated,\n });\n if (result.accounts.length) {\n return result.accounts[0];\n } else if (/https?:\\/\\/[^/]+\\/@/.test(account)) {\n const accountURL = new URL(account);\n const acct = accountURL.pathname.replace(/^\\//, '');\n const result = await masto.v2.search.fetch({\n q: acct,\n type: 'accounts',\n limit: 1,\n resolve: authenticated,\n });\n if (result.accounts.length) {\n return result.accounts[0];\n }\n }\n }\n } else {\n return account;\n }\n }}\n />\n </div>\n );\n}\n\nexport default AccountSheet;\n","import './drafts.css';\n\nimport { useEffect, useMemo, useReducer, useState } from 'react';\n\nimport { api } from '../utils/api';\nimport db from '../utils/db';\nimport niceDateTime from '../utils/nice-date-time';\nimport states from '../utils/states';\nimport { getCurrentAccountNS } from '../utils/store-utils';\n\nimport Icon from './icon';\nimport Loader from './loader';\nimport MenuConfirm from './menu-confirm';\n\nfunction Drafts({ onClose }) {\n const { masto } = api();\n const [uiState, setUIState] = useState('default');\n const [drafts, setDrafts] = useState([]);\n const [reloadCount, reload] = useReducer((c) => c + 1, 0);\n\n useEffect(() => {\n setUIState('loading');\n (async () => {\n try {\n const keys = await db.drafts.keys();\n if (keys.length) {\n const ns = getCurrentAccountNS();\n const ownKeys = keys.filter((key) => key.startsWith(ns));\n if (ownKeys.length) {\n const drafts = await db.drafts.getMany(ownKeys);\n drafts.sort(\n (a, b) =>\n new Date(b.updatedAt).getTime() -\n new Date(a.updatedAt).getTime(),\n );\n setDrafts(drafts);\n } else {\n setDrafts([]);\n }\n } else {\n setDrafts([]);\n }\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n }, [reloadCount]);\n\n const hasDrafts = drafts?.length > 0;\n\n return (\n <div class=\"sheet\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>\n Unsent drafts <Loader abrupt hidden={uiState !== 'loading'} />\n </h2>\n {hasDrafts && (\n <div class=\"insignificant\">\n Looks like you have unsent drafts. Let's continue where you left\n off.\n </div>\n )}\n </header>\n <main>\n {hasDrafts ? (\n <>\n <ul class=\"drafts-list\">\n {drafts.map((draft) => {\n const { updatedAt, key, draftStatus, replyTo } = draft;\n const updatedAtDate = new Date(updatedAt);\n return (\n <li key={updatedAt}>\n <div class=\"mini-draft-meta\">\n <b>\n <Icon icon={replyTo ? 'reply' : 'quill'} size=\"s\" />{' '}\n <time>\n {!!replyTo && (\n <>\n @{replyTo.account.acct}\n <br />\n </>\n )}\n {niceDateTime(updatedAtDate)}\n </time>\n </b>\n <MenuConfirm\n confirmLabel={<span>Delete this draft?</span>}\n menuItemClassName=\"danger\"\n align=\"end\"\n disabled={uiState === 'loading'}\n onClick={() => {\n (async () => {\n try {\n // const yes = confirm('Delete this draft?');\n // if (yes) {\n await db.drafts.del(key);\n reload();\n // }\n } catch (e) {\n alert('Error deleting draft! Please try again.');\n }\n })();\n }}\n >\n <button\n type=\"button\"\n class=\"small light\"\n disabled={uiState === 'loading'}\n >\n Delete…\n </button>\n </MenuConfirm>\n </div>\n <button\n type=\"button\"\n disabled={uiState === 'loading'}\n class=\"draft-item\"\n onClick={async () => {\n // console.log({ draftStatus });\n let replyToStatus;\n if (replyTo) {\n setUIState('loading');\n try {\n replyToStatus = await masto.v1.statuses\n .$select(replyTo.id)\n .fetch();\n } catch (e) {\n console.error(e);\n alert('Error fetching reply-to status!');\n setUIState('default');\n return;\n }\n setUIState('default');\n }\n window.__COMPOSE__ = {\n draftStatus,\n replyToStatus,\n };\n states.showCompose = true;\n states.showDrafts = false;\n }}\n >\n <MiniDraft draft={draft} />\n </button>\n </li>\n );\n })}\n </ul>\n {drafts.length > 1 && (\n <p>\n <MenuConfirm\n confirmLabel={<span>Delete all drafts?</span>}\n menuItemClassName=\"danger\"\n disabled={uiState === 'loading'}\n onClick={() => {\n (async () => {\n // const yes = confirm('Delete all drafts?');\n // if (yes) {\n setUIState('loading');\n try {\n await db.drafts.delMany(\n drafts.map((draft) => draft.key),\n );\n setUIState('default');\n reload();\n } catch (e) {\n console.error(e);\n alert('Error deleting drafts! Please try again.');\n setUIState('error');\n }\n // }\n })();\n }}\n >\n <button\n type=\"button\"\n class=\"light danger\"\n disabled={uiState === 'loading'}\n >\n Delete all…\n </button>\n </MenuConfirm>\n </p>\n )}\n </>\n ) : (\n <p>No drafts found.</p>\n )}\n </main>\n </div>\n );\n}\n\nfunction MiniDraft({ draft }) {\n const { draftStatus, replyTo } = draft;\n const { status, spoilerText, poll, mediaAttachments } = draftStatus;\n const hasPoll = poll?.options?.length > 0;\n const hasMedia = mediaAttachments?.length > 0;\n const hasPollOrMedia = hasPoll || hasMedia;\n const firstImageMedia = useMemo(() => {\n if (!hasMedia) return;\n const image = mediaAttachments.find((media) => /image/.test(media.type));\n if (!image) return;\n const { file } = image;\n const objectURL = URL.createObjectURL(file);\n return objectURL;\n }, [hasMedia, mediaAttachments]);\n return (\n <>\n <div class=\"mini-draft\">\n {hasPollOrMedia && (\n <div\n class={`mini-draft-aside ${firstImageMedia ? 'has-image' : ''}`}\n style={\n firstImageMedia\n ? {\n '--bg-image': `url(${firstImageMedia})`,\n }\n : {}\n }\n >\n {hasPoll && <Icon icon=\"poll\" />}\n {hasMedia && (\n <span>\n <Icon icon=\"attachment\" />{' '}\n <small>{mediaAttachments?.length}</small>\n </span>\n )}\n </div>\n )}\n <div class=\"mini-draft-main\">\n {!!spoilerText && <div class=\"mini-draft-spoiler\">{spoilerText}</div>}\n {!!status && <div class=\"mini-draft-status\">{status}</div>}\n </div>\n </div>\n </>\n );\n}\n\nexport default Drafts;\n","import { api } from './api';\nimport store from './store';\n\nexport async function fetchRelationships(accounts, relationshipsMap = {}) {\n if (!accounts?.length) return;\n const { masto } = api();\n\n const currentAccount = store.session.get('currentAccount');\n const uniqueAccountIds = accounts.reduce((acc, a) => {\n // 1. Ignore duplicate accounts\n // 2. Ignore accounts that are already inside relationshipsMap\n // 3. Ignore currently logged in account\n if (\n !acc.includes(a.id) &&\n !relationshipsMap[a.id] &&\n a.id !== currentAccount\n ) {\n acc.push(a.id);\n }\n return acc;\n }, []);\n if (!uniqueAccountIds.length) return null;\n\n try {\n const relationships = await masto.v1.accounts.relationships.fetch({\n id: uniqueAccountIds,\n });\n const newRelationshipsMap = relationships.reduce((acc, r) => {\n acc[r.id] = r;\n return acc;\n }, {});\n return newRelationshipsMap;\n } catch (e) {\n console.error(e);\n // It's okay to fail\n return null;\n }\n}\n","import './generic-accounts.css';\n\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { InView } from 'react-intersection-observer';\nimport { useSnapshot } from 'valtio';\n\nimport { api } from '../utils/api';\nimport { fetchRelationships } from '../utils/relationships';\nimport states from '../utils/states';\nimport useLocationChange from '../utils/useLocationChange';\n\nimport AccountBlock from './account-block';\nimport Icon from './icon';\nimport Loader from './loader';\n\nexport default function GenericAccounts({\n instance,\n excludeRelationshipAttrs = [],\n onClose = () => {},\n}) {\n const { masto, instance: currentInstance } = api();\n const isCurrentInstance = instance ? instance === currentInstance : true;\n const snapStates = useSnapshot(states);\n ``;\n const [uiState, setUIState] = useState('default');\n const [accounts, setAccounts] = useState([]);\n const [showMore, setShowMore] = useState(false);\n\n useLocationChange(onClose);\n\n if (!snapStates.showGenericAccounts) {\n return null;\n }\n\n const {\n id,\n heading,\n fetchAccounts,\n accounts: staticAccounts,\n showReactions,\n } = snapStates.showGenericAccounts;\n\n const [relationshipsMap, setRelationshipsMap] = useState({});\n\n const loadRelationships = async (accounts) => {\n if (!accounts?.length) return;\n if (!isCurrentInstance) return;\n const relationships = await fetchRelationships(accounts, relationshipsMap);\n if (relationships) {\n setRelationshipsMap({\n ...relationshipsMap,\n ...relationships,\n });\n }\n };\n\n const loadAccounts = (firstLoad) => {\n if (!fetchAccounts) return;\n if (firstLoad) setAccounts([]);\n setUIState('loading');\n (async () => {\n try {\n const { done, value } = await fetchAccounts(firstLoad);\n if (Array.isArray(value)) {\n if (firstLoad) {\n const accounts = [];\n for (let i = 0; i < value.length; i++) {\n const account = value[i];\n const theAccount = accounts.find(\n (a, j) => a.id === account.id && i !== j,\n );\n if (!theAccount) {\n accounts.push({\n _types: [],\n ...account,\n });\n } else {\n theAccount._types.push(...account._types);\n }\n }\n setAccounts(accounts);\n } else {\n // setAccounts((prev) => [...prev, ...value]);\n // Merge accounts by id and _types\n setAccounts((prev) => {\n const newAccounts = prev;\n for (const account of value) {\n const theAccount = newAccounts.find((a) => a.id === account.id);\n if (!theAccount) {\n newAccounts.push(account);\n } else {\n theAccount._types.push(...account._types);\n }\n }\n return newAccounts;\n });\n }\n setShowMore(!done);\n\n loadRelationships(value);\n } else {\n setShowMore(false);\n }\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n };\n\n const firstLoad = useRef(true);\n useEffect(() => {\n if (staticAccounts?.length > 0) {\n setAccounts(staticAccounts);\n loadRelationships(staticAccounts);\n } else {\n loadAccounts(true);\n firstLoad.current = false;\n }\n }, [staticAccounts, fetchAccounts]);\n\n useEffect(() => {\n if (firstLoad.current) return;\n // reloadGenericAccounts contains value like {id: 'mute', counter: 1}\n // We only need to reload if the id matches\n if (snapStates.reloadGenericAccounts?.id === id) {\n loadAccounts(true);\n }\n }, [snapStates.reloadGenericAccounts.counter]);\n\n return (\n <div id=\"generic-accounts-container\" class=\"sheet\" tabindex=\"-1\">\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n <header>\n <h2>{heading || 'Accounts'}</h2>\n </header>\n <main>\n {accounts.length > 0 ? (\n <>\n <ul class=\"accounts-list\">\n {accounts.map((account) => {\n const relationship = relationshipsMap[account.id];\n const key = `${account.id}-${account._types?.length || ''}`;\n return (\n <li key={key}>\n {showReactions && account._types?.length > 0 && (\n <div class=\"reactions-block\">\n {account._types.map((type) => (\n <Icon\n icon={\n {\n reblog: 'rocket',\n favourite: 'heart',\n }[type]\n }\n class={`${type}-icon`}\n />\n ))}\n </div>\n )}\n <div class=\"account-relationships\">\n <AccountBlock\n account={account}\n showStats\n relationship={relationship}\n excludeRelationshipAttrs={excludeRelationshipAttrs}\n />\n </div>\n </li>\n );\n })}\n </ul>\n {uiState === 'default' ? (\n showMore ? (\n <InView\n onChange={(inView) => {\n if (inView) {\n loadAccounts();\n }\n }}\n >\n <button\n type=\"button\"\n class=\"plain block\"\n onClick={() => loadAccounts()}\n >\n Show more…\n </button>\n </InView>\n ) : (\n <p class=\"ui-state insignificant\">The end.</p>\n )\n ) : (\n uiState === 'loading' && (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n )\n )}\n </>\n ) : uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : uiState === 'error' ? (\n <p class=\"ui-state\">Error loading accounts</p>\n ) : (\n <p class=\"ui-state insignificant\">Nothing to show</p>\n )}\n </main>\n </div>\n );\n}\n","import { Menu, MenuItem } from '@szhsin/react-menu';\nimport { useState } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport getTranslateTargetLanguage from '../utils/get-translate-target-language';\nimport localeMatch from '../utils/locale-match';\nimport { speak, supportsTTS } from '../utils/speech';\nimport states from '../utils/states';\n\nimport Icon from './icon';\nimport Menu2 from './menu2';\nimport TranslationBlock from './translation-block';\n\nexport default function MediaAltModal({ alt, lang, onClose }) {\n const snapStates = useSnapshot(states);\n const [forceTranslate, setForceTranslate] = useState(false);\n const targetLanguage = getTranslateTargetLanguage(true);\n const contentTranslationHideLanguages =\n snapStates.settings.contentTranslationHideLanguages || [];\n const differentLanguage =\n !!lang &&\n lang !== targetLanguage &&\n !localeMatch([lang], [targetLanguage]) &&\n !contentTranslationHideLanguages.find(\n (l) => lang === l || localeMatch([lang], [l]),\n );\n\n return (\n <div class=\"sheet\" tabindex=\"-1\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close outer\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header class=\"header-grid\">\n <h2>Media description</h2>\n <div class=\"header-side\">\n <Menu2\n align=\"end\"\n menuButton={\n <button type=\"button\" class=\"plain4\">\n <Icon icon=\"more\" alt=\"More\" size=\"xl\" />\n </button>\n }\n >\n <MenuItem\n disabled={forceTranslate}\n onClick={() => {\n setForceTranslate(true);\n }}\n >\n <Icon icon=\"translate\" />\n <span>Translate</span>\n </MenuItem>\n {supportsTTS && (\n <MenuItem\n onClick={() => {\n speak(alt, lang);\n }}\n >\n <Icon icon=\"speak\" />\n <span>Speak</span>\n </MenuItem>\n )}\n </Menu2>\n </div>\n </header>\n <main lang={lang} dir=\"auto\">\n <p\n style={{\n whiteSpace: 'pre-wrap',\n textWrap: 'pretty',\n }}\n >\n {alt}\n </p>\n {(differentLanguage || forceTranslate) && (\n <TranslationBlock\n forceTranslate={forceTranslate}\n sourceLanguage={lang}\n text={alt}\n />\n )}\n </main>\n </div>\n );\n}\n","// https://gist.github.com/earthbound19/e7fe15fdf8ca3ef814750a61bc75b5ce\nfunction clamp(value, min, max) {\n return Math.max(Math.min(value, max), min);\n}\n\nconst gammaToLinear = (c) =>\n c >= 0.04045 ? Math.pow((c + 0.055) / 1.055, 2.4) : c / 12.92;\nconst linearToGamma = (c) =>\n c >= 0.0031308 ? 1.055 * Math.pow(c, 1 / 2.4) - 0.055 : 12.92 * c;\n\nexport function rgb2oklab([r, g, b]) {\n r = gammaToLinear(r / 255);\n g = gammaToLinear(g / 255);\n b = gammaToLinear(b / 255);\n var l = 0.4122214708 * r + 0.5363325363 * g + 0.0514459929 * b;\n var m = 0.2119034982 * r + 0.6806995451 * g + 0.1073969566 * b;\n var s = 0.0883024619 * r + 0.2817188376 * g + 0.6299787005 * b;\n l = Math.cbrt(l);\n m = Math.cbrt(m);\n s = Math.cbrt(s);\n return [\n l * +0.2104542553 + m * +0.793617785 + s * -0.0040720468,\n l * +1.9779984951 + m * -2.428592205 + s * +0.4505937099,\n l * +0.0259040371 + m * +0.7827717662 + s * -0.808675766,\n ];\n}\n\nexport function oklab2rgb([L, a, b]) {\n var l = L + a * +0.3963377774 + b * +0.2158037573;\n var m = L + a * -0.1055613458 + b * -0.0638541728;\n var s = L + a * -0.0894841775 + b * -1.291485548;\n // The ** operator here cubes; same as l_*l_*l_ in the C++ example:\n l = l ** 3;\n m = m ** 3;\n s = s ** 3;\n var r = l * +4.0767416621 + m * -3.3077115913 + s * +0.2309699292;\n var g = l * -1.2684380046 + m * +2.6097574011 + s * -0.3413193965;\n var b = l * -0.0041960863 + m * -0.7034186147 + s * +1.707614701;\n // Convert linear RGB values returned from oklab math to sRGB for our use before returning them:\n r = 255 * linearToGamma(r);\n g = 255 * linearToGamma(g);\n b = 255 * linearToGamma(b);\n // OPTION: clamp r g and b values to the range 0-255; but if you use the values immediately to draw, JavaScript clamps them on use:\n r = clamp(r, 0, 255);\n g = clamp(g, 0, 255);\n b = clamp(b, 0, 255);\n // OPTION: round the values. May not be necessary if you use them immediately for rendering in JavaScript, as JavaScript (also) discards decimals on render:\n r = Math.round(r);\n g = Math.round(g);\n b = Math.round(b);\n return [r, g, b];\n}\n","import { MenuDivider, MenuItem } from '@szhsin/react-menu';\nimport { getBlurHashAverageColor } from 'fast-blurhash';\nimport {\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\n\nimport { oklab2rgb, rgb2oklab } from '../utils/color-utils';\nimport showToast from '../utils/show-toast';\nimport states from '../utils/states';\n\nimport Icon from './icon';\nimport Link from './link';\nimport Media from './media';\nimport Menu2 from './menu2';\nimport MenuLink from './menu-link';\n\nconst { PHANPY_IMG_ALT_API_URL: IMG_ALT_API_URL } = import.meta.env;\n\nfunction MediaModal({\n mediaAttachments,\n statusID,\n instance,\n lang,\n index = 0,\n onClose = () => {},\n}) {\n const [uiState, setUIState] = useState('default');\n const carouselRef = useRef(null);\n\n const [currentIndex, setCurrentIndex] = useState(index);\n const carouselFocusItem = useRef(null);\n useLayoutEffect(() => {\n carouselFocusItem.current?.scrollIntoView();\n\n // history.pushState({ mediaModal: true }, '');\n // const handlePopState = (e) => {\n // if (e.state?.mediaModal) {\n // onClose();\n // }\n // };\n // window.addEventListener('popstate', handlePopState);\n // return () => {\n // window.removeEventListener('popstate', handlePopState);\n // };\n }, []);\n const prevStatusID = useRef(statusID);\n useEffect(() => {\n const scrollLeft = index * carouselRef.current.clientWidth;\n const differentStatusID = prevStatusID.current !== statusID;\n if (differentStatusID) prevStatusID.current = statusID;\n carouselRef.current.scrollTo({\n left: scrollLeft,\n behavior: differentStatusID ? 'auto' : 'smooth',\n });\n carouselRef.current.focus();\n }, [index, statusID]);\n\n const [showControls, setShowControls] = useState(true);\n\n useEffect(() => {\n let handleSwipe = () => {\n onClose();\n };\n if (carouselRef.current) {\n carouselRef.current.addEventListener('swiped-down', handleSwipe);\n }\n return () => {\n if (carouselRef.current) {\n carouselRef.current.removeEventListener('swiped-down', handleSwipe);\n }\n };\n }, []);\n\n useHotkeys(\n 'esc',\n onClose,\n {\n ignoreEventWhen: (e) => {\n const hasModal = !!document.querySelector('#modal-container > *');\n return hasModal;\n },\n },\n [onClose],\n );\n\n useEffect(() => {\n let handleScroll = () => {\n const { clientWidth, scrollLeft } = carouselRef.current;\n const index = Math.round(scrollLeft / clientWidth);\n setCurrentIndex(index);\n };\n if (carouselRef.current) {\n carouselRef.current.addEventListener('scroll', handleScroll, {\n passive: true,\n });\n }\n return () => {\n if (carouselRef.current) {\n carouselRef.current.removeEventListener('scroll', handleScroll);\n }\n };\n }, []);\n\n useEffect(() => {\n let timer = setTimeout(() => {\n carouselRef.current?.focus?.();\n }, 100);\n return () => clearTimeout(timer);\n }, []);\n\n const mediaAccentColors = useMemo(() => {\n return mediaAttachments?.map((media) => {\n const { blurhash } = media;\n if (blurhash) {\n const averageColor = getBlurHashAverageColor(blurhash);\n const labAverageColor = rgb2oklab(averageColor);\n return oklab2rgb([0.6, labAverageColor[1], labAverageColor[2]]);\n }\n return null;\n });\n }, [mediaAttachments]);\n const mediaAccentGradient = useMemo(() => {\n const gap = 5;\n const range = 100 / mediaAccentColors.length;\n return (\n mediaAccentColors\n ?.map((color, i) => {\n const start = i * range + gap;\n const end = (i + 1) * range - gap;\n if (color) {\n return `\n rgba(${color?.join(',')}, 0.4) ${start}%,\n rgba(${color?.join(',')}, 0.4) ${end}%\n `;\n }\n\n return `\n transparent ${start}%,\n transparent ${end}%\n `;\n })\n ?.join(', ') || 'transparent'\n );\n }, [mediaAccentColors]);\n\n let toastRef = useRef(null);\n useEffect(() => {\n return () => {\n toastRef.current?.hideToast?.();\n };\n }, []);\n\n return (\n <div\n class={`media-modal-container media-modal-count-${mediaAttachments?.length}`}\n >\n <div\n ref={carouselRef}\n tabIndex=\"0\"\n data-swipe-threshold=\"44\"\n class=\"carousel\"\n onClick={(e) => {\n if (\n e.target.classList.contains('carousel-item') ||\n e.target.classList.contains('media') ||\n e.target.classList.contains('media-zoom')\n ) {\n onClose();\n }\n }}\n style={\n mediaAttachments.length > 1\n ? {\n backgroundAttachment: 'local',\n backgroundImage: `linear-gradient(\n to right, ${mediaAccentGradient})`,\n }\n : {}\n }\n >\n {mediaAttachments?.map((media, i) => {\n const accentColor =\n mediaAttachments.length === 1 ? mediaAccentColors[i] : null;\n return (\n <div\n class=\"carousel-item\"\n style={\n accentColor\n ? {\n '--accent-color': `rgb(${accentColor?.join(',')})`,\n '--accent-alpha-color': `rgba(${accentColor?.join(\n ',',\n )}, 0.4)`,\n }\n : {}\n }\n tabindex=\"0\"\n key={media.id}\n ref={i === currentIndex ? carouselFocusItem : null}\n onClick={(e) => {\n // console.log(e);\n // if (e.target !== e.currentTarget) {\n // setShowControls(!showControls);\n // }\n if (!e.target.classList.contains('media')) {\n setShowControls(!showControls);\n }\n }}\n >\n {!!media.description && (\n <button\n type=\"button\"\n class=\"media-alt\"\n hidden={!showControls}\n onClick={() => {\n states.showMediaAlt = {\n alt: media.description,\n lang,\n };\n }}\n >\n <span class=\"alt-badge\">ALT</span>\n <span class=\"media-alt-desc\" lang={lang} dir=\"auto\">\n {media.description}\n </span>\n </button>\n )}\n <Media media={media} showOriginal lang={lang} />\n </div>\n );\n })}\n </div>\n <div class=\"carousel-top-controls\" hidden={!showControls}>\n <span>\n <button\n type=\"button\"\n class=\"carousel-button\"\n onClick={() => onClose()}\n >\n <Icon icon=\"x\" />\n </button>\n </span>\n {mediaAttachments?.length > 1 ? (\n <span class=\"carousel-dots\">\n {mediaAttachments?.map((media, i) => (\n <button\n key={media.id}\n type=\"button\"\n disabled={i === currentIndex}\n class={`carousel-dot ${i === currentIndex ? 'active' : ''}`}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n carouselRef.current.scrollTo({\n left: carouselRef.current.clientWidth * i,\n behavior: 'smooth',\n });\n carouselRef.current.focus();\n }}\n >\n <Icon icon=\"round\" size=\"s\" />\n </button>\n ))}\n </span>\n ) : (\n <span />\n )}\n <span>\n <Menu2\n overflow=\"auto\"\n align=\"end\"\n position=\"anchor\"\n gap={4}\n menuClassName=\"glass-menu\"\n menuButton={\n <button type=\"button\" class=\"carousel-button\">\n <Icon icon=\"more\" alt=\"More\" />\n </button>\n }\n >\n <MenuLink\n href={\n mediaAttachments[currentIndex]?.remoteUrl ||\n mediaAttachments[currentIndex]?.url\n }\n class=\"carousel-button\"\n target=\"_blank\"\n title=\"Open original media in new window\"\n >\n <Icon icon=\"popout\" />\n <span>Open original media</span>\n </MenuLink>\n {import.meta.env.DEV && // Only dev for now\n !!states.settings.mediaAltGenerator &&\n !!IMG_ALT_API_URL &&\n !!mediaAttachments[currentIndex]?.url &&\n !mediaAttachments[currentIndex]?.description &&\n mediaAttachments[currentIndex]?.type === 'image' && (\n <>\n <MenuDivider />\n <MenuItem\n disabled={uiState === 'loading'}\n onClick={() => {\n setUIState('loading');\n toastRef.current = showToast({\n text: 'Attempting to describe image. Please wait...',\n duration: -1,\n });\n (async function () {\n try {\n const response = await fetch(\n `${IMG_ALT_API_URL}?image=${encodeURIComponent(\n mediaAttachments[currentIndex]?.url,\n )}`,\n ).then((r) => r.json());\n states.showMediaAlt = {\n alt: response.description,\n };\n } catch (e) {\n console.error(e);\n showToast('Failed to describe image');\n } finally {\n setUIState('default');\n toastRef.current?.hideToast?.();\n }\n })();\n }}\n >\n <Icon icon=\"sparkles2\" />\n <span>Describe image…</span>\n </MenuItem>\n </>\n )}\n </Menu2>{' '}\n <Link\n to={`${instance ? `/${instance}` : ''}/s/${statusID}${\n window.matchMedia('(min-width: calc(40em + 350px))').matches\n ? `?media=${currentIndex + 1}`\n : ''\n }`}\n class=\"button carousel-button media-post-link\"\n // onClick={() => {\n // // if small screen (not media query min-width 40em + 350px), run onClose\n // if (\n // !window.matchMedia('(min-width: calc(40em + 350px))').matches\n // ) {\n // onClose();\n // }\n // }}\n >\n <span class=\"button-label\">View post </span>»\n </Link>\n </span>\n </div>\n {mediaAttachments?.length > 1 && (\n <div class=\"carousel-controls\" hidden={!showControls}>\n <button\n type=\"button\"\n class=\"carousel-button\"\n hidden={currentIndex === 0}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n carouselRef.current.focus();\n carouselRef.current.scrollTo({\n left: carouselRef.current.clientWidth * (currentIndex - 1),\n behavior: 'smooth',\n });\n }}\n >\n <Icon icon=\"arrow-left\" />\n </button>\n <button\n type=\"button\"\n class=\"carousel-button\"\n hidden={currentIndex === mediaAttachments.length - 1}\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n carouselRef.current.focus();\n carouselRef.current.scrollTo({\n left: carouselRef.current.clientWidth * (currentIndex + 1),\n behavior: 'smooth',\n });\n }}\n >\n <Icon icon=\"arrow-right\" />\n </button>\n </div>\n )}\n </div>\n );\n}\n\nexport default MediaModal;\n","export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20viewBox='0%200%2084%2062'%3e%3crect%20width='64'%20height='48'%20x='18'%20y='2'%20fill='%23fff'%20stroke='%23999'%20stroke-width='3'%20rx='4'/%3e%3crect%20width='32'%20height='48'%20x='2'%20y='12'%20fill='%23fff'%20stroke='%23999'%20stroke-width='3'%20rx='4'/%3e%3cpath%20fill='%234169E1'%20d='M14%2052a4%204%200%201%201-8%200%204%204%200%200%201%208%200Zm64-42a4%204%200%201%201-8%200%204%204%200%200%201%208%200Z'/%3e%3c/svg%3e\"","export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20viewBox='0%200%2082%2062'%3e%3crect%20width='78'%20height='58'%20x='2'%20y='2'%20fill='%23999'%20fill-opacity='.3'%20stroke='%23999'%20stroke-width='3'%20rx='4'/%3e%3crect%20width='18'%20height='46'%20x='8'%20y='8'%20fill='%23fff'%20stroke='%23999'%20stroke-width='2'%20rx='1'/%3e%3crect%20width='18'%20height='46'%20x='32'%20y='8'%20fill='%23fff'%20stroke='%23999'%20stroke-width='2'%20rx='1'/%3e%3crect%20width='18'%20height='46'%20x='56'%20y='8'%20fill='%23fff'%20stroke='%23999'%20stroke-width='2'%20rx='1'/%3e%3c/svg%3e\"","export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20fill='none'%20viewBox='0%200%2084%2062'%3e%3crect%20width='64'%20height='48'%20x='18'%20y='2'%20fill='%23fff'%20stroke='%23999'%20stroke-width='3'%20rx='4'/%3e%3cpath%20fill='%23999'%20fill-opacity='.3'%20d='M19%203h62v10H19z'/%3e%3cpath%20stroke='%234169E1'%20stroke-width='2'%20d='M43%208a2%202%200%201%201-4%200%202%202%200%200%201%204%200Z'/%3e%3cpath%20stroke='%23999'%20stroke-width='2'%20d='M52%208a2%202%200%201%201-4%200%202%202%200%200%201%204%200Zm9%200a2%202%200%201%201-4%200%202%202%200%200%201%204%200Z'/%3e%3crect%20width='32'%20height='48'%20x='2'%20y='12'%20fill='%23fff'%20stroke='%23999'%20stroke-width='3'%20rx='4'/%3e%3cpath%20fill='%23999'%20fill-opacity='.3'%20d='M3%2049h30v10H3z'/%3e%3cpath%20stroke='%234169E1'%20stroke-width='2'%20d='M11%2054a2%202%200%201%201-4%200%202%202%200%200%201%204%200Z'/%3e%3cpath%20stroke='%23999'%20stroke-width='2'%20d='M20%2054a2%202%200%201%201-4%200%202%202%200%200%201%204%200Zm9%200a2%202%200%201%201-4%200%202%202%200%200%201%204%200Z'/%3e%3c/svg%3e\"","import { api } from '../utils/api';\nimport store from '../utils/store';\n\nconst LIMIT = 200;\nconst MAX_FETCH = 10;\n\nexport async function fetchFollowedTags() {\n const { masto } = api();\n const iterator = masto.v1.followedTags.list({\n limit: LIMIT,\n });\n const tags = [];\n let fetchCount = 0;\n do {\n const { value, done } = await iterator.next();\n if (done || value?.length === 0) break;\n tags.push(...value);\n fetchCount++;\n } while (fetchCount < MAX_FETCH);\n tags.sort((a, b) => a.name.localeCompare(b.name));\n console.log(tags);\n\n if (tags.length) {\n setTimeout(() => {\n // Save to local storage, with saved timestamp\n store.account.set('followedTags', {\n tags,\n updatedAt: Date.now(),\n });\n }, 1);\n }\n\n return tags;\n}\n\nconst MAX_AGE = 24 * 60 * 60 * 1000; // 1 day\nexport async function getFollowedTags() {\n try {\n const { tags, updatedAt } = store.account.get('followedTags') || {};\n if (!tags?.length) return await fetchFollowedTags();\n if (Date.now() - updatedAt > MAX_AGE) {\n // Stale-while-revalidate\n fetchFollowedTags();\n return tags;\n }\n return tags;\n } catch (e) {\n return [];\n }\n}\n\nconst fauxDiv = document.createElement('div');\nexport const extractTagsFromStatus = (content) => {\n if (!content) return [];\n if (content.indexOf('#') === -1) return [];\n fauxDiv.innerHTML = content;\n const hashtagLinks = fauxDiv.querySelectorAll('a.hashtag');\n if (!hashtagLinks.length) return [];\n return Array.from(hashtagLinks).map((a) =>\n a.innerText.trim().replace(/^[^#]*#+/, ''),\n );\n};\n","import { useEffect, useState } from 'preact/hooks';\n\nfunction AsyncText({ children }) {\n if (typeof children === 'string') return children;\n const [text, setText] = useState('');\n useEffect(() => {\n Promise.resolve(children).then(setText);\n }, [children]);\n return text;\n}\n\nexport default AsyncText;\n","import './shortcuts-settings.css';\n\nimport { useAutoAnimate } from '@formkit/auto-animate/preact';\nimport {\n compressToEncodedURIComponent,\n decompressFromEncodedURIComponent,\n} from 'lz-string';\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport floatingButtonUrl from '../assets/floating-button.svg';\nimport multiColumnUrl from '../assets/multi-column.svg';\nimport tabMenuBarUrl from '../assets/tab-menu-bar.svg';\n\nimport { api } from '../utils/api';\nimport { fetchFollowedTags } from '../utils/followed-tags';\nimport pmem from '../utils/pmem';\nimport showToast from '../utils/show-toast';\nimport states from '../utils/states';\n\nimport AsyncText from './AsyncText';\nimport Icon from './icon';\nimport MenuConfirm from './menu-confirm';\nimport Modal from './modal';\n\nexport const SHORTCUTS_LIMIT = 9;\n\nconst TYPES = [\n 'following',\n 'mentions',\n 'notifications',\n 'list',\n 'public',\n 'trending',\n 'search',\n 'hashtag',\n 'bookmarks',\n 'favourites',\n // NOTE: Hide for now\n // 'account-statuses', // Need @acct search first\n];\nconst TYPE_TEXT = {\n following: 'Home / Following',\n notifications: 'Notifications',\n list: 'List',\n public: 'Public (Local / Federated)',\n search: 'Search',\n 'account-statuses': 'Account',\n bookmarks: 'Bookmarks',\n favourites: 'Likes',\n hashtag: 'Hashtag',\n trending: 'Trending',\n mentions: 'Mentions',\n};\nconst TYPE_PARAMS = {\n list: [\n {\n text: 'List ID',\n name: 'id',\n },\n ],\n public: [\n {\n text: 'Local only',\n name: 'local',\n type: 'checkbox',\n },\n {\n text: 'Instance',\n name: 'instance',\n type: 'text',\n placeholder: 'Optional, e.g. mastodon.social',\n notRequired: true,\n },\n ],\n trending: [\n {\n text: 'Instance',\n name: 'instance',\n type: 'text',\n placeholder: 'Optional, e.g. mastodon.social',\n notRequired: true,\n },\n ],\n search: [\n {\n text: 'Search term',\n name: 'query',\n type: 'text',\n placeholder: 'Optional, unless for multi-column mode',\n notRequired: true,\n },\n ],\n 'account-statuses': [\n {\n text: '@',\n name: 'id',\n type: 'text',\n placeholder: 'cheeaun@mastodon.social',\n },\n ],\n hashtag: [\n {\n text: '#',\n name: 'hashtag',\n type: 'text',\n placeholder: 'e.g. PixelArt (Max 5, space-separated)',\n pattern: '[^#]+',\n },\n {\n text: 'Media only',\n name: 'media',\n type: 'checkbox',\n },\n {\n text: 'Instance',\n name: 'instance',\n type: 'text',\n placeholder: 'Optional, e.g. mastodon.social',\n notRequired: true,\n },\n ],\n};\nconst fetchListTitle = pmem(async ({ id }) => {\n const list = await api().masto.v1.lists.$select(id).fetch();\n return list.title;\n});\nconst fetchAccountTitle = pmem(async ({ id }) => {\n const account = await api().masto.v1.accounts.$select(id).fetch();\n return account.username || account.acct || account.displayName;\n});\nexport const SHORTCUTS_META = {\n following: {\n id: 'home',\n title: (_, index) => (index === 0 ? 'Home' : 'Following'),\n path: '/',\n icon: 'home',\n },\n mentions: {\n id: 'mentions',\n title: 'Mentions',\n path: '/mentions',\n icon: 'at',\n },\n notifications: {\n id: 'notifications',\n title: 'Notifications',\n path: '/notifications',\n icon: 'notification',\n },\n list: {\n id: 'list',\n title: fetchListTitle,\n path: ({ id }) => `/l/${id}`,\n icon: 'list',\n },\n public: {\n id: 'public',\n title: ({ local }) => (local ? 'Local' : 'Federated'),\n subtitle: ({ instance }) => instance || api().instance,\n path: ({ local, instance }) => `/${instance}/p${local ? '/l' : ''}`,\n icon: ({ local }) => (local ? 'building' : 'earth'),\n },\n trending: {\n id: 'trending',\n title: 'Trending',\n subtitle: ({ instance }) => instance || api().instance,\n path: ({ instance }) => `/${instance}/trending`,\n icon: 'chart',\n },\n search: {\n id: 'search',\n title: ({ query }) => (query ? `\"${query}\"` : 'Search'),\n path: ({ query }) =>\n query ? `/search?q=${query}&type=statuses` : '/search',\n icon: 'search',\n excludeViewMode: ({ query }) => (!query ? ['multi-column'] : []),\n },\n 'account-statuses': {\n id: 'account-statuses',\n title: fetchAccountTitle,\n path: ({ id }) => `/a/${id}`,\n icon: 'user',\n },\n bookmarks: {\n id: 'bookmarks',\n title: 'Bookmarks',\n path: '/b',\n icon: 'bookmark',\n },\n favourites: {\n id: 'favourites',\n title: 'Likes',\n path: '/f',\n icon: 'heart',\n },\n hashtag: {\n id: 'hashtag',\n title: ({ hashtag }) => hashtag,\n subtitle: ({ instance }) => instance || api().instance,\n path: ({ hashtag, instance, media }) =>\n `${instance ? `/${instance}` : ''}/t/${hashtag.split(/\\s+/).join('+')}${\n media ? '?media=1' : ''\n }`,\n icon: 'hashtag',\n },\n};\n\nfunction ShortcutsSettings({ onClose }) {\n const snapStates = useSnapshot(states);\n const { shortcuts } = snapStates;\n const [showForm, setShowForm] = useState(false);\n const [showImportExport, setShowImportExport] = useState(false);\n\n const [shortcutsListParent] = useAutoAnimate();\n\n return (\n <div id=\"shortcuts-settings-container\" class=\"sheet\" tabindex=\"-1\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>\n <Icon icon=\"shortcut\" /> Shortcuts{' '}\n <sup\n style={{\n fontSize: 12,\n opacity: 0.5,\n textTransform: 'uppercase',\n }}\n >\n beta\n </sup>\n </h2>\n </header>\n <main>\n <p>Specify a list of shortcuts that'll appear as:</p>\n <div class=\"shortcuts-view-mode\">\n {[\n {\n value: 'float-button',\n label: 'Floating button',\n imgURL: floatingButtonUrl,\n },\n {\n value: 'tab-menu-bar',\n label: 'Tab/Menu bar',\n imgURL: tabMenuBarUrl,\n },\n {\n value: 'multi-column',\n label: 'Multi-column',\n imgURL: multiColumnUrl,\n },\n ].map(({ value, label, imgURL }) => {\n const checked =\n snapStates.settings.shortcutsViewMode === value ||\n (value === 'float-button' &&\n !snapStates.settings.shortcutsViewMode);\n return (\n <label key={value} class={checked ? 'checked' : ''}>\n <input\n type=\"radio\"\n name=\"shortcuts-view-mode\"\n value={value}\n checked={checked}\n onChange={(e) => {\n states.settings.shortcutsViewMode = e.target.value;\n }}\n />{' '}\n <img src={imgURL} alt=\"\" width=\"80\" height=\"58\" />{' '}\n <span>{label}</span>\n </label>\n );\n })}\n </div>\n {shortcuts.length > 0 ? (\n <ol class=\"shortcuts-list\" ref={shortcutsListParent}>\n {shortcuts.filter(Boolean).map((shortcut, i) => {\n // const key = i + Object.values(shortcut);\n const key = Object.values(shortcut).join('-');\n const { type } = shortcut;\n if (!SHORTCUTS_META[type]) return null;\n let { icon, title, subtitle, excludeViewMode } =\n SHORTCUTS_META[type];\n if (typeof title === 'function') {\n title = title(shortcut, i);\n }\n if (typeof subtitle === 'function') {\n subtitle = subtitle(shortcut, i);\n }\n if (typeof icon === 'function') {\n icon = icon(shortcut, i);\n }\n if (typeof excludeViewMode === 'function') {\n excludeViewMode = excludeViewMode(shortcut, i);\n }\n const excludedViewMode = excludeViewMode?.includes(\n snapStates.settings.shortcutsViewMode,\n );\n return (\n <li key={key}>\n <Icon icon={icon} />\n <span class=\"shortcut-text\">\n <AsyncText>{title}</AsyncText>\n {subtitle && (\n <>\n {' '}\n <small class=\"ib insignificant\">{subtitle}</small>\n </>\n )}\n {excludedViewMode && (\n <span class=\"tag\">\n Not available in current view mode\n </span>\n )}\n </span>\n <span class=\"shortcut-actions\">\n <button\n type=\"button\"\n class=\"plain small\"\n disabled={i === 0}\n onClick={() => {\n const shortcutsArr = Array.from(states.shortcuts);\n if (i > 0) {\n const temp = states.shortcuts[i - 1];\n shortcutsArr[i - 1] = shortcut;\n shortcutsArr[i] = temp;\n states.shortcuts = shortcutsArr;\n }\n }}\n >\n <Icon icon=\"arrow-up\" alt=\"Move up\" />\n </button>\n <button\n type=\"button\"\n class=\"plain small\"\n disabled={i === shortcuts.length - 1}\n onClick={() => {\n const shortcutsArr = Array.from(states.shortcuts);\n if (i < states.shortcuts.length - 1) {\n const temp = states.shortcuts[i + 1];\n shortcutsArr[i + 1] = shortcut;\n shortcutsArr[i] = temp;\n states.shortcuts = shortcutsArr;\n }\n }}\n >\n <Icon icon=\"arrow-down\" alt=\"Move down\" />\n </button>\n <button\n type=\"button\"\n class=\"plain small\"\n onClick={() => {\n setShowForm({\n shortcut,\n shortcutIndex: i,\n });\n }}\n >\n <Icon icon=\"pencil\" alt=\"Edit\" />\n </button>\n {/* <button\n type=\"button\"\n class=\"plain small\"\n onClick={() => {\n states.shortcuts.splice(i, 1);\n }}\n >\n <Icon icon=\"x\" alt=\"Remove\" />\n </button> */}\n </span>\n </li>\n );\n })}\n </ol>\n ) : (\n <div class=\"ui-state insignificant\">\n <p>No shortcuts yet. Tap on the Add shortcut button.</p>\n <p>\n Not sure what to add?\n <br />\n Try adding{' '}\n <a\n href=\"#\"\n onClick={(e) => {\n e.preventDefault();\n states.shortcuts = [\n {\n type: 'following',\n },\n {\n type: 'notifications',\n },\n ];\n }}\n >\n Home / Following and Notifications\n </a>{' '}\n first.\n </p>\n </div>\n )}\n <p class=\"insignificant\">\n {shortcuts.length >= SHORTCUTS_LIMIT &&\n `Max ${SHORTCUTS_LIMIT} shortcuts`}\n </p>\n <p\n style={{\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n }}\n >\n <button\n type=\"button\"\n class=\"light\"\n onClick={() => setShowImportExport(true)}\n >\n Import/export\n </button>\n <button\n type=\"button\"\n disabled={shortcuts.length >= SHORTCUTS_LIMIT}\n onClick={() => setShowForm(true)}\n >\n <Icon icon=\"plus\" /> <span>Add shortcut</span>\n </button>\n </p>\n </main>\n {showForm && (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n setShowForm(false);\n }\n }}\n >\n <ShortcutForm\n shortcut={showForm.shortcut}\n shortcutIndex={showForm.shortcutIndex}\n onSubmit={({ result, mode }) => {\n console.log('onSubmit', result);\n if (mode === 'edit') {\n states.shortcuts[showForm.shortcutIndex] = result;\n } else {\n states.shortcuts.push(result);\n }\n }}\n onClose={() => setShowForm(false)}\n />\n </Modal>\n )}\n {showImportExport && (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n setShowImportExport(false);\n }\n }}\n >\n <ImportExport\n shortcuts={shortcuts}\n onClose={() => setShowImportExport(false)}\n />\n </Modal>\n )}\n </div>\n );\n}\n\nconst FETCH_MAX_AGE = 1000 * 60; // 1 minute\nconst fetchLists = pmem(\n () => {\n const { masto } = api();\n return masto.v1.lists.list();\n },\n {\n maxAge: FETCH_MAX_AGE,\n },\n);\n\nconst FORM_NOTES = {\n search: `For multi-column mode, search term is required, else the column will not be shown.`,\n hashtag: 'Multiple hashtags are supported. Space-separated.',\n};\n\nfunction ShortcutForm({\n onSubmit,\n disabled,\n shortcut,\n shortcutIndex,\n onClose,\n}) {\n console.log('shortcut', shortcut);\n const editMode = !!shortcut;\n const [currentType, setCurrentType] = useState(shortcut?.type || null);\n const { masto } = api();\n\n const [uiState, setUIState] = useState('default');\n const [lists, setLists] = useState([]);\n const [followedHashtags, setFollowedHashtags] = useState([]);\n useEffect(() => {\n (async () => {\n if (currentType !== 'list') return;\n try {\n setUIState('loading');\n const lists = await fetchLists();\n lists.sort((a, b) => a.title.localeCompare(b.title));\n setLists(lists);\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n\n (async () => {\n if (currentType !== 'hashtag') return;\n try {\n const tags = await fetchFollowedTags();\n setFollowedHashtags(tags);\n } catch (e) {\n console.error(e);\n }\n })();\n }, [currentType]);\n\n const formRef = useRef();\n useEffect(() => {\n if (editMode && currentType && TYPE_PARAMS[currentType]) {\n // Populate form\n const form = formRef.current;\n TYPE_PARAMS[currentType].forEach(({ name, type }) => {\n const input = form.querySelector(`[name=\"${name}\"]`);\n if (input && shortcut[name]) {\n if (type === 'checkbox') {\n input.checked = shortcut[name] === 'on' ? true : false;\n } else {\n input.value = shortcut[name];\n }\n }\n });\n }\n }, [editMode, currentType]);\n\n return (\n <div id=\"shortcut-settings-form\" class=\"sheet\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>{editMode ? 'Edit' : 'Add'} shortcut</h2>\n </header>\n <main tabindex=\"-1\">\n <form\n ref={formRef}\n onSubmit={(e) => {\n // Construct a nice object from form\n e.preventDefault();\n const data = new FormData(e.target);\n const result = {};\n data.forEach((value, key) => {\n result[key] = value?.trim();\n if (key === 'instance') {\n // Remove protocol and trailing slash\n result[key] = result[key]\n .replace(/^https?:\\/\\//, '')\n .replace(/\\/+$/, '');\n // Remove @acct@ or acct@ from instance URL\n result[key] = result[key].replace(/^@?[^@]+@/, '');\n }\n });\n console.log('result', result);\n if (!result.type) return;\n onSubmit({\n result,\n mode: editMode ? 'edit' : 'add',\n });\n // Reset\n e.target.reset();\n setCurrentType(null);\n onClose?.();\n }}\n >\n <p>\n <label>\n <span>Timeline</span>\n <select\n required\n disabled={disabled}\n onChange={(e) => {\n setCurrentType(e.target.value);\n }}\n defaultValue={editMode ? shortcut.type : undefined}\n name=\"type\"\n >\n <option></option>\n {TYPES.map((type) => (\n <option value={type}>{TYPE_TEXT[type]}</option>\n ))}\n </select>\n </label>\n </p>\n {TYPE_PARAMS[currentType]?.map?.(\n ({ text, name, type, placeholder, pattern, notRequired }) => {\n if (currentType === 'list') {\n return (\n <p>\n <label>\n <span>List</span>\n <select\n name=\"id\"\n required={!notRequired}\n disabled={disabled || uiState === 'loading'}\n defaultValue={editMode ? shortcut.id : undefined}\n >\n {lists.map((list) => (\n <option value={list.id}>{list.title}</option>\n ))}\n </select>\n </label>\n </p>\n );\n }\n\n return (\n <p>\n <label>\n <span>{text}</span>{' '}\n <input\n type={type}\n switch={type === 'checkbox' || undefined}\n name={name}\n placeholder={placeholder}\n required={type === 'text' && !notRequired}\n disabled={disabled}\n list={\n currentType === 'hashtag'\n ? 'followed-hashtags-datalist'\n : null\n }\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck={false}\n pattern={pattern}\n />\n {currentType === 'hashtag' &&\n followedHashtags.length > 0 && (\n <datalist id=\"followed-hashtags-datalist\">\n {followedHashtags.map((tag) => (\n <option value={tag.name} />\n ))}\n </datalist>\n )}\n </label>\n </p>\n );\n },\n )}\n {!!FORM_NOTES[currentType] && (\n <p class=\"form-note insignificant\">\n <Icon icon=\"info\" />\n {FORM_NOTES[currentType]}\n </p>\n )}\n <footer>\n <button\n type=\"submit\"\n class=\"block\"\n disabled={disabled || uiState === 'loading'}\n >\n {editMode ? 'Save' : 'Add'}\n </button>\n {editMode && (\n <button\n type=\"button\"\n class=\"light danger\"\n onClick={() => {\n states.shortcuts.splice(shortcutIndex, 1);\n onClose?.();\n }}\n >\n Remove\n </button>\n )}\n </footer>\n </form>\n </main>\n </div>\n );\n}\n\nfunction ImportExport({ shortcuts, onClose }) {\n const shortcutsStr = useMemo(() => {\n if (!shortcuts) return '';\n if (!shortcuts.filter(Boolean).length) return '';\n return compressToEncodedURIComponent(\n JSON.stringify(shortcuts.filter(Boolean)),\n );\n }, [shortcuts]);\n const [importShortcutStr, setImportShortcutStr] = useState('');\n const [importUIState, setImportUIState] = useState('default');\n const parsedImportShortcutStr = useMemo(() => {\n if (!importShortcutStr) {\n setImportUIState('default');\n return null;\n }\n try {\n const parsed = JSON.parse(\n decompressFromEncodedURIComponent(importShortcutStr),\n );\n // Very basic validation, I know\n if (!Array.isArray(parsed)) throw new Error('Not an array');\n setImportUIState('default');\n return parsed;\n } catch (err) {\n // Fallback to JSON string parsing\n // There's a chance that someone might want to import a JSON string instead of the compressed version\n try {\n const parsed = JSON.parse(importShortcutStr);\n if (!Array.isArray(parsed)) throw new Error('Not an array');\n setImportUIState('default');\n return parsed;\n } catch (err) {\n setImportUIState('error');\n return null;\n }\n }\n }, [importShortcutStr]);\n const hasCurrentSettings = states.shortcuts.length > 0;\n\n return (\n <div id=\"import-export-container\" class=\"sheet\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>\n Import/Export <small class=\"ib insignificant\">Shortcuts</small>\n </h2>\n </header>\n <main tabindex=\"-1\">\n <section>\n <h3>\n <Icon icon=\"arrow-down-circle\" size=\"l\" class=\"insignificant\" />{' '}\n <span>Import</span>\n </h3>\n <p>\n <input\n type=\"text\"\n name=\"import\"\n placeholder=\"Paste shortcuts here\"\n class=\"block\"\n onInput={(e) => {\n setImportShortcutStr(e.target.value);\n }}\n />\n </p>\n {!!parsedImportShortcutStr &&\n Array.isArray(parsedImportShortcutStr) && (\n <>\n <p>\n <b>{parsedImportShortcutStr.length}</b> shortcut\n {parsedImportShortcutStr.length > 1 ? 's' : ''}{' '}\n <small class=\"insignificant\">\n ({importShortcutStr.length} characters)\n </small>\n </p>\n <ol class=\"import-settings-list\">\n {parsedImportShortcutStr.map((shortcut) => (\n <li>\n <span\n style={{\n opacity: shortcuts.some((s) =>\n // Compare all properties\n Object.keys(s).every(\n (key) => s[key] === shortcut[key],\n ),\n )\n ? 1\n : 0,\n }}\n >\n *\n </span>\n <span>\n {TYPE_TEXT[shortcut.type]}\n {shortcut.type === 'list' && ' ⚠️'}{' '}\n {TYPE_PARAMS[shortcut.type]?.map?.(\n ({ text, name, type }) =>\n shortcut[name] ? (\n <>\n <span class=\"tag collapsed insignificant\">\n {text}:{' '}\n {type === 'checkbox'\n ? shortcut[name] === 'on'\n ? '✅'\n : '❌'\n : shortcut[name]}\n </span>{' '}\n </>\n ) : null,\n )}\n </span>\n </li>\n ))}\n </ol>\n <p>\n <small>* Exists in current shortcuts</small>\n <br />\n <small>\n ⚠️ List may not work if it's from a different account.\n </small>\n </p>\n </>\n )}\n {importUIState === 'error' && (\n <p class=\"error\">\n <small>⚠️ Invalid settings format</small>\n </p>\n )}\n <p>\n {hasCurrentSettings && (\n <>\n <MenuConfirm\n confirmLabel=\"Append to current shortcuts?\"\n menuFooter={\n <div class=\"footer\">\n Only shortcuts that don’t exist in current shortcuts will\n be appended.\n </div>\n }\n onClick={() => {\n // states.shortcuts = [\n // ...states.shortcuts,\n // ...parsedImportShortcutStr,\n // ];\n // Append non-unique shortcuts only\n const nonUniqueShortcuts = parsedImportShortcutStr.filter(\n (shortcut) =>\n !states.shortcuts.some((s) =>\n // Compare all properties\n Object.keys(s).every(\n (key) => s[key] === shortcut[key],\n ),\n ),\n );\n if (!nonUniqueShortcuts.length) {\n showToast('No new shortcuts to import');\n return;\n }\n let newShortcuts = [\n ...states.shortcuts,\n ...nonUniqueShortcuts,\n ];\n const exceededLimit = newShortcuts.length > SHORTCUTS_LIMIT;\n if (exceededLimit) {\n // If exceeded, trim it\n newShortcuts = newShortcuts.slice(0, SHORTCUTS_LIMIT);\n }\n states.shortcuts = newShortcuts;\n showToast(\n exceededLimit\n ? `Shortcuts imported. Exceeded max ${SHORTCUTS_LIMIT}, so the rest are not imported.`\n : 'Shortcuts imported',\n );\n onClose?.();\n }}\n >\n <button\n type=\"button\"\n class=\"plain2\"\n disabled={!parsedImportShortcutStr}\n >\n Import & append…\n </button>\n </MenuConfirm>{' '}\n </>\n )}\n <MenuConfirm\n confirmLabel={\n hasCurrentSettings\n ? 'Override current shortcuts?'\n : 'Import shortcuts?'\n }\n menuItemClassName={hasCurrentSettings ? 'danger' : undefined}\n onClick={() => {\n states.shortcuts = parsedImportShortcutStr;\n showToast('Shortcuts imported');\n onClose?.();\n }}\n >\n <button\n type=\"button\"\n class=\"plain2\"\n disabled={!parsedImportShortcutStr}\n >\n {hasCurrentSettings ? 'or override…' : 'Import…'}\n </button>\n </MenuConfirm>\n </p>\n </section>\n <section>\n <h3>\n <Icon icon=\"arrow-up-circle\" size=\"l\" class=\"insignificant\" />{' '}\n <span>Export</span>\n </h3>\n <p>\n <input\n style={{ width: '100%' }}\n type=\"text\"\n value={shortcutsStr}\n readOnly\n onClick={(e) => {\n if (!e.target.value) return;\n e.target.select();\n // Copy url to clipboard\n try {\n navigator.clipboard.writeText(e.target.value);\n showToast('Shortcuts copied');\n } catch (e) {\n console.error(e);\n showToast('Unable to copy shortcuts');\n }\n }}\n />\n </p>\n <p>\n <button\n type=\"button\"\n class=\"plain2\"\n disabled={!shortcutsStr}\n onClick={() => {\n try {\n navigator.clipboard.writeText(shortcutsStr);\n showToast('Shortcut settings copied');\n } catch (e) {\n console.error(e);\n showToast('Unable to copy shortcut settings');\n }\n }}\n >\n <Icon icon=\"clipboard\" /> <span>Copy</span>\n </button>{' '}\n {navigator?.share &&\n navigator?.canShare?.({\n text: shortcutsStr,\n }) && (\n <button\n type=\"button\"\n class=\"plain2\"\n disabled={!shortcutsStr}\n onClick={() => {\n try {\n navigator.share({\n text: shortcutsStr,\n });\n } catch (e) {\n console.error(e);\n alert(\"Sharing doesn't seem to work.\");\n }\n }}\n >\n <Icon icon=\"share\" /> <span>Share</span>\n </button>\n )}{' '}\n {shortcutsStr.length > 0 && (\n <small class=\"insignificant\">\n {shortcutsStr.length} characters\n </small>\n )}\n </p>\n {!!shortcutsStr && (\n <details>\n <summary class=\"insignificant\">\n <small>Raw Shortcuts JSON</small>\n </summary>\n <textarea style={{ width: '100%' }} rows={10} readOnly>\n {JSON.stringify(shortcuts.filter(Boolean), null, 2)}\n </textarea>\n </details>\n )}\n </section>\n </main>\n </div>\n );\n}\n\nexport default ShortcutsSettings;\n","import { useLocation, useNavigate } from 'react-router-dom';\nimport { subscribe, useSnapshot } from 'valtio';\n\nimport Accounts from '../pages/accounts';\nimport Settings from '../pages/settings';\nimport focusDeck from '../utils/focus-deck';\nimport showToast from '../utils/show-toast';\nimport states from '../utils/states';\n\nimport AccountSheet from './account-sheet';\nimport Compose from './compose';\nimport Drafts from './drafts';\nimport GenericAccounts from './generic-accounts';\nimport MediaAltModal from './media-alt-modal';\nimport MediaModal from './media-modal';\nimport Modal from './modal';\nimport ShortcutsSettings from './shortcuts-settings';\n\nsubscribe(states, (changes) => {\n for (const [action, path, value, prevValue] of changes) {\n // When closing modal, focus on deck\n if (/^show/i.test(path) && !value) {\n focusDeck();\n }\n }\n});\n\nexport default function Modals() {\n const snapStates = useSnapshot(states);\n const navigate = useNavigate();\n const location = useLocation();\n\n return (\n <>\n {!!snapStates.showCompose && (\n <Modal>\n <Compose\n replyToStatus={\n typeof snapStates.showCompose !== 'boolean'\n ? snapStates.showCompose.replyToStatus\n : window.__COMPOSE__?.replyToStatus || null\n }\n editStatus={\n states.showCompose?.editStatus ||\n window.__COMPOSE__?.editStatus ||\n null\n }\n draftStatus={\n states.showCompose?.draftStatus ||\n window.__COMPOSE__?.draftStatus ||\n null\n }\n onClose={(results) => {\n const { newStatus, instance, type } = results || {};\n states.showCompose = false;\n window.__COMPOSE__ = null;\n if (newStatus) {\n states.reloadStatusPage++;\n showToast({\n text: {\n post: 'Post published. Check it out.',\n reply: 'Reply posted. Check it out.',\n edit: 'Post updated. Check it out.',\n }[type || 'post'],\n delay: 1000,\n duration: 10_000, // 10 seconds\n onClick: (toast) => {\n toast.hideToast();\n states.prevLocation = location;\n navigate(\n instance\n ? `/${instance}/s/${newStatus.id}`\n : `/s/${newStatus.id}`,\n );\n },\n });\n }\n }}\n />\n </Modal>\n )}\n {!!snapStates.showSettings && (\n <Modal\n onClose={() => {\n states.showSettings = false;\n }}\n >\n <Settings\n onClose={() => {\n states.showSettings = false;\n }}\n />\n </Modal>\n )}\n {!!snapStates.showAccounts && (\n <Modal\n onClose={() => {\n states.showAccounts = false;\n }}\n >\n <Accounts\n onClose={() => {\n states.showAccounts = false;\n }}\n />\n </Modal>\n )}\n {!!snapStates.showAccount && (\n <Modal\n class=\"light\"\n onClose={() => {\n states.showAccount = false;\n }}\n >\n <AccountSheet\n account={snapStates.showAccount?.account || snapStates.showAccount}\n instance={snapStates.showAccount?.instance}\n onClose={({ destination } = {}) => {\n states.showAccount = false;\n // states.showGenericAccounts = false;\n // if (destination) {\n // states.showAccounts = false;\n // }\n }}\n />\n </Modal>\n )}\n {!!snapStates.showDrafts && (\n <Modal\n onClose={() => {\n states.showDrafts = false;\n }}\n >\n <Drafts onClose={() => (states.showDrafts = false)} />\n </Modal>\n )}\n {!!snapStates.showMediaModal && (\n <Modal\n onClick={(e) => {\n if (\n e.target === e.currentTarget ||\n e.target.classList.contains('media')\n ) {\n states.showMediaModal = false;\n }\n }}\n >\n <MediaModal\n mediaAttachments={snapStates.showMediaModal.mediaAttachments}\n instance={snapStates.showMediaModal.instance}\n index={snapStates.showMediaModal.index}\n statusID={snapStates.showMediaModal.statusID}\n onClose={() => {\n states.showMediaModal = false;\n }}\n />\n </Modal>\n )}\n {!!snapStates.showShortcutsSettings && (\n <Modal\n class=\"light\"\n onClose={() => {\n states.showShortcutsSettings = false;\n }}\n >\n <ShortcutsSettings\n onClose={() => (states.showShortcutsSettings = false)}\n />\n </Modal>\n )}\n {!!snapStates.showGenericAccounts && (\n <Modal\n class=\"light\"\n onClose={() => {\n states.showGenericAccounts = false;\n }}\n >\n <GenericAccounts\n instance={snapStates.showGenericAccounts.instance}\n excludeRelationshipAttrs={\n snapStates.showGenericAccounts.excludeRelationshipAttrs\n }\n onClose={() => (states.showGenericAccounts = false)}\n />\n </Modal>\n )}\n {!!snapStates.showMediaAlt && (\n <Modal\n class=\"light\"\n onClose={(e) => {\n states.showMediaAlt = false;\n }}\n >\n <MediaAltModal\n alt={snapStates.showMediaAlt.alt || snapStates.showMediaAlt}\n lang={snapStates.showMediaAlt?.lang}\n onClose={() => {\n states.showMediaAlt = false;\n }}\n />\n </Modal>\n )}\n </>\n );\n}\n","import { useState } from 'preact/hooks';\n\nimport { api } from '../utils/api';\n\nimport Icon from './icon';\nimport Loader from './loader';\n\nfunction FollowRequestButtons({ accountID, onChange }) {\n const { masto } = api();\n const [uiState, setUIState] = useState('default');\n const [requestState, setRequestState] = useState(null); // accept, reject\n const [relationship, setRelationship] = useState(null);\n\n const hasRelationship = relationship !== null;\n\n return (\n <p class=\"follow-request-buttons\">\n <button\n type=\"button\"\n disabled={uiState === 'loading' || hasRelationship}\n onClick={() => {\n setUIState('loading');\n setRequestState('accept');\n (async () => {\n try {\n const rel = await masto.v1.followRequests\n .$select(accountID)\n .authorize();\n if (!rel?.followedBy) {\n throw new Error('Follow request not accepted');\n }\n setRelationship(rel);\n onChange();\n } catch (e) {\n console.error(e);\n }\n setUIState('default');\n })();\n }}\n >\n Accept\n </button>{' '}\n <button\n type=\"button\"\n disabled={uiState === 'loading' || hasRelationship}\n class=\"light danger\"\n onClick={() => {\n setUIState('loading');\n setRequestState('reject');\n (async () => {\n try {\n const rel = await masto.v1.followRequests\n .$select(accountID)\n .reject();\n if (rel?.followedBy) {\n throw new Error('Follow request not rejected');\n }\n setRelationship(rel);\n onChange();\n } catch (e) {\n console.error(e);\n setUIState('default');\n }\n })();\n }}\n >\n Reject\n </button>\n <span class=\"follow-request-states\">\n {hasRelationship && requestState ? (\n requestState === 'accept' ? (\n <Icon icon=\"check-circle\" alt=\"Accepted\" class=\"follow-accepted\" />\n ) : (\n <Icon icon=\"x-circle\" alt=\"Rejected\" class=\"follow-rejected\" />\n )\n ) : (\n <Loader hidden={uiState !== 'loading'} />\n )}\n </span>\n </p>\n );\n}\n\nexport default FollowRequestButtons;\n","import { Fragment } from 'preact';\nimport { memo } from 'preact/compat';\n\nimport shortenNumber from '../utils/shorten-number';\nimport states from '../utils/states';\nimport store from '../utils/store';\nimport useTruncated from '../utils/useTruncated';\n\nimport Avatar from './avatar';\nimport FollowRequestButtons from './follow-request-buttons';\nimport Icon from './icon';\nimport Link from './link';\nimport NameText from './name-text';\nimport RelativeTime from './relative-time';\nimport Status from './status';\n\nconst NOTIFICATION_ICONS = {\n mention: 'comment',\n status: 'notification',\n reblog: 'rocket',\n follow: 'follow',\n follow_request: 'follow-add',\n favourite: 'heart',\n poll: 'poll',\n update: 'pencil',\n 'admin.signup': 'account-edit',\n 'admin.report': 'account-warning',\n};\n\n/*\nNotification types\n==================\nmention = Someone mentioned you in their status\nstatus = Someone you enabled notifications for has posted a status\nreblog = Someone boosted one of your statuses\nfollow = Someone followed you\nfollow_request = Someone requested to follow you\nfavourite = Someone favourited one of your statuses\npoll = A poll you have voted in or created has ended\nupdate = A status you interacted with has been edited\nadmin.sign_up = Someone signed up (optionally sent to admins)\nadmin.report = A new report has been filed\n*/\n\nconst contentText = {\n mention: 'mentioned you in their post.',\n status: 'published a post.',\n reblog: 'boosted your post.',\n 'reblog+account': (count) => `boosted ${count} of your posts.`,\n reblog_reply: 'boosted your reply.',\n follow: 'followed you.',\n follow_request: 'requested to follow you.',\n favourite: 'liked your post.',\n 'favourite+account': (count) => `liked ${count} of your posts.`,\n favourite_reply: 'liked your reply.',\n poll: 'A poll you have voted in or created has ended.',\n 'poll-self': 'A poll you have created has ended.',\n 'poll-voted': 'A poll you have voted in has ended.',\n update: 'A post you interacted with has been edited.',\n 'favourite+reblog': 'boosted & liked your post.',\n 'favourite+reblog+account': (count) =>\n `boosted & liked ${count} of your posts.`,\n 'favourite+reblog_reply': 'boosted & liked your reply.',\n 'admin.sign_up': 'signed up.',\n 'admin.report': (targetAccount) => <>reported {targetAccount}</>,\n};\n\nconst AVATARS_LIMIT = 50;\n\nfunction Notification({\n notification,\n instance,\n isStatic,\n disableContextMenu,\n}) {\n const { id, status, account, report, _accounts, _statuses } = notification;\n let { type } = notification;\n\n // status = Attached when type of the notification is favourite, reblog, status, mention, poll, or update\n const actualStatus = status?.reblog || status;\n const actualStatusID = actualStatus?.id;\n\n const currentAccount = store.session.get('currentAccount');\n const isSelf = currentAccount === account?.id;\n const isVoted = status?.poll?.voted;\n const isReplyToOthers =\n !!status?.inReplyToAccountId &&\n status?.inReplyToAccountId !== currentAccount &&\n status?.account?.id === currentAccount;\n\n let favsCount = 0;\n let reblogsCount = 0;\n if (type === 'favourite+reblog') {\n for (const account of _accounts) {\n if (account._types?.includes('favourite')) {\n favsCount++;\n }\n if (account._types?.includes('reblog')) {\n reblogsCount++;\n }\n }\n if (!reblogsCount && favsCount) type = 'favourite';\n if (!favsCount && reblogsCount) type = 'reblog';\n }\n\n let text;\n if (type === 'poll') {\n text = contentText[isSelf ? 'poll-self' : isVoted ? 'poll-voted' : 'poll'];\n } else if (\n type === 'reblog' ||\n type === 'favourite' ||\n type === 'favourite+reblog'\n ) {\n if (_statuses?.length > 1) {\n text = contentText[`${type}+account`];\n } else if (isReplyToOthers) {\n text = contentText[`${type}_reply`];\n } else {\n text = contentText[type];\n }\n } else if (contentText[type]) {\n text = contentText[type];\n } else {\n // Anticipate unhandled notification types, possibly from Mastodon forks or non-Mastodon instances\n // This surfaces the error to the user, hoping that users will report it\n text = `[Unknown notification type: ${type}]`;\n }\n\n if (typeof text === 'function') {\n const count = _statuses?.length || _accounts?.length;\n if (count) {\n text = text(count);\n } else if (type === 'admin.report') {\n const targetAccount = report?.targetAccount;\n if (targetAccount) {\n text = text(<NameText account={targetAccount} showAvatar />);\n }\n }\n }\n\n if (type === 'mention' && !status) {\n // Could be deleted\n return null;\n }\n\n const formattedCreatedAt =\n notification.createdAt && new Date(notification.createdAt).toLocaleString();\n\n const genericAccountsHeading =\n {\n 'favourite+reblog': 'Boosted/Liked by…',\n favourite: 'Liked by…',\n reblog: 'Boosted by…',\n follow: 'Followed by…',\n }[type] || 'Accounts';\n const handleOpenGenericAccounts = () => {\n states.showGenericAccounts = {\n heading: genericAccountsHeading,\n accounts: _accounts,\n showReactions: type === 'favourite+reblog',\n excludeRelationshipAttrs: type === 'follow' ? ['followedBy'] : [],\n };\n };\n\n console.debug('RENDER Notification', notification.id);\n\n return (\n <div\n class={`notification notification-${type}`}\n data-notification-id={id}\n tabIndex=\"0\"\n >\n <div\n class={`notification-type notification-${type}`}\n title={formattedCreatedAt}\n >\n {type === 'favourite+reblog' ? (\n <>\n <Icon icon=\"rocket\" size=\"xl\" alt={type} class=\"reblog-icon\" />\n <Icon icon=\"heart\" size=\"xl\" alt={type} class=\"favourite-icon\" />\n </>\n ) : (\n <Icon\n icon={NOTIFICATION_ICONS[type] || 'notification'}\n size=\"xl\"\n alt={type}\n />\n )}\n </div>\n <div class=\"notification-content\">\n {type !== 'mention' && (\n <>\n <p>\n {!/poll|update/i.test(type) && (\n <>\n {_accounts?.length > 1 ? (\n <>\n <b tabIndex=\"0\" onClick={handleOpenGenericAccounts}>\n <span title={_accounts.length}>\n {shortenNumber(_accounts.length)}\n </span>{' '}\n people\n </b>{' '}\n </>\n ) : (\n <>\n <NameText account={account} showAvatar />{' '}\n </>\n )}\n </>\n )}\n {text}\n {type === 'mention' && (\n <span class=\"insignificant\">\n {' '}\n •{' '}\n <RelativeTime\n datetime={notification.createdAt}\n format=\"micro\"\n />\n </span>\n )}\n </p>\n {type === 'follow_request' && (\n <FollowRequestButtons accountID={account.id} />\n )}\n </>\n )}\n {_accounts?.length > 1 && (\n <p class=\"avatars-stack\">\n {_accounts.slice(0, AVATARS_LIMIT).map((account) => (\n <Fragment key={account.id}>\n <a\n key={account.id}\n href={account.url}\n rel=\"noopener noreferrer\"\n class=\"account-avatar-stack\"\n onClick={(e) => {\n e.preventDefault();\n states.showAccount = account;\n }}\n >\n <Avatar\n url={account.avatarStatic}\n size={\n _accounts.length <= 10\n ? 'xxl'\n : _accounts.length < 20\n ? 'xl'\n : _accounts.length < 30\n ? 'l'\n : _accounts.length < 40\n ? 'm'\n : 's' // My god, this person is popular!\n }\n key={account.id}\n alt={`${account.displayName} @${account.acct}`}\n squircle={account?.bot}\n />\n {type === 'favourite+reblog' && (\n <div class=\"account-sub-icons\">\n {account._types.map((type) => (\n <Icon\n icon={NOTIFICATION_ICONS[type]}\n size=\"s\"\n class={`${type}-icon`}\n />\n ))}\n </div>\n )}\n </a>{' '}\n </Fragment>\n ))}\n <button\n type=\"button\"\n class=\"small plain\"\n onClick={handleOpenGenericAccounts}\n >\n {_accounts.length > AVATARS_LIMIT &&\n `+${_accounts.length - AVATARS_LIMIT}`}\n <Icon icon=\"chevron-down\" />\n </button>\n </p>\n )}\n {_statuses?.length > 1 && (\n <ul class=\"notification-group-statuses\">\n {_statuses.map((status) => (\n <li key={status.id}>\n <TruncatedLink\n class={`status-link status-type-${type}`}\n to={\n instance ? `/${instance}/s/${status.id}` : `/s/${status.id}`\n }\n >\n <Status status={status} size=\"s\" />\n </TruncatedLink>\n </li>\n ))}\n </ul>\n )}\n {status && (!_statuses?.length || _statuses?.length <= 1) && (\n <TruncatedLink\n class={`status-link status-type-${type}`}\n to={\n instance\n ? `/${instance}/s/${actualStatusID}`\n : `/s/${actualStatusID}`\n }\n onContextMenu={\n !disableContextMenu\n ? (e) => {\n const post = e.target.querySelector('.status');\n if (post) {\n // Fire a custom event to open the context menu\n if (e.metaKey) return;\n e.preventDefault();\n post.dispatchEvent(\n new MouseEvent('contextmenu', {\n clientX: e.clientX,\n clientY: e.clientY,\n }),\n );\n }\n }\n : undefined\n }\n >\n {isStatic ? (\n <Status status={actualStatus} size=\"s\" />\n ) : (\n <Status statusID={actualStatusID} size=\"s\" />\n )}\n </TruncatedLink>\n )}\n </div>\n </div>\n );\n}\n\nfunction TruncatedLink(props) {\n const ref = useTruncated();\n return <Link {...props} data-read-more=\"Read more →\" ref={ref} />;\n}\n\nexport default memo(Notification);\n","import { memo } from 'preact/compat';\nimport { useLayoutEffect, useState } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport { api } from '../utils/api';\nimport states from '../utils/states';\nimport {\n getAccountByAccessToken,\n getCurrentAccount,\n} from '../utils/store-utils';\nimport usePageVisibility from '../utils/usePageVisibility';\n\nimport Icon from './icon';\nimport Link from './link';\nimport Modal from './modal';\nimport Notification from './notification';\n\nexport default memo(function NotificationService() {\n if (!('serviceWorker' in navigator)) return null;\n\n const snapStates = useSnapshot(states);\n const { routeNotification } = snapStates;\n\n console.log('🛎️ Notification service', routeNotification);\n\n const { id, accessToken } = routeNotification || {};\n const [showNotificationSheet, setShowNotificationSheet] = useState(false);\n\n useLayoutEffect(() => {\n if (!id || !accessToken) return;\n const { instance: currentInstance } = api();\n const { masto, instance } = api({\n accessToken,\n });\n console.log('API', { accessToken, currentInstance, instance });\n const sameInstance = currentInstance === instance;\n const account = accessToken\n ? getAccountByAccessToken(accessToken)\n : getCurrentAccount();\n (async () => {\n const notification = await masto.v1.notifications.$select(id).fetch();\n if (notification && account) {\n console.log('🛎️ Notification', { id, notification, account });\n const accountInstance = account.instanceURL;\n const { type, status, account: notificationAccount } = notification;\n const hasModal = !!document.querySelector('#modal-container > *');\n const isFollow = type === 'follow' && !!notificationAccount?.id;\n const hasAccount = !!notificationAccount?.id;\n const hasStatus = !!status?.id;\n if (isFollow && sameInstance) {\n // Show account sheet, can handle different instances\n states.showAccount = {\n account: notificationAccount,\n instance: accountInstance,\n };\n } else if (hasModal || !sameInstance || (hasAccount && hasStatus)) {\n // Show sheet of notification, if\n // - there is a modal open\n // - the notification is from another instance\n // - the notification has both account and status, gives choice for users to go to account or status\n setShowNotificationSheet({\n id,\n account,\n notification,\n sameInstance,\n });\n } else {\n if (hasStatus) {\n // Go to status page\n location.hash = `/${currentInstance}/s/${status.id}`;\n } else if (isFollow) {\n // Go to profile page\n location.hash = `/${currentInstance}/a/${notificationAccount.id}`;\n } else {\n // Go to notifications page\n location.hash = '/notifications';\n }\n }\n } else {\n console.warn('🛎️ Notification not found', id);\n }\n })();\n }, [id, accessToken]);\n\n useLayoutEffect(() => {\n // Listen to message from service worker\n const handleMessage = (event) => {\n console.log('💥💥💥 Message event', event);\n const { type, id, accessToken } = event?.data || {};\n if (type === 'notification') {\n states.routeNotification = {\n id,\n accessToken,\n };\n }\n };\n console.log('👂👂👂 Listen to message');\n navigator.serviceWorker.addEventListener('message', handleMessage);\n return () => {\n console.log('👂👂👂 Remove listen to message');\n navigator.serviceWorker.removeEventListener('message', handleMessage);\n };\n }, []);\n\n useLayoutEffect(() => {\n if (navigator?.clearAppBadge) {\n navigator.clearAppBadge();\n }\n }, []);\n usePageVisibility((visible) => {\n if (visible && navigator?.clearAppBadge) {\n console.log('🔰 Clear app badge');\n navigator.clearAppBadge();\n }\n });\n\n const onClose = () => {\n setShowNotificationSheet(false);\n states.routeNotification = null;\n\n // If url is #/notifications?id=123, go to #/notifications\n if (/\\/notifications\\?id=/i.test(location.hash)) {\n location.hash = '/notifications';\n }\n };\n\n if (showNotificationSheet) {\n const { id, account, notification, sameInstance } = showNotificationSheet;\n return (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n onClose();\n }\n }}\n >\n <div class=\"sheet\" tabIndex=\"-1\">\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n <header>\n <b>Notification</b>\n </header>\n <main>\n {!sameInstance && (\n <p>This notification is from your other account.</p>\n )}\n <div\n class=\"notification-peek\"\n // style={{\n // pointerEvents: sameInstance ? '' : 'none',\n // }}\n onClick={(e) => {\n const { target } = e;\n // If button or links\n if (e.target.tagName === 'BUTTON' || e.target.tagName === 'A') {\n onClose();\n }\n }}\n >\n <Notification\n instance={account.instanceURL}\n notification={notification}\n isStatic\n />\n </div>\n <div\n style={{\n textAlign: 'end',\n }}\n >\n <Link to=\"/notifications\" class=\"button light\" onClick={onClose}>\n <span>View all notifications</span> <Icon icon=\"arrow-right\" />\n </Link>\n </div>\n </main>\n </div>\n </Modal>\n );\n }\n\n return null;\n});\n","import { forwardRef } from 'preact/compat';\nimport { useImperativeHandle, useRef, useState } from 'preact/hooks';\nimport { useSearchParams } from 'react-router-dom';\n\nimport { api } from '../utils/api';\n\nimport Icon from './icon';\nimport Link from './link';\n\nconst SearchForm = forwardRef((props, ref) => {\n const { instance } = api();\n const [searchParams, setSearchParams] = useSearchParams();\n const [searchMenuOpen, setSearchMenuOpen] = useState(false);\n const [query, setQuery] = useState(searchParams.get('q') || '');\n const type = searchParams.get('type');\n const formRef = useRef(null);\n\n const searchFieldRef = useRef(null);\n useImperativeHandle(ref, () => ({\n setValue: (value) => {\n setQuery(value);\n },\n focus: () => {\n searchFieldRef.current.focus();\n },\n select: () => {\n searchFieldRef.current.select();\n },\n blur: () => {\n searchFieldRef.current.blur();\n },\n }));\n\n return (\n <form\n ref={formRef}\n class=\"search-popover-container\"\n onSubmit={(e) => {\n e.preventDefault();\n\n const isSearchPage = /\\/search/.test(location.hash);\n if (isSearchPage) {\n if (query) {\n const params = {\n q: query,\n };\n if (type) params.type = type; // Preserve type\n setSearchParams(params);\n } else {\n setSearchParams({});\n }\n } else {\n if (query) {\n location.hash = `/search?q=${encodeURIComponent(query)}${\n type ? `&type=${type}` : ''\n }`;\n } else {\n location.hash = `/search`;\n }\n }\n\n props?.onSubmit?.(e);\n }}\n >\n <input\n ref={searchFieldRef}\n value={query}\n name=\"q\"\n type=\"search\"\n // autofocus\n placeholder=\"Search\"\n dir=\"auto\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n onSearch={(e) => {\n if (!e.target.value) {\n setSearchParams({});\n }\n }}\n onInput={(e) => {\n setQuery(e.target.value);\n setSearchMenuOpen(true);\n }}\n onFocus={() => {\n setSearchMenuOpen(true);\n }}\n onBlur={() => {\n setTimeout(() => {\n setSearchMenuOpen(false);\n }, 100);\n formRef.current\n ?.querySelector('.search-popover-item.focus')\n ?.classList.remove('focus');\n }}\n onKeyDown={(e) => {\n const { key } = e;\n switch (key) {\n case 'Escape':\n setSearchMenuOpen(false);\n break;\n case 'Down':\n case 'ArrowDown':\n e.preventDefault();\n if (searchMenuOpen) {\n const focusItem = formRef.current.querySelector(\n '.search-popover-item.focus',\n );\n if (focusItem) {\n let nextItem = focusItem.nextElementSibling;\n while (nextItem && nextItem.hidden) {\n nextItem = nextItem.nextElementSibling;\n }\n if (nextItem) {\n nextItem.classList.add('focus');\n const siblings = Array.from(\n nextItem.parentElement.children,\n ).filter((el) => el !== nextItem);\n siblings.forEach((el) => {\n el.classList.remove('focus');\n });\n }\n } else {\n const firstItem = formRef.current.querySelector(\n '.search-popover-item',\n );\n if (firstItem) {\n firstItem.classList.add('focus');\n }\n }\n }\n break;\n case 'Up':\n case 'ArrowUp':\n e.preventDefault();\n if (searchMenuOpen) {\n const focusItem = document.querySelector(\n '.search-popover-item.focus',\n );\n if (focusItem) {\n let prevItem = focusItem.previousElementSibling;\n while (prevItem && prevItem.hidden) {\n prevItem = prevItem.previousElementSibling;\n }\n if (prevItem) {\n prevItem.classList.add('focus');\n const siblings = Array.from(\n prevItem.parentElement.children,\n ).filter((el) => el !== prevItem);\n siblings.forEach((el) => {\n el.classList.remove('focus');\n });\n }\n } else {\n const lastItem = document.querySelector(\n '.search-popover-item:last-child',\n );\n if (lastItem) {\n lastItem.classList.add('focus');\n }\n }\n }\n break;\n case 'Enter':\n if (searchMenuOpen) {\n const focusItem = document.querySelector(\n '.search-popover-item.focus',\n );\n if (focusItem) {\n e.preventDefault();\n focusItem.click();\n }\n setSearchMenuOpen(false);\n props?.onSubmit?.(e);\n }\n break;\n }\n }}\n />\n <div class=\"search-popover\" hidden={!searchMenuOpen || !query}>\n {!!query &&\n [\n {\n label: (\n <>\n Posts with <q>{query}</q>\n </>\n ),\n to: `/search?q=${encodeURIComponent(query)}&type=statuses`,\n hidden: /^https?:/.test(query),\n },\n {\n label: (\n <>\n Posts tagged with <mark>#{query.replace(/^#/, '')}</mark>\n </>\n ),\n to: `/${instance}/t/${query.replace(/^#/, '')}`,\n hidden:\n /^@/.test(query) || /^https?:/.test(query) || /\\s/.test(query),\n top: /^#/.test(query),\n type: 'link',\n },\n {\n label: (\n <>\n Look up <mark>{query}</mark>\n </>\n ),\n to: `/${query}`,\n hidden: !/^https?:/.test(query),\n top: /^https?:/.test(query),\n type: 'link',\n },\n {\n label: (\n <>\n Accounts with <q>{query}</q>\n </>\n ),\n to: `/search?q=${encodeURIComponent(query)}&type=accounts`,\n },\n ]\n .sort((a, b) => {\n if (a.top && !b.top) return -1;\n if (!a.top && b.top) return 1;\n return 0;\n })\n .map(({ label, to, hidden, type }) => (\n <Link\n to={to}\n class=\"search-popover-item\"\n hidden={hidden}\n onClick={(e) => {\n props?.onSubmit?.(e);\n }}\n >\n <Icon\n icon={type === 'link' ? 'arrow-right' : 'search'}\n class=\"more-insignificant\"\n />\n <span>{label}</span>{' '}\n </Link>\n ))}\n </div>\n </form>\n );\n});\n\nexport default SearchForm;\n","import './search-command.css';\n\nimport { memo } from 'preact/compat';\nimport { useRef, useState } from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\n\nimport SearchForm from './search-form';\n\nexport default memo(function SearchCommand({ onClose = () => {} }) {\n const [showSearch, setShowSearch] = useState(false);\n const searchFormRef = useRef(null);\n\n useHotkeys(\n '/',\n (e) => {\n setShowSearch(true);\n setTimeout(() => {\n searchFormRef.current?.focus?.();\n searchFormRef.current?.select?.();\n }, 0);\n },\n {\n preventDefault: true,\n ignoreEventWhen: (e) => {\n const isSearchPage = /\\/search/.test(location.hash);\n const hasModal = !!document.querySelector('#modal-container > *');\n return isSearchPage || hasModal;\n },\n },\n );\n\n const closeSearch = () => {\n setShowSearch(false);\n onClose();\n };\n\n useHotkeys(\n 'esc',\n (e) => {\n searchFormRef.current?.blur?.();\n closeSearch();\n },\n {\n enabled: showSearch,\n enableOnFormTags: true,\n preventDefault: true,\n },\n );\n\n return (\n <div\n id=\"search-command-container\"\n hidden={!showSearch}\n onClick={(e) => {\n console.log(e);\n if (e.target === e.currentTarget) {\n closeSearch();\n }\n }}\n >\n <SearchForm\n ref={searchFormRef}\n onSubmit={() => {\n closeSearch();\n }}\n />\n </div>\n );\n});\n","import './shortcuts.css';\n\nimport { Menu, MenuItem } from '@szhsin/react-menu';\nimport { memo } from 'preact/compat';\nimport { useMemo, useRef } from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\nimport { useNavigate } from 'react-router-dom';\nimport { useSnapshot } from 'valtio';\n\nimport { SHORTCUTS_META } from '../components/shortcuts-settings';\nimport { api } from '../utils/api';\nimport states from '../utils/states';\n\nimport AsyncText from './AsyncText';\nimport Icon from './icon';\nimport Link from './link';\nimport Menu2 from './menu2';\nimport MenuLink from './menu-link';\n\nfunction Shortcuts() {\n const { instance } = api();\n const snapStates = useSnapshot(states);\n const { shortcuts, settings } = snapStates;\n\n if (!shortcuts.length) {\n return null;\n }\n if (\n settings.shortcutsViewMode === 'multi-column' ||\n (!settings.shortcutsViewMode && settings.shortcutsColumnsMode)\n ) {\n return null;\n }\n\n const menuRef = useRef();\n\n const formattedShortcuts = useMemo(\n () =>\n shortcuts\n .map((pin, i) => {\n const { type, ...data } = pin;\n if (!SHORTCUTS_META[type]) return null;\n let { id, path, title, subtitle, icon } = SHORTCUTS_META[type];\n\n if (typeof id === 'function') {\n id = id(data, i);\n }\n if (typeof path === 'function') {\n path = path(\n {\n ...data,\n instance: data.instance || instance,\n },\n i,\n );\n }\n if (typeof title === 'function') {\n title = title(data, i);\n }\n if (typeof subtitle === 'function') {\n subtitle = subtitle(data, i);\n }\n if (typeof icon === 'function') {\n icon = icon(data, i);\n }\n\n return {\n id,\n path,\n title,\n subtitle,\n icon,\n };\n })\n .filter(Boolean),\n [shortcuts],\n );\n\n const navigate = useNavigate();\n useHotkeys(['1', '2', '3', '4', '5', '6', '7', '8', '9'], (e, handler) => {\n const index = parseInt(handler.keys[0], 10) - 1;\n if (index < formattedShortcuts.length) {\n const { path } = formattedShortcuts[index];\n if (path) {\n navigate(path);\n menuRef.current?.closeMenu?.();\n }\n }\n });\n\n return (\n <div id=\"shortcuts\">\n {snapStates.settings.shortcutsViewMode === 'tab-menu-bar' ? (\n <nav\n class=\"tab-bar\"\n onContextMenu={(e) => {\n e.preventDefault();\n states.showShortcutsSettings = true;\n }}\n >\n <ul>\n {formattedShortcuts.map(\n ({ id, path, title, subtitle, icon }, i) => {\n return (\n <li key={`${i}-${id}-${title}-${subtitle}-${path}`}>\n <Link\n class={subtitle ? 'has-subtitle' : ''}\n to={path}\n onClick={(e) => {\n if (e.target.classList.contains('is-active')) {\n e.preventDefault();\n const page = document.getElementById(`${id}-page`);\n console.log(id, page);\n if (page) {\n page.scrollTop = 0;\n const updatesButton =\n page.querySelector('.updates-button');\n if (updatesButton) {\n updatesButton.click();\n }\n }\n }\n }}\n >\n <Icon icon={icon} size=\"xl\" alt={title} />\n <span>\n <AsyncText>{title}</AsyncText>\n {subtitle && (\n <>\n <br />\n <small>{subtitle}</small>\n </>\n )}\n </span>\n </Link>\n </li>\n );\n },\n )}\n </ul>\n </nav>\n ) : (\n <Menu2\n instanceRef={menuRef}\n overflow=\"auto\"\n viewScroll=\"close\"\n menuClassName=\"glass-menu shortcuts-menu\"\n gap={8}\n position=\"anchor\"\n menuButton={\n <button\n type=\"button\"\n id=\"shortcuts-button\"\n class=\"plain\"\n onContextMenu={(e) => {\n e.preventDefault();\n states.showShortcutsSettings = true;\n }}\n onTransitionStart={(e) => {\n // Close menu if the button disappears\n try {\n const { target } = e;\n if (getComputedStyle(target).pointerEvents === 'none') {\n menuRef.current?.closeMenu?.();\n }\n } catch (e) {}\n }}\n >\n <Icon icon=\"shortcut\" size=\"xl\" alt=\"Shortcuts\" />\n </button>\n }\n >\n {formattedShortcuts.map(({ id, path, title, subtitle, icon }, i) => {\n return (\n <MenuLink\n to={path}\n key={`${i}-${id}-${title}-${subtitle}-${path}`}\n class=\"glass-menu-item\"\n >\n <Icon icon={icon} size=\"l\" />{' '}\n <span class=\"menu-grow\">\n <span>\n <AsyncText>{title}</AsyncText>\n </span>\n {subtitle && (\n <>\n {' '}\n <small class=\"more-insignificant\">{subtitle}</small>\n </>\n )}\n </span>\n <span class=\"menu-shortcut hide-until-focus-visible\">\n {i + 1}\n </span>\n </MenuLink>\n );\n })}\n </Menu2>\n )}\n </div>\n );\n}\n\nexport default memo(Shortcuts);\n","import { extractTagsFromStatus, getFollowedTags } from './followed-tags';\nimport { fetchRelationships } from './relationships';\nimport states, { statusKey } from './states';\nimport store from './store';\n\nexport function groupBoosts(values) {\n let newValues = [];\n let boostStash = [];\n let serialBoosts = 0;\n for (let i = 0; i < values.length; i++) {\n const item = values[i];\n if (item.reblog && !item.account?.group) {\n boostStash.push(item);\n serialBoosts++;\n } else {\n newValues.push(item);\n if (serialBoosts < 3) {\n serialBoosts = 0;\n }\n }\n }\n // if boostStash is more than quarter of values\n // or if there are 3 or more boosts in a row\n if (\n values.length > 10 &&\n (boostStash.length > values.length / 4 || serialBoosts >= 3)\n ) {\n // if boostStash is more than 3 quarter of values\n const boostStashID = boostStash.map((status) => status.id);\n if (boostStash.length > (values.length * 3) / 4) {\n // insert boost array at the end of specialHome list\n newValues = [\n ...newValues,\n { id: boostStashID, items: boostStash, type: 'boosts' },\n ];\n } else {\n // insert boosts array in the middle of specialHome list\n const half = Math.floor(newValues.length / 2);\n newValues = [\n ...newValues.slice(0, half),\n {\n id: boostStashID,\n items: boostStash,\n type: 'boosts',\n },\n ...newValues.slice(half),\n ];\n }\n return newValues;\n } else {\n return values;\n }\n}\n\nexport function dedupeBoosts(items, instance) {\n const boostedStatusIDs = store.account.get('boostedStatusIDs') || {};\n const filteredItems = items.filter((item) => {\n if (!item.reblog) return true;\n const statusKey = `${instance}-${item.reblog.id}`;\n const boosterID = boostedStatusIDs[statusKey];\n if (boosterID && boosterID !== item.id) {\n console.warn(\n `🚫 Duplicate boost by ${item.account.displayName}`,\n item,\n item.reblog,\n );\n return false;\n } else {\n boostedStatusIDs[statusKey] = item.id;\n }\n return true;\n });\n // Limit to 50\n const keys = Object.keys(boostedStatusIDs);\n if (keys.length > 50) {\n keys.slice(0, keys.length - 50).forEach((key) => {\n delete boostedStatusIDs[key];\n });\n }\n store.account.set('boostedStatusIDs', boostedStatusIDs);\n return filteredItems;\n}\n\nexport function groupContext(items) {\n const contexts = [];\n let contextIndex = 0;\n items.forEach((item) => {\n for (let i = 0; i < contexts.length; i++) {\n if (contexts[i].find((t) => t.id === item.id)) return;\n if (\n contexts[i].find((t) => t.id === item.inReplyToId) ||\n contexts[i].find((t) => t.inReplyToId === item.id)\n ) {\n contexts[i].push(item);\n return;\n }\n }\n const repliedItem = items.find((i) => i.id === item.inReplyToId);\n if (repliedItem) {\n contexts[contextIndex++] = [item, repliedItem];\n }\n });\n\n // Check for cross-item contexts\n // Merge contexts into one if they have a common item (same id)\n for (let i = 0; i < contexts.length; i++) {\n for (let j = i + 1; j < contexts.length; j++) {\n const commonItem = contexts[i].find((t) => contexts[j].includes(t));\n if (commonItem) {\n contexts[i] = [...contexts[i], ...contexts[j]];\n // Remove duplicate items\n contexts[i] = contexts[i].filter(\n (item, index, self) =>\n self.findIndex((t) => t.id === item.id) === index,\n );\n contexts.splice(j, 1);\n j--;\n }\n }\n }\n\n // Sort items by checking inReplyToId\n contexts.forEach((context) => {\n context.sort((a, b) => {\n if (!a.inReplyToId && !b.inReplyToId) {\n return new Date(a.createdAt) - new Date(b.createdAt);\n }\n if (a.inReplyToId === b.id) return 1;\n if (b.inReplyToId === a.id) return -1;\n if (!a.inReplyToId) return -1;\n if (!b.inReplyToId) return 1;\n return new Date(a.createdAt) - new Date(b.createdAt);\n });\n });\n\n // Tag items that has different author than first post's author\n contexts.forEach((context) => {\n const firstItemAccountID = context[0].account.id;\n context.forEach((item) => {\n if (item.account.id !== firstItemAccountID) {\n item._differentAuthor = true;\n }\n });\n });\n\n if (contexts.length) console.log('🧵 Contexts', contexts);\n\n const newItems = [];\n const appliedContextIndices = [];\n items.forEach((item) => {\n if (item.reblog) {\n newItems.push(item);\n return;\n }\n for (let i = 0; i < contexts.length; i++) {\n if (contexts[i].find((t) => t.id === item.id)) {\n if (appliedContextIndices.includes(i)) return;\n const contextItems = contexts[i];\n contextItems.sort((a, b) => {\n const aDate = new Date(a.createdAt);\n const bDate = new Date(b.createdAt);\n return aDate - bDate;\n });\n const firstItemAccountID = contextItems[0].account.id;\n newItems.push({\n id: contextItems.map((i) => i.id),\n items: contextItems,\n type: contextItems.every((it) => it.account.id === firstItemAccountID)\n ? 'thread'\n : 'conversation',\n });\n appliedContextIndices.push(i);\n return;\n }\n }\n newItems.push(item);\n });\n\n return newItems;\n}\n\nexport async function assignFollowedTags(items, instance) {\n const followedTags = await getFollowedTags(); // [{name: 'tag'}, {...}]\n if (!followedTags.length) return;\n const { statusFollowedTags } = states;\n console.log('statusFollowedTags', statusFollowedTags);\n const statusWithFollowedTags = [];\n items.forEach((item) => {\n if (item.reblog) return;\n const { id, content, tags = [] } = item;\n const sKey = statusKey(id, instance);\n if (statusFollowedTags[sKey]?.length) return;\n const extractedTags = extractTagsFromStatus(content);\n if (!extractedTags.length && !tags.length) return;\n const itemFollowedTags = followedTags.reduce((acc, tag) => {\n if (\n extractedTags.some((t) => t.toLowerCase() === tag.name.toLowerCase()) ||\n tags.some((t) => t.name.toLowerCase() === tag.name.toLowerCase())\n ) {\n acc.push(tag.name);\n }\n return acc;\n }, []);\n if (itemFollowedTags.length) {\n // statusFollowedTags[sKey] = itemFollowedTags;\n statusWithFollowedTags.push({\n item,\n sKey,\n followedTags: itemFollowedTags,\n });\n }\n });\n\n if (statusWithFollowedTags.length) {\n const accounts = statusWithFollowedTags.map((s) => s.item.account);\n const relationships = await fetchRelationships(accounts);\n if (!relationships) return;\n\n statusWithFollowedTags.forEach((s) => {\n const { item, sKey, followedTags } = s;\n const r = relationships[item.account.id];\n if (!r.following) {\n statusFollowedTags[sKey] = followedTags;\n }\n });\n }\n}\n\nexport function clearFollowedTagsState() {\n states.statusFollowedTags = {};\n}\n","import { useLayoutEffect, useState } from 'preact/hooks';\n\nexport default function useScroll({\n scrollableRef,\n distanceFromStart = 1, // ratio of clientHeight/clientWidth\n distanceFromEnd = 1, // ratio of clientHeight/clientWidth\n scrollThresholdStart = 10,\n scrollThresholdEnd = 10,\n direction = 'vertical',\n distanceFromStartPx: _distanceFromStartPx,\n distanceFromEndPx: _distanceFromEndPx,\n} = {}) {\n const [scrollDirection, setScrollDirection] = useState(null);\n const [reachStart, setReachStart] = useState(false);\n const [reachEnd, setReachEnd] = useState(false);\n const [nearReachStart, setNearReachStart] = useState(false);\n const [nearReachEnd, setNearReachEnd] = useState(false);\n const isVertical = direction === 'vertical';\n\n useLayoutEffect(() => {\n const scrollableElement = scrollableRef.current;\n if (!scrollableElement) return {};\n let previousScrollStart = isVertical\n ? scrollableElement.scrollTop\n : scrollableElement.scrollLeft;\n\n function onScroll() {\n const {\n scrollTop,\n scrollLeft,\n scrollHeight,\n scrollWidth,\n clientHeight,\n clientWidth,\n } = scrollableElement;\n const scrollStart = isVertical ? scrollTop : scrollLeft;\n const scrollDimension = isVertical ? scrollHeight : scrollWidth;\n const clientDimension = isVertical ? clientHeight : clientWidth;\n const scrollDistance = Math.abs(scrollStart - previousScrollStart);\n const distanceFromStartPx =\n _distanceFromStartPx ||\n Math.min(\n clientDimension * distanceFromStart,\n scrollDimension,\n scrollStart,\n );\n const distanceFromEndPx =\n _distanceFromEndPx ||\n Math.min(\n clientDimension * distanceFromEnd,\n scrollDimension,\n scrollDimension - scrollStart - clientDimension,\n );\n\n if (\n scrollDistance >=\n (previousScrollStart < scrollStart\n ? scrollThresholdEnd\n : scrollThresholdStart)\n ) {\n setScrollDirection(previousScrollStart < scrollStart ? 'end' : 'start');\n previousScrollStart = scrollStart;\n }\n\n setReachStart(scrollStart <= 0);\n setReachEnd(scrollStart + clientDimension >= scrollDimension);\n setNearReachStart(scrollStart <= distanceFromStartPx);\n setNearReachEnd(\n scrollStart + clientDimension >= scrollDimension - distanceFromEndPx,\n );\n }\n\n scrollableElement.addEventListener('scroll', onScroll, { passive: true });\n\n return () => scrollableElement.removeEventListener('scroll', onScroll);\n }, [\n distanceFromStart,\n distanceFromEnd,\n scrollThresholdStart,\n scrollThresholdEnd,\n ]);\n\n return {\n scrollDirection,\n reachStart,\n reachEnd,\n nearReachStart,\n nearReachEnd,\n init: () => {\n if (scrollableRef.current) {\n scrollableRef.current.dispatchEvent(new Event('scroll'));\n }\n },\n };\n}\n","import { useEffect, useLayoutEffect, useState } from 'preact/hooks';\n\nexport default function useScrollFn(\n {\n scrollableRef,\n distanceFromStart = 1, // ratio of clientHeight/clientWidth\n distanceFromEnd = 1, // ratio of clientHeight/clientWidth\n scrollThresholdStart = 10,\n scrollThresholdEnd = 10,\n direction = 'vertical',\n distanceFromStartPx: _distanceFromStartPx,\n distanceFromEndPx: _distanceFromEndPx,\n init,\n } = {},\n callback,\n deps,\n) {\n if (!callback) return;\n const [scrollDirection, setScrollDirection] = useState(null);\n const [reachStart, setReachStart] = useState(false);\n const [reachEnd, setReachEnd] = useState(false);\n const [nearReachStart, setNearReachStart] = useState(false);\n const [nearReachEnd, setNearReachEnd] = useState(false);\n const isVertical = direction === 'vertical';\n\n useLayoutEffect(() => {\n const scrollableElement = scrollableRef.current;\n if (!scrollableElement) return {};\n let previousScrollStart = isVertical\n ? scrollableElement.scrollTop\n : scrollableElement.scrollLeft;\n\n function onScroll() {\n const {\n scrollTop,\n scrollLeft,\n scrollHeight,\n scrollWidth,\n clientHeight,\n clientWidth,\n } = scrollableElement;\n const scrollStart = isVertical ? scrollTop : scrollLeft;\n const scrollDimension = isVertical ? scrollHeight : scrollWidth;\n const clientDimension = isVertical ? clientHeight : clientWidth;\n const scrollDistance = Math.abs(scrollStart - previousScrollStart);\n const distanceFromStartPx =\n _distanceFromStartPx ||\n Math.min(\n clientDimension * distanceFromStart,\n scrollDimension,\n scrollStart,\n );\n const distanceFromEndPx =\n _distanceFromEndPx ||\n Math.min(\n clientDimension * distanceFromEnd,\n scrollDimension,\n scrollDimension - scrollStart - clientDimension,\n );\n\n if (\n scrollDistance >=\n (previousScrollStart < scrollStart\n ? scrollThresholdEnd\n : scrollThresholdStart)\n ) {\n setScrollDirection(previousScrollStart < scrollStart ? 'end' : 'start');\n previousScrollStart = scrollStart;\n }\n\n setReachStart(scrollStart <= 0);\n setReachEnd(scrollStart + clientDimension >= scrollDimension);\n setNearReachStart(scrollStart <= distanceFromStartPx);\n setNearReachEnd(\n scrollStart + clientDimension >= scrollDimension - distanceFromEndPx,\n );\n }\n\n scrollableElement.addEventListener('scroll', onScroll, { passive: true });\n\n return () => scrollableElement.removeEventListener('scroll', onScroll);\n }, [\n distanceFromStart,\n distanceFromEnd,\n scrollThresholdStart,\n scrollThresholdEnd,\n ]);\n\n useEffect(() => {\n callback({\n scrollDirection,\n reachStart,\n reachEnd,\n nearReachStart,\n nearReachEnd,\n });\n }, [\n scrollDirection,\n reachStart,\n reachEnd,\n nearReachStart,\n nearReachEnd,\n ...deps,\n ]);\n\n useEffect(() => {\n if (init && scrollableRef.current) {\n queueMicrotask(() => {\n scrollableRef.current.dispatchEvent(new Event('scroll'));\n });\n }\n }, [init]);\n\n // return {\n // scrollDirection,\n // reachStart,\n // reachEnd,\n // nearReachStart,\n // nearReachEnd,\n // init: () => {\n // if (scrollableRef.current) {\n // scrollableRef.current.dispatchEvent(new Event('scroll'));\n // }\n // },\n // };\n}\n","import './media-post.css';\n\nimport { memo } from 'preact/compat';\nimport { useContext, useMemo } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport FilterContext from '../utils/filter-context';\nimport { isFiltered } from '../utils/filters';\nimport states, { statusKey } from '../utils/states';\nimport store from '../utils/store';\n\nimport Media from './media';\n\nfunction MediaPost({\n class: className,\n statusID,\n status,\n instance,\n parent,\n // allowFilters,\n onMediaClick,\n}) {\n let sKey = statusKey(statusID, instance);\n const snapStates = useSnapshot(states);\n if (!status) {\n status = snapStates.statuses[sKey] || snapStates.statuses[statusID];\n sKey = statusKey(status?.id, instance);\n }\n if (!status) {\n return null;\n }\n\n const {\n account: {\n acct,\n avatar,\n avatarStatic,\n id: accountId,\n url: accountURL,\n displayName,\n username,\n emojis: accountEmojis,\n bot,\n group,\n },\n id,\n repliesCount,\n reblogged,\n reblogsCount,\n favourited,\n favouritesCount,\n bookmarked,\n poll,\n muted,\n sensitive,\n spoilerText,\n visibility, // public, unlisted, private, direct\n language,\n editedAt,\n filtered,\n card,\n createdAt,\n inReplyToId,\n inReplyToAccountId,\n content,\n mentions,\n mediaAttachments,\n reblog,\n uri,\n url,\n emojis,\n // Non-API props\n _deleted,\n _pinned,\n // _filtered,\n } = status;\n\n if (!mediaAttachments?.length) {\n return null;\n }\n\n const debugHover = (e) => {\n if (e.shiftKey) {\n console.log({\n ...status,\n });\n }\n };\n\n const currentAccount = useMemo(() => {\n return store.session.get('currentAccount');\n }, []);\n const isSelf = useMemo(() => {\n return currentAccount && currentAccount === accountId;\n }, [accountId, currentAccount]);\n\n const filterContext = useContext(FilterContext);\n const filterInfo = !isSelf && isFiltered(filtered, filterContext);\n\n if (filterInfo?.action === 'hide') {\n return null;\n }\n\n console.debug('RENDER Media post', id, status?.account.displayName);\n\n const hasSpoiler = sensitive;\n const readingExpandMedia = useMemo(() => {\n // default | show_all | hide_all\n const prefs = store.account.get('preferences') || {};\n return prefs['reading:expand:media'] || 'default';\n }, []);\n const showSpoilerMedia = readingExpandMedia === 'show_all';\n\n const Parent = parent || 'div';\n\n return mediaAttachments.map((media, i) => {\n const mediaKey = `${sKey}-${media.id}`;\n const filterTitleStr = filterInfo?.titlesStr;\n return (\n <Parent\n data-state-post-id={sKey}\n onMouseEnter={debugHover}\n key={mediaKey}\n data-spoiler-text={\n spoilerText || (sensitive ? 'Sensitive media' : undefined)\n }\n data-filtered-text={\n filterInfo\n ? `Filtered${filterTitleStr ? `: ${filterTitleStr}` : ''}`\n : undefined\n }\n class={`\n media-post\n ${filterInfo ? 'filtered' : ''}\n ${hasSpoiler ? 'has-spoiler' : ''}\n ${showSpoilerMedia ? 'show-media' : ''}\n `}\n >\n <Media\n class={className}\n media={media}\n lang={language}\n to={`/${instance}/s/${id}?media-only=${i + 1}`}\n onClick={\n onMediaClick ? (e) => onMediaClick(e, i, media, status) : undefined\n }\n />\n </Parent>\n );\n });\n}\n\nexport default memo(MediaPost);\n","import './nav-menu.css';\n\nimport { ControlledMenu, MenuDivider, MenuItem } from '@szhsin/react-menu';\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { useLongPress } from 'use-long-press';\nimport { useSnapshot } from 'valtio';\n\nimport { api } from '../utils/api';\nimport safeBoundingBoxPadding from '../utils/safe-bounding-box-padding';\nimport states from '../utils/states';\nimport store from '../utils/store';\n\nimport Avatar from './avatar';\nimport Icon from './icon';\nimport MenuLink from './menu-link';\n\nfunction NavMenu(props) {\n const snapStates = useSnapshot(states);\n const { masto, instance, authenticated } = api();\n\n const [currentAccount, setCurrentAccount] = useState();\n const [moreThanOneAccount, setMoreThanOneAccount] = useState(false);\n\n useEffect(() => {\n const accounts = store.local.getJSON('accounts') || [];\n const acc = accounts.find(\n (account) => account.info.id === store.session.get('currentAccount'),\n );\n if (acc) setCurrentAccount(acc);\n setMoreThanOneAccount(accounts.length > 1);\n }, []);\n\n // Home = Following\n // But when in multi-column mode, Home becomes columns of anything\n // User may choose pin or not to pin Following\n // If user doesn't pin Following, we show it in the menu\n const showFollowing =\n (snapStates.settings.shortcutsViewMode === 'multi-column' ||\n (!snapStates.settings.shortcutsViewMode &&\n snapStates.settings.shortcutsColumnsMode)) &&\n !snapStates.shortcuts.find((pin) => pin.type === 'following');\n\n const bindLongPress = useLongPress(\n () => {\n states.showAccounts = true;\n },\n {\n threshold: 600,\n detect: 'touch',\n cancelOnMovement: true,\n },\n );\n\n const buttonRef = useRef();\n const [menuState, setMenuState] = useState(undefined);\n\n const boundingBoxPadding = safeBoundingBoxPadding([\n 0,\n 0,\n snapStates.settings.shortcutsViewMode === 'tab-menu-bar' ? 50 : 0,\n 0,\n ]);\n\n const mutesIterator = useRef();\n async function fetchMutes(firstLoad) {\n if (firstLoad || !mutesIterator.current) {\n mutesIterator.current = masto.v1.mutes.list({\n limit: 80,\n });\n }\n const results = await mutesIterator.current.next();\n return results;\n }\n\n const blocksIterator = useRef();\n async function fetchBlocks(firstLoad) {\n if (firstLoad || !blocksIterator.current) {\n blocksIterator.current = masto.v1.blocks.list({\n limit: 80,\n });\n }\n const results = await blocksIterator.current.next();\n return results;\n }\n\n return (\n <>\n <button\n ref={buttonRef}\n type=\"button\"\n class={`button plain nav-menu-button ${\n moreThanOneAccount ? 'with-avatar' : ''\n } ${open ? 'active' : ''}`}\n style={{ position: 'relative' }}\n onClick={() => {\n setMenuState((state) => (!state ? 'open' : undefined));\n }}\n onContextMenu={(e) => {\n e.preventDefault();\n states.showAccounts = true;\n }}\n {...bindLongPress()}\n >\n {moreThanOneAccount && (\n <Avatar\n url={\n currentAccount?.info?.avatar || currentAccount?.info?.avatarStatic\n }\n size=\"l\"\n squircle={currentAccount?.info?.bot}\n />\n )}\n <Icon icon=\"menu\" size={moreThanOneAccount ? 's' : 'l'} />\n </button>\n <ControlledMenu\n menuClassName=\"nav-menu\"\n state={menuState}\n anchorRef={buttonRef}\n onClose={() => {\n setMenuState(undefined);\n }}\n containerProps={{\n style: {\n zIndex: 10,\n },\n onClick: () => {\n setMenuState(undefined);\n },\n }}\n portal={{\n target: document.body,\n }}\n {...props}\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n align=\"center\"\n boundingBoxPadding={boundingBoxPadding}\n unmountOnClose\n >\n {!!snapStates.appVersion?.commitHash &&\n __COMMIT_HASH__ !== snapStates.appVersion.commitHash && (\n <div class=\"top-menu\">\n <MenuItem\n onClick={() => {\n const yes = confirm('Reload page now to update?');\n if (yes) {\n (async () => {\n try {\n location.reload();\n } catch (e) {}\n })();\n }\n }}\n >\n <Icon icon=\"sparkles\" class=\"sparkle-icon\" size=\"l\" />{' '}\n <span>New update available…</span>\n </MenuItem>\n <MenuDivider />\n </div>\n )}\n <section>\n <MenuLink to=\"/\">\n <Icon icon=\"home\" size=\"l\" /> <span>Home</span>\n </MenuLink>\n {authenticated && (\n <>\n {showFollowing && (\n <MenuLink to=\"/following\">\n <Icon icon=\"following\" size=\"l\" /> <span>Following</span>\n </MenuLink>\n )}\n <MenuLink to=\"/mentions\">\n <Icon icon=\"at\" size=\"l\" /> <span>Mentions</span>\n </MenuLink>\n <MenuLink to=\"/notifications\">\n <Icon icon=\"notification\" size=\"l\" /> <span>Notifications</span>\n {snapStates.notificationsShowNew && (\n <sup title=\"New\" style={{ opacity: 0.5 }}>\n {' '}\n •\n </sup>\n )}\n </MenuLink>\n <MenuDivider />\n <MenuLink to=\"/l\">\n <Icon icon=\"list\" size=\"l\" /> <span>Lists</span>\n </MenuLink>\n <MenuLink to=\"/ft\">\n <Icon icon=\"hashtag\" size=\"l\" /> <span>Followed Hashtags</span>\n </MenuLink>\n <MenuLink to=\"/b\">\n <Icon icon=\"bookmark\" size=\"l\" /> <span>Bookmarks</span>\n </MenuLink>\n <MenuLink to=\"/f\">\n <Icon icon=\"heart\" size=\"l\" /> <span>Likes</span>\n </MenuLink>\n </>\n )}\n <MenuDivider />\n <MenuLink to={`/search`}>\n <Icon icon=\"search\" size=\"l\" /> <span>Search</span>\n </MenuLink>\n <MenuLink to={`/${instance}/p/l`}>\n <Icon icon=\"building\" size=\"l\" /> <span>Local</span>\n </MenuLink>\n <MenuLink to={`/${instance}/p`}>\n <Icon icon=\"earth\" size=\"l\" /> <span>Federated</span>\n </MenuLink>\n <MenuLink to={`/${instance}/trending`}>\n <Icon icon=\"chart\" size=\"l\" /> <span>Trending</span>\n </MenuLink>\n </section>\n <section>\n {authenticated ? (\n <>\n <MenuDivider />\n {currentAccount?.info?.id && (\n <MenuLink to={`/${instance}/a/${currentAccount.info.id}`}>\n <Icon icon=\"user\" size=\"l\" /> <span>Profile</span>\n </MenuLink>\n )}\n <MenuItem\n onClick={() => {\n states.showAccounts = true;\n }}\n >\n <Icon icon=\"group\" size=\"l\" /> <span>Accounts…</span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n states.showGenericAccounts = {\n id: 'mute',\n heading: 'Muted users',\n fetchAccounts: fetchMutes,\n excludeRelationshipAttrs: ['muting'],\n };\n }}\n >\n <Icon icon=\"mute\" size=\"l\" /> Muted users…\n </MenuItem>\n <MenuItem\n onClick={() => {\n states.showGenericAccounts = {\n id: 'block',\n heading: 'Blocked users',\n fetchAccounts: fetchBlocks,\n excludeRelationshipAttrs: ['blocking'],\n };\n }}\n >\n <Icon icon=\"block\" size=\"l\" />\n Blocked users…\n </MenuItem>\n <MenuDivider className=\"divider-grow\" />\n <MenuItem\n onClick={() => {\n states.showKeyboardShortcutsHelp = true;\n }}\n >\n <Icon icon=\"keyboard\" size=\"l\" />{' '}\n <span>Keyboard shortcuts</span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n states.showShortcutsSettings = true;\n }}\n >\n <Icon icon=\"shortcut\" size=\"l\" />{' '}\n <span>Shortcuts / Columns…</span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n states.showSettings = true;\n }}\n >\n <Icon icon=\"gear\" size=\"l\" /> <span>Settings…</span>\n </MenuItem>\n </>\n ) : (\n <>\n <MenuDivider />\n <MenuLink to=\"/login\">\n <Icon icon=\"user\" size=\"l\" /> <span>Log in</span>\n </MenuLink>\n <MenuItem\n onClick={() => {\n states.showSettings = true;\n }}\n >\n <Icon icon=\"gear\" size=\"l\" /> <span>Settings…</span>\n </MenuItem>\n </>\n )}\n </section>\n </ControlledMenu>\n </>\n );\n}\n\nexport default NavMenu;\n","import { useCallback, useEffect, useRef, useState } from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\nimport { InView } from 'react-intersection-observer';\nimport { useDebouncedCallback } from 'use-debounce';\nimport { useSnapshot } from 'valtio';\n\nimport FilterContext from '../utils/filter-context';\nimport { filteredItems, isFiltered } from '../utils/filters';\nimport states, { statusKey } from '../utils/states';\nimport statusPeek from '../utils/status-peek';\nimport { groupBoosts, groupContext } from '../utils/timeline-utils';\nimport useInterval from '../utils/useInterval';\nimport usePageVisibility from '../utils/usePageVisibility';\nimport useScroll from '../utils/useScroll';\nimport useScrollFn from '../utils/useScrollFn';\n\nimport Icon from './icon';\nimport Link from './link';\nimport MediaPost from './media-post';\nimport NavMenu from './nav-menu';\nimport Status from './status';\n\nconst scrollIntoViewOptions = {\n block: 'nearest',\n inline: 'center',\n behavior: 'smooth',\n};\n\nfunction Timeline({\n title,\n titleComponent,\n id,\n instance,\n emptyText,\n errorText,\n useItemID, // use statusID instead of status object, assuming it's already in states\n boostsCarousel,\n fetchItems = () => {},\n checkForUpdates = () => {},\n checkForUpdatesInterval = 15_000, // 15 seconds\n headerStart,\n headerEnd,\n timelineStart,\n // allowFilters,\n refresh,\n view,\n filterContext,\n showFollowedTags,\n}) {\n const snapStates = useSnapshot(states);\n const [items, setItems] = useState([]);\n const [uiState, setUIState] = useState('default');\n const [showMore, setShowMore] = useState(false);\n const [showNew, setShowNew] = useState(false);\n const [visible, setVisible] = useState(true);\n const scrollableRef = useRef();\n\n console.debug('RENDER Timeline', id, refresh);\n\n const allowGrouping = view !== 'media';\n const loadItems = useDebouncedCallback(\n (firstLoad) => {\n setShowNew(false);\n if (uiState === 'loading') return;\n setUIState('loading');\n (async () => {\n try {\n let { done, value } = await fetchItems(firstLoad);\n if (Array.isArray(value)) {\n // Avoid grouping for pinned posts\n const [pinnedPosts, otherPosts] = value.reduce(\n (acc, item) => {\n if (item._pinned) {\n acc[0].push(item);\n } else {\n acc[1].push(item);\n }\n return acc;\n },\n [[], []],\n );\n value = otherPosts;\n if (allowGrouping) {\n if (boostsCarousel) {\n value = groupBoosts(value);\n }\n value = groupContext(value);\n }\n if (pinnedPosts.length) {\n value = pinnedPosts.concat(value);\n }\n console.log(value);\n if (firstLoad) {\n setItems(value);\n } else {\n setItems((items) => [...items, ...value]);\n }\n if (!value.length) done = true;\n setShowMore(!done);\n } else {\n setShowMore(false);\n }\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n } finally {\n loadItems.cancel();\n }\n })();\n },\n 1500,\n {\n leading: true,\n trailing: false,\n },\n );\n\n const itemsSelector = '.timeline-item, .timeline-item-alt';\n\n const jRef = useHotkeys('j, shift+j', (_, handler) => {\n // focus on next status after active item\n const activeItem = document.activeElement.closest(itemsSelector);\n const activeItemRect = activeItem?.getBoundingClientRect();\n const allItems = Array.from(\n scrollableRef.current.querySelectorAll(itemsSelector),\n );\n if (\n activeItem &&\n activeItemRect.top < scrollableRef.current.clientHeight &&\n activeItemRect.bottom > 0\n ) {\n const activeItemIndex = allItems.indexOf(activeItem);\n let nextItem = allItems[activeItemIndex + 1];\n if (handler.shift) {\n // get next status that's not .timeline-item-alt\n nextItem = allItems.find(\n (item, index) =>\n index > activeItemIndex &&\n !item.classList.contains('timeline-item-alt'),\n );\n }\n if (nextItem) {\n nextItem.focus();\n nextItem.scrollIntoView(scrollIntoViewOptions);\n }\n } else {\n // If active status is not in viewport, get the topmost status-link in viewport\n const topmostItem = allItems.find((item) => {\n const itemRect = item.getBoundingClientRect();\n return itemRect.top >= 44 && itemRect.left >= 0; // 44 is the magic number for header height, not real\n });\n if (topmostItem) {\n topmostItem.focus();\n topmostItem.scrollIntoView(scrollIntoViewOptions);\n }\n }\n });\n\n const kRef = useHotkeys('k, shift+k', (_, handler) => {\n // focus on previous status after active item\n const activeItem = document.activeElement.closest(itemsSelector);\n const activeItemRect = activeItem?.getBoundingClientRect();\n const allItems = Array.from(\n scrollableRef.current.querySelectorAll(itemsSelector),\n );\n if (\n activeItem &&\n activeItemRect.top < scrollableRef.current.clientHeight &&\n activeItemRect.bottom > 0\n ) {\n const activeItemIndex = allItems.indexOf(activeItem);\n let prevItem = allItems[activeItemIndex - 1];\n if (handler.shift) {\n // get prev status that's not .timeline-item-alt\n prevItem = allItems.findLast(\n (item, index) =>\n index < activeItemIndex &&\n !item.classList.contains('timeline-item-alt'),\n );\n }\n if (prevItem) {\n prevItem.focus();\n prevItem.scrollIntoView(scrollIntoViewOptions);\n }\n } else {\n // If active status is not in viewport, get the topmost status-link in viewport\n const topmostItem = allItems.find((item) => {\n const itemRect = item.getBoundingClientRect();\n return itemRect.top >= 44 && itemRect.left >= 0; // 44 is the magic number for header height, not real\n });\n if (topmostItem) {\n topmostItem.focus();\n topmostItem.scrollIntoView(scrollIntoViewOptions);\n }\n }\n });\n\n const oRef = useHotkeys(['enter', 'o'], () => {\n // open active status\n const activeItem = document.activeElement.closest(itemsSelector);\n if (activeItem) {\n activeItem.click();\n }\n });\n\n // const {\n // scrollDirection,\n // nearReachStart,\n // nearReachEnd,\n // reachStart,\n // reachEnd,\n // } = useScroll({\n // scrollableRef,\n // distanceFromEnd: 2,\n // scrollThresholdStart: 44,\n // });\n const headerRef = useRef();\n // const [hiddenUI, setHiddenUI] = useState(false);\n const [nearReachStart, setNearReachStart] = useState(false);\n useScrollFn(\n {\n scrollableRef,\n distanceFromEnd: 2,\n scrollThresholdStart: 44,\n },\n ({\n scrollDirection,\n nearReachStart,\n nearReachEnd,\n reachStart,\n reachEnd,\n }) => {\n // setHiddenUI(scrollDirection === 'end' && !nearReachEnd);\n if (headerRef.current) {\n const hiddenUI = scrollDirection === 'end' && !nearReachStart;\n headerRef.current.hidden = hiddenUI;\n }\n setNearReachStart(nearReachStart);\n if (reachStart) {\n loadItems(true);\n } else if (nearReachEnd || (reachEnd && showMore)) {\n loadItems();\n }\n },\n [],\n );\n\n useEffect(() => {\n scrollableRef.current?.scrollTo({ top: 0 });\n loadItems(true);\n }, []);\n useEffect(() => {\n loadItems(true);\n }, [refresh]);\n\n // useEffect(() => {\n // if (reachStart) {\n // loadItems(true);\n // }\n // }, [reachStart]);\n\n // useEffect(() => {\n // if (nearReachEnd || (reachEnd && showMore)) {\n // loadItems();\n // }\n // }, [nearReachEnd, showMore]);\n\n const prevView = useRef(view);\n useEffect(() => {\n if (prevView.current !== view) {\n prevView.current = view;\n setItems([]);\n }\n }, [view]);\n\n const loadOrCheckUpdates = useCallback(\n async ({ disableIdleCheck = false } = {}) => {\n const noPointers = scrollableRef.current\n ? getComputedStyle(scrollableRef.current).pointerEvents === 'none'\n : false;\n console.log('✨ Load or check updates', id, {\n autoRefresh: snapStates.settings.autoRefresh,\n scrollTop: scrollableRef.current.scrollTop,\n disableIdleCheck,\n idle: window.__IDLE__,\n inBackground: inBackground(),\n noPointers,\n });\n if (\n snapStates.settings.autoRefresh &&\n scrollableRef.current.scrollTop < 16 &&\n (disableIdleCheck || window.__IDLE__) &&\n !inBackground() &&\n !noPointers\n ) {\n console.log('✨ Load updates', id, snapStates.settings.autoRefresh);\n loadItems(true);\n } else {\n console.log('✨ Check updates', id, snapStates.settings.autoRefresh);\n const hasUpdate = await checkForUpdates();\n if (hasUpdate) {\n console.log('✨ Has new updates', id);\n setShowNew(true);\n }\n }\n },\n [id, loadItems, checkForUpdates, snapStates.settings.autoRefresh],\n );\n\n const lastHiddenTime = useRef();\n usePageVisibility(\n (visible) => {\n if (visible) {\n const timeDiff = Date.now() - lastHiddenTime.current;\n if (!lastHiddenTime.current || timeDiff > 1000 * 3) {\n // 3 seconds\n loadOrCheckUpdates({\n disableIdleCheck: true,\n });\n }\n } else {\n lastHiddenTime.current = Date.now();\n }\n setVisible(visible);\n },\n [checkForUpdates, loadOrCheckUpdates, snapStates.settings.autoRefresh],\n );\n\n // checkForUpdates interval\n useInterval(\n loadOrCheckUpdates,\n visible && !showNew\n ? checkForUpdatesInterval * (nearReachStart ? 1 : 2)\n : null,\n );\n\n // const hiddenUI = scrollDirection === 'end' && !nearReachStart;\n\n return (\n <FilterContext.Provider value={filterContext}>\n <div\n id={`${id}-page`}\n class=\"deck-container\"\n ref={(node) => {\n scrollableRef.current = node;\n jRef.current = node;\n kRef.current = node;\n oRef.current = node;\n }}\n tabIndex=\"-1\"\n >\n <div class=\"timeline-deck deck\">\n <header\n ref={headerRef}\n // hidden={hiddenUI}\n onClick={(e) => {\n if (!e.target.closest('a, button')) {\n scrollableRef.current?.scrollTo({\n top: 0,\n behavior: 'smooth',\n });\n }\n }}\n onDblClick={(e) => {\n if (!e.target.closest('a, button')) {\n loadItems(true);\n }\n }}\n class={uiState === 'loading' ? 'loading' : ''}\n >\n <div class=\"header-grid\">\n <div class=\"header-side\">\n <NavMenu />\n {headerStart !== null && headerStart !== undefined ? (\n headerStart\n ) : (\n <Link to=\"/\" class=\"button plain home-button\">\n <Icon icon=\"home\" size=\"l\" />\n </Link>\n )}\n </div>\n {title && (titleComponent ? titleComponent : <h1>{title}</h1>)}\n <div class=\"header-side\">\n {/* <Loader hidden={uiState !== 'loading'} /> */}\n {!!headerEnd && headerEnd}\n </div>\n </div>\n {items.length > 0 &&\n uiState !== 'loading' &&\n // !hiddenUI &&\n showNew && (\n <button\n class=\"updates-button shiny-pill\"\n type=\"button\"\n onClick={() => {\n loadItems(true);\n scrollableRef.current?.scrollTo({\n top: 0,\n behavior: 'smooth',\n });\n }}\n >\n <Icon icon=\"arrow-up\" /> New posts\n </button>\n )}\n </header>\n {!!timelineStart && (\n <div\n class={`timeline-start ${uiState === 'loading' ? 'loading' : ''}`}\n >\n {timelineStart}\n </div>\n )}\n {!!items.length ? (\n <>\n <ul class={`timeline ${view ? `timeline-${view}` : ''}`}>\n {items.map((status) => (\n <TimelineItem\n status={status}\n instance={instance}\n useItemID={useItemID}\n // allowFilters={allowFilters}\n filterContext={filterContext}\n key={status.id + status?._pinned + view}\n view={view}\n showFollowedTags={showFollowedTags}\n />\n ))}\n {showMore &&\n uiState === 'loading' &&\n (view === 'media' ? null : (\n <>\n <li\n style={{\n height: '20vh',\n }}\n >\n <Status skeleton />\n </li>\n <li\n style={{\n height: '25vh',\n }}\n >\n <Status skeleton />\n </li>\n </>\n ))}\n </ul>\n {uiState === 'default' &&\n (showMore ? (\n <InView\n onChange={(inView) => {\n if (inView) {\n loadItems();\n }\n }}\n >\n <button\n type=\"button\"\n class=\"plain block\"\n onClick={() => loadItems()}\n style={{ marginBlockEnd: '6em' }}\n >\n Show more…\n </button>\n </InView>\n ) : (\n <p class=\"ui-state insignificant\">The end.</p>\n ))}\n </>\n ) : uiState === 'loading' ? (\n <ul class=\"timeline\">\n {Array.from({ length: 5 }).map((_, i) =>\n view === 'media' ? (\n <div\n style={{\n height: '50vh',\n }}\n />\n ) : (\n <li key={i}>\n <Status skeleton />\n </li>\n ),\n )}\n </ul>\n ) : (\n uiState !== 'error' && <p class=\"ui-state\">{emptyText}</p>\n )}\n {uiState === 'error' && (\n <p class=\"ui-state\">\n {errorText}\n <br />\n <br />\n <button type=\"button\" onClick={() => loadItems(!items.length)}>\n Try again\n </button>\n </p>\n )}\n </div>\n </div>\n </FilterContext.Provider>\n );\n}\n\nfunction TimelineItem({\n status,\n instance,\n useItemID,\n // allowFilters,\n filterContext,\n view,\n showFollowedTags,\n}) {\n const { id: statusID, reblog, items, type, _pinned } = status;\n if (_pinned) useItemID = false;\n const actualStatusID = reblog?.id || statusID;\n const url = instance\n ? `/${instance}/s/${actualStatusID}`\n : `/s/${actualStatusID}`;\n let title = '';\n if (type === 'boosts') {\n title = `${items.length} Boosts`;\n } else if (type === 'pinned') {\n title = 'Pinned posts';\n }\n const isCarousel = type === 'boosts' || type === 'pinned';\n if (items) {\n const fItems = filteredItems(items, filterContext);\n if (isCarousel) {\n // Here, we don't hide filtered posts, but we sort them last\n fItems.sort((a, b) => {\n // if (a._filtered && !b._filtered) {\n // return 1;\n // }\n // if (!a._filtered && b._filtered) {\n // return -1;\n // }\n const aFiltered = isFiltered(a.filtered, filterContext);\n const bFiltered = isFiltered(b.filtered, filterContext);\n if (aFiltered && !bFiltered) {\n return 1;\n }\n if (!aFiltered && bFiltered) {\n return -1;\n }\n return 0;\n });\n return (\n <li key={`timeline-${statusID}`} class=\"timeline-item-carousel\">\n <StatusCarousel title={title} class={`${type}-carousel`}>\n {fItems.map((item) => {\n const { id: statusID, reblog, _pinned } = item;\n const actualStatusID = reblog?.id || statusID;\n const url = instance\n ? `/${instance}/s/${actualStatusID}`\n : `/s/${actualStatusID}`;\n if (_pinned) useItemID = false;\n return (\n <li key={statusID}>\n <Link class=\"status-carousel-link timeline-item-alt\" to={url}>\n {useItemID ? (\n <Status\n statusID={statusID}\n instance={instance}\n size=\"s\"\n contentTextWeight\n enableCommentHint\n // allowFilters={allowFilters}\n />\n ) : (\n <Status\n status={item}\n instance={instance}\n size=\"s\"\n contentTextWeight\n enableCommentHint\n // allowFilters={allowFilters}\n />\n )}\n </Link>\n </li>\n );\n })}\n </StatusCarousel>\n </li>\n );\n }\n const manyItems = fItems.length > 3;\n return fItems.map((item, i) => {\n const { id: statusID, _differentAuthor } = item;\n const url = instance ? `/${instance}/s/${statusID}` : `/s/${statusID}`;\n const isMiddle = i > 0 && i < fItems.length - 1;\n const isSpoiler = item.sensitive && !!item.spoilerText;\n const showCompact =\n (!_differentAuthor && isSpoiler && i > 0) ||\n (manyItems &&\n isMiddle &&\n (type === 'thread' ||\n (type === 'conversation' &&\n !_differentAuthor &&\n !fItems[i - 1]._differentAuthor &&\n !fItems[i + 1]._differentAuthor)));\n const isStart = i === 0;\n const isEnd = i === fItems.length - 1;\n return (\n <li\n key={`timeline-${statusID}`}\n class={`timeline-item-container timeline-item-container-type-${type} timeline-item-container-${\n isStart ? 'start' : isEnd ? 'end' : 'middle'\n } ${_differentAuthor ? 'timeline-item-diff-author' : ''}`}\n >\n <Link class=\"status-link timeline-item\" to={url}>\n {showCompact ? (\n <TimelineStatusCompact status={item} instance={instance} />\n ) : useItemID ? (\n <Status\n statusID={statusID}\n instance={instance}\n enableCommentHint={isEnd}\n showFollowedTags={showFollowedTags}\n // allowFilters={allowFilters}\n />\n ) : (\n <Status\n status={item}\n instance={instance}\n enableCommentHint={isEnd}\n showFollowedTags={showFollowedTags}\n // allowFilters={allowFilters}\n />\n )}\n </Link>\n </li>\n );\n });\n }\n\n const itemKey = `timeline-${statusID + _pinned}`;\n\n if (view === 'media') {\n return useItemID ? (\n <MediaPost\n class=\"timeline-item\"\n parent=\"li\"\n key={itemKey}\n statusID={statusID}\n instance={instance}\n // allowFilters={allowFilters}\n />\n ) : (\n <MediaPost\n class=\"timeline-item\"\n parent=\"li\"\n key={itemKey}\n status={status}\n instance={instance}\n // allowFilters={allowFilters}\n />\n );\n }\n\n return (\n <li key={itemKey}>\n <Link class=\"status-link timeline-item\" to={url}>\n {useItemID ? (\n <Status\n statusID={statusID}\n instance={instance}\n enableCommentHint\n showFollowedTags={showFollowedTags}\n // allowFilters={allowFilters}\n />\n ) : (\n <Status\n status={status}\n instance={instance}\n enableCommentHint\n showFollowedTags={showFollowedTags}\n // allowFilters={allowFilters}\n />\n )}\n </Link>\n </li>\n );\n}\n\nfunction StatusCarousel({ title, class: className, children }) {\n const carouselRef = useRef();\n // const { reachStart, reachEnd, init } = useScroll({\n // scrollableRef: carouselRef,\n // direction: 'horizontal',\n // });\n const startButtonRef = useRef();\n const endButtonRef = useRef();\n useScrollFn(\n {\n scrollableRef: carouselRef,\n direction: 'horizontal',\n init: true,\n },\n ({ reachStart, reachEnd }) => {\n if (startButtonRef.current) startButtonRef.current.disabled = reachStart;\n if (endButtonRef.current) endButtonRef.current.disabled = reachEnd;\n },\n [],\n );\n // useEffect(() => {\n // init?.();\n // }, []);\n\n return (\n <div class={`status-carousel ${className}`}>\n <header>\n <h3>{title}</h3>\n <span>\n <button\n ref={startButtonRef}\n type=\"button\"\n class=\"small plain2\"\n // disabled={reachStart}\n onClick={() => {\n carouselRef.current?.scrollBy({\n left: -Math.min(320, carouselRef.current?.offsetWidth),\n behavior: 'smooth',\n });\n }}\n >\n <Icon icon=\"chevron-left\" />\n </button>{' '}\n <button\n ref={endButtonRef}\n type=\"button\"\n class=\"small plain2\"\n // disabled={reachEnd}\n onClick={() => {\n carouselRef.current?.scrollBy({\n left: Math.min(320, carouselRef.current?.offsetWidth),\n behavior: 'smooth',\n });\n }}\n >\n <Icon icon=\"chevron-right\" />\n </button>\n </span>\n </header>\n <ul ref={carouselRef}>{children}</ul>\n </div>\n );\n}\n\nfunction TimelineStatusCompact({ status, instance }) {\n const snapStates = useSnapshot(states);\n const { id, visibility } = status;\n const statusPeekText = statusPeek(status);\n const sKey = statusKey(id, instance);\n return (\n <article\n class={`status compact-thread ${\n visibility === 'direct' ? 'visibility-direct' : ''\n }`}\n tabindex=\"-1\"\n >\n {!!snapStates.statusThreadNumber[sKey] ? (\n <div class=\"status-thread-badge\">\n <Icon icon=\"thread\" size=\"s\" />\n {snapStates.statusThreadNumber[sKey]\n ? ` ${snapStates.statusThreadNumber[sKey]}/X`\n : ''}\n </div>\n ) : (\n <div class=\"status-thread-badge\">\n <Icon icon=\"thread\" size=\"s\" />\n </div>\n )}\n <div class=\"content-compact\" title={statusPeekText}>\n {statusPeekText}\n {status.sensitive && status.spoilerText && (\n <>\n {' '}\n <span class=\"spoiler-badge\">\n <Icon icon=\"eye-close\" size=\"s\" />\n </span>\n </>\n )}\n </div>\n </article>\n );\n}\n\nfunction inBackground() {\n return !!document.querySelector('.deck-backdrop, #modal-container > *');\n}\n\nexport default Timeline;\n","import { MenuItem } from '@szhsin/react-menu';\nimport {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'preact/hooks';\nimport { useParams, useSearchParams } from 'react-router-dom';\nimport { useSnapshot } from 'valtio';\n\nimport AccountInfo from '../components/account-info';\nimport EmojiText from '../components/emoji-text';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Menu2 from '../components/menu2';\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport pmem from '../utils/pmem';\nimport showToast from '../utils/show-toast';\nimport states from '../utils/states';\nimport { saveStatus } from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\nconst MIN_YEAR = 1983;\nconst MIN_YEAR_MONTH = `${MIN_YEAR}-01`; // Birth of the Internet\n\nconst supportsInputMonth = (() => {\n try {\n const input = document.createElement('input');\n input.setAttribute('type', 'month');\n return input.type === 'month';\n } catch (e) {\n return false;\n }\n})();\n\nasync function _isSearchEnabled(instance) {\n const { masto } = api({ instance });\n const results = await masto.v2.search.fetch({\n q: 'from:me',\n type: 'statuses',\n limit: 1,\n });\n return !!results?.statuses?.length;\n}\nconst isSearchEnabled = pmem(_isSearchEnabled);\n\nfunction AccountStatuses() {\n const snapStates = useSnapshot(states);\n const { id, ...params } = useParams();\n const [searchParams, setSearchParams] = useSearchParams();\n const month = searchParams.get('month');\n const excludeReplies = !searchParams.get('replies');\n const excludeBoosts = !!searchParams.get('boosts');\n const tagged = searchParams.get('tagged');\n const media = !!searchParams.get('media');\n const { masto, instance, authenticated } = api({ instance: params.instance });\n const { masto: currentMasto, instance: currentInstance } = api();\n const accountStatusesIterator = useRef();\n\n const allSearchParams = [month, excludeReplies, excludeBoosts, tagged, media];\n const [account, setAccount] = useState();\n const searchOffsetRef = useRef(0);\n useEffect(() => {\n searchOffsetRef.current = 0;\n }, allSearchParams);\n\n const sameCurrentInstance = useMemo(\n () => instance === currentInstance,\n [instance, currentInstance],\n );\n const [searchEnabled, setSearchEnabled] = useState(false);\n useEffect(() => {\n // Only enable for current logged-in instance\n // Most remote instances don't allow unauthenticated searches\n if (!sameCurrentInstance) return;\n if (!account?.acct) return;\n (async () => {\n const enabled = await isSearchEnabled(instance);\n console.log({ enabled });\n setSearchEnabled(enabled);\n })();\n }, [instance, sameCurrentInstance, account?.acct]);\n\n async function fetchAccountStatuses(firstLoad) {\n const isValidMonth = /^\\d{4}-[01]\\d$/.test(month);\n const isValidYear = month?.split?.('-')?.[0] >= MIN_YEAR;\n if (isValidMonth && isValidYear) {\n if (!account) {\n return {\n value: [],\n done: true,\n };\n }\n const [_year, _month] = month.split('-');\n const monthIndex = parseInt(_month, 10) - 1;\n // YYYY-MM (no day)\n // Search options:\n // - from:account\n // - after:YYYY-MM-DD (non-inclusive)\n // - before:YYYY-MM-DD (non-inclusive)\n\n // Last day of previous month\n const after = new Date(_year, monthIndex, 0);\n const afterStr = `${after.getFullYear()}-${(after.getMonth() + 1)\n .toString()\n .padStart(2, '0')}-${after.getDate().toString().padStart(2, '0')}`;\n // First day of next month\n const before = new Date(_year, monthIndex + 1, 1);\n const beforeStr = `${before.getFullYear()}-${(before.getMonth() + 1)\n .toString()\n .padStart(2, '0')}-${before.getDate().toString().padStart(2, '0')}`;\n console.log({\n month,\n _year,\n _month,\n monthIndex,\n after,\n before,\n afterStr,\n beforeStr,\n });\n\n let limit;\n if (firstLoad) {\n limit = LIMIT + 1;\n searchOffsetRef.current = 0;\n } else {\n limit = LIMIT + searchOffsetRef.current + 1;\n searchOffsetRef.current += LIMIT;\n }\n\n const searchResults = await masto.v2.search.fetch({\n q: `from:${account.acct} after:${afterStr} before:${beforeStr}`,\n type: 'statuses',\n limit,\n offset: searchOffsetRef.current,\n });\n if (searchResults?.statuses?.length) {\n const value = searchResults.statuses.slice(0, LIMIT);\n value.forEach((item) => {\n saveStatus(item, instance);\n });\n const done = searchResults.statuses.length <= LIMIT;\n return { value, done };\n } else {\n return { value: [], done: true };\n }\n }\n\n const results = [];\n if (firstLoad) {\n const { value } = await masto.v1.accounts\n .$select(id)\n .statuses.list({\n pinned: true,\n })\n .next();\n if (value?.length && !tagged && !media) {\n const pinnedStatuses = value.map((status) => {\n saveStatus(status, instance);\n return {\n ...status,\n _pinned: true,\n };\n });\n if (pinnedStatuses.length >= 3) {\n const pinnedStatusesIds = pinnedStatuses.map((status) => status.id);\n results.push({\n id: pinnedStatusesIds,\n items: pinnedStatuses,\n type: 'pinned',\n });\n } else {\n results.push(...pinnedStatuses);\n }\n }\n }\n if (firstLoad || !accountStatusesIterator.current) {\n accountStatusesIterator.current = masto.v1.accounts\n .$select(id)\n .statuses.list({\n limit: LIMIT,\n exclude_replies: excludeReplies,\n exclude_reblogs: excludeBoosts,\n only_media: media,\n tagged,\n });\n }\n const { value, done } = await accountStatusesIterator.current.next();\n if (value?.length) {\n results.push(...value);\n\n value.forEach((item) => {\n saveStatus(item, instance);\n });\n }\n return {\n value: results,\n done,\n };\n }\n\n const [featuredTags, setFeaturedTags] = useState([]);\n useTitle(\n account?.acct\n ? `${account?.displayName ? account.displayName + ' ' : ''}@${\n account.acct\n }${\n !excludeReplies\n ? ' (+ Replies)'\n : excludeBoosts\n ? ' (- Boosts)'\n : tagged\n ? ` (#${tagged})`\n : media\n ? ' (Media)'\n : month\n ? ` (${new Date(month).toLocaleString('default', {\n month: 'long',\n year: 'numeric',\n })})`\n : ''\n }`\n : 'Account posts',\n '/:instance?/a/:id',\n );\n\n const fetchAccountPromiseRef = useRef();\n const fetchAccount = useCallback(() => {\n const fetchPromise =\n fetchAccountPromiseRef.current || masto.v1.accounts.$select(id).fetch();\n fetchAccountPromiseRef.current = fetchPromise;\n return fetchPromise;\n }, [id, masto]);\n\n useEffect(() => {\n (async () => {\n try {\n const acc = await fetchAccount();\n console.log(acc);\n setAccount(acc);\n } catch (e) {\n console.error(e);\n }\n try {\n const featuredTags = await masto.v1.accounts\n .$select(id)\n .featuredTags.list();\n console.log({ featuredTags });\n setFeaturedTags(featuredTags);\n } catch (e) {\n console.error(e);\n }\n })();\n }, [id]);\n\n const { displayName, acct, emojis } = account || {};\n\n const accountInfoMemo = useMemo(() => {\n const cachedAccount = snapStates.accounts[`${id}@${instance}`];\n return (\n <AccountInfo\n instance={instance}\n account={cachedAccount || id}\n fetchAccount={fetchAccount}\n authenticated={authenticated}\n standalone\n />\n );\n }, [id, instance, authenticated, fetchAccount]);\n\n const filterBarRef = useRef();\n const TimelineStart = useMemo(() => {\n const filtered =\n !excludeReplies || excludeBoosts || tagged || media || !!month;\n\n return (\n <>\n {accountInfoMemo}\n <div\n class=\"filter-bar\"\n ref={filterBarRef}\n style={{\n position: 'relative',\n }}\n >\n {filtered ? (\n <Link\n to={`/${instance}/a/${id}`}\n class=\"insignificant filter-clear\"\n title=\"Clear filters\"\n key=\"clear-filters\"\n >\n <Icon icon=\"x\" size=\"l\" />\n </Link>\n ) : (\n <Icon icon=\"filter\" class=\"insignificant\" size=\"l\" />\n )}\n <Link\n to={`/${instance}/a/${id}${excludeReplies ? '?replies=1' : ''}`}\n onClick={() => {\n if (excludeReplies) {\n showToast('Showing post with replies');\n }\n }}\n class={excludeReplies ? '' : 'is-active'}\n >\n + Replies\n </Link>\n <Link\n to={`/${instance}/a/${id}${excludeBoosts ? '' : '?boosts=0'}`}\n onClick={() => {\n if (!excludeBoosts) {\n showToast('Showing posts without boosts');\n }\n }}\n class={!excludeBoosts ? '' : 'is-active'}\n >\n - Boosts\n </Link>\n <Link\n to={`/${instance}/a/${id}${media ? '' : '?media=1'}`}\n onClick={() => {\n if (!media) {\n showToast('Showing posts with media');\n }\n }}\n class={media ? 'is-active' : ''}\n >\n Media\n </Link>\n {featuredTags.map((tag) => (\n <Link\n key={tag.id}\n to={`/${instance}/a/${id}${\n tagged === tag.name\n ? ''\n : `?tagged=${encodeURIComponent(tag.name)}`\n }`}\n onClick={() => {\n if (tagged !== tag.name) {\n showToast(`Showing posts tagged with #${tag.name}`);\n }\n }}\n class={tagged === tag.name ? 'is-active' : ''}\n >\n <span>\n <span class=\"more-insignificant\">#</span>\n {tag.name}\n </span>\n {\n // The count differs based on instance 😅\n }\n {/* <span class=\"filter-count\">{tag.statusesCount}</span> */}\n </Link>\n ))}\n {searchEnabled &&\n (supportsInputMonth ? (\n <label class={`filter-field ${month ? 'is-active' : ''}`}>\n <Icon icon=\"month\" size=\"l\" />\n <input\n type=\"month\"\n disabled={!account?.acct}\n value={month || ''}\n min={MIN_YEAR_MONTH}\n max={new Date().toISOString().slice(0, 7)}\n onInput={(e) => {\n const { value, validity } = e.currentTarget;\n if (!validity.valid) return;\n setSearchParams(\n value\n ? {\n month: value,\n }\n : {},\n );\n const [year, month] = value.split('-');\n const monthIndex = parseInt(month, 10) - 1;\n const date = new Date(year, monthIndex);\n showToast(\n `Showing posts in ${date.toLocaleString('default', {\n month: 'long',\n year: 'numeric',\n })}`,\n );\n }}\n />\n </label>\n ) : (\n // Fallback to <select> for month and <input type=\"number\"> for year\n <MonthPicker\n class={`filter-field ${month ? 'is-active' : ''}`}\n disabled={!account?.acct}\n value={month || ''}\n min={MIN_YEAR_MONTH}\n max={new Date().toISOString().slice(0, 7)}\n onInput={(e) => {\n const { value, validity } = e;\n if (!validity.valid) return;\n setSearchParams(\n value\n ? {\n month: value,\n }\n : {},\n );\n }}\n />\n ))}\n </div>\n </>\n );\n }, [\n id,\n instance,\n authenticated,\n featuredTags,\n searchEnabled,\n ...allSearchParams,\n ]);\n\n useEffect(() => {\n // Focus on .is-active\n const active = filterBarRef.current?.querySelector('.is-active');\n if (active) {\n console.log('active', active, active.offsetLeft);\n filterBarRef.current.scrollTo({\n behavior: 'smooth',\n left:\n active.offsetLeft -\n (filterBarRef.current.offsetWidth - active.offsetWidth) / 2,\n });\n }\n }, [featuredTags, searchEnabled, ...allSearchParams]);\n\n const accountInstance = useMemo(() => {\n if (!account?.url) return null;\n const domain = new URL(account.url).hostname;\n return domain;\n }, [account]);\n const sameInstance = instance === accountInstance;\n const allowSwitch = !!account && !sameInstance;\n\n return (\n <Timeline\n key={id}\n title={`${account?.acct ? '@' + account.acct : 'Posts'}`}\n titleComponent={\n <h1\n class=\"header-double-lines header-account\"\n // onClick={() => {\n // states.showAccount = {\n // account,\n // instance,\n // };\n // }}\n >\n <b>\n <EmojiText text={displayName} emojis={emojis} />\n </b>\n <div>\n <span>@{acct}</span>\n </div>\n </h1>\n }\n id=\"account-statuses\"\n instance={instance}\n emptyText=\"Nothing to see here yet.\"\n errorText=\"Unable to load posts\"\n fetchItems={fetchAccountStatuses}\n useItemID\n view={media ? 'media' : undefined}\n boostsCarousel={snapStates.settings.boostsCarousel}\n timelineStart={TimelineStart}\n refresh={[\n excludeReplies,\n excludeBoosts,\n tagged,\n media,\n month + account?.acct,\n ].toString()}\n headerEnd={\n <Menu2\n portal\n // setDownOverflow\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n menuButton={\n <button type=\"button\" class=\"plain\">\n <Icon icon=\"more\" size=\"l\" />\n </button>\n }\n >\n <MenuItem\n disabled={!allowSwitch}\n onClick={() => {\n (async () => {\n try {\n const { masto } = api({\n instance: accountInstance,\n });\n const acc = await masto.v1.accounts.lookup({\n acct: account.acct,\n });\n const { id } = acc;\n location.hash = `/${accountInstance}/a/${id}`;\n } catch (e) {\n console.error(e);\n alert('Unable to fetch account info');\n }\n })();\n }}\n >\n <Icon icon=\"transfer\" />{' '}\n <small class=\"menu-double-lines\">\n Switch to account's instance (<b>{accountInstance}</b>)\n </small>\n </MenuItem>\n {!sameCurrentInstance && (\n <MenuItem\n onClick={() => {\n (async () => {\n try {\n const acc = await currentMasto.v1.accounts.lookup({\n acct: account.acct + '@' + instance,\n });\n const { id } = acc;\n location.hash = `/${currentInstance}/a/${id}`;\n } catch (e) {\n console.error(e);\n alert('Unable to fetch account info');\n }\n })();\n }}\n >\n <Icon icon=\"transfer\" />{' '}\n <small class=\"menu-double-lines\">\n Switch to my instance (<b>{currentInstance}</b>)\n </small>\n </MenuItem>\n )}\n </Menu2>\n }\n />\n );\n}\n\nfunction MonthPicker(props) {\n const {\n class: className,\n disabled,\n value,\n min,\n max,\n onInput = () => {},\n } = props;\n const [_year, _month] = value?.split('-') || [];\n const monthFieldRef = useRef();\n const yearFieldRef = useRef();\n\n const checkValidity = (month, year) => {\n const [minYear, minMonth] = min?.split('-') || [];\n const [maxYear, maxMonth] = max?.split('-') || [];\n if (year < minYear) return false;\n if (year > maxYear) return false;\n if (year === minYear && month < minMonth) return false;\n if (year === maxYear && month > maxMonth) return false;\n return true;\n };\n\n return (\n <div class={className}>\n <Icon icon=\"month\" size=\"l\" />\n <select\n ref={monthFieldRef}\n disabled={disabled}\n value={_month || ''}\n onInput={(e) => {\n const { value: month } = e.currentTarget;\n const year = yearFieldRef.current.value;\n if (!checkValidity(month, year))\n return {\n value: '',\n validity: {\n valid: false,\n },\n };\n onInput({\n value: month ? `${year}-${month}` : '',\n validity: {\n valid: true,\n },\n });\n }}\n >\n <option value=\"\">Month</option>\n <option disabled>-----</option>\n {Array.from({ length: 12 }, (_, i) => (\n <option\n value={\n // Month is 1-indexed\n (i + 1).toString().padStart(2, '0')\n }\n key={i}\n >\n {new Date(0, i).toLocaleString('default', {\n month: 'long',\n })}\n </option>\n ))}\n </select>{' '}\n <input\n ref={yearFieldRef}\n type=\"number\"\n disabled={disabled}\n value={_year || new Date().getFullYear()}\n min={min?.slice(0, 4) || MIN_YEAR}\n max={max?.slice(0, 4) || new Date().getFullYear()}\n onInput={(e) => {\n const { value: year, validity } = e.currentTarget;\n const month = monthFieldRef.current.value;\n if (!validity.valid || !checkValidity(month, year))\n return {\n value: '',\n validity: {\n valid: false,\n },\n };\n onInput({\n value: year ? `${year}-${month}` : '',\n validity: {\n valid: true,\n },\n });\n }}\n style={{\n width: '4.5em',\n }}\n />\n </div>\n );\n}\n\nexport default AccountStatuses;\n","import { useRef } from 'preact/hooks';\n\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\nfunction Bookmarks() {\n useTitle('Bookmarks', '/b');\n const { masto, instance } = api();\n const bookmarksIterator = useRef();\n async function fetchBookmarks(firstLoad) {\n if (firstLoad || !bookmarksIterator.current) {\n bookmarksIterator.current = masto.v1.bookmarks.list({ limit: LIMIT });\n }\n return await bookmarksIterator.current.next();\n }\n\n return (\n <Timeline\n title=\"Bookmarks\"\n id=\"bookmarks\"\n emptyText=\"No bookmarks yet. Go bookmark something!\"\n errorText=\"Unable to load bookmarks\"\n instance={instance}\n fetchItems={fetchBookmarks}\n />\n );\n}\n\nexport default Bookmarks;\n","import { useRef } from 'preact/hooks';\n\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\nfunction Favourites() {\n useTitle('Likes', '/f');\n const { masto, instance } = api();\n const favouritesIterator = useRef();\n async function fetchFavourites(firstLoad) {\n if (firstLoad || !favouritesIterator.current) {\n favouritesIterator.current = masto.v1.favourites.list({ limit: LIMIT });\n }\n return await favouritesIterator.current.next();\n }\n\n return (\n <Timeline\n title=\"Likes\"\n id=\"favourites\"\n emptyText=\"No likes yet. Go like something!\"\n errorText=\"Unable to load likes\"\n instance={instance}\n fetchItems={fetchFavourites}\n />\n );\n}\n\nexport default Favourites;\n","import { useEffect, useState } from 'preact/hooks';\n\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport NavMenu from '../components/nav-menu';\nimport { api } from '../utils/api';\nimport { fetchFollowedTags } from '../utils/followed-tags';\nimport useTitle from '../utils/useTitle';\n\nfunction FollowedHashtags() {\n const { masto, instance } = api();\n useTitle(`Followed Hashtags`, `/ft`);\n const [uiState, setUIState] = useState('default');\n\n const [followedHashtags, setFollowedHashtags] = useState([]);\n useEffect(() => {\n setUIState('loading');\n (async () => {\n try {\n const tags = await fetchFollowedTags();\n setFollowedHashtags(tags);\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n }, []);\n\n return (\n <div id=\"followed-hashtags-page\" class=\"deck-container\" tabIndex=\"-1\">\n <div class=\"timeline-deck deck\">\n <header>\n <div class=\"header-grid\">\n <div class=\"header-side\">\n <NavMenu />\n <Link to=\"/\" class=\"button plain\">\n <Icon icon=\"home\" size=\"l\" />\n </Link>\n </div>\n <h1>Followed Hashtags</h1>\n <div class=\"header-side\" />\n </div>\n </header>\n <main>\n {followedHashtags.length > 0 ? (\n <ul class=\"link-list\">\n {followedHashtags.map((tag) => (\n <li>\n <Link\n to={\n instance ? `/${instance}/t/${tag.name}` : `/t/${tag.name}`\n }\n >\n <Icon icon=\"hashtag\" /> <span>{tag.name}</span>\n </Link>\n </li>\n ))}\n </ul>\n ) : uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : uiState === 'error' ? (\n <p class=\"ui-state\">Unable to load followed hashtags.</p>\n ) : (\n <p class=\"ui-state\">No hashtags followed yet.</p>\n )}\n </main>\n </div>\n </div>\n );\n}\n\nexport default FollowedHashtags;\n","import { useEffect, useRef } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport { filteredItems } from '../utils/filters';\nimport states from '../utils/states';\nimport { getStatus, saveStatus } from '../utils/states';\nimport {\n assignFollowedTags,\n clearFollowedTagsState,\n dedupeBoosts,\n} from '../utils/timeline-utils';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\nfunction Following({ title, path, id, ...props }) {\n useTitle(title || 'Following', path || '/following');\n const { masto, streaming, instance } = api();\n const snapStates = useSnapshot(states);\n const homeIterator = useRef();\n const latestItem = useRef();\n\n console.debug('RENDER Following', title, id);\n\n async function fetchHome(firstLoad) {\n if (firstLoad || !homeIterator.current) {\n homeIterator.current = masto.v1.timelines.home.list({ limit: LIMIT });\n }\n const results = await homeIterator.current.next();\n let { value } = results;\n if (value?.length) {\n let latestItemChanged = false;\n if (firstLoad) {\n if (value[0].id !== latestItem.current) {\n latestItemChanged = true;\n }\n latestItem.current = value[0].id;\n console.log('First load', latestItem.current);\n }\n\n // value = filteredItems(value, 'home');\n value.forEach((item) => {\n saveStatus(item, instance);\n });\n value = dedupeBoosts(value, instance);\n if (firstLoad && latestItemChanged) clearFollowedTagsState();\n assignFollowedTags(value, instance);\n\n // ENFORCE sort by datetime (Latest first)\n value.sort((a, b) => {\n const aDate = new Date(a.createdAt);\n const bDate = new Date(b.createdAt);\n return bDate - aDate;\n });\n }\n return {\n ...results,\n value,\n };\n }\n\n async function checkForUpdates() {\n try {\n const results = await masto.v1.timelines.home\n .list({\n limit: 5,\n since_id: latestItem.current,\n })\n .next();\n let { value } = results;\n console.log('checkForUpdates', latestItem.current, value);\n if (value?.length) {\n latestItem.current = value[0].id;\n value = dedupeBoosts(value, instance);\n value = filteredItems(value, 'home');\n if (value.some((item) => !item.reblog)) {\n return true;\n }\n }\n return false;\n } catch (e) {\n return false;\n }\n }\n\n useEffect(() => {\n let sub;\n (async () => {\n if (streaming) {\n sub = streaming.user.subscribe();\n console.log('🎏 Streaming user', sub);\n for await (const entry of sub) {\n if (!sub) break;\n if (entry.event === 'status.update') {\n const status = entry.payload;\n console.log(`🔄 Status ${status.id} updated`);\n saveStatus(status, instance);\n } else if (entry.event === 'delete') {\n const statusID = entry.payload;\n console.log(`❌ Status ${statusID} deleted`);\n // delete states.statuses[statusID];\n const s = getStatus(statusID, instance);\n if (s) s._deleted = true;\n }\n }\n console.log('💥 Streaming user loop STOPPED');\n }\n })();\n return () => {\n sub?.unsubscribe?.();\n sub = null;\n };\n }, [streaming]);\n\n return (\n <Timeline\n title={title || 'Following'}\n id={id || 'following'}\n emptyText=\"Nothing to see here.\"\n errorText=\"Unable to load posts.\"\n instance={instance}\n fetchItems={fetchHome}\n checkForUpdates={checkForUpdates}\n useItemID\n boostsCarousel={snapStates.settings.boostsCarousel}\n {...props}\n // allowFilters\n filterContext=\"home\"\n showFollowedTags\n />\n );\n}\n\nexport default Following;\n","import {\n FocusableItem,\n MenuDivider,\n MenuGroup,\n MenuHeader,\n MenuItem,\n} from '@szhsin/react-menu';\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { useNavigate, useParams, useSearchParams } from 'react-router-dom';\n\nimport Icon from '../components/icon';\nimport Menu2 from '../components/menu2';\nimport MenuConfirm from '../components/menu-confirm';\nimport { SHORTCUTS_LIMIT } from '../components/shortcuts-settings';\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport { filteredItems } from '../utils/filters';\nimport showToast from '../utils/show-toast';\nimport states from '../utils/states';\nimport { saveStatus } from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\n// Limit is 4 per \"mode\"\n// https://github.com/mastodon/mastodon/issues/15194\n// Hard-coded https://github.com/mastodon/mastodon/blob/19614ba2477f3d12468f5ec251ce1cc5f8c6210c/app/models/tag_feed.rb#L4\nconst TAGS_LIMIT_PER_MODE = 4;\nconst TOTAL_TAGS_LIMIT = TAGS_LIMIT_PER_MODE + 1;\n\nfunction Hashtags({ media: mediaView, columnMode, ...props }) {\n // const navigate = useNavigate();\n let { hashtag, ...params } = columnMode ? {} : useParams();\n if (props.hashtag) hashtag = props.hashtag;\n let hashtags = hashtag.trim().split(/[\\s+]+/);\n hashtags.sort();\n hashtag = hashtags[0];\n const [searchParams, setSearchParams] = useSearchParams();\n const media = mediaView || !!searchParams.get('media');\n const linkParams = media ? '?media=1' : '';\n\n const { masto, instance, authenticated } = api({\n instance: props?.instance || params.instance,\n });\n const {\n masto: currentMasto,\n instance: currentInstance,\n authenticated: currentAuthenticated,\n } = api();\n const hashtagTitle = hashtags.map((t) => `#${t}`).join(' ');\n const hashtagPostTitle = media ? ` (Media only)` : '';\n const title = instance\n ? `${hashtagTitle}${hashtagPostTitle} on ${instance}`\n : `${hashtagTitle}${hashtagPostTitle}`;\n useTitle(title, `/:instance?/t/:hashtag`);\n const latestItem = useRef();\n\n // const hashtagsIterator = useRef();\n const maxID = useRef(undefined);\n async function fetchHashtags(firstLoad) {\n // if (firstLoad || !hashtagsIterator.current) {\n // hashtagsIterator.current = masto.v1.timelines.tag.$select(hashtag).list({\n // limit: LIMIT,\n // any: hashtags.slice(1),\n // });\n // }\n // const results = await hashtagsIterator.current.next();\n\n // NOTE: Temporary fix for listHashtag not persisting `any` in subsequent calls.\n const results = await masto.v1.timelines.tag\n .$select(hashtag)\n .list({\n limit: LIMIT,\n any: hashtags.slice(1),\n maxId: firstLoad ? undefined : maxID.current,\n onlyMedia: media,\n })\n .next();\n let { value } = results;\n if (value?.length) {\n if (firstLoad) {\n latestItem.current = value[0].id;\n }\n\n // value = filteredItems(value, 'public');\n value.forEach((item) => {\n saveStatus(item, instance, {\n skipThreading: media, // If media view, no need to form threads\n });\n });\n\n maxID.current = value[value.length - 1].id;\n }\n return {\n ...results,\n value,\n };\n }\n\n async function checkForUpdates() {\n try {\n const results = await masto.v1.timelines.tag\n .$select(hashtag)\n .list({\n limit: 1,\n any: hashtags.slice(1),\n since_id: latestItem.current,\n onlyMedia: media,\n })\n .next();\n let { value } = results;\n value = filteredItems(value, 'public');\n if (value?.length) {\n return true;\n }\n return false;\n } catch (e) {\n return false;\n }\n }\n\n const [followUIState, setFollowUIState] = useState('default');\n const [info, setInfo] = useState();\n // Get hashtag info\n useEffect(() => {\n (async () => {\n try {\n const info = await masto.v1.tags.$select(hashtag).fetch();\n console.log(info);\n setInfo(info);\n } catch (e) {\n console.error(e);\n }\n })();\n }, [hashtag]);\n\n const reachLimit = hashtags.length >= TOTAL_TAGS_LIMIT;\n\n return (\n <Timeline\n key={instance + hashtagTitle}\n title={title}\n titleComponent={\n !!instance && (\n <h1 class=\"header-double-lines\">\n <b>{hashtagTitle}</b>\n <div>{instance}</div>\n </h1>\n )\n }\n id=\"hashtag\"\n instance={instance}\n emptyText=\"No one has posted anything with this tag yet.\"\n errorText=\"Unable to load posts with this tag\"\n fetchItems={fetchHashtags}\n checkForUpdates={checkForUpdates}\n useItemID\n view={media ? 'media' : undefined}\n refresh={media}\n // allowFilters\n filterContext=\"public\"\n headerEnd={\n <Menu2\n portal\n setDownOverflow\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n menuButton={\n <button type=\"button\" class=\"plain\">\n <Icon icon=\"more\" size=\"l\" />\n </button>\n }\n >\n {!!info && hashtags.length === 1 && (\n <>\n <MenuConfirm\n subMenu\n confirm={info.following}\n confirmLabel={`Unfollow #${hashtag}?`}\n disabled={followUIState === 'loading' || !authenticated}\n onClick={() => {\n setFollowUIState('loading');\n if (info.following) {\n // const yes = confirm(`Unfollow #${hashtag}?`);\n // if (!yes) {\n // setFollowUIState('default');\n // return;\n // }\n masto.v1.tags\n .$select(hashtag)\n .unfollow()\n .then(() => {\n setInfo({ ...info, following: false });\n showToast(`Unfollowed #${hashtag}`);\n })\n .catch((e) => {\n alert(e);\n console.error(e);\n })\n .finally(() => {\n setFollowUIState('default');\n });\n } else {\n masto.v1.tags\n .$select(hashtag)\n .follow()\n .then(() => {\n setInfo({ ...info, following: true });\n showToast(`Followed #${hashtag}`);\n })\n .catch((e) => {\n alert(e);\n console.error(e);\n })\n .finally(() => {\n setFollowUIState('default');\n });\n }\n }}\n >\n {info.following ? (\n <>\n <Icon icon=\"check-circle\" /> <span>Following…</span>\n </>\n ) : (\n <>\n <Icon icon=\"plus\" /> <span>Follow</span>\n </>\n )}\n </MenuConfirm>\n <MenuDivider />\n </>\n )}\n <MenuHeader className=\"plain\">Filters</MenuHeader>\n <MenuItem\n type=\"checkbox\"\n checked={!!media}\n onClick={() => {\n if (media) {\n searchParams.delete('media');\n } else {\n searchParams.set('media', '1');\n }\n setSearchParams(searchParams);\n }}\n >\n <Icon icon=\"check-circle\" />{' '}\n <span class=\"menu-grow\">Media only</span>\n </MenuItem>\n <MenuDivider />\n <FocusableItem className=\"menu-field\" disabled={reachLimit}>\n {({ ref }) => (\n <form\n onSubmit={(e) => {\n e.preventDefault();\n const newHashtag = e.target[0].value?.trim?.();\n // Use includes but need to be case insensitive\n if (\n newHashtag &&\n !hashtags.some(\n (t) => t.toLowerCase() === newHashtag.toLowerCase(),\n )\n ) {\n hashtags.push(newHashtag);\n hashtags.sort();\n // navigate(\n // instance\n // ? `/${instance}/t/${hashtags.join('+')}`\n // : `/t/${hashtags.join('+')}`,\n // );\n location.hash = instance\n ? `/${instance}/t/${hashtags.join('+')}`\n : `/t/${hashtags.join('+')}${linkParams}`;\n }\n }}\n >\n <Icon icon=\"hashtag\" />\n <input\n ref={ref}\n type=\"text\"\n placeholder={\n reachLimit ? `Max ${TOTAL_TAGS_LIMIT} tags` : 'Add hashtag'\n }\n required\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck={false}\n // no spaces, no hashtags\n pattern=\"[^#][^\\s#]+[^#]\"\n disabled={reachLimit}\n />\n </form>\n )}\n </FocusableItem>\n <MenuGroup takeOverflow>\n {hashtags.map((t, i) => (\n <MenuItem\n key={t}\n disabled={hashtags.length === 1}\n onClick={(e) => {\n hashtags.splice(i, 1);\n hashtags.sort();\n // navigate(\n // instance\n // ? `/${instance}/t/${hashtags.join('+')}`\n // : `/t/${hashtags.join('+')}`,\n // );\n location.hash = instance\n ? `/${instance}/t/${hashtags.join('+')}${linkParams}`\n : `/t/${hashtags.join('+')}${linkParams}`;\n }}\n >\n <Icon icon=\"x\" alt=\"Remove hashtag\" class=\"danger-icon\" />\n <span>\n <span class=\"more-insignificant\">#</span>\n {t}\n </span>\n </MenuItem>\n ))}\n </MenuGroup>\n <MenuDivider />\n <MenuItem\n disabled={!currentAuthenticated}\n onClick={() => {\n if (states.shortcuts.length >= SHORTCUTS_LIMIT) {\n alert(\n `Max ${SHORTCUTS_LIMIT} shortcuts reached. Unable to add shortcut.`,\n );\n return;\n }\n const shortcut = {\n type: 'hashtag',\n hashtag: hashtags.join(' '),\n instance,\n media: media ? 'on' : undefined,\n };\n // Check if already exists\n const exists = states.shortcuts.some(\n (s) =>\n s.type === shortcut.type &&\n s.hashtag\n .split(/[\\s+]+/)\n .sort()\n .join(' ') ===\n shortcut.hashtag\n .split(/[\\s+]+/)\n .sort()\n .join(' ') &&\n (s.instance ? s.instance === shortcut.instance : true) &&\n (s.media ? !!s.media === !!shortcut.media : true),\n );\n if (exists) {\n alert('This shortcut already exists');\n } else {\n states.shortcuts.push(shortcut);\n showToast(`Hashtag shortcut added`);\n }\n }}\n >\n <Icon icon=\"shortcut\" /> <span>Add to Shorcuts</span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n let newInstance = prompt(\n 'Enter a new instance e.g. \"mastodon.social\"',\n );\n if (!/\\./.test(newInstance)) {\n if (newInstance) alert('Invalid instance');\n return;\n }\n if (newInstance) {\n newInstance = newInstance.toLowerCase().trim();\n // navigate(`/${newInstance}/t/${hashtags.join('+')}`);\n location.hash = `/${newInstance}/t/${hashtags.join(\n '+',\n )}${linkParams}`;\n }\n }}\n >\n <Icon icon=\"bus\" /> <span>Go to another instance…</span>\n </MenuItem>\n {currentInstance !== instance && (\n <MenuItem\n onClick={() => {\n location.hash = `/${currentInstance}/t/${hashtags.join(\n '+',\n )}${linkParams}`;\n }}\n >\n <Icon icon=\"bus\" />{' '}\n <small class=\"menu-double-lines\">\n Go to my instance (<b>{currentInstance}</b>)\n </small>\n </MenuItem>\n )}\n </Menu2>\n }\n />\n );\n}\n\nexport default Hashtags;\n","import './lists.css';\n\nimport { Menu, MenuItem } from '@szhsin/react-menu';\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { InView } from 'react-intersection-observer';\nimport { useNavigate, useParams } from 'react-router-dom';\nimport { useSnapshot } from 'valtio';\n\nimport AccountBlock from '../components/account-block';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport ListAddEdit from '../components/list-add-edit';\nimport Menu2 from '../components/menu2';\nimport MenuConfirm from '../components/menu-confirm';\nimport Modal from '../components/modal';\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport { filteredItems } from '../utils/filters';\nimport states, { saveStatus } from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\nfunction List(props) {\n const snapStates = useSnapshot(states);\n const { masto, instance } = api();\n const id = props?.id || useParams()?.id;\n // const navigate = useNavigate();\n const latestItem = useRef();\n // const [reloadCount, reload] = useReducer((c) => c + 1, 0);\n\n const listIterator = useRef();\n async function fetchList(firstLoad) {\n if (firstLoad || !listIterator.current) {\n listIterator.current = masto.v1.timelines.list.$select(id).list({\n limit: LIMIT,\n });\n }\n const results = await listIterator.current.next();\n let { value } = results;\n if (value?.length) {\n if (firstLoad) {\n latestItem.current = value[0].id;\n }\n\n // value = filteredItems(value, 'home');\n value.forEach((item) => {\n saveStatus(item, instance);\n });\n }\n return {\n ...results,\n value,\n };\n }\n\n async function checkForUpdates() {\n try {\n const results = await masto.v1.timelines.list.$select(id).list({\n limit: 1,\n since_id: latestItem.current,\n });\n let { value } = results;\n value = filteredItems(value, 'home');\n if (value?.length) {\n return true;\n }\n return false;\n } catch (e) {\n return false;\n }\n }\n\n const [list, setList] = useState({ title: 'List' });\n // const [title, setTitle] = useState(`List`);\n useTitle(list.title, `/l/:id`);\n useEffect(() => {\n (async () => {\n try {\n const list = await masto.v1.lists.$select(id).fetch();\n setList(list);\n // setTitle(list.title);\n } catch (e) {\n console.error(e);\n }\n })();\n }, [id]);\n\n const [showListAddEditModal, setShowListAddEditModal] = useState(false);\n const [showManageMembersModal, setShowManageMembersModal] = useState(false);\n\n return (\n <>\n <Timeline\n key={id}\n title={list.title}\n id=\"list\"\n emptyText=\"Nothing yet.\"\n errorText=\"Unable to load posts.\"\n instance={instance}\n fetchItems={fetchList}\n checkForUpdates={checkForUpdates}\n useItemID\n boostsCarousel={snapStates.settings.boostsCarousel}\n // allowFilters\n filterContext=\"home\"\n // refresh={reloadCount}\n headerStart={\n <Link to=\"/l\" class=\"button plain\">\n <Icon icon=\"list\" size=\"l\" />\n </Link>\n }\n headerEnd={\n <Menu2\n portal\n setDownOverflow\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n menuButton={\n <button type=\"button\" class=\"plain\">\n <Icon icon=\"more\" size=\"l\" />\n </button>\n }\n >\n <MenuItem\n onClick={() =>\n setShowListAddEditModal({\n list,\n })\n }\n >\n <Icon icon=\"pencil\" size=\"l\" />\n <span>Edit</span>\n </MenuItem>\n <MenuItem onClick={() => setShowManageMembersModal(true)}>\n <Icon icon=\"group\" size=\"l\" />\n <span>Manage members</span>\n </MenuItem>\n </Menu2>\n }\n />\n {showListAddEditModal && (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n setShowListAddEditModal(false);\n }\n }}\n >\n <ListAddEdit\n list={showListAddEditModal?.list}\n onClose={(result) => {\n if (result.state === 'success' && result.list) {\n setList(result.list);\n // reload();\n } else if (result.state === 'deleted') {\n // navigate('/l');\n location.hash = '/l';\n }\n setShowListAddEditModal(false);\n }}\n />\n </Modal>\n )}\n {showManageMembersModal && (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n setShowManageMembersModal(false);\n }\n }}\n >\n <ListManageMembers\n listID={id}\n onClose={() => setShowManageMembersModal(false)}\n />\n </Modal>\n )}\n </>\n );\n}\n\nconst MEMBERS_LIMIT = 40;\nfunction ListManageMembers({ listID, onClose }) {\n // Show list of members with [Remove] button\n // API only returns 40 members at a time, so this need to be paginated with infinite scroll\n // Show [Add] button after removing a member\n const { masto, instance } = api();\n const [members, setMembers] = useState([]);\n const [uiState, setUIState] = useState('default');\n const [showMore, setShowMore] = useState(false);\n\n const membersIterator = useRef();\n\n async function fetchMembers(firstLoad) {\n setShowMore(false);\n setUIState('loading');\n (async () => {\n try {\n if (firstLoad || !membersIterator.current) {\n membersIterator.current = masto.v1.lists\n .$select(listID)\n .accounts.list({\n limit: MEMBERS_LIMIT,\n });\n }\n const results = await membersIterator.current.next();\n let { done, value } = results;\n if (value?.length) {\n if (firstLoad) {\n setMembers(value);\n } else {\n setMembers(members.concat(value));\n }\n setShowMore(!done);\n } else {\n setShowMore(false);\n }\n setUIState('default');\n } catch (e) {\n setUIState('error');\n }\n })();\n }\n\n useEffect(() => {\n fetchMembers(true);\n }, []);\n\n return (\n <div class=\"sheet\" id=\"list-manage-members-container\">\n {!!onClose && (\n <button type=\"button\" class=\"sheet-close\" onClick={onClose}>\n <Icon icon=\"x\" />\n </button>\n )}\n <header>\n <h2>Manage members</h2>\n </header>\n <main>\n <ul>\n {members.map((member) => (\n <li key={member.id}>\n <AccountBlock account={member} instance={instance} />\n <RemoveAddButton account={member} listID={listID} />\n </li>\n ))}\n {showMore && uiState === 'default' && (\n <InView as=\"li\" onChange={(inView) => inView && fetchMembers()}>\n <button type=\"button\" class=\"light block\" onClick={fetchMembers}>\n Show more…\n </button>\n </InView>\n )}\n </ul>\n </main>\n </div>\n );\n}\n\nfunction RemoveAddButton({ account, listID }) {\n const { masto } = api();\n const [uiState, setUIState] = useState('default');\n const [removed, setRemoved] = useState(false);\n\n return (\n <MenuConfirm\n confirm={!removed}\n confirmLabel={<span>Remove @{account.username} from list?</span>}\n align=\"end\"\n menuItemClassName=\"danger\"\n onClick={() => {\n if (removed) {\n setUIState('loading');\n (async () => {\n try {\n await masto.v1.lists.$select(listID).accounts.create({\n accountIds: [account.id],\n });\n setUIState('default');\n setRemoved(false);\n } catch (e) {\n setUIState('error');\n }\n })();\n } else {\n // const yes = confirm(`Remove ${account.username} from this list?`);\n // if (!yes) return;\n setUIState('loading');\n\n (async () => {\n try {\n await masto.v1.lists.$select(listID).accounts.remove({\n accountIds: [account.id],\n });\n setUIState('default');\n setRemoved(true);\n } catch (e) {\n setUIState('error');\n }\n })();\n }\n }}\n >\n <button\n type=\"button\"\n class={`light ${removed ? '' : 'danger'}`}\n disabled={uiState === 'loading'}\n >\n {removed ? 'Add' : 'Remove…'}\n </button>\n </MenuConfirm>\n );\n}\n\nexport default List;\n","import { useMemo, useRef, useState } from 'preact/hooks';\nimport { useSearchParams } from 'react-router-dom';\n\nimport Link from '../components/link';\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport { saveStatus } from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\nconst emptySearchParams = new URLSearchParams();\n\nfunction Mentions({ columnMode, ...props }) {\n const { masto, instance } = api();\n const [searchParams] = columnMode ? [emptySearchParams] : useSearchParams();\n const [stateType, setStateType] = useState(null);\n const type = props?.type || searchParams.get('type') || stateType;\n useTitle(`Mentions${type === 'private' ? ' (Private)' : ''}`, '/mentions');\n\n const mentionsIterator = useRef();\n const latestItem = useRef();\n\n async function fetchMentions(firstLoad) {\n if (firstLoad || !mentionsIterator.current) {\n mentionsIterator.current = masto.v1.notifications.list({\n limit: LIMIT,\n types: ['mention'],\n });\n }\n const results = await mentionsIterator.current.next();\n let { value } = results;\n if (value?.length) {\n if (firstLoad) {\n latestItem.current = value[0].id;\n console.log('First load', latestItem.current);\n }\n\n value.forEach(({ status: item }) => {\n saveStatus(item, instance);\n });\n }\n return {\n ...results,\n value: value?.map((item) => item.status),\n };\n }\n\n const conversationsIterator = useRef();\n const latestConversationItem = useRef();\n async function fetchConversations(firstLoad) {\n if (firstLoad || !conversationsIterator.current) {\n conversationsIterator.current = masto.v1.conversations.list({\n limit: LIMIT,\n });\n }\n const results = await conversationsIterator.current.next();\n let { value } = results;\n value = value?.filter((item) => item.lastStatus);\n if (value?.length) {\n if (firstLoad) {\n latestConversationItem.current = value[0].lastStatus.id;\n console.log('First load', latestConversationItem.current);\n }\n\n value.forEach(({ lastStatus: item }) => {\n saveStatus(item, instance);\n });\n }\n console.log('results', results);\n return {\n ...results,\n value: value?.map((item) => item.lastStatus),\n };\n }\n\n function fetchItems(...args) {\n if (type === 'private') {\n return fetchConversations(...args);\n }\n return fetchMentions(...args);\n }\n\n async function checkForUpdates() {\n if (type === 'private') {\n try {\n const results = await masto.v1.conversations\n .list({\n limit: 1,\n since_id: latestConversationItem.current,\n })\n .next();\n let { value } = results;\n console.log(\n 'checkForUpdates PRIVATE',\n latestConversationItem.current,\n value,\n );\n if (value?.length) {\n latestConversationItem.current = value[0].lastStatus.id;\n return true;\n }\n return false;\n } catch (e) {\n return false;\n }\n } else {\n try {\n const results = await masto.v1.notifications\n .list({\n limit: 1,\n types: ['mention'],\n since_id: latestItem.current,\n })\n .next();\n let { value } = results;\n console.log('checkForUpdates ALL', latestItem.current, value);\n if (value?.length) {\n latestItem.current = value[0].id;\n return true;\n }\n return false;\n } catch (e) {\n return false;\n }\n }\n }\n\n const TimelineStart = useMemo(() => {\n return (\n <div class=\"filter-bar centered\">\n <Link\n to=\"/mentions\"\n class={!type ? 'is-active' : ''}\n onClick={(e) => {\n if (columnMode) {\n e.preventDefault();\n setStateType(null);\n }\n }}\n >\n All\n </Link>\n <Link\n to=\"/mentions?type=private\"\n class={type === 'private' ? 'is-active' : ''}\n onClick={(e) => {\n if (columnMode) {\n e.preventDefault();\n setStateType('private');\n }\n }}\n >\n Private\n </Link>\n </div>\n );\n }, [type]);\n\n return (\n <Timeline\n title=\"Mentions\"\n id=\"mentions\"\n emptyText=\"No one mentioned you :(\"\n errorText=\"Unable to load mentions.\"\n instance={instance}\n fetchItems={fetchItems}\n checkForUpdates={checkForUpdates}\n useItemID\n timelineStart={TimelineStart}\n refresh={type}\n />\n );\n}\n\nexport default Mentions;\n","// This is like very lame \"type-checking\" lol\nconst notificationTypeKeys = {\n mention: ['account', 'status'],\n status: ['account', 'status'],\n reblog: ['account', 'status'],\n follow: ['account'],\n follow_request: ['account'],\n favourite: ['account', 'status'],\n poll: ['status'],\n update: ['status'],\n};\nfunction fixNotifications(notifications) {\n return notifications.filter((notification) => {\n const { type, id, createdAt } = notification;\n if (!type) {\n console.warn('Notification missing type', notification);\n return false;\n }\n if (!id || !createdAt) {\n console.warn('Notification missing id or createdAt', notification);\n // Continue processing this despite missing id or createdAt\n }\n const keys = notificationTypeKeys[type];\n if (keys?.length) {\n return keys.every((key) => !!notification[key]);\n }\n return true; // skip other types\n });\n}\n\nfunction groupNotifications(notifications) {\n // Filter out invalid notifications\n notifications = fixNotifications(notifications);\n\n // Create new flat list of notifications\n // Combine sibling notifications based on type and status id\n // Concat all notification.account into an array of _accounts\n const notificationsMap = {};\n const cleanNotifications = [];\n for (let i = 0, j = 0; i < notifications.length; i++) {\n const notification = notifications[i];\n const { id, status, account, type, createdAt } = notification;\n const date = createdAt ? new Date(createdAt).toLocaleDateString() : '';\n let virtualType = type;\n if (type === 'favourite' || type === 'reblog') {\n virtualType = 'favourite+reblog';\n }\n const key = `${status?.id}-${virtualType}-${date}`;\n const mappedNotification = notificationsMap[key];\n if (virtualType === 'follow_request') {\n cleanNotifications[j++] = notification;\n } else if (mappedNotification?.account) {\n const mappedAccount = mappedNotification._accounts.find(\n (a) => a.id === account.id,\n );\n if (mappedAccount) {\n mappedAccount._types.push(type);\n mappedAccount._types.sort().reverse();\n mappedNotification.id += `-${id}`;\n } else {\n account._types = [type];\n mappedNotification._accounts.push(account);\n mappedNotification.id += `-${id}`;\n }\n } else {\n account._types = [type];\n let n = (notificationsMap[key] = {\n ...notification,\n type: virtualType,\n _accounts: [account],\n });\n cleanNotifications[j++] = n;\n }\n }\n\n // 2nd pass to group \"favourite+reblog\"-type notifications by account if _accounts.length <= 1\n // This means one acount has favourited and reblogged the multiple statuses\n // The grouped notification\n // - type: \"favourite+reblog+account\"\n // - _statuses: [status, status, ...]\n const notificationsMap2 = {};\n const cleanNotifications2 = [];\n for (let i = 0, j = 0; i < cleanNotifications.length; i++) {\n const notification = cleanNotifications[i];\n const { id, account, _accounts, type, createdAt } = notification;\n const date = createdAt ? new Date(createdAt).toLocaleDateString() : '';\n if (type === 'favourite+reblog' && account && _accounts.length === 1) {\n const key = `${account?.id}-${type}-${date}`;\n const mappedNotification = notificationsMap2[key];\n if (mappedNotification) {\n mappedNotification._statuses.push(notification.status);\n mappedNotification.id += `-${id}`;\n } else {\n let n = (notificationsMap2[key] = {\n ...notification,\n type,\n _statuses: [notification.status],\n });\n cleanNotifications2[j++] = n;\n }\n } else {\n cleanNotifications2[j++] = notification;\n }\n }\n\n console.log({ notifications, cleanNotifications, cleanNotifications2 });\n\n // return cleanNotifications;\n return cleanNotifications2;\n}\n\nexport default groupNotifications;\n","import './notifications.css';\n\nimport { Fragment } from 'preact';\nimport { memo } from 'preact/compat';\nimport { useCallback, useEffect, useRef, useState } from 'preact/hooks';\nimport { InView } from 'react-intersection-observer';\nimport { useSearchParams } from 'react-router-dom';\nimport { useSnapshot } from 'valtio';\nimport { subscribeKey } from 'valtio/utils';\n\nimport AccountBlock from '../components/account-block';\nimport FollowRequestButtons from '../components/follow-request-buttons';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport NavMenu from '../components/nav-menu';\nimport Notification from '../components/notification';\nimport { api } from '../utils/api';\nimport enhanceContent from '../utils/enhance-content';\nimport groupNotifications from '../utils/group-notifications';\nimport handleContentLinks from '../utils/handle-content-links';\nimport niceDateTime from '../utils/nice-date-time';\nimport { getRegistration } from '../utils/push-notifications';\nimport shortenNumber from '../utils/shorten-number';\nimport states, { saveStatus } from '../utils/states';\nimport { getCurrentInstance } from '../utils/store-utils';\nimport usePageVisibility from '../utils/usePageVisibility';\nimport useScroll from '../utils/useScroll';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 30; // 30 is the maximum limit :(\nconst emptySearchParams = new URLSearchParams();\n\nfunction Notifications({ columnMode }) {\n useTitle('Notifications', '/notifications');\n const { masto, instance } = api();\n const snapStates = useSnapshot(states);\n const [uiState, setUIState] = useState('default');\n const [searchParams] = columnMode ? [emptySearchParams] : useSearchParams();\n const notificationID = searchParams.get('id');\n const notificationAccessToken = searchParams.get('access_token');\n const [showMore, setShowMore] = useState(false);\n const [onlyMentions, setOnlyMentions] = useState(false);\n const scrollableRef = useRef();\n const { nearReachEnd, scrollDirection, reachStart, nearReachStart } =\n useScroll({\n scrollableRef,\n });\n const hiddenUI = scrollDirection === 'end' && !nearReachStart;\n const [followRequests, setFollowRequests] = useState([]);\n const [announcements, setAnnouncements] = useState([]);\n\n console.debug('RENDER Notifications');\n\n const notificationsIterator = useRef();\n async function fetchNotifications(firstLoad) {\n if (firstLoad || !notificationsIterator.current) {\n // Reset iterator\n notificationsIterator.current = masto.v1.notifications.list({\n limit: LIMIT,\n excludeTypes: ['follow_request'],\n });\n }\n const allNotifications = await notificationsIterator.current.next();\n const notifications = allNotifications.value;\n\n if (notifications?.length) {\n notifications.forEach((notification) => {\n saveStatus(notification.status, instance, {\n skipThreading: true,\n });\n });\n\n const groupedNotifications = groupNotifications(notifications);\n\n if (firstLoad) {\n states.notificationsLast = notifications[0];\n states.notifications = groupedNotifications;\n\n // Update last read marker\n masto.v1.markers\n .create({\n notifications: {\n lastReadId: notifications[0].id,\n },\n })\n .catch(() => {});\n } else {\n states.notifications.push(...groupedNotifications);\n }\n }\n\n states.notificationsShowNew = false;\n states.notificationsLastFetchTime = Date.now();\n return allNotifications;\n }\n\n async function fetchFollowRequests() {\n // Note: no pagination here yet because this better be on a separate page. Should be rare use-case???\n try {\n return await masto.v1.followRequests.list({\n limit: 80,\n });\n } catch (e) {\n // Silently fail\n return [];\n }\n }\n\n const loadFollowRequests = () => {\n setUIState('loading');\n (async () => {\n try {\n const requests = await fetchFollowRequests();\n setFollowRequests(requests);\n setUIState('default');\n } catch (e) {\n setUIState('error');\n }\n })();\n };\n\n async function fetchAnnouncements() {\n try {\n return await masto.v1.announcements.list();\n } catch (e) {\n // Silently fail\n return [];\n }\n }\n\n const loadNotifications = (firstLoad) => {\n setShowNew(false);\n setUIState('loading');\n (async () => {\n try {\n const fetchNotificationsPromise = fetchNotifications(firstLoad);\n\n if (firstLoad) {\n fetchAnnouncements()\n .then((announcements) => {\n announcements.sort((a, b) => {\n // Sort by updatedAt first, then createdAt\n const aDate = new Date(a.updatedAt || a.createdAt);\n const bDate = new Date(b.updatedAt || b.createdAt);\n return bDate - aDate;\n });\n setAnnouncements(announcements);\n })\n .catch(() => {});\n\n fetchFollowRequests()\n .then((requests) => {\n setFollowRequests(requests);\n })\n .catch(() => {});\n }\n\n const { done } = await fetchNotificationsPromise;\n setShowMore(!done);\n\n setUIState('default');\n } catch (e) {\n setUIState('error');\n }\n })();\n };\n\n useEffect(() => {\n loadNotifications(true);\n }, []);\n useEffect(() => {\n if (reachStart) {\n loadNotifications(true);\n }\n }, [reachStart]);\n\n // useEffect(() => {\n // if (nearReachEnd && showMore) {\n // loadNotifications();\n // }\n // }, [nearReachEnd, showMore]);\n\n const [showNew, setShowNew] = useState(false);\n\n const loadUpdates = useCallback(\n ({ disableIdleCheck = false } = {}) => {\n if (uiState === 'loading') {\n return;\n }\n console.log('✨ Load updates', {\n autoRefresh: snapStates.settings.autoRefresh,\n scrollTop: scrollableRef.current?.scrollTop,\n inBackground: inBackground(),\n disableIdleCheck,\n });\n if (\n snapStates.settings.autoRefresh &&\n scrollableRef.current?.scrollTop < 16 &&\n (disableIdleCheck || window.__IDLE__) &&\n !inBackground()\n ) {\n loadNotifications(true);\n }\n },\n [snapStates.notificationsShowNew, snapStates.settings.autoRefresh, uiState],\n );\n // useEffect(loadUpdates, [snapStates.notificationsShowNew]);\n\n const lastHiddenTime = useRef();\n usePageVisibility((visible) => {\n let unsub;\n if (visible) {\n const timeDiff = Date.now() - lastHiddenTime.current;\n if (!lastHiddenTime.current || timeDiff > 1000 * 3) {\n // 3 seconds\n loadUpdates({\n disableIdleCheck: true,\n });\n } else {\n lastHiddenTime.current = Date.now();\n }\n unsub = subscribeKey(states, 'notificationsShowNew', (v) => {\n if (v) {\n loadUpdates();\n }\n setShowNew(v);\n });\n }\n return () => {\n unsub?.();\n };\n });\n\n const todayDate = new Date();\n const yesterdayDate = new Date(todayDate - 24 * 60 * 60 * 1000);\n let currentDay = new Date();\n const showTodayEmpty = !snapStates.notifications.some(\n (notification) =>\n new Date(notification.createdAt).toDateString() ===\n todayDate.toDateString(),\n );\n\n const announcementsListRef = useRef();\n\n useEffect(() => {\n if (notificationID) {\n states.routeNotification = {\n id: notificationID,\n accessToken: atob(notificationAccessToken),\n };\n }\n }, [notificationID, notificationAccessToken]);\n\n // useEffect(() => {\n // if (uiState === 'default') {\n // (async () => {\n // try {\n // const registration = await getRegistration();\n // if (registration?.getNotifications) {\n // const notifications = await registration.getNotifications();\n // console.log('🔔 Push notifications', notifications);\n // // Close all notifications?\n // // notifications.forEach((notification) => {\n // // notification.close();\n // // });\n // }\n // } catch (e) {}\n // })();\n // }\n // }, [uiState]);\n\n return (\n <div\n id=\"notifications-page\"\n class=\"deck-container\"\n ref={scrollableRef}\n tabIndex=\"-1\"\n >\n <div class={`timeline-deck deck ${onlyMentions ? 'only-mentions' : ''}`}>\n <header\n hidden={hiddenUI}\n onClick={(e) => {\n if (!e.target.closest('a, button')) {\n scrollableRef.current?.scrollTo({ top: 0, behavior: 'smooth' });\n }\n }}\n class={uiState === 'loading' ? 'loading' : ''}\n >\n <div class=\"header-grid\">\n <div class=\"header-side\">\n <NavMenu />\n <Link to=\"/\" class=\"button plain\">\n <Icon icon=\"home\" size=\"l\" alt=\"Home\" />\n </Link>\n </div>\n <h1>Notifications</h1>\n <div class=\"header-side\">\n {/* <Loader hidden={uiState !== 'loading'} /> */}\n </div>\n </div>\n {showNew && uiState !== 'loading' && (\n <button\n class=\"updates-button shiny-pill\"\n type=\"button\"\n onClick={() => {\n loadNotifications(true);\n scrollableRef.current?.scrollTo({\n top: 0,\n behavior: 'smooth',\n });\n }}\n >\n <Icon icon=\"arrow-up\" /> New notifications\n </button>\n )}\n </header>\n {announcements.length > 0 && (\n <div class=\"shazam-container\">\n <div class=\"shazam-container-inner\">\n <details class=\"announcements\">\n <summary>\n <span>\n <Icon icon=\"announce\" class=\"announcement-icon\" size=\"l\" />{' '}\n <b>Announcement{announcements.length > 1 ? 's' : ''}</b>{' '}\n <small class=\"insignificant\">{instance}</small>\n </span>\n {announcements.length > 1 && (\n <span class=\"announcements-nav-buttons\">\n {announcements.map((announcement, index) => (\n <button\n type=\"button\"\n class=\"plain2 small\"\n onClick={() => {\n announcementsListRef.current?.children[\n index\n ].scrollIntoView({\n behavior: 'smooth',\n block: 'nearest',\n });\n }}\n >\n {index + 1}\n </button>\n ))}\n </span>\n )}\n </summary>\n <ul\n class={`announcements-list-${\n announcements.length > 1 ? 'multiple' : 'single'\n }`}\n ref={announcementsListRef}\n >\n {announcements.map((announcement) => (\n <li>\n <AnnouncementBlock announcement={announcement} />\n </li>\n ))}\n </ul>\n </details>\n </div>\n </div>\n )}\n {followRequests.length > 0 && (\n <div class=\"follow-requests\">\n <h2 class=\"timeline-header\">Follow requests</h2>\n {followRequests.length > 5 ? (\n <details>\n <summary>{followRequests.length} follow requests</summary>\n <ul>\n {followRequests.map((account) => (\n <li key={account.id}>\n <AccountBlock account={account} />\n <FollowRequestButtons\n accountID={account.id}\n onChange={() => {\n // loadFollowRequests();\n // loadNotifications(true);\n }}\n />\n </li>\n ))}\n </ul>\n </details>\n ) : (\n <ul>\n {followRequests.map((account) => (\n <li key={account.id}>\n <AccountBlock account={account} />\n <FollowRequestButtons\n accountID={account.id}\n onChange={() => {\n // loadFollowRequests();\n // loadNotifications(true);\n }}\n />\n </li>\n ))}\n </ul>\n )}\n </div>\n )}\n <div id=\"mentions-option\">\n <label>\n <input\n type=\"checkbox\"\n checked={onlyMentions}\n onChange={(e) => {\n setOnlyMentions(e.target.checked);\n }}\n />{' '}\n Only mentions\n </label>\n </div>\n <h2 class=\"timeline-header\">Today</h2>\n {showTodayEmpty && !!snapStates.notifications.length && (\n <p class=\"ui-state insignificant\">\n {uiState === 'default' ? \"You're all caught up.\" : <>…</>}\n </p>\n )}\n {snapStates.notifications.length ? (\n <>\n {snapStates.notifications\n // This is leaked from Notifications popover\n .filter((n) => n.type !== 'follow_request')\n .map((notification) => {\n if (onlyMentions && notification.type !== 'mention') {\n return null;\n }\n const notificationDay = new Date(notification.createdAt);\n const differentDay =\n notificationDay.toDateString() !== currentDay.toDateString();\n if (differentDay) {\n currentDay = notificationDay;\n }\n // if notificationDay is yesterday, show \"Yesterday\"\n // if notificationDay is before yesterday, show date\n const heading =\n notificationDay.toDateString() ===\n yesterdayDate.toDateString()\n ? 'Yesterday'\n : niceDateTime(currentDay, {\n hideTime: true,\n });\n return (\n <Fragment key={notification.id}>\n {differentDay && <h2 class=\"timeline-header\">{heading}</h2>}\n <Notification\n instance={instance}\n notification={notification}\n key={notification.id}\n />\n </Fragment>\n );\n })}\n </>\n ) : (\n <>\n {uiState === 'loading' && (\n <>\n <ul class=\"timeline flat\">\n {Array.from({ length: 5 }).map((_, i) => (\n <li class=\"notification skeleton\">\n <div class=\"notification-type\">\n <Icon icon=\"notification\" size=\"xl\" />\n </div>\n <div class=\"notification-content\">\n <p>███████████ ████</p>\n </div>\n </li>\n ))}\n </ul>\n </>\n )}\n {uiState === 'error' && (\n <p class=\"ui-state\">\n Unable to load notifications\n <br />\n <br />\n <button type=\"button\" onClick={() => loadNotifications(true)}>\n Try again\n </button>\n </p>\n )}\n </>\n )}\n {showMore && (\n <InView\n onChange={(inView) => {\n if (inView) {\n loadNotifications();\n }\n }}\n >\n <button\n type=\"button\"\n class=\"plain block\"\n disabled={uiState === 'loading'}\n onClick={() => loadNotifications()}\n style={{ marginBlockEnd: '6em' }}\n >\n {uiState === 'loading' ? (\n <Loader abrupt />\n ) : (\n <>Show more…</>\n )}\n </button>\n </InView>\n )}\n </div>\n </div>\n );\n}\n\nfunction inBackground() {\n return !!document.querySelector('.deck-backdrop, #modal-container > *');\n}\n\nfunction AnnouncementBlock({ announcement }) {\n const { instance } = api();\n const { contact } = getCurrentInstance();\n const contactAccount = contact?.account;\n const {\n id,\n content,\n startsAt,\n endsAt,\n published,\n allDay,\n publishedAt,\n updatedAt,\n read,\n mentions,\n statuses,\n tags,\n emojis,\n reactions,\n } = announcement;\n\n const publishedAtDate = new Date(publishedAt);\n const publishedDateText = niceDateTime(publishedAtDate);\n const updatedAtDate = new Date(updatedAt);\n const updatedAtText = niceDateTime(updatedAtDate);\n\n return (\n <div class=\"announcement-block\">\n <AccountBlock account={contactAccount} />\n <div\n class=\"announcement-content\"\n onClick={handleContentLinks({ mentions, instance })}\n dangerouslySetInnerHTML={{\n __html: enhanceContent(content, {\n emojis,\n }),\n }}\n />\n <p class=\"insignificant\">\n <time datetime={publishedAtDate.toISOString()}>\n {niceDateTime(publishedAtDate)}\n </time>\n {updatedAt && updatedAtText !== publishedDateText && (\n <>\n {' '}\n •{' '}\n <span class=\"ib\">\n Updated{' '}\n <time datetime={updatedAtDate.toISOString()}>\n {niceDateTime(updatedAtDate)}\n </time>\n </span>\n </>\n )}\n </p>\n <div class=\"announcement-reactions\" hidden>\n {reactions.map((reaction) => {\n const { name, count, me, staticUrl, url } = reaction;\n return (\n <button type=\"button\" class={`plain4 small ${me ? 'reacted' : ''}`}>\n {url || staticUrl ? (\n <img src={url || staticUrl} alt={name} width=\"16\" height=\"16\" />\n ) : (\n <span>{name}</span>\n )}{' '}\n <span class=\"count\">{shortenNumber(count)}</span>\n </button>\n );\n })}\n </div>\n </div>\n );\n}\n\nexport default memo(Notifications);\n","import { Menu, MenuDivider, MenuItem } from '@szhsin/react-menu';\nimport { useRef } from 'preact/hooks';\nimport { useNavigate, useParams } from 'react-router-dom';\nimport { useSnapshot } from 'valtio';\n\nimport Icon from '../components/icon';\nimport Menu2 from '../components/menu2';\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport { filteredItems } from '../utils/filters';\nimport states from '../utils/states';\nimport { saveStatus } from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\nfunction Public({ local, columnMode, ...props }) {\n const snapStates = useSnapshot(states);\n const isLocal = !!local;\n const params = columnMode ? {} : useParams();\n const { masto, instance } = api({\n instance: props?.instance || params.instance,\n });\n const { masto: currentMasto, instance: currentInstance } = api();\n const title = `${isLocal ? 'Local' : 'Federated'} timeline (${instance})`;\n useTitle(title, isLocal ? `/:instance?/p/l` : `/:instance?/p`);\n // const navigate = useNavigate();\n const latestItem = useRef();\n\n const publicIterator = useRef();\n async function fetchPublic(firstLoad) {\n if (firstLoad || !publicIterator.current) {\n publicIterator.current = masto.v1.timelines.public.list({\n limit: LIMIT,\n local: isLocal,\n });\n }\n const results = await publicIterator.current.next();\n let { value } = results;\n if (value?.length) {\n if (firstLoad) {\n latestItem.current = value[0].id;\n }\n\n // value = filteredItems(value, 'public');\n value.forEach((item) => {\n saveStatus(item, instance);\n });\n }\n return {\n ...results,\n value,\n };\n }\n\n async function checkForUpdates() {\n try {\n const results = await masto.v1.timelines.public\n .list({\n limit: 1,\n local: isLocal,\n since_id: latestItem.current,\n })\n .next();\n let { value } = results;\n value = filteredItems(value, 'public');\n if (value?.length) {\n return true;\n }\n return false;\n } catch (e) {\n return false;\n }\n }\n\n return (\n <Timeline\n key={instance + isLocal}\n title={title}\n titleComponent={\n <h1 class=\"header-double-lines\">\n <b>{isLocal ? 'Local timeline' : 'Federated timeline'}</b>\n <div>{instance}</div>\n </h1>\n }\n id=\"public\"\n instance={instance}\n emptyText=\"No one has posted anything yet.\"\n errorText=\"Unable to load posts\"\n fetchItems={fetchPublic}\n checkForUpdates={checkForUpdates}\n useItemID\n headerStart={<></>}\n boostsCarousel={snapStates.settings.boostsCarousel}\n // allowFilters\n filterContext=\"public\"\n headerEnd={\n <Menu2\n portal\n // setDownOverflow\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n menuButton={\n <button type=\"button\" class=\"plain\">\n <Icon icon=\"more\" size=\"l\" />\n </button>\n }\n >\n <MenuItem href={isLocal ? `/#/${instance}/p` : `/#/${instance}/p/l`}>\n {isLocal ? (\n <>\n <Icon icon=\"transfer\" /> <span>Switch to Federated</span>\n </>\n ) : (\n <>\n <Icon icon=\"transfer\" /> <span>Switch to Local</span>\n </>\n )}\n </MenuItem>\n <MenuDivider />\n <MenuItem\n onClick={() => {\n let newInstance = prompt(\n 'Enter a new instance e.g. \"mastodon.social\"',\n );\n if (!/\\./.test(newInstance)) {\n if (newInstance) alert('Invalid instance');\n return;\n }\n if (newInstance) {\n newInstance = newInstance.toLowerCase().trim();\n // navigate(isLocal ? `/${newInstance}/p/l` : `/${newInstance}/p`);\n location.hash = isLocal\n ? `/${newInstance}/p/l`\n : `/${newInstance}/p`;\n }\n }}\n >\n <Icon icon=\"bus\" /> <span>Go to another instance…</span>\n </MenuItem>\n {currentInstance !== instance && (\n <MenuItem\n onClick={() => {\n location.hash = isLocal\n ? `/${currentInstance}/p/l`\n : `/${currentInstance}/p`;\n }}\n >\n <Icon icon=\"bus\" />{' '}\n <small class=\"menu-double-lines\">\n Go to my instance (<b>{currentInstance}</b>)\n </small>\n </MenuItem>\n )}\n </Menu2>\n }\n />\n );\n}\n\nexport default Public;\n","import './search.css';\n\nimport { useAutoAnimate } from '@formkit/auto-animate/preact';\nimport { useEffect, useLayoutEffect, useRef, useState } from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\nimport { InView } from 'react-intersection-observer';\nimport { useParams, useSearchParams } from 'react-router-dom';\n\nimport AccountBlock from '../components/account-block';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport NavMenu from '../components/nav-menu';\nimport SearchForm from '../components/search-form';\nimport Status from '../components/status';\nimport { api } from '../utils/api';\nimport { fetchRelationships } from '../utils/relationships';\nimport shortenNumber from '../utils/shorten-number';\nimport usePageVisibility from '../utils/usePageVisibility';\nimport useScroll from '../utils/useScroll';\nimport useTitle from '../utils/useTitle';\n\nconst SHORT_LIMIT = 5;\nconst LIMIT = 40;\nconst emptySearchParams = new URLSearchParams();\n\nfunction Search({ columnMode, ...props }) {\n const params = columnMode ? {} : useParams();\n const { masto, instance, authenticated } = api({\n instance: params.instance,\n });\n const [uiState, setUIState] = useState('default');\n const [searchParams] = columnMode ? [emptySearchParams] : useSearchParams();\n const searchFormRef = useRef();\n const q = props?.query || searchParams.get('q');\n const type = columnMode\n ? 'statuses'\n : props?.type || searchParams.get('type');\n useTitle(\n q\n ? `Search: ${q}${\n type\n ? ` (${\n {\n statuses: 'Posts',\n accounts: 'Accounts',\n hashtags: 'Hashtags',\n }[type]\n })`\n : ''\n }`\n : 'Search',\n `/search`,\n );\n\n const [showMore, setShowMore] = useState(false);\n const offsetRef = useRef(0);\n useEffect(() => {\n offsetRef.current = 0;\n }, [q, type]);\n\n const scrollableRef = useRef();\n useLayoutEffect(() => {\n scrollableRef.current?.scrollTo?.(0, 0);\n }, [q, type]);\n\n const [statusResults, setStatusResults] = useState([]);\n const [accountResults, setAccountResults] = useState([]);\n const [hashtagResults, setHashtagResults] = useState([]);\n useEffect(() => {\n setStatusResults([]);\n setAccountResults([]);\n setHashtagResults([]);\n }, [q]);\n const setTypeResultsFunc = {\n statuses: setStatusResults,\n accounts: setAccountResults,\n hashtags: setHashtagResults,\n };\n\n const [relationshipsMap, setRelationshipsMap] = useState({});\n const loadRelationships = async (accounts) => {\n if (!accounts?.length) return;\n const relationships = await fetchRelationships(accounts, relationshipsMap);\n if (relationships) {\n setRelationshipsMap({\n ...relationshipsMap,\n ...relationships,\n });\n }\n };\n\n function loadResults(firstLoad) {\n if (firstLoad) {\n offsetRef.current = 0;\n }\n\n if (!firstLoad && !authenticated) {\n // Search results pagination is only available to authenticated users\n return;\n }\n\n setUIState('loading');\n if (firstLoad && !type) {\n setStatusResults(statusResults.slice(0, SHORT_LIMIT));\n setAccountResults(accountResults.slice(0, SHORT_LIMIT));\n setHashtagResults(hashtagResults.slice(0, SHORT_LIMIT));\n }\n\n (async () => {\n const params = {\n q,\n resolve: authenticated,\n limit: SHORT_LIMIT,\n };\n if (type) {\n params.limit = LIMIT;\n params.type = type;\n if (authenticated) params.offset = offsetRef.current;\n }\n\n try {\n const results = await masto.v2.search.fetch(params);\n console.log(results);\n if (type) {\n if (firstLoad) {\n setTypeResultsFunc[type](results[type]);\n const length = results[type]?.length;\n offsetRef.current = LIMIT;\n setShowMore(!!length);\n } else {\n setTypeResultsFunc[type]((prev) => [...prev, ...results[type]]);\n const length = results[type]?.length;\n offsetRef.current = offsetRef.current + LIMIT;\n setShowMore(!!length);\n }\n } else {\n setStatusResults(results.statuses || []);\n setAccountResults(results.accounts || []);\n setHashtagResults(results.hashtags || []);\n offsetRef.current = 0;\n setShowMore(false);\n }\n loadRelationships(results.accounts);\n\n setUIState('default');\n } catch (err) {\n console.error(err);\n setUIState('error');\n }\n })();\n }\n\n const { reachStart } = useScroll({\n scrollableRef,\n });\n const lastHiddenTime = useRef();\n usePageVisibility((visible) => {\n if (visible && reachStart) {\n const timeDiff = Date.now() - lastHiddenTime.current;\n if (!lastHiddenTime.current || timeDiff > 1000 * 3) {\n // 3 seconds\n loadResults(true);\n } else {\n lastHiddenTime.current = Date.now();\n }\n }\n });\n\n useEffect(() => {\n searchFormRef.current?.setValue?.(q || '');\n if (q) {\n loadResults(true);\n } else {\n searchFormRef.current?.focus?.();\n }\n }, [q, type, instance]);\n\n useHotkeys(\n '/',\n (e) => {\n searchFormRef.current?.focus?.();\n },\n {\n preventDefault: true,\n },\n );\n\n const [filterBarParent] = useAutoAnimate();\n\n return (\n <div id=\"search-page\" class=\"deck-container\" ref={scrollableRef}>\n <div class=\"timeline-deck deck\">\n <header class={uiState === 'loading' ? 'loading' : ''}>\n <div class=\"header-grid\">\n <div class=\"header-side\">\n <NavMenu />\n </div>\n <SearchForm ref={searchFormRef} />\n <div class=\"header-side\">\n <button\n type=\"button\"\n class=\"plain\"\n onClick={() => {\n loadResults(true);\n }}\n disabled={uiState === 'loading'}\n >\n <Icon icon=\"search\" size=\"l\" />\n </button>\n </div>\n </div>\n </header>\n <main>\n {!!q && !columnMode && (\n <div\n ref={filterBarParent}\n class={`filter-bar ${uiState === 'loading' ? 'loading' : ''}`}\n >\n {!!type && (\n <Link to={`/search${q ? `?q=${encodeURIComponent(q)}` : ''}`}>\n ‹ All\n </Link>\n )}\n {[\n {\n label: 'Accounts',\n type: 'accounts',\n to: `/search?q=${encodeURIComponent(q)}&type=accounts`,\n },\n {\n label: 'Hashtags',\n type: 'hashtags',\n to: `/search?q=${encodeURIComponent(q)}&type=hashtags`,\n },\n {\n label: 'Posts',\n type: 'statuses',\n to: `/search?q=${encodeURIComponent(q)}&type=statuses`,\n },\n ]\n .sort((a, b) => {\n if (a.type === type) return -1;\n if (b.type === type) return 1;\n return 0;\n })\n .map((link) => (\n <Link to={link.to} key={link.type}>\n {link.label}\n </Link>\n ))}\n </div>\n )}\n {!!q ? (\n <>\n {(!type || type === 'accounts') && (\n <>\n {type !== 'accounts' && (\n <h2 class=\"timeline-header\">Accounts</h2>\n )}\n {accountResults.length > 0 ? (\n <>\n <ul class=\"timeline flat accounts-list\">\n {accountResults.map((account) => (\n <li key={account.id}>\n <AccountBlock\n account={account}\n instance={instance}\n showStats\n relationship={relationshipsMap[account.id]}\n />\n </li>\n ))}\n </ul>\n {type !== 'accounts' && (\n <div class=\"ui-state\">\n <Link\n class=\"plain button\"\n to={`/search?q=${q}&type=accounts`}\n >\n See more accounts <Icon icon=\"arrow-right\" />\n </Link>\n </div>\n )}\n </>\n ) : (\n !type &&\n (uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : (\n <p class=\"ui-state\">No accounts found.</p>\n ))\n )}\n </>\n )}\n {(!type || type === 'hashtags') && (\n <>\n {type !== 'hashtags' && (\n <h2 class=\"timeline-header\">Hashtags</h2>\n )}\n {hashtagResults.length > 0 ? (\n <>\n <ul class=\"link-list hashtag-list\">\n {hashtagResults.map((hashtag) => {\n const { name, history } = hashtag;\n const total = history?.reduce?.(\n (acc, cur) => acc + +cur.uses,\n 0,\n );\n return (\n <li key={`${name}-${total}`}>\n <Link\n to={\n instance\n ? `/${instance}/t/${name}`\n : `/t/${name}`\n }\n >\n <Icon icon=\"hashtag\" />\n <span>{name}</span>\n {!!total && (\n <span class=\"count\">\n {shortenNumber(total)}\n </span>\n )}\n </Link>\n </li>\n );\n })}\n </ul>\n {type !== 'hashtags' && (\n <div class=\"ui-state\">\n <Link\n class=\"plain button\"\n to={`/search?q=${q}&type=hashtags`}\n >\n See more hashtags <Icon icon=\"arrow-right\" />\n </Link>\n </div>\n )}\n </>\n ) : (\n !type &&\n (uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : (\n <p class=\"ui-state\">No hashtags found.</p>\n ))\n )}\n </>\n )}\n {(!type || type === 'statuses') && (\n <>\n {type !== 'statuses' && (\n <h2 class=\"timeline-header\">Posts</h2>\n )}\n {statusResults.length > 0 ? (\n <>\n <ul class=\"timeline\">\n {statusResults.map((status) => (\n <li key={status.id}>\n <Link\n class=\"status-link\"\n to={\n instance\n ? `/${instance}/s/${status.id}`\n : `/s/${status.id}`\n }\n >\n <Status status={status} />\n </Link>\n </li>\n ))}\n </ul>\n {type !== 'statuses' && (\n <div class=\"ui-state\">\n <Link\n class=\"plain button\"\n to={`/search?q=${q}&type=statuses`}\n >\n See more posts <Icon icon=\"arrow-right\" />\n </Link>\n </div>\n )}\n </>\n ) : (\n !type &&\n (uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : (\n <p class=\"ui-state\">No posts found.</p>\n ))\n )}\n </>\n )}\n {!!type &&\n (uiState === 'default' ? (\n showMore ? (\n <InView\n onChange={(inView) => {\n if (inView) {\n loadResults();\n }\n }}\n >\n <button\n type=\"button\"\n class=\"plain block\"\n onClick={() => loadResults()}\n style={{ marginBlockEnd: '6em' }}\n >\n Show more…\n </button>\n </InView>\n ) : (\n <p class=\"ui-state insignificant\">The end.</p>\n )\n ) : (\n uiState === 'loading' && (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n )\n ))}\n </>\n ) : uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader abrupt />\n </p>\n ) : (\n <p class=\"ui-state\">\n Enter your search term or paste a URL above to get started.\n </p>\n )}\n </main>\n </div>\n </div>\n );\n}\n\nexport default Search;\n","import './trending.css';\n\nimport { MenuItem } from '@szhsin/react-menu';\nimport { getBlurHashAverageColor } from 'fast-blurhash';\nimport { useMemo, useRef, useState } from 'preact/hooks';\nimport { useNavigate, useParams } from 'react-router-dom';\nimport { useSnapshot } from 'valtio';\n\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Menu2 from '../components/menu2';\nimport RelativeTime from '../components/relative-time';\nimport Timeline from '../components/timeline';\nimport { api } from '../utils/api';\nimport { oklab2rgb, rgb2oklab } from '../utils/color-utils';\nimport { filteredItems } from '../utils/filters';\nimport pmem from '../utils/pmem';\nimport shortenNumber from '../utils/shorten-number';\nimport states from '../utils/states';\nimport { saveStatus } from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst LIMIT = 20;\n\nconst fetchLinks = pmem(\n (masto) => {\n return masto.v1.trends.links.list().next();\n },\n {\n // News last much longer\n maxAge: 10 * 60 * 1000, // 10 minutes\n },\n);\n\nfunction Trending({ columnMode, ...props }) {\n const snapStates = useSnapshot(states);\n const params = columnMode ? {} : useParams();\n const { masto, instance } = api({\n instance: props?.instance || params.instance,\n });\n const { masto: currentMasto, instance: currentInstance } = api();\n const title = `Trending (${instance})`;\n useTitle(title, `/:instance?/trending`);\n // const navigate = useNavigate();\n const latestItem = useRef();\n\n const [hashtags, setHashtags] = useState([]);\n const [links, setLinks] = useState([]);\n const trendIterator = useRef();\n async function fetchTrend(firstLoad) {\n if (firstLoad || !trendIterator.current) {\n trendIterator.current = masto.v1.trends.statuses.list({\n limit: LIMIT,\n });\n\n // Get hashtags\n try {\n const iterator = masto.v1.trends.tags.list();\n const { value: tags } = await iterator.next();\n console.log('tags', tags);\n if (tags?.length) {\n setHashtags(tags);\n }\n } catch (e) {\n console.error(e);\n }\n\n // Get links\n try {\n const { value } = await fetchLinks(masto);\n // 4 types available: link, photo, video, rich\n // Only want links for now\n const links = value?.filter?.((link) => link.type === 'link');\n console.log('links', links);\n if (links?.length) {\n setLinks(links);\n }\n } catch (e) {\n console.error(e);\n }\n }\n const results = await trendIterator.current.next();\n let { value } = results;\n if (value?.length) {\n if (firstLoad) {\n latestItem.current = value[0].id;\n }\n\n // value = filteredItems(value, 'public'); // Might not work here\n value.forEach((item) => {\n saveStatus(item, instance);\n });\n }\n return {\n ...results,\n value,\n };\n }\n\n async function checkForUpdates() {\n try {\n const results = await masto.v1.trends.statuses\n .list({\n limit: 1,\n // NOT SUPPORTED\n // since_id: latestItem.current,\n })\n .next();\n let { value } = results;\n value = filteredItems(value, 'public');\n if (value?.length && value[0].id !== latestItem.current) {\n latestItem.current = value[0].id;\n return true;\n }\n return false;\n } catch (e) {\n return false;\n }\n }\n\n const TimelineStart = useMemo(() => {\n return (\n <>\n {!!hashtags.length && (\n <div class=\"filter-bar expandable\">\n <Icon icon=\"chart\" class=\"insignificant\" size=\"l\" />\n {hashtags.map((tag, i) => {\n const { name, history } = tag;\n const total = history.reduce((acc, cur) => acc + +cur.uses, 0);\n return (\n <Link to={`/${instance}/t/${name}`} key={name}>\n <span>\n <span class=\"more-insignificant\">#</span>\n {name}\n </span>\n <span class=\"filter-count\">{shortenNumber(total)}</span>\n </Link>\n );\n })}\n </div>\n )}\n {!!links.length && (\n <div class=\"links-bar\">\n <header>\n <h3>Trending News</h3>\n </header>\n {links.map((link) => {\n const {\n authorName,\n authorUrl,\n blurhash,\n description,\n height,\n image,\n imageDescription,\n language,\n providerName,\n providerUrl,\n publishedAt,\n title,\n url,\n width,\n } = link;\n const domain = new URL(url).hostname\n .replace(/^www\\./, '')\n .replace(/\\/$/, '');\n let accentColor;\n if (blurhash) {\n const averageColor = getBlurHashAverageColor(blurhash);\n const labAverageColor = rgb2oklab(averageColor);\n accentColor = oklab2rgb([\n 0.6,\n labAverageColor[1],\n labAverageColor[2],\n ]);\n }\n\n return (\n <a\n key={url}\n href={url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n style={\n accentColor\n ? {\n '--accent-color': `rgb(${accentColor.join(',')})`,\n '--accent-alpha-color': `rgba(${accentColor.join(\n ',',\n )}, 0.4)`,\n }\n : {}\n }\n >\n <article>\n <figure>\n <img\n src={image}\n alt={imageDescription}\n width={width}\n height={height}\n loading=\"lazy\"\n />\n </figure>\n <div class=\"article-body\">\n <header>\n <div class=\"article-meta\">\n <span class=\"domain\">{domain}</span>{' '}\n {!!publishedAt && <>· </>}\n {!!publishedAt && (\n <>\n <RelativeTime\n datetime={publishedAt}\n format=\"micro\"\n />\n </>\n )}\n </div>\n {!!title && (\n <h1 class=\"title\" lang={language} dir=\"auto\">\n {title}\n </h1>\n )}\n </header>\n {!!description && (\n <p class=\"description\" lang={language} dir=\"auto\">\n {description}\n </p>\n )}\n </div>\n </article>\n </a>\n );\n })}\n </div>\n )}\n </>\n );\n }, [hashtags, links]);\n\n return (\n <Timeline\n key={instance}\n title={title}\n titleComponent={\n <h1 class=\"header-double-lines\">\n <b>Trending</b>\n <div>{instance}</div>\n </h1>\n }\n id=\"trending\"\n instance={instance}\n emptyText=\"No trending posts.\"\n errorText=\"Unable to load posts\"\n fetchItems={fetchTrend}\n checkForUpdates={checkForUpdates}\n checkForUpdatesInterval={5 * 60 * 1000} // 5 minutes\n useItemID\n headerStart={<></>}\n boostsCarousel={snapStates.settings.boostsCarousel}\n // allowFilters\n filterContext=\"public\"\n timelineStart={TimelineStart}\n headerEnd={\n <Menu2\n portal\n // setDownOverflow\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n menuButton={\n <button type=\"button\" class=\"plain\">\n <Icon icon=\"more\" size=\"l\" />\n </button>\n }\n >\n <MenuItem\n onClick={() => {\n let newInstance = prompt(\n 'Enter a new instance e.g. \"mastodon.social\"',\n );\n if (!/\\./.test(newInstance)) {\n if (newInstance) alert('Invalid instance');\n return;\n }\n if (newInstance) {\n newInstance = newInstance.toLowerCase().trim();\n // navigate(`/${newInstance}/trending`);\n location.hash = `/${newInstance}/trending`;\n }\n }}\n >\n <Icon icon=\"bus\" /> <span>Go to another instance…</span>\n </MenuItem>\n {currentInstance !== instance && (\n <MenuItem\n onClick={() => {\n location.hash = `/${currentInstance}/trending`;\n }}\n >\n <Icon icon=\"bus\" />{' '}\n <small class=\"menu-double-lines\">\n Go to my instance (<b>{currentInstance}</b>)\n </small>\n </MenuItem>\n )}\n </Menu2>\n }\n />\n );\n}\n\nexport default Trending;\n","import { useHotkeys } from 'react-hotkeys-hook';\nimport { useSnapshot } from 'valtio';\n\nimport Bookmarks from '../pages/bookmarks';\nimport Favourites from '../pages/favourites';\nimport Following from '../pages/following';\nimport Hashtag from '../pages/hashtag';\nimport List from '../pages/list';\nimport Mentions from '../pages/mentions';\nimport Notifications from '../pages/notifications';\nimport Public from '../pages/public';\nimport Search from '../pages/search';\nimport Trending from '../pages/trending';\nimport states from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nfunction Columns() {\n useTitle('Home', '/');\n const snapStates = useSnapshot(states);\n const { shortcuts } = snapStates;\n\n console.debug('RENDER Columns', shortcuts);\n\n const components = shortcuts.map((shortcut) => {\n if (!shortcut) return null;\n const { type, ...params } = shortcut;\n const Component = {\n following: Following,\n notifications: Notifications,\n list: List,\n public: Public,\n bookmarks: Bookmarks,\n favourites: Favourites,\n hashtag: Hashtag,\n mentions: Mentions,\n trending: Trending,\n search: Search,\n }[type];\n if (!Component) return null;\n // Don't show Search column with no query, for now\n if (type === 'search' && !params.query) return null;\n return (\n <Component key={type + JSON.stringify(params)} {...params} columnMode />\n );\n });\n\n useHotkeys(['1', '2', '3', '4', '5', '6', '7', '8', '9'], (e, handler) => {\n try {\n const index = parseInt(handler.keys[0], 10) - 1;\n document.querySelectorAll('#columns > *')[index].focus();\n } catch (e) {\n console.error(e);\n }\n });\n\n return (\n <div\n id=\"columns\"\n onContextMenu={(e) => {\n // If right-click on header, but not links or buttons\n if (\n e.target.closest('.deck > header') &&\n !e.target.closest('a') &&\n !e.target.closest('button')\n ) {\n e.preventDefault();\n states.showShortcutsSettings = true;\n }\n }}\n >\n {components}\n </div>\n );\n}\n\nexport default Columns;\n","import './notifications-menu.css';\n\nimport { ControlledMenu } from '@szhsin/react-menu';\nimport { memo } from 'preact/compat';\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { useSnapshot } from 'valtio';\n\nimport Columns from '../components/columns';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport Notification from '../components/notification';\nimport { api } from '../utils/api';\nimport db from '../utils/db';\nimport groupNotifications from '../utils/group-notifications';\nimport states, { saveStatus } from '../utils/states';\nimport { getCurrentAccountNS } from '../utils/store-utils';\n\nimport Following from './following';\n\nfunction Home() {\n const snapStates = useSnapshot(states);\n useEffect(() => {\n (async () => {\n const keys = await db.drafts.keys();\n if (keys.length) {\n const ns = getCurrentAccountNS();\n const ownKeys = keys.filter((key) => key.startsWith(ns));\n if (ownKeys.length) {\n states.showDrafts = true;\n }\n }\n })();\n }, []);\n\n return (\n <>\n {(snapStates.settings.shortcutsViewMode === 'multi-column' ||\n (!snapStates.settings.shortcutsViewMode &&\n snapStates.settings.shortcutsColumnsMode)) &&\n !!snapStates.shortcuts?.length ? (\n <Columns />\n ) : (\n <Following\n title=\"Home\"\n path=\"/\"\n id=\"home\"\n headerStart={false}\n headerEnd={<NotificationsLink />}\n />\n )}\n </>\n );\n}\n\nfunction NotificationsLink() {\n const snapStates = useSnapshot(states);\n const notificationLinkRef = useRef();\n const [menuState, setMenuState] = useState(undefined);\n return (\n <>\n <Link\n ref={notificationLinkRef}\n to=\"/notifications\"\n class={`button plain notifications-button ${\n snapStates.notificationsShowNew ? 'has-badge' : ''\n } ${menuState || ''}`}\n onClick={(e) => {\n e.stopPropagation();\n if (window.matchMedia('(min-width: calc(40em))').matches) {\n e.preventDefault();\n setMenuState((state) => (!state ? 'open' : undefined));\n }\n }}\n >\n <Icon icon=\"notification\" size=\"l\" alt=\"Notifications\" />\n </Link>\n <NotificationsMenu\n state={menuState}\n anchorRef={notificationLinkRef}\n onClose={() => setMenuState(undefined)}\n />\n </>\n );\n}\n\nconst NOTIFICATIONS_LIMIT = 30;\nconst NOTIFICATIONS_DISPLAY_LIMIT = 5;\nfunction NotificationsMenu({ anchorRef, state, onClose }) {\n const { masto, instance } = api();\n const snapStates = useSnapshot(states);\n const [uiState, setUIState] = useState('default');\n\n const notificationsIterator = masto.v1.notifications.list({\n limit: NOTIFICATIONS_LIMIT,\n });\n\n async function fetchNotifications() {\n const allNotifications = await notificationsIterator.next();\n const notifications = allNotifications.value;\n\n if (notifications?.length) {\n notifications.forEach((notification) => {\n saveStatus(notification.status, instance, {\n skipThreading: true,\n });\n });\n\n const groupedNotifications = groupNotifications(notifications);\n\n states.notificationsLast = notifications[0];\n states.notifications = groupedNotifications;\n\n // Update last read marker\n masto.v1.markers\n .create({\n notifications: {\n lastReadId: notifications[0].id,\n },\n })\n .catch(() => {});\n }\n\n states.notificationsShowNew = false;\n states.notificationsLastFetchTime = Date.now();\n return allNotifications;\n }\n\n const [hasFollowRequests, setHasFollowRequests] = useState(false);\n function fetchFollowRequests() {\n return masto.v1.followRequests.list({\n limit: 1,\n });\n }\n\n function loadNotifications() {\n setUIState('loading');\n (async () => {\n try {\n await fetchNotifications();\n const followRequests = await fetchFollowRequests();\n setHasFollowRequests(!!followRequests?.length);\n setUIState('default');\n } catch (e) {\n setUIState('error');\n }\n })();\n }\n\n useEffect(() => {\n if (state === 'open') loadNotifications();\n }, [state]);\n\n return (\n <ControlledMenu\n menuClassName=\"notifications-menu\"\n state={state}\n anchorRef={anchorRef}\n onClose={onClose}\n portal={{\n target: document.body,\n }}\n overflow=\"auto\"\n viewScroll=\"close\"\n position=\"anchor\"\n align=\"center\"\n boundingBoxPadding=\"8 8 8 8\"\n >\n <header>\n <h2>Notifications</h2>\n </header>\n <main>\n {snapStates.notifications.length ? (\n <>\n {snapStates.notifications\n .slice(0, NOTIFICATIONS_DISPLAY_LIMIT)\n .map((notification) => (\n <Notification\n key={notification.id}\n instance={instance}\n notification={notification}\n disableContextMenu\n />\n ))}\n </>\n ) : uiState === 'loading' ? (\n <div class=\"ui-state\">\n <Loader abrupt />\n </div>\n ) : (\n uiState === 'error' && (\n <div class=\"ui-state\">\n <p>Unable to fetch notifications.</p>\n <p>\n <button type=\"button\" onClick={loadNotifications}>\n Try again\n </button>\n </p>\n </div>\n )\n )}\n </main>\n <footer>\n <Link to=\"/mentions\" class=\"button plain\">\n <Icon icon=\"at\" /> <span>Mentions</span>\n </Link>\n <Link to=\"/notifications\" class=\"button plain2\">\n {hasFollowRequests ? (\n <>\n <span class=\"tag collapsed\">New</span>{' '}\n <span>Follow Requests</span>\n </>\n ) : (\n <b>See all</b>\n )}{' '}\n <Icon icon=\"arrow-right\" />\n </Link>\n </footer>\n </ControlledMenu>\n );\n}\n\nexport default memo(Home);\n","// export const statusRegex = /\\/@([^@\\/]+)@?([^\\/]+)?\\/([^\\/]+)\\/?$/i;\n// export const statusNoteRegex = /\\/notes\\/([^\\/]+)\\/?$/i;\n\nconst statusPostRegexes = [\n /^\\/@[^@\\/]+\\/(?:statuses|posts)\\/([^\\/]+)/i, // GoToSocial, Takahe\n /\\/notes\\/([^\\/]+)/i, // Misskey, Firefish\n /^\\/(?:notice|objects)\\/([a-z0-9-]+)/i, // Pleroma\n /\\/@[^@\\/]+@?[^\\/]+?\\/([^\\/]+)/i, // Mastodon\n];\n\nexport function getInstanceStatusObject(url) {\n // Regex /:username/:id, where username = @username or @username@domain, id = anything\n const { hostname, pathname } = new URL(url);\n // const [, username, domain, id] = pathname.match(statusRegex) || [];\n for (const regex of statusPostRegexes) {\n const [, id] = pathname.match(regex) || [];\n console.log(pathname, regex, id);\n if (id) {\n return {\n instance: hostname,\n id,\n };\n }\n }\n return null;\n}\n\nfunction getInstanceStatusURL(url) {\n const { instance, id } = getInstanceStatusObject(url);\n if (instance && id) {\n return `/${instance}/s/${id}`;\n }\n return null;\n}\n\nexport default getInstanceStatusURL;\n","import { useLayoutEffect, useState } from 'preact/hooks';\nimport { useLocation } from 'react-router-dom';\n\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport { api } from '../utils/api';\nimport getInstanceStatusURL, {\n getInstanceStatusObject,\n} from '../utils/get-instance-status-url';\n\nexport default function HttpRoute() {\n const location = useLocation();\n const url = location.pathname.replace(/^\\//, '');\n const statusObject = getInstanceStatusObject(url);\n // const statusURL = getInstanceStatusURL(url);\n const statusURL = statusObject?.instance\n ? `/${statusObject.instance}/s/${statusObject.id}`\n : null;\n const [uiState, setUIState] = useState('loading');\n\n useLayoutEffect(() => {\n setUIState('loading');\n (async () => {\n // Check if status returns 200\n try {\n const { instance, id } = statusObject;\n const { masto } = api({ instance });\n const status = await masto.v1.statuses.$select(id).fetch();\n if (status) {\n window.location.hash = statusURL + '?view=full';\n return;\n }\n } catch (e) {}\n\n // Fallback to search\n {\n const { masto: currentMasto, instance: currentInstance } = api();\n const result = await currentMasto.v2.search.fetch({\n q: url,\n type: 'statuses',\n limit: 1,\n resolve: true,\n });\n if (result.statuses.length) {\n const status = result.statuses[0];\n window.location.hash = `/${currentInstance}/s/${status.id}?view=full`;\n } else {\n // Fallback to original URL, which will probably show error\n window.location.hash = statusURL + '?view=full';\n }\n }\n })();\n }, [statusURL]);\n\n return (\n <div class=\"ui-state\" tabIndex=\"-1\">\n {uiState === 'loading' ? (\n <>\n <Loader abrupt />\n <h2>Resolving…</h2>\n <p>\n <a href={url} target=\"_blank\" rel=\"noopener noreferrer\">\n {url}\n </a>\n </p>\n </>\n ) : (\n <>\n <h2>Unable to resolve URL</h2>\n <p>\n <a href={url} target=\"_blank\" rel=\"noopener noreferrer\">\n {url}\n </a>\n </p>\n </>\n )}\n <hr />\n <p>\n <Link to=\"/\">Go home</Link>\n </p>\n </div>\n );\n}\n","import './lists.css';\n\nimport { useEffect, useReducer, useRef, useState } from 'preact/hooks';\n\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport ListAddEdit from '../components/list-add-edit';\nimport Loader from '../components/loader';\nimport Modal from '../components/modal';\nimport NavMenu from '../components/nav-menu';\nimport { api } from '../utils/api';\nimport useTitle from '../utils/useTitle';\n\nfunction Lists() {\n const { masto } = api();\n useTitle(`Lists`, `/l`);\n const [uiState, setUIState] = useState('default');\n\n const [reloadCount, reload] = useReducer((c) => c + 1, 0);\n const [lists, setLists] = useState([]);\n useEffect(() => {\n setUIState('loading');\n (async () => {\n try {\n const lists = await masto.v1.lists.list();\n lists.sort((a, b) => a.title.localeCompare(b.title));\n console.log(lists);\n setLists(lists);\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n }, [reloadCount]);\n\n const [showListAddEditModal, setShowListAddEditModal] = useState(false);\n\n return (\n <div id=\"lists-page\" class=\"deck-container\" tabIndex=\"-1\">\n <div class=\"timeline-deck deck\">\n <header>\n <div class=\"header-grid\">\n <div class=\"header-side\">\n <NavMenu />\n <Link to=\"/\" class=\"button plain\">\n <Icon icon=\"home\" size=\"l\" />\n </Link>\n </div>\n <h1>Lists</h1>\n <div class=\"header-side\">\n <button\n type=\"button\"\n class=\"plain\"\n onClick={() => setShowListAddEditModal(true)}\n >\n <Icon icon=\"plus\" size=\"l\" alt=\"New list\" />\n </button>\n </div>\n </div>\n </header>\n <main>\n {lists.length > 0 ? (\n <ul class=\"link-list\">\n {lists.map((list) => (\n <li>\n <Link to={`/l/${list.id}`}>\n <span>\n <Icon icon=\"list\" /> <span>{list.title}</span>\n </span>\n {/* <button\n type=\"button\"\n class=\"plain\"\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n setShowListAddEditModal({\n list,\n });\n }}\n >\n <Icon icon=\"pencil\" />\n </button> */}\n </Link>\n </li>\n ))}\n </ul>\n ) : uiState === 'loading' ? (\n <p class=\"ui-state\">\n <Loader />\n </p>\n ) : uiState === 'error' ? (\n <p class=\"ui-state\">Unable to load lists.</p>\n ) : (\n <p class=\"ui-state\">No lists yet.</p>\n )}\n </main>\n </div>\n {showListAddEditModal && (\n <Modal\n class=\"light\"\n onClick={(e) => {\n if (e.target === e.currentTarget) {\n setShowListAddEditModal(false);\n }\n }}\n >\n <ListAddEdit\n list={showListAddEditModal?.list}\n onClose={(result) => {\n if (result.state === 'success') {\n reload();\n }\n setShowListAddEditModal(false);\n }}\n />\n </Modal>\n )}\n </div>\n );\n}\n\nexport default Lists;\n","export default \"__VITE_ASSET__Y_wpqkTO__\"","const { PHANPY_CLIENT_NAME: CLIENT_NAME, PHANPY_WEBSITE: WEBSITE } = import.meta\n .env;\n\nconst SCOPES = 'read write follow push';\n\nexport async function registerApplication({ instanceURL }) {\n const registrationParams = new URLSearchParams({\n client_name: CLIENT_NAME,\n redirect_uris: location.origin + location.pathname,\n scopes: SCOPES,\n website: WEBSITE,\n });\n const registrationResponse = await fetch(\n `https://${instanceURL}/api/v1/apps`,\n {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n },\n body: registrationParams.toString(),\n },\n );\n const registrationJSON = await registrationResponse.json();\n console.log({ registrationJSON });\n return registrationJSON;\n}\n\nexport async function getAuthorizationURL({ instanceURL, client_id }) {\n const authorizationParams = new URLSearchParams({\n client_id,\n scope: SCOPES,\n redirect_uri: location.origin + location.pathname,\n // redirect_uri: 'urn:ietf:wg:oauth:2.0:oob',\n response_type: 'code',\n });\n const authorizationURL = `https://${instanceURL}/oauth/authorize?${authorizationParams.toString()}`;\n return authorizationURL;\n}\n\nexport async function getAccessToken({\n instanceURL,\n client_id,\n client_secret,\n code,\n}) {\n const params = new URLSearchParams({\n client_id,\n client_secret,\n redirect_uri: location.origin + location.pathname,\n grant_type: 'authorization_code',\n code,\n scope: SCOPES,\n });\n const tokenResponse = await fetch(`https://${instanceURL}/oauth/token`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n },\n body: params.toString(),\n });\n const tokenJSON = await tokenResponse.json();\n console.log({ tokenJSON });\n return tokenJSON;\n}\n","import './login.css';\n\nimport { useEffect, useRef, useState } from 'preact/hooks';\nimport { useSearchParams } from 'react-router-dom';\n\nimport logo from '../assets/logo.svg';\n\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport instancesListURL from '../data/instances.json?url';\nimport { getAuthorizationURL, registerApplication } from '../utils/auth';\nimport store from '../utils/store';\nimport useTitle from '../utils/useTitle';\n\nconst { PHANPY_DEFAULT_INSTANCE: DEFAULT_INSTANCE } = import.meta.env;\n\nfunction Login() {\n useTitle('Log in');\n const instanceURLRef = useRef();\n const cachedInstanceURL = store.local.get('instanceURL');\n const [uiState, setUIState] = useState('default');\n const [searchParams] = useSearchParams();\n const instance = searchParams.get('instance');\n const submit = searchParams.get('submit');\n const [instanceText, setInstanceText] = useState(\n instance || cachedInstanceURL?.toLowerCase() || '',\n );\n\n const [instancesList, setInstancesList] = useState([]);\n useEffect(() => {\n (async () => {\n try {\n const res = await fetch(instancesListURL);\n const data = await res.json();\n setInstancesList(data);\n } catch (e) {\n // Silently fail\n console.error(e);\n }\n })();\n }, []);\n\n // useEffect(() => {\n // if (cachedInstanceURL) {\n // instanceURLRef.current.value = cachedInstanceURL.toLowerCase();\n // }\n // }, []);\n\n const submitInstance = (instanceURL) => {\n if (!instanceURL) return;\n store.local.set('instanceURL', instanceURL);\n\n (async () => {\n setUIState('loading');\n try {\n const { client_id, client_secret, vapid_key } =\n await registerApplication({\n instanceURL,\n });\n\n if (client_id && client_secret) {\n store.session.set('clientID', client_id);\n store.session.set('clientSecret', client_secret);\n store.session.set('vapidKey', vapid_key);\n\n location.href = await getAuthorizationURL({\n instanceURL,\n client_id,\n });\n } else {\n alert('Failed to register application');\n }\n setUIState('default');\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n };\n\n const cleanInstanceText = instanceText\n ? instanceText\n .replace(/^https?:\\/\\//, '') // Remove protocol from instance URL\n .replace(/\\/+$/, '') // Remove trailing slash\n .replace(/^@?[^@]+@/, '') // Remove @?acct@\n .trim()\n : null;\n const instanceTextLooksLikeDomain =\n /[^\\s\\r\\n\\t\\/\\\\]+\\.[^\\s\\r\\n\\t\\/\\\\]+/.test(cleanInstanceText) &&\n !/[\\s\\/\\\\@]/.test(cleanInstanceText);\n\n const instancesSuggestions = cleanInstanceText\n ? instancesList\n .filter((instance) => instance.includes(instanceText))\n .sort((a, b) => {\n // Move text that starts with instanceText to the start\n const aStartsWith = a\n .toLowerCase()\n .startsWith(instanceText.toLowerCase());\n const bStartsWith = b\n .toLowerCase()\n .startsWith(instanceText.toLowerCase());\n if (aStartsWith && !bStartsWith) return -1;\n if (!aStartsWith && bStartsWith) return 1;\n return 0;\n })\n .slice(0, 10)\n : [];\n\n const selectedInstanceText = instanceTextLooksLikeDomain\n ? cleanInstanceText\n : instancesSuggestions?.length\n ? instancesSuggestions[0]\n : instanceText\n ? instancesList.find((instance) => instance.includes(instanceText))\n : null;\n\n const onSubmit = (e) => {\n e.preventDefault();\n // const { elements } = e.target;\n // let instanceURL = elements.instanceURL.value.toLowerCase();\n // // Remove protocol from instance URL\n // instanceURL = instanceURL.replace(/^https?:\\/\\//, '').replace(/\\/+$/, '');\n // // Remove @acct@ or acct@ from instance URL\n // instanceURL = instanceURL.replace(/^@?[^@]+@/, '');\n // if (!/\\./.test(instanceURL)) {\n // instanceURL = instancesList.find((instance) =>\n // instance.includes(instanceURL),\n // );\n // }\n // submitInstance(instanceURL);\n submitInstance(selectedInstanceText);\n };\n\n if (submit) {\n useEffect(() => {\n submitInstance(instance || selectedInstanceText);\n }, []);\n }\n\n return (\n <main id=\"login\" style={{ textAlign: 'center' }}>\n <form onSubmit={onSubmit}>\n <h1>\n <img src={logo} alt=\"\" width=\"80\" height=\"80\" />\n <br />\n Log in\n </h1>\n <label>\n <p>Instance</p>\n <input\n value={instanceText}\n required\n type=\"text\"\n class=\"large\"\n id=\"instanceURL\"\n ref={instanceURLRef}\n disabled={uiState === 'loading'}\n // list=\"instances-list\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n autocomplete=\"off\"\n spellcheck={false}\n placeholder=\"instance domain\"\n onInput={(e) => {\n setInstanceText(e.target.value);\n }}\n />\n {instancesSuggestions?.length > 0 ? (\n <ul id=\"instances-suggestions\">\n {instancesSuggestions.map((instance, i) => (\n <li>\n <button\n type=\"button\"\n class=\"plain5\"\n onClick={() => {\n submitInstance(instance);\n }}\n >\n {instance}\n </button>\n </li>\n ))}\n </ul>\n ) : (\n <div id=\"instances-eg\">e.g. “mastodon.social”</div>\n )}\n {/* <datalist id=\"instances-list\">\n {instancesList.map((instance) => (\n <option value={instance} />\n ))}\n </datalist> */}\n </label>\n {uiState === 'error' && (\n <p class=\"error\">\n Failed to log in. Please try again or another instance.\n </p>\n )}\n <div>\n <button\n disabled={\n uiState === 'loading' || !instanceText || !selectedInstanceText\n }\n >\n {selectedInstanceText\n ? `Continue with ${selectedInstanceText}`\n : 'Continue'}\n </button>{' '}\n </div>\n <Loader hidden={uiState !== 'loading'} />\n <hr />\n {!DEFAULT_INSTANCE && (\n <p>\n <a href=\"https://joinmastodon.org/servers\" target=\"_blank\">\n Don't have an account? Create one!\n </a>\n </p>\n )}\n <p>\n <Link to=\"/\">Go home</Link>\n </p>\n </form>\n </main>\n );\n}\n\nexport default Login;\n","import './status.css';\n\nimport { Menu, MenuDivider, MenuHeader, MenuItem } from '@szhsin/react-menu';\nimport debounce from 'just-debounce-it';\nimport pRetry from 'p-retry';\nimport { memo } from 'preact/compat';\nimport {\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'preact/hooks';\nimport { useHotkeys } from 'react-hotkeys-hook';\nimport { InView } from 'react-intersection-observer';\nimport { matchPath, useSearchParams } from 'react-router-dom';\nimport { useDebouncedCallback } from 'use-debounce';\nimport { useSnapshot } from 'valtio';\n\nimport Avatar from '../components/avatar';\nimport Icon from '../components/icon';\nimport Link from '../components/link';\nimport Loader from '../components/loader';\nimport MediaModal from '../components/media-modal';\nimport Menu2 from '../components/menu2';\nimport NameText from '../components/name-text';\nimport RelativeTime from '../components/relative-time';\nimport Status from '../components/status';\nimport { api } from '../utils/api';\nimport htmlContentLength from '../utils/html-content-length';\nimport shortenNumber from '../utils/shorten-number';\nimport states, {\n getStatus,\n saveStatus,\n statusKey,\n threadifyStatus,\n} from '../utils/states';\nimport statusPeek from '../utils/status-peek';\nimport { getCurrentAccount } from '../utils/store-utils';\nimport useScroll from '../utils/useScroll';\nimport useTitle from '../utils/useTitle';\n\nimport getInstanceStatusURL from './../utils/get-instance-status-url';\n\nconst LIMIT = 40;\nconst SUBCOMMENTS_OPEN_ALL_LIMIT = 10;\nconst MAX_WEIGHT = 5;\n\nlet cachedRepliesToggle = {};\nlet cachedStatusesMap = {};\nlet scrollPositions = {};\nfunction resetScrollPosition(id) {\n delete cachedStatusesMap[id];\n delete scrollPositions[id];\n}\n\nconst scrollIntoViewOptions = {\n block: 'nearest',\n inline: 'center',\n behavior: 'smooth',\n};\n\n// Select all statuses except those inside collapsed details/summary\n// Hat-tip to @AmeliaBR@front-end.social\n// https://front-end.social/@AmeliaBR/109784776146144471\nconst STATUSES_SELECTOR =\n '.status-link:not(details:not([open]) > summary ~ *, details:not([open]) > summary ~ * *), .status-focus:not(details:not([open]) > summary ~ *, details:not([open]) > summary ~ * *)';\n\nconst STATUS_URL_REGEX = /\\/s\\//i;\n\nfunction StatusPage(params) {\n const { id } = params;\n const { masto, instance } = api({ instance: params.instance });\n const snapStates = useSnapshot(states);\n const [searchParams, setSearchParams] = useSearchParams();\n const mediaParam = searchParams.get('media');\n const mediaOnlyParam = searchParams.get('media-only');\n const mediaIndex = parseInt(mediaParam || mediaOnlyParam, 10);\n let showMedia = mediaIndex > 0;\n const mediaStatusID = searchParams.get('mediaStatusID');\n const mediaStatus = getStatus(mediaStatusID, instance);\n if (mediaStatusID && !mediaStatus) {\n showMedia = false;\n }\n const showMediaOnly = showMedia && !!mediaOnlyParam;\n\n const sKey = statusKey(id, instance);\n const [heroStatus, setHeroStatus] = useState(states.statuses[sKey]);\n useEffect(() => {\n if (states.statuses[sKey]) {\n setHeroStatus(states.statuses[sKey]);\n }\n }, [sKey]);\n\n const closeLink = useMemo(() => {\n const { prevLocation } = states;\n const pathname =\n (prevLocation?.pathname || '') + (prevLocation?.search || '');\n const matchStatusPath =\n matchPath('/:instance/s/:id', pathname) || matchPath('/s/:id', pathname);\n if (!pathname || matchStatusPath) {\n return '/';\n }\n return pathname;\n }, []);\n\n useEffect(() => {\n if (!heroStatus && showMedia) {\n (async () => {\n try {\n const status = await masto.v1.statuses.$select(id).fetch();\n saveStatus(status, instance);\n setHeroStatus(status);\n } catch (err) {\n console.error(err);\n alert('Unable to load post.');\n location.hash = closeLink;\n }\n })();\n }\n }, [showMedia]);\n\n const mediaAttachments = mediaStatusID\n ? mediaStatus?.mediaAttachments\n : heroStatus?.mediaAttachments;\n\n const handleMediaClose = useCallback(() => {\n if (\n !window.matchMedia('(min-width: calc(40em + 350px))').matches &&\n snapStates.prevLocation\n ) {\n history.back();\n } else {\n if (showMediaOnly) {\n location.hash = closeLink;\n } else {\n searchParams.delete('media');\n searchParams.delete('mediaStatusID');\n setSearchParams(searchParams);\n }\n }\n }, [showMediaOnly, closeLink, snapStates.prevLocation]);\n\n useEffect(() => {\n let timer = setTimeout(() => {\n // carouselRef.current?.focus?.();\n const $carousel = document.querySelector('.carousel');\n if ($carousel) {\n $carousel.focus();\n }\n }, 100);\n return () => clearTimeout(timer);\n }, [showMediaOnly]);\n\n return (\n <div class=\"deck-backdrop\">\n {showMedia ? (\n mediaAttachments?.length ? (\n <MediaModal\n mediaAttachments={mediaAttachments}\n statusID={mediaStatusID || id}\n instance={instance}\n lang={heroStatus?.language}\n index={mediaIndex - 1}\n onClose={handleMediaClose}\n />\n ) : (\n <div class=\"media-modal-container loading\">\n <Loader abrupt />\n </div>\n )\n ) : (\n <Link to={closeLink} />\n )}\n {!showMediaOnly && (\n <StatusThread\n id={id}\n instance={params.instance}\n closeLink={closeLink}\n />\n )}\n </div>\n );\n}\n\nfunction StatusThread({ id, closeLink = '/', instance: propInstance }) {\n const [searchParams, setSearchParams] = useSearchParams();\n const mediaParam = searchParams.get('media');\n const mediaStatusID = searchParams.get('mediaStatusID');\n const showMedia = parseInt(mediaParam, 10) > 0;\n const firstLoad = useRef(\n !states.prevLocation &&\n (history.length === 1 ||\n ('navigation' in window && navigation?.entries?.()?.length === 1)),\n );\n const [viewMode, setViewMode] = useState(\n searchParams.get('view') || firstLoad.current ? 'full' : null,\n );\n const translate = !!parseInt(searchParams.get('translate'));\n const { masto, instance } = api({ instance: propInstance });\n const {\n masto: currentMasto,\n instance: currentInstance,\n authenticated,\n } = api();\n const sameInstance = instance === currentInstance;\n const snapStates = useSnapshot(states);\n const [statuses, setStatuses] = useState([]);\n const [uiState, setUIState] = useState('default');\n const heroStatusRef = useRef();\n const sKey = statusKey(id, instance);\n const totalDescendants = useRef(0);\n\n const scrollableRef = useRef();\n useEffect(() => {\n scrollableRef.current?.focus();\n }, []);\n useEffect(() => {\n const onScroll = debounce(() => {\n // console.log('onScroll');\n if (!scrollableRef.current) return;\n const { scrollTop } = scrollableRef.current;\n if (uiState !== 'loading') {\n scrollPositions[id] = scrollTop;\n }\n }, 50);\n scrollableRef.current?.addEventListener('scroll', onScroll, {\n passive: true,\n });\n onScroll();\n return () => {\n onScroll.cancel();\n scrollableRef.current?.removeEventListener('scroll', onScroll);\n };\n }, [id, uiState !== 'loading']);\n\n const scrollOffsets = useRef();\n const initContext = ({ reloadHero } = {}) => {\n console.debug('initContext', id);\n setUIState('loading');\n let heroTimer;\n\n const cachedStatuses = cachedStatusesMap[id];\n if (cachedStatuses) {\n // Case 1: It's cached, let's restore them to make it snappy\n const reallyCachedStatuses = cachedStatuses.filter(\n (s) => states.statuses[sKey],\n // Some are not cached in the global state, so we need to filter them out\n );\n setStatuses(reallyCachedStatuses);\n } else {\n // const heroIndex = statuses.findIndex((s) => s.id === id);\n // if (heroIndex !== -1) {\n // // Case 2: It's in current statuses. Slice off all descendant statuses after the hero status to be safe\n // const slicedStatuses = statuses.slice(0, heroIndex + 1);\n // setStatuses(slicedStatuses);\n // } else {\n // Case 3: Not cached and not in statuses, let's start from scratch\n setStatuses([{ id }]);\n // }\n }\n\n (async () => {\n const heroFetch = () =>\n pRetry(() => masto.v1.statuses.$select(id).fetch(), {\n retries: 4,\n });\n const contextFetch = pRetry(\n () => masto.v1.statuses.$select(id).context.fetch(),\n {\n retries: 8,\n },\n );\n\n const hasStatus = !!snapStates.statuses[sKey];\n let heroStatus = snapStates.statuses[sKey];\n if (hasStatus && !reloadHero) {\n console.debug('Hero status is cached');\n } else {\n try {\n heroStatus = await heroFetch();\n saveStatus(heroStatus, instance);\n // Give time for context to appear\n await new Promise((resolve) => {\n setTimeout(resolve, 100);\n });\n } catch (e) {\n console.error(e);\n setUIState('error');\n return;\n }\n }\n\n try {\n const context = await contextFetch;\n const { ancestors, descendants } = context;\n\n totalDescendants.current = descendants?.length || 0;\n\n const missingStatuses = new Set();\n ancestors.forEach((status) => {\n saveStatus(status, instance, {\n skipThreading: true,\n });\n if (\n status.inReplyToId &&\n !ancestors.find((s) => s.id === status.inReplyToId)\n ) {\n missingStatuses.add(status.inReplyToId);\n }\n });\n const ancestorsIsThread = ancestors.every(\n (s) => s.account.id === heroStatus.account.id,\n );\n const nestedDescendants = [];\n descendants.forEach((status) => {\n saveStatus(status, instance, {\n skipThreading: true,\n });\n\n if (\n status.inReplyToId &&\n !descendants.find((s) => s.id === status.inReplyToId) &&\n status.inReplyToId !== heroStatus.id\n ) {\n missingStatuses.add(status.inReplyToId);\n }\n\n if (status.inReplyToAccountId === status.account.id) {\n // If replying to self, it's part of the thread, level 1\n nestedDescendants.push(status);\n } else if (status.inReplyToId === heroStatus.id) {\n // If replying to the hero status, it's a reply, level 1\n nestedDescendants.push(status);\n } else if (\n !status.inReplyToAccountId &&\n nestedDescendants.find((s) => s.id === status.inReplyToId) &&\n status.account.id === heroStatus.account.id\n ) {\n // If replying to hero's own statuses, it's part of the thread, level 1\n nestedDescendants.push(status);\n } else {\n // If replying to someone else, it's a reply to a reply, level 2\n const parent = descendants.find((s) => s.id === status.inReplyToId);\n if (parent) {\n if (!parent.__replies) {\n parent.__replies = [];\n }\n parent.__replies.push(status);\n } else {\n // If no parent, something is wrong\n console.warn('No parent found for', status);\n }\n }\n });\n\n console.log({ ancestors, descendants, nestedDescendants });\n if (missingStatuses.size) {\n console.error('Missing statuses', [...missingStatuses]);\n }\n\n function expandReplies(_replies) {\n return _replies?.map((_r) => ({\n id: _r.id,\n account: _r.account,\n repliesCount: _r.repliesCount,\n content: _r.content,\n weight: calcStatusWeight(_r),\n replies: expandReplies(_r.__replies),\n }));\n }\n\n const allStatuses = [\n ...ancestors.map((s) => ({\n id: s.id,\n ancestor: true,\n isThread: ancestorsIsThread,\n accountID: s.account.id,\n account: s.account,\n repliesCount: s.repliesCount,\n weight: calcStatusWeight(s),\n })),\n {\n id,\n accountID: heroStatus.account.id,\n weight: calcStatusWeight(heroStatus),\n },\n ...nestedDescendants.map((s) => ({\n id: s.id,\n account: s.account,\n accountID: s.account.id,\n descendant: true,\n thread: s.account.id === heroStatus.account.id,\n weight: calcStatusWeight(s),\n replies: expandReplies(s.__replies),\n })),\n ];\n\n setUIState('default');\n scrollOffsets.current = {\n offsetTop: heroStatusRef.current?.offsetTop,\n scrollTop: scrollableRef.current?.scrollTop,\n };\n\n // Set limit to hero's index\n const heroLimit = allStatuses.findIndex((s) => s.id === id);\n if (heroLimit >= limit) {\n setLimit(heroLimit + 1);\n }\n\n console.log({ allStatuses });\n setStatuses(allStatuses);\n cachedStatusesMap[id] = allStatuses;\n\n // Let's threadify this one\n // Note that all non-hero statuses will trigger saveStatus which will threadify them too\n // By right, at this point, all descendant statuses should be cached\n threadifyStatus(heroStatus, instance);\n } catch (e) {\n console.error(e);\n setUIState('error');\n }\n })();\n\n return () => {\n clearTimeout(heroTimer);\n };\n };\n\n useEffect(initContext, [id, masto]);\n useEffect(() => {\n if (!statuses.length) return;\n console.debug('STATUSES', statuses);\n const scrollPosition = scrollPositions[id];\n console.debug('scrollPosition', scrollPosition);\n if (!!scrollPosition) {\n console.debug('Case 1', {\n id,\n scrollPosition,\n });\n scrollableRef.current.scrollTop = scrollPosition;\n } else if (scrollOffsets.current) {\n const newScrollOffsets = {\n offsetTop: heroStatusRef.current?.offsetTop,\n scrollTop: scrollableRef.current?.scrollTop,\n };\n const newScrollTop =\n newScrollOffsets.offsetTop -\n scrollOffsets.current.offsetTop +\n newScrollOffsets.scrollTop;\n console.debug('Case 2', {\n scrollOffsets: scrollOffsets.current,\n newScrollOffsets,\n newScrollTop,\n statuses: [...statuses],\n });\n scrollableRef.current.scrollTop = newScrollTop;\n } else if (statuses.length === 1) {\n console.debug('Case 3', {\n id,\n });\n scrollableRef.current.scrollTop = 0;\n }\n\n // RESET\n scrollOffsets.current = null;\n }, [statuses]);\n\n useEffect(() => {\n if (snapStates.reloadStatusPage <= 0) return;\n // Delete the cache for the context\n (async () => {\n try {\n const { instanceURL } = getCurrentAccount();\n const contextURL = `https://${instanceURL}/api/v1/statuses/${id}/context`;\n console.log('Clear cache', contextURL);\n const apiCache = await caches.open('api');\n await apiCache.delete(contextURL, { ignoreVary: true });\n\n return initContext({\n reloadHero: true,\n });\n } catch (e) {\n console.error(e);\n }\n })();\n }, [snapStates.reloadStatusPage]);\n\n useEffect(() => {\n return () => {\n // RESET\n scrollPositions = {};\n states.reloadStatusPage = 0;\n cachedStatusesMap = {};\n cachedRepliesToggle = {};\n statusWeightCache.clear();\n };\n }, []);\n\n const heroStatus = snapStates.statuses[sKey] || snapStates.statuses[id];\n const heroDisplayName = useMemo(() => {\n // Remove shortcodes from display name\n if (!heroStatus) return '';\n const { account } = heroStatus;\n const div = document.createElement('div');\n div.innerHTML = account.displayName;\n return div.innerText.trim();\n }, [heroStatus]);\n const heroContentText = useMemo(() => {\n if (!heroStatus) return '';\n let text = statusPeek(heroStatus);\n if (text.length > 64) {\n // \"The title should ideally be less than 64 characters in length\"\n // https://www.w3.org/Provider/Style/TITLE.html\n text = text.slice(0, 64) + '…';\n }\n return text;\n }, [heroStatus]);\n useTitle(\n heroDisplayName && heroContentText\n ? `${heroDisplayName}: \"${heroContentText}\"`\n : 'Status',\n '/:instance?/s/:id',\n );\n\n const postInstance = useMemo(() => {\n if (!heroStatus) return;\n const { url } = heroStatus;\n if (!url) return;\n return new URL(url).hostname;\n }, [heroStatus]);\n const postSameInstance = useMemo(() => {\n if (!postInstance) return;\n return postInstance === instance;\n }, [postInstance, instance]);\n\n const [limit, setLimit] = useState(LIMIT);\n const showMore = useMemo(() => {\n // return number of statuses to show\n return statuses.length - limit;\n }, [statuses.length, limit]);\n\n const hasDescendants = statuses.some((s) => s.descendant);\n const ancestors = statuses.filter((s) => s.ancestor);\n\n const [heroInView, setHeroInView] = useState(true);\n const onView = useDebouncedCallback(setHeroInView, 100);\n const heroPointer = useMemo(() => {\n // get top offset of heroStatus\n if (!heroStatusRef.current || heroInView) return null;\n const { top } = heroStatusRef.current.getBoundingClientRect();\n return top > 0 ? 'down' : 'up';\n }, [heroInView]);\n\n useHotkeys(\n 'esc',\n () => {\n location.hash = closeLink;\n },\n {\n // If media is open, esc to close media first\n // Else close the status page\n enabled: !showMedia,\n ignoreEventWhen: (e) => {\n const hasModal = !!document.querySelector('#modal-container > *');\n return hasModal;\n },\n },\n );\n // For backspace, will always close both media and status page\n useHotkeys('backspace', () => {\n location.hash = closeLink;\n });\n\n useHotkeys('j', () => {\n const activeStatus = document.activeElement.closest(\n '.status-link, .status-focus',\n );\n const activeStatusRect = activeStatus?.getBoundingClientRect();\n const allStatusLinks = Array.from(\n scrollableRef.current.querySelectorAll(STATUSES_SELECTOR),\n );\n console.log({ allStatusLinks });\n if (\n activeStatus &&\n activeStatusRect.top < scrollableRef.current.clientHeight &&\n activeStatusRect.bottom > 0\n ) {\n const activeStatusIndex = allStatusLinks.indexOf(activeStatus);\n let nextStatus = allStatusLinks[activeStatusIndex + 1];\n if (nextStatus) {\n nextStatus.focus();\n nextStatus.scrollIntoView(scrollIntoViewOptions);\n }\n } else {\n // If active status is not in viewport, get the topmost status-link in viewport\n const topmostStatusLink = allStatusLinks.find((statusLink) => {\n const statusLinkRect = statusLink.getBoundingClientRect();\n return statusLinkRect.top >= 44 && statusLinkRect.left >= 0; // 44 is the magic number for header height, not real\n });\n if (topmostStatusLink) {\n topmostStatusLink.focus();\n topmostStatusLink.scrollIntoView(scrollIntoViewOptions);\n }\n }\n });\n\n useHotkeys('k', () => {\n const activeStatus = document.activeElement.closest(\n '.status-link, .status-focus',\n );\n const activeStatusRect = activeStatus?.getBoundingClientRect();\n const allStatusLinks = Array.from(\n scrollableRef.current.querySelectorAll(STATUSES_SELECTOR),\n );\n if (\n activeStatus &&\n activeStatusRect.top < scrollableRef.current.clientHeight &&\n activeStatusRect.bottom > 0\n ) {\n const activeStatusIndex = allStatusLinks.indexOf(activeStatus);\n let prevStatus = allStatusLinks[activeStatusIndex - 1];\n if (prevStatus) {\n prevStatus.focus();\n prevStatus.scrollIntoView(scrollIntoViewOptions);\n }\n } else {\n // If active status is not in viewport, get the topmost status-link in viewport\n const topmostStatusLink = allStatusLinks.find((statusLink) => {\n const statusLinkRect = statusLink.getBoundingClientRect();\n return statusLinkRect.top >= 44 && statusLinkRect.left >= 0; // 44 is the magic number for header height, not real\n });\n if (topmostStatusLink) {\n topmostStatusLink.focus();\n topmostStatusLink.scrollIntoView(scrollIntoViewOptions);\n }\n }\n });\n\n // NOTE: I'm not sure if 'x' is the best shortcut for this, might change it later\n // IDEA: x is for expand\n useHotkeys('x', () => {\n const activeStatus = document.activeElement.closest(\n '.status-link, .status-focus',\n );\n if (activeStatus) {\n const details = activeStatus.nextElementSibling;\n if (details && details.tagName.toLowerCase() === 'details') {\n details.open = !details.open;\n }\n }\n });\n\n const { nearReachStart } = useScroll({\n scrollableRef,\n distanceFromStartPx: 16,\n });\n\n const initialPageState = useRef(showMedia ? 'media+status' : 'status');\n\n const handleMediaClick = useCallback(\n (e, i, media, status) => {\n e.preventDefault();\n e.stopPropagation();\n setSearchParams({\n media: i + 1,\n mediaStatusID: status.id,\n });\n },\n [id],\n );\n\n const handleStatusLinkClick = useCallback((e, status) => {\n resetScrollPosition(status.id);\n }, []);\n\n useEffect(() => {\n let timer;\n if (mediaStatusID && showMedia) {\n timer = setTimeout(() => {\n const status = scrollableRef.current?.querySelector(\n `.status-link[href*=\"/${mediaStatusID}\"]`,\n );\n if (status) {\n status.scrollIntoView(scrollIntoViewOptions);\n }\n }, 400); // After CSS transition\n }\n return () => {\n clearTimeout(timer);\n };\n }, [mediaStatusID, showMedia]);\n\n const renderStatus = useCallback(\n (status) => {\n const {\n id: statusID,\n ancestor,\n isThread,\n descendant,\n thread,\n replies,\n repliesCount,\n weight,\n } = status;\n const isHero = statusID === id;\n // const StatusParent = useCallback(\n // (props) =>\n // isThread || thread || ancestor ? (\n // <Link\n // class=\"status-link\"\n // to={\n // instance ? `/${instance}/s/${statusID}` : `/s/${statusID}`\n // }\n // onClick={() => {\n // resetScrollPosition(statusID);\n // }}\n // {...props}\n // />\n // ) : (\n // <div class=\"status-focus\" tabIndex={0} {...props} />\n // ),\n // [isThread, thread],\n // );\n return (\n <li\n key={statusID}\n ref={isHero ? heroStatusRef : null}\n class={`${ancestor ? 'ancestor' : ''} ${\n descendant ? 'descendant' : ''\n } ${thread ? 'thread' : ''} ${isHero ? 'hero' : ''}`}\n >\n {isHero ? (\n <>\n <InView\n threshold={0.1}\n onChange={onView}\n class=\"status-focus\"\n tabIndex={0}\n >\n <Status\n statusID={statusID}\n instance={instance}\n withinContext\n size=\"l\"\n enableTranslate\n forceTranslate={translate}\n />\n </InView>\n {uiState !== 'loading' && !authenticated ? (\n <div class=\"post-status-banner\">\n <p>\n You're not logged in. Interactions (reply, boost, etc) are\n not possible.\n </p>\n <Link to=\"/login\" class=\"button\">\n Log in\n </Link>\n </div>\n ) : (\n !sameInstance && (\n <div class=\"post-status-banner\">\n <p>\n This post is from another instance (<b>{instance}</b>).\n Interactions (reply, boost, etc) are not possible.\n </p>\n <button\n type=\"button\"\n disabled={uiState === 'loading'}\n onClick={() => {\n setUIState('loading');\n (async () => {\n try {\n const results = await currentMasto.v2.search.fetch({\n q: heroStatus.url,\n type: 'statuses',\n resolve: true,\n limit: 1,\n });\n if (results.statuses.length) {\n const status = results.statuses[0];\n location.hash = currentInstance\n ? `/${currentInstance}/s/${status.id}`\n : `/s/${status.id}`;\n } else {\n throw new Error('No results');\n }\n } catch (e) {\n setUIState('default');\n alert('Error: ' + e);\n console.error(e);\n }\n })();\n }}\n >\n <Icon icon=\"transfer\" /> Switch to my instance to enable\n interactions\n </button>\n </div>\n )\n )}\n </>\n ) : (\n // <StatusParent>\n <Link\n class=\"status-link\"\n to={instance ? `/${instance}/s/${statusID}` : `/s/${statusID}`}\n onClick={() => {\n resetScrollPosition(statusID);\n }}\n >\n <Status\n statusID={statusID}\n instance={instance}\n withinContext\n size={thread || ancestor ? 'm' : 's'}\n enableTranslate\n onMediaClick={handleMediaClick}\n onStatusLinkClick={handleStatusLinkClick}\n />\n {ancestor && repliesCount > 1 && (\n <div class=\"replies-link\">\n <Icon icon=\"comment2\" />{' '}\n <span title={repliesCount}>\n {shortenNumber(repliesCount)}\n </span>\n </div>\n )}{' '}\n {/* {replies?.length > LIMIT && (\n <div class=\"replies-link\">\n <Icon icon=\"comment\" />{' '}\n <span title={replies.length}>\n {shortenNumber(replies.length)}\n </span>\n </div>\n )} */}\n {/* </StatusParent> */}\n </Link>\n )}\n {descendant && replies?.length > 0 && (\n <SubComments\n instance={instance}\n replies={replies}\n hasParentThread={thread}\n level={1}\n accWeight={weight}\n openAll={totalDescendants.current < SUBCOMMENTS_OPEN_ALL_LIMIT}\n />\n )}\n {uiState === 'loading' &&\n isHero &&\n !!heroStatus?.repliesCount &&\n !hasDescendants && (\n <div class=\"status-loading\">\n <Loader />\n </div>\n )}\n {uiState === 'error' &&\n isHero &&\n !!heroStatus?.repliesCount &&\n !hasDescendants && (\n <div class=\"status-error\">\n Unable to load replies.\n <br />\n <button\n type=\"button\"\n class=\"plain\"\n onClick={() => {\n states.reloadStatusPage++;\n }}\n >\n Try again\n </button>\n </div>\n )}\n </li>\n );\n },\n [\n id,\n instance,\n uiState,\n authenticated,\n sameInstance,\n translate,\n handleMediaClick,\n handleStatusLinkClick,\n hasDescendants,\n ],\n );\n\n const prevLocationIsStatusPage = useMemo(() => {\n // Navigation API\n if ('navigation' in window && navigation?.entries) {\n const prevEntry = navigation.entries()[navigation.currentEntry.index - 1];\n if (prevEntry?.url) {\n return STATUS_URL_REGEX.test(prevEntry.url);\n }\n }\n return STATUS_URL_REGEX.test(states.prevLocation?.pathname);\n }, [sKey]);\n\n const moreStatusesKeys = useMemo(() => {\n if (!showMore) return [];\n const ids = [];\n function getIDs(status) {\n ids.push(status.id);\n if (status.replies) {\n status.replies.forEach(getIDs);\n }\n }\n statuses.slice(limit).forEach(getIDs);\n return ids.map((id) => statusKey(id, instance));\n }, [showMore, statuses, limit, instance]);\n\n return (\n <div\n tabIndex=\"-1\"\n ref={scrollableRef}\n class={`status-deck deck contained ${\n statuses.length > 1 ? 'padded-bottom' : ''\n } ${\n initialPageState.current === 'status' && !firstLoad.current\n ? 'slide-in'\n : ''\n } ${viewMode ? `deck-view-${viewMode}` : ''}`}\n onAnimationEnd={(e) => {\n // Fix the bounce effect when switching viewMode\n // `slide-in` animation kicks in when switching viewMode\n if (initialPageState.current === 'status') {\n // e.target.classList.remove('slide-in');\n initialPageState.current = null;\n }\n }}\n >\n <header\n class={`${heroInView ? 'inview' : ''} ${\n uiState === 'loading' ? 'loading' : ''\n }`}\n onDblClick={(e) => {\n // reload statuses\n states.reloadStatusPage++;\n }}\n >\n {/* <div>\n <Link class=\"button plain deck-close\" href={closeLink}>\n <Icon icon=\"chevron-left\" size=\"xl\" />\n </Link>\n </div> */}\n <div class=\"header-grid header-grid-2\">\n <h1>\n {prevLocationIsStatusPage && (\n <button\n type=\"button\"\n class=\"plain deck-back\"\n onClick={() => {\n history.back();\n }}\n >\n <Icon icon=\"chevron-left\" size=\"xl\" />\n </button>\n )}\n {!heroInView && heroStatus && uiState !== 'loading' ? (\n <>\n <span class=\"hero-heading\">\n <NameText\n account={heroStatus.account}\n instance={instance}\n showAvatar\n short\n />{' '}\n <span class=\"insignificant\">\n •{' '}\n <RelativeTime\n datetime={heroStatus.createdAt}\n format=\"micro\"\n />\n </span>\n </span>{' '}\n <button\n type=\"button\"\n class=\"ancestors-indicator light small\"\n onClick={(e) => {\n e.preventDefault();\n e.stopPropagation();\n heroStatusRef.current.scrollIntoView({\n behavior: 'smooth',\n block: 'start',\n });\n }}\n title=\"Go to main post\"\n >\n <Icon\n icon={heroPointer === 'down' ? 'arrow-down' : 'arrow-up'}\n />\n </button>\n </>\n ) : (\n <>\n Post{' '}\n <button\n type=\"button\"\n class=\"ancestors-indicator light small\"\n onClick={(e) => {\n // Scroll to top\n e.preventDefault();\n e.stopPropagation();\n scrollableRef.current.scrollTo({\n top: 0,\n behavior: 'smooth',\n });\n }}\n hidden={!ancestors.length || nearReachStart}\n title={`${ancestors.length} posts above ‒ Go to top`}\n >\n <Icon icon=\"arrow-up\" />\n {ancestors\n .filter(\n (a, i, arr) =>\n arr.findIndex((b) => b.accountID === a.accountID) === i,\n )\n .slice(0, 3)\n .map((ancestor) => (\n <Avatar\n key={ancestor.account.id}\n url={ancestor.account.avatar}\n alt={ancestor.account.displayName}\n />\n ))}\n {/* <Icon icon=\"comment\" />{' '} */}\n {ancestors.length > 3 && (\n <>\n {' '}\n <span class=\"insignificant\">\n {shortenNumber(ancestors.length)}\n </span>\n </>\n )}\n </button>\n </>\n )}\n </h1>\n <div class=\"header-side\">\n <button\n type=\"button\"\n class=\"plain4 button-switch-view\"\n style={{\n display: viewMode === 'full' ? '' : 'none',\n }}\n onClick={() => {\n setViewMode(null);\n searchParams.delete('media');\n searchParams.delete('media-only');\n searchParams.delete('view');\n setSearchParams(searchParams);\n }}\n title=\"Switch to Side Peek view\"\n >\n <Icon icon=\"layout4\" size=\"l\" />\n </button>\n <Menu2\n align=\"end\"\n portal={{\n // Need this, else the menu click will cause scroll jump\n target: scrollableRef.current,\n }}\n menuButton={\n <button type=\"button\" class=\"button plain4\">\n <Icon icon=\"more\" alt=\"Actions\" size=\"xl\" />\n </button>\n }\n >\n <MenuItem\n disabled={uiState === 'loading'}\n onClick={() => {\n states.reloadStatusPage++;\n }}\n >\n <Icon icon=\"refresh\" />\n <span>Refresh</span>\n </MenuItem>\n <MenuItem\n className=\"menu-switch-view\"\n onClick={() => {\n setViewMode(viewMode === 'full' ? null : 'full');\n searchParams.delete('media');\n searchParams.delete('media-only');\n if (viewMode === 'full') {\n searchParams.delete('view');\n } else {\n searchParams.set('view', 'full');\n }\n setSearchParams(searchParams);\n }}\n >\n <Icon\n icon={\n {\n '': 'layout5',\n full: 'layout4',\n }[viewMode || '']\n }\n />\n <span>\n Switch to {viewMode === 'full' ? 'Side Peek' : 'Full'} view\n </span>\n </MenuItem>\n <MenuItem\n onClick={() => {\n // Click all buttons with class .spoiler but not .spoiling\n const buttons = Array.from(\n scrollableRef.current.querySelectorAll(\n '.spoiler-button:not(.spoiling), .spoiler-media-button:not(.spoiling)',\n ),\n );\n buttons.forEach((button) => {\n button.click();\n });\n }}\n >\n <Icon icon=\"eye-open\" /> <span>Show all sensitive content</span>\n </MenuItem>\n <MenuDivider />\n <MenuHeader className=\"plain\">Experimental</MenuHeader>\n <MenuItem\n disabled={!postInstance || postSameInstance}\n onClick={() => {\n const statusURL = getInstanceStatusURL(heroStatus.url);\n if (statusURL) {\n location.hash = statusURL;\n } else {\n alert('Unable to switch');\n }\n }}\n >\n <Icon icon=\"transfer\" />\n <small class=\"menu-double-lines\">\n Switch to post's instance\n {postInstance ? (\n <>\n {' '}\n (<b>{postInstance}</b>)\n </>\n ) : (\n ''\n )}\n </small>\n </MenuItem>\n </Menu2>\n <Link class=\"button plain deck-close\" to={closeLink}>\n <Icon icon=\"x\" size=\"xl\" />\n </Link>\n </div>\n </div>\n </header>\n {!!statuses.length && heroStatus ? (\n <ul\n class={`timeline flat contextual grow ${\n uiState === 'loading' ? 'loading' : ''\n }`}\n >\n {statuses.slice(0, limit).map(renderStatus)}\n {showMore > 0 && (\n <li>\n <button\n type=\"button\"\n class=\"plain block show-more\"\n disabled={uiState === 'loading'}\n onClick={() => setLimit((l) => l + LIMIT)}\n style={{ marginBlockEnd: '6em' }}\n data-state-post-ids={moreStatusesKeys.join(' ')}\n >\n <div class=\"ib avatars-bunch\">\n {/* show avatars for first 5 statuses */}\n {statuses.slice(limit, limit + 5).map((status) => (\n <Avatar\n key={status.id}\n url={status.account.avatarStatic}\n // title={`${status.avatar.displayName} (@${status.avatar.acct})`}\n />\n ))}\n </div>{' '}\n <div class=\"ib\">\n Show more…{' '}\n <span class=\"tag\">\n {showMore > LIMIT ? `${LIMIT}+` : showMore}\n </span>\n </div>\n </button>\n </li>\n )}\n </ul>\n ) : (\n <>\n {uiState === 'loading' && (\n <ul class=\"timeline flat contextual grow loading\">\n <li>\n <Status skeleton size=\"l\" />\n </li>\n </ul>\n )}\n {uiState === 'error' && (\n <p class=\"ui-state\">\n Unable to load post\n <br />\n <br />\n <button\n type=\"button\"\n onClick={() => {\n states.reloadStatusPage++;\n }}\n >\n Try again\n </button>\n </p>\n )}\n </>\n )}\n </div>\n );\n}\n\nfunction SubComments({\n replies,\n instance,\n hasParentThread,\n level,\n accWeight,\n openAll,\n}) {\n const [searchParams, setSearchParams] = useSearchParams();\n\n // Total comments count, including sub-replies\n const diveDeep = (replies) => {\n return replies.reduce((acc, reply) => {\n const { repliesCount, replies } = reply;\n const count = replies?.length || repliesCount;\n return acc + count + diveDeep(replies || []);\n }, 0);\n };\n const totalComments = replies.length + diveDeep(replies);\n const sameCount = replies.length === totalComments;\n\n // Get the first 3 accounts, unique by id\n const accounts = replies\n .map((r) => r.account)\n .filter((a, i, arr) => arr.findIndex((b) => b.id === a.id) === i)\n .slice(0, 3);\n\n const totalWeight = useMemo(() => {\n return replies?.reduce((acc, reply) => {\n return acc + reply?.weight;\n }, accWeight);\n }, [accWeight, replies?.length]);\n\n let open = false;\n if (openAll) {\n open = true;\n } else if (totalWeight <= MAX_WEIGHT) {\n open = true;\n } else if (!hasParentThread && totalComments === 1) {\n const shortReply = calcStatusWeight(replies[0]) < 2;\n if (shortReply) open = true;\n }\n const openBefore = cachedRepliesToggle[replies[0].id];\n\n const handleMediaClick = useCallback((e, i, media, status) => {\n e.preventDefault();\n e.stopPropagation();\n setSearchParams({\n media: i + 1,\n mediaStatusID: status.id,\n });\n }, []);\n\n const detailsRef = useRef();\n useLayoutEffect(() => {\n function handleScroll(e) {\n e.target.dataset.scrollLeft = e.target.scrollLeft;\n }\n detailsRef.current?.addEventListener('scroll', handleScroll, {\n passive: true,\n });\n return () => {\n detailsRef.current?.removeEventListener('scroll', handleScroll);\n };\n }, []);\n\n return (\n <details\n ref={detailsRef}\n class=\"replies\"\n open={openBefore || open}\n onToggle={(e) => {\n const { open } = e.target;\n // use first reply as ID\n cachedRepliesToggle[replies[0].id] = open;\n }}\n style={{\n '--comments-level': level,\n }}\n data-comments-level={level}\n data-comments-level-overflow={level > 4}\n >\n <summary class=\"replies-summary\" hidden={open}>\n <span class=\"avatars\">\n {accounts.map((a) => (\n <Avatar\n key={a.id}\n url={a.avatarStatic}\n title={`${a.displayName} @${a.username}`}\n squircle={a?.bot}\n />\n ))}\n </span>\n <b>\n <span title={replies.length}>{shortenNumber(replies.length)}</span>{' '}\n repl\n {replies.length === 1 ? 'y' : 'ies'}\n </b>\n {!sameCount && totalComments > 1 && (\n <>\n {' '}\n ·{' '}\n <span>\n <span title={totalComments}>{shortenNumber(totalComments)}</span>{' '}\n comment\n {totalComments === 1 ? '' : 's'}\n </span>\n </>\n )}\n </summary>\n <ul>\n {replies.map((r) => (\n <li key={r.id}>\n <Link\n class=\"status-link\"\n to={instance ? `/${instance}/s/${r.id}` : `/s/${r.id}`}\n onClick={() => {\n resetScrollPosition(r.id);\n }}\n >\n {/* <div class=\"status-focus\" tabIndex={0}> */}\n <Status\n statusID={r.id}\n instance={instance}\n withinContext\n size=\"s\"\n enableTranslate\n onMediaClick={handleMediaClick}\n />\n {!r.replies?.length && r.repliesCount > 0 && (\n <div class=\"replies-link\">\n <Icon icon=\"comment2\" />{' '}\n <span title={r.repliesCount}>\n {shortenNumber(r.repliesCount)}\n </span>\n </div>\n )}\n {/* </div> */}\n </Link>\n {r.replies?.length && (\n <SubComments\n instance={instance}\n replies={r.replies}\n level={level + 1}\n accWeight={!open ? r.weight : totalWeight}\n openAll={openAll}\n />\n )}\n </li>\n ))}\n </ul>\n </details>\n );\n}\n\nconst MEDIA_VIRTUAL_LENGTH = 140;\nconst POLL_VIRTUAL_LENGTH = 35;\nconst CARD_VIRTUAL_LENGTH = 70;\nconst WEIGHT_SEGMENT = 140;\nconst statusWeightCache = new Map();\nfunction calcStatusWeight(status) {\n const cachedWeight = statusWeightCache.get(status.id);\n if (cachedWeight) return cachedWeight;\n const { spoilerText, content, mediaAttachments, poll, card } = status;\n const length = htmlContentLength(spoilerText + content);\n const mediaLength = mediaAttachments?.length ? MEDIA_VIRTUAL_LENGTH : 0;\n const pollLength = (poll?.options?.length || 0) * POLL_VIRTUAL_LENGTH;\n const cardLength =\n card && (mediaAttachments?.length || poll?.options?.length)\n ? 0\n : CARD_VIRTUAL_LENGTH;\n const totalLength = length + mediaLength + pollLength + cardLength;\n const weight = totalLength / WEIGHT_SEGMENT;\n statusWeightCache.set(status.id, weight);\n return weight;\n}\n\nexport default memo(StatusPage);\n","import { useParams } from 'react-router-dom';\n\nimport Status from './status';\n\nexport default function StatusRoute() {\n const params = useParams();\n const { id, instance } = params;\n return <Status id={id} instance={instance} />;\n}\n","export default \"__VITE_ASSET__W5CngKHO__\"","export default \"__VITE_ASSET__vmqRZ5q5__\"","export default \"__VITE_ASSET__DFAo1Udm__\"","export default \"__VITE_ASSET__D2_o1n6___\"","export default \"__VITE_ASSET__ySLnBMku__\"","export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xml:space='preserve'%20fill-rule='evenodd'%20stroke-linejoin='round'%20stroke-miterlimit='2'%20clip-rule='evenodd'%20viewBox='0%200%20102%2028'%3e%3cpath%20fill='none'%20d='M0%200h101.5v27.5H0z'/%3e%3cg%20fill-rule='nonzero'%3e%3cpath%20fill='url(%23a)'%20d='M2.32%2021.85c1.4%200%202.21-.85%202.21-2.3v-4.64H8.5c4.45%200%207.54-2.9%207.54-7.24%200-4.35-2.98-7.24-7.32-7.24h-6.4C.93.43.11%201.28.11%202.73v16.82c0%201.45.82%202.3%202.21%202.3Zm2.21-10.4V3.94h3c2.54%200%204%201.34%204%203.75s-1.47%203.76-4%203.76h-3Z'/%3e%3cpath%20fill='url(%23b)'%20d='M20.52%2021.88c1.25%200%202.13-.76%202.13-2.23v-7.04c0-2.07%201.2-3.49%203.21-3.49%201.95%200%202.95%201.23%202.95%203.25v7.28c0%201.47.89%202.23%202.13%202.23%201.26%200%202.14-.76%202.14-2.23v-8.18c0-3.64-1.99-5.9-5.48-5.9-2.38%200-4.1%201.12-4.93%203.1h-.09V2.3c0-1.38-.78-2.2-2.1-2.2-1.31%200-2.1.82-2.1%202.2v17.34c0%201.47.9%202.23%202.14%202.23Z'/%3e%3cpath%20fill='url(%23c)'%20d='M40.45%2021.82c1.96%200%203.93-.98%204.8-2.65h.1v.8c.08%201.27.89%201.91%202.05%201.91%201.21%200%202.08-.73%202.08-2.15v-8.95c0-3.17-2.63-5.25-6.65-5.25-3.26%200-5.78%201.16-6.5%203.04-.15.32-.23.63-.23.96%200%20.97.75%201.64%201.79%201.64.69%200%201.23-.26%201.7-.79.95-1.23%201.74-1.65%203.04-1.65%201.62%200%202.64.85%202.64%202.31v1.04l-3.95.24c-3.93.23-6.13%201.88-6.13%204.74%200%202.83%202.27%204.76%205.26%204.76Zm1.4-3.09c-1.43%200-2.4-.73-2.4-1.9%200-1.12.91-1.83%202.51-1.95l3.31-.2v1.14c0%201.7-1.54%202.91-3.41%202.91Z'/%3e%3cpath%20fill='url(%23d)'%20d='M54.37%2021.88c1.26%200%202.14-.76%202.14-2.23v-7.09c0-2.03%201.21-3.44%203.13-3.44s2.89%201.17%202.89%203.22v7.31c0%201.47.88%202.23%202.14%202.23%201.24%200%202.13-.76%202.13-2.23v-8.2c0-3.68-1.96-5.87-5.45-5.87-2.41%200-4%201.07-4.83%203.01h-.09v-.87c0-1.35-.85-2.17-2.14-2.17-1.28%200-2.06.82-2.06%202.15v11.95c0%201.47.9%202.23%202.14%202.23Z'/%3e%3cpath%20fill='url(%23e)'%20d='M71.65%2027.17c1.26%200%202.14-.76%202.14-2.23v-6h.09a5.15%205.15%200%200%200%204.88%202.88c3.92%200%206.35-3.05%206.35-8.1%200-5.07-2.44-8.1-6.43-8.1a5.12%205.12%200%200%200-4.86%202.99h-.09v-.85c0-1.45-.88-2.21-2.1-2.21-1.24%200-2.11.76-2.11%202.2v17.2c0%201.46.89%202.22%202.13%202.22Zm5.6-8.8c-2.1%200-3.47-1.8-3.47-4.65%200-2.81%201.37-4.67%203.47-4.67%202.14%200%203.49%201.83%203.49%204.67%200%202.86-1.35%204.66-3.5%204.66Z'/%3e%3cpath%20fill='url(%23f)'%20d='M89.61%2027.39c3.44%200%205.26-1.5%206.73-5.55l4.81-13.1a4%204%200%200%200%20.24-1.26c0-1.13-.85-1.93-2.08-1.93-1.1%200-1.71.51-2.07%201.7l-3.4%2010.9h-.08L90.35%207.28c-.36-1.25-.94-1.73-2.07-1.73-1.26%200-2.21.83-2.21%201.99%200%20.35.09.82.25%201.26l5%2013.21-.21.56c-.52%201.1-1.32%201.42-2.07%201.42l-.75-.01c-.96%200-1.56.54-1.56%201.4%200%201.29%201%202%202.88%202Z'/%3e%3c/g%3e%3cdefs%3e%3cradialGradient%20id='a'%20cx='0'%20cy='0'%20r='1'%20gradientTransform='rotate(28.51%20.06%20.22)%20scale(57.6252)'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20offset='0'%20stop-color='%23a4bff7'/%3e%3cstop%20offset='1'%20stop-color='%236081e6'/%3e%3c/radialGradient%3e%3cradialGradient%20id='b'%20cx='0'%20cy='0'%20r='1'%20gradientTransform='rotate(28.51%20.06%20.22)%20scale(57.6252)'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20offset='0'%20stop-color='%23a4bff7'/%3e%3cstop%20offset='1'%20stop-color='%236081e6'/%3e%3c/radialGradient%3e%3cradialGradient%20id='c'%20cx='0'%20cy='0'%20r='1'%20gradientTransform='rotate(28.51%20.06%20.22)%20scale(57.6252)'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20offset='0'%20stop-color='%23a4bff7'/%3e%3cstop%20offset='1'%20stop-color='%236081e6'/%3e%3c/radialGradient%3e%3cradialGradient%20id='d'%20cx='0'%20cy='0'%20r='1'%20gradientTransform='rotate(28.51%20.06%20.22)%20scale(57.6252)'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20offset='0'%20stop-color='%23a4bff7'/%3e%3cstop%20offset='1'%20stop-color='%236081e6'/%3e%3c/radialGradient%3e%3cradialGradient%20id='e'%20cx='0'%20cy='0'%20r='1'%20gradientTransform='rotate(28.51%20.06%20.22)%20scale(57.6252)'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20offset='0'%20stop-color='%23a4bff7'/%3e%3cstop%20offset='1'%20stop-color='%236081e6'/%3e%3c/radialGradient%3e%3cradialGradient%20id='f'%20cx='0'%20cy='0'%20r='1'%20gradientTransform='rotate(28.51%20.06%20.22)%20scale(57.6252)'%20gradientUnits='userSpaceOnUse'%3e%3cstop%20offset='0'%20stop-color='%23a4bff7'/%3e%3cstop%20offset='1'%20stop-color='%236081e6'/%3e%3c/radialGradient%3e%3c/defs%3e%3c/svg%3e\"","import './welcome.css';\n\nimport boostsCarouselUrl from '../assets/features/boosts-carousel.jpg';\nimport groupedNotificationsUrl from '../assets/features/grouped-notifications.jpg';\nimport multiColumnUrl from '../assets/features/multi-column.jpg';\nimport multiHashtagTimelineUrl from '../assets/features/multi-hashtag-timeline.jpg';\nimport nestedCommentsThreadUrl from '../assets/features/nested-comments-thread.jpg';\nimport logoText from '../assets/logo-text.svg';\nimport logo from '../assets/logo.svg';\n\nimport Link from '../components/link';\nimport states from '../utils/states';\nimport useTitle from '../utils/useTitle';\n\nconst {\n PHANPY_DEFAULT_INSTANCE: DEFAULT_INSTANCE,\n PHANPY_WEBSITE: WEBSITE,\n PHANPY_PRIVACY_POLICY_URL: PRIVACY_POLICY_URL,\n PHANPY_DEFAULT_INSTANCE_REGISTRATION_URL: DEFAULT_INSTANCE_REGISTRATION_URL,\n} = import.meta.env;\nconst appSite = WEBSITE\n ? WEBSITE.replace(/https?:\\/\\//g, '').replace(/\\/$/, '')\n : null;\nconst appVersion = __BUILD_TIME__\n ? `${__BUILD_TIME__.slice(0, 10).replace(/-/g, '.')}${\n __COMMIT_HASH__ ? `.${__COMMIT_HASH__}` : ''\n }`\n : null;\n\nfunction Welcome() {\n useTitle(null, ['/', '/welcome']);\n return (\n <main id=\"welcome\">\n <div class=\"hero-container\">\n <div class=\"hero-content\">\n <h1>\n <img\n src={logo}\n alt=\"\"\n width=\"160\"\n height=\"160\"\n style={{\n aspectRatio: '1/1',\n marginBlockEnd: -16,\n }}\n />\n <img src={logoText} alt=\"Phanpy\" width=\"200\" />\n </h1>\n <p class=\"desc\">A minimalistic opinionated Mastodon web client.</p>\n <p>\n <Link\n to={\n DEFAULT_INSTANCE\n ? `/login?instance=${DEFAULT_INSTANCE}&submit=1`\n : '/login'\n }\n class=\"button\"\n >\n {DEFAULT_INSTANCE ? 'Log in' : 'Log in with Mastodon'}\n </Link>\n </p>\n {DEFAULT_INSTANCE && DEFAULT_INSTANCE_REGISTRATION_URL && (\n <p>\n <a href={DEFAULT_INSTANCE_REGISTRATION_URL} class=\"button plain5\">\n Sign up\n </a>\n </p>\n )}\n {!DEFAULT_INSTANCE && (\n <p class=\"insignificant\">\n <small>\n Connect your existing Mastodon/Fediverse account.\n <br />\n Your credentials are not stored on this server.\n </small>\n </p>\n )}\n </div>\n {(appSite || appVersion) && (\n <p class=\"app-site-version\">\n <small>\n {appSite} {appVersion}\n </small>\n </p>\n )}\n <p>\n <a href=\"https://github.com/cheeaun/phanpy\" target=\"_blank\">\n Built\n </a>{' '}\n by{' '}\n <a\n href=\"https://mastodon.social/@cheeaun\"\n target=\"_blank\"\n onClick={(e) => {\n e.preventDefault();\n states.showAccount = 'cheeaun@mastodon.social';\n }}\n >\n @cheeaun\n </a>\n .{' '}\n <a href={PRIVACY_POLICY_URL} target=\"_blank\">\n Privacy Policy\n </a>\n .\n </p>\n </div>\n <div id=\"why-container\">\n <div class=\"sections\">\n <section>\n <img\n src={boostsCarouselUrl}\n alt=\"Screenshot of Boosts Carousel\"\n loading=\"lazy\"\n />\n <h4>Boosts Carousel</h4>\n <p>\n Visually separate original posts and re-shared posts (boosted\n posts).\n </p>\n </section>\n <section>\n <img\n src={nestedCommentsThreadUrl}\n alt=\"Screenshot of nested comments thread\"\n loading=\"lazy\"\n />\n <h4>Nested comments thread</h4>\n <p>Effortlessly follow conversations. Semi-collapsible replies.</p>\n </section>\n <section>\n <img\n src={groupedNotificationsUrl}\n alt=\"Screenshot of grouped notifications\"\n loading=\"lazy\"\n />\n <h4>Grouped notifications</h4>\n <p>\n Similar notifications are grouped and collapsed to reduce clutter.\n </p>\n </section>\n <section>\n <img\n src={multiColumnUrl}\n alt=\"Screenshot of multi-column UI\"\n loading=\"lazy\"\n />\n <h4>Single or multi-column</h4>\n <p>\n By default, single column for zen-mode seekers. Configurable\n multi-column for power users.\n </p>\n </section>\n <section>\n <img\n src={multiHashtagTimelineUrl}\n alt=\"Screenshot of multi-hashtag timeline with a form to add more hashtags\"\n loading=\"lazy\"\n />\n <h4>Multi-hashtag timeline</h4>\n <p>Up to 5 hashtags combined into a single timeline.</p>\n </section>\n </div>\n </div>\n </main>\n );\n}\n\nexport default Welcome;\n","// Replace alert() with toastify-js\nimport Toastify from 'toastify-js';\n\nconst nativeAlert = window.alert;\nif (!window.__nativeAlert) window.__nativeAlert = nativeAlert;\n\nwindow.alert = function (message) {\n console.debug(\n 'ALERT: This is a custom alert() function. Native alert() is still available as window.__nativeAlert()',\n );\n // If Error object, show the message\n if (message instanceof Error && message?.message) {\n message = message.message;\n }\n // If not string, stringify it\n if (typeof message !== 'string') {\n message = JSON.stringify(message);\n }\n\n const toast = Toastify({\n text: message,\n className: 'alert',\n gravity: 'top',\n position: 'center',\n duration: 10_000,\n offset: {\n y: 48,\n },\n onClick: () => {\n toast.hideToast();\n },\n });\n toast.showToast();\n};\n","import './app.css';\n\nimport debounce from 'just-debounce-it';\nimport {\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'preact/hooks';\nimport { matchPath, Route, Routes, useLocation } from 'react-router-dom';\nimport 'swiped-events';\nimport { subscribe } from 'valtio';\n\nimport BackgroundService from './components/background-service';\nimport ComposeButton from './components/compose-button';\nimport { ICONS } from './components/icon';\nimport KeyboardShortcutsHelp from './components/keyboard-shortcuts-help';\nimport Loader from './components/loader';\nimport Modals from './components/modals';\nimport NotificationService from './components/notification-service';\nimport SearchCommand from './components/search-command';\nimport Shortcuts from './components/shortcuts';\nimport NotFound from './pages/404';\nimport AccountStatuses from './pages/account-statuses';\nimport Bookmarks from './pages/bookmarks';\nimport Favourites from './pages/favourites';\nimport FollowedHashtags from './pages/followed-hashtags';\nimport Following from './pages/following';\nimport Hashtag from './pages/hashtag';\nimport Home from './pages/home';\nimport HttpRoute from './pages/http-route';\nimport List from './pages/list';\nimport Lists from './pages/lists';\nimport Login from './pages/login';\nimport Mentions from './pages/mentions';\nimport Notifications from './pages/notifications';\nimport Public from './pages/public';\nimport Search from './pages/search';\nimport StatusRoute from './pages/status-route';\nimport Trending from './pages/trending';\nimport Welcome from './pages/welcome';\nimport {\n api,\n initAccount,\n initClient,\n initInstance,\n initPreferences,\n} from './utils/api';\nimport { getAccessToken } from './utils/auth';\nimport focusDeck from './utils/focus-deck';\nimport states, { initStates, statusKey } from './utils/states';\nimport store from './utils/store';\nimport { getCurrentAccount } from './utils/store-utils';\nimport './utils/toast-alert';\n\nwindow.__STATES__ = states;\nwindow.__STATES_STATS__ = () => {\n const keys = [\n 'statuses',\n 'accounts',\n 'spoilers',\n 'unfurledLinks',\n 'statusQuotes',\n ];\n const counts = {};\n keys.forEach((key) => {\n counts[key] = Object.keys(states[key]).length;\n });\n console.warn('STATE stats', counts);\n\n const { statuses } = states;\n const unmountedPosts = [];\n for (const key in statuses) {\n const $post = document.querySelector(\n `[data-state-post-id~=\"${key}\"], [data-state-post-ids~=\"${key}\"]`,\n );\n if (!$post) {\n unmountedPosts.push(key);\n }\n }\n console.warn('Unmounted posts', unmountedPosts.length, unmountedPosts);\n};\n\n// Experimental \"garbage collection\" for states\n// Every 15 minutes\n// Only posts for now\nsetInterval(() => {\n if (!window.__IDLE__) return;\n const { statuses, unfurledLinks, notifications } = states;\n let keysCount = 0;\n const { instance } = api();\n for (const key in statuses) {\n if (!window.__IDLE__) break;\n try {\n const $post = document.querySelector(\n `[data-state-post-id~=\"${key}\"], [data-state-post-ids~=\"${key}\"]`,\n );\n const postInNotifications = notifications.some(\n (n) => key === statusKey(n.status?.id, instance),\n );\n if (!$post && !postInNotifications) {\n delete states.statuses[key];\n delete states.statusQuotes[key];\n for (const link in unfurledLinks) {\n const unfurled = unfurledLinks[link];\n const sKey = statusKey(unfurled.id, unfurled.instance);\n if (sKey === key) {\n delete states.unfurledLinks[link];\n break;\n }\n }\n keysCount++;\n }\n } catch (e) {}\n }\n if (keysCount) {\n console.info(`GC: Removed ${keysCount} keys`);\n }\n}, 15 * 60 * 1000);\n\n// Preload icons\n// There's probably a better way to do this\n// Related: https://github.com/vitejs/vite/issues/10600\nsetTimeout(() => {\n for (const icon in ICONS) {\n queueMicrotask(() => {\n if (Array.isArray(ICONS[icon])) {\n ICONS[icon][0]?.();\n } else {\n ICONS[icon]?.();\n }\n });\n }\n}, 5000);\n\n(() => {\n window.__IDLE__ = true;\n const nonIdleEvents = [\n 'mousemove',\n 'mousedown',\n 'resize',\n 'keydown',\n 'touchstart',\n 'pointerdown',\n 'pointermove',\n 'wheel',\n ];\n const setIdle = () => {\n window.__IDLE__ = true;\n };\n const IDLE_TIME = 3_000; // 3 seconds\n const debouncedSetIdle = debounce(setIdle, IDLE_TIME);\n const onNonIdle = () => {\n window.__IDLE__ = false;\n debouncedSetIdle();\n };\n nonIdleEvents.forEach((event) => {\n window.addEventListener(event, onNonIdle, {\n passive: true,\n capture: true,\n });\n });\n window.addEventListener('blur', setIdle, {\n passive: true,\n });\n // When cursor leaves the window, set idle\n document.documentElement.addEventListener(\n 'mouseleave',\n (e) => {\n if (!e.relatedTarget && !e.toElement) {\n setIdle();\n }\n },\n {\n passive: true,\n },\n );\n // document.addEventListener(\n // 'visibilitychange',\n // () => {\n // if (document.visibilityState === 'visible') {\n // onNonIdle();\n // }\n // },\n // {\n // passive: true,\n // },\n // );\n})();\n\n// Possible fix for iOS PWA theme-color bug\n// It changes when loading web pages in \"webview\"\nconst isIOS = /iPad|iPhone|iPod/.test(navigator.userAgent);\nif (isIOS) {\n document.addEventListener('visibilitychange', () => {\n if (document.visibilityState === 'visible') {\n const theme = store.local.get('theme');\n let $meta;\n if (theme) {\n // Get current meta\n $meta = document.querySelector(\n `meta[name=\"theme-color\"][data-theme-setting=\"manual\"]`,\n );\n if ($meta) {\n const color = $meta.content;\n const tempColor =\n theme === 'light'\n ? $meta.dataset.themeLightColorTemp\n : $meta.dataset.themeDarkColorTemp;\n $meta.content = tempColor || '';\n setTimeout(() => {\n $meta.content = color;\n }, 10);\n }\n } else {\n // Get current color scheme\n const colorScheme = window.matchMedia('(prefers-color-scheme: dark)')\n .matches\n ? 'dark'\n : 'light';\n // Get current theme-color\n $meta = document.querySelector(\n `meta[name=\"theme-color\"][media*=\"${colorScheme}\"]`,\n );\n if ($meta) {\n const color = $meta.dataset.content;\n const tempColor = $meta.dataset.contentTemp;\n $meta.content = tempColor || '';\n setTimeout(() => {\n $meta.content = color;\n }, 10);\n }\n }\n }\n });\n}\n\n{\n const theme = store.local.get('theme');\n // If there's a theme, it's NOT auto\n if (theme) {\n // dark | light\n document.documentElement.classList.add(`is-${theme}`);\n document\n .querySelector('meta[name=\"color-scheme\"]')\n .setAttribute('content', theme || 'dark light');\n\n // Enable manual theme <meta>\n const $manualMeta = document.querySelector(\n 'meta[data-theme-setting=\"manual\"]',\n );\n if ($manualMeta) {\n $manualMeta.name = 'theme-color';\n $manualMeta.content =\n theme === 'light'\n ? $manualMeta.dataset.themeLightColor\n : $manualMeta.dataset.themeDarkColor;\n }\n // Disable auto theme <meta>s\n const $autoMetas = document.querySelectorAll(\n 'meta[data-theme-setting=\"auto\"]',\n );\n $autoMetas.forEach((m) => {\n m.name = '';\n });\n }\n const textSize = store.local.get('textSize');\n if (textSize) {\n document.documentElement.style.setProperty('--text-size', `${textSize}px`);\n }\n}\n\nsubscribe(states, (changes) => {\n for (const [action, path, value, prevValue] of changes) {\n // Change #app dataset based on settings.shortcutsViewMode\n if (path.join('.') === 'settings.shortcutsViewMode') {\n const $app = document.getElementById('app');\n if ($app) {\n $app.dataset.shortcutsViewMode = states.shortcuts?.length ? value : '';\n }\n }\n\n // Add/Remove cloak class to body\n if (path.join('.') === 'settings.cloakMode') {\n const $body = document.body;\n $body.classList.toggle('cloak', value);\n }\n }\n});\n\nfunction App() {\n const [isLoggedIn, setIsLoggedIn] = useState(false);\n const [uiState, setUIState] = useState('loading');\n\n useEffect(() => {\n const instanceURL = store.local.get('instanceURL');\n const code = decodeURIComponent(\n (window.location.search.match(/code=([^&]+)/) || [, ''])[1],\n );\n\n if (code) {\n console.log({ code });\n // Clear the code from the URL\n window.history.replaceState(\n {},\n document.title,\n window.location.pathname || '/',\n );\n\n const clientID = store.session.get('clientID');\n const clientSecret = store.session.get('clientSecret');\n const vapidKey = store.session.get('vapidKey');\n\n (async () => {\n setUIState('loading');\n const { access_token: accessToken } = await getAccessToken({\n instanceURL,\n client_id: clientID,\n client_secret: clientSecret,\n code,\n });\n\n const client = initClient({ instance: instanceURL, accessToken });\n await Promise.allSettled([\n initInstance(client, instanceURL),\n initAccount(client, instanceURL, accessToken, vapidKey),\n ]);\n initStates();\n initPreferences(client);\n\n setIsLoggedIn(true);\n setUIState('default');\n })();\n } else {\n window.__IGNORE_GET_ACCOUNT_ERROR__ = true;\n const account = getCurrentAccount();\n if (account) {\n store.session.set('currentAccount', account.info.id);\n const { client } = api({ account });\n const { instance } = client;\n // console.log('masto', masto);\n initStates();\n initPreferences(client);\n setUIState('loading');\n (async () => {\n try {\n await initInstance(client, instance);\n } catch (e) {\n } finally {\n setIsLoggedIn(true);\n setUIState('default');\n }\n })();\n } else {\n setUIState('default');\n }\n }\n }, []);\n\n let location = useLocation();\n states.currentLocation = location.pathname;\n // useLayoutEffect(() => {\n // states.currentLocation = location.pathname;\n // }, [location.pathname]);\n\n useEffect(focusDeck, [location, isLoggedIn]);\n\n if (/\\/https?:/.test(location.pathname)) {\n return <HttpRoute />;\n }\n\n return (\n <>\n <PrimaryRoutes isLoggedIn={isLoggedIn} loading={uiState === 'loading'} />\n <SecondaryRoutes isLoggedIn={isLoggedIn} />\n {uiState === 'default' && (\n <Routes>\n <Route path=\"/:instance?/s/:id\" element={<StatusRoute />} />\n </Routes>\n )}\n {isLoggedIn && <ComposeButton />}\n {isLoggedIn && <Shortcuts />}\n <Modals />\n {isLoggedIn && <NotificationService />}\n <BackgroundService isLoggedIn={isLoggedIn} />\n {uiState !== 'loading' && <SearchCommand onClose={focusDeck} />}\n <KeyboardShortcutsHelp />\n </>\n );\n}\n\nfunction PrimaryRoutes({ isLoggedIn, loading }) {\n const location = useLocation();\n const nonRootLocation = useMemo(() => {\n const { pathname } = location;\n return !/^\\/(login|welcome)/.test(pathname);\n }, [location]);\n\n return (\n <Routes location={nonRootLocation || location}>\n <Route\n path=\"/\"\n element={\n isLoggedIn ? (\n <Home />\n ) : loading ? (\n <Loader id=\"loader-root\" />\n ) : (\n <Welcome />\n )\n }\n />\n <Route path=\"/login\" element={<Login />} />\n <Route path=\"/welcome\" element={<Welcome />} />\n </Routes>\n );\n}\n\nfunction getPrevLocation() {\n return states.prevLocation || null;\n}\nfunction SecondaryRoutes({ isLoggedIn }) {\n // const snapStates = useSnapshot(states);\n const location = useLocation();\n // const prevLocation = snapStates.prevLocation;\n const backgroundLocation = useRef(getPrevLocation());\n\n const isModalPage = useMemo(() => {\n return (\n matchPath('/:instance/s/:id', location.pathname) ||\n matchPath('/s/:id', location.pathname)\n );\n }, [location.pathname, matchPath]);\n if (isModalPage) {\n if (!backgroundLocation.current)\n backgroundLocation.current = getPrevLocation();\n } else {\n backgroundLocation.current = null;\n }\n console.debug({\n backgroundLocation: backgroundLocation.current,\n location,\n });\n\n return (\n <Routes location={backgroundLocation.current || location}>\n {isLoggedIn && (\n <>\n <Route path=\"/notifications\" element={<Notifications />} />\n <Route path=\"/mentions\" element={<Mentions />} />\n <Route path=\"/following\" element={<Following />} />\n <Route path=\"/b\" element={<Bookmarks />} />\n <Route path=\"/f\" element={<Favourites />} />\n <Route path=\"/l\">\n <Route index element={<Lists />} />\n <Route path=\":id\" element={<List />} />\n </Route>\n <Route path=\"/ft\" element={<FollowedHashtags />} />\n </>\n )}\n <Route path=\"/:instance?/t/:hashtag\" element={<Hashtag />} />\n <Route path=\"/:instance?/a/:id\" element={<AccountStatuses />} />\n <Route path=\"/:instance?/p\">\n <Route index element={<Public />} />\n <Route path=\"l\" element={<Public local />} />\n </Route>\n <Route path=\"/:instance?/trending\" element={<Trending />} />\n <Route path=\"/:instance?/search\" element={<Search />} />\n {/* <Route path=\"/:anything\" element={<NotFound />} /> */}\n </Routes>\n );\n}\n\nexport { App };\n","import './index.css';\n\nimport './cloak-mode.css';\n\nimport { render } from 'preact';\nimport { HashRouter } from 'react-router-dom';\n\nimport { App } from './app';\n\nif (import.meta.env.DEV) {\n import('preact/debug');\n}\n\n// AbortSignal.timeout polyfill\n// Temporary fix from https://github.com/mo/abortcontroller-polyfill/issues/73#issuecomment-1541180943\n// Incorrect implementation, but should be good enough for now\nif ('AbortSignal' in window) {\n AbortSignal.timeout =\n AbortSignal.timeout ||\n ((duration) => {\n const controller = new AbortController();\n setTimeout(() => controller.abort(), duration);\n return controller.signal;\n });\n}\n\nrender(\n <HashRouter>\n <App />\n </HashRouter>,\n document.getElementById('app'),\n);\n\n// Storage cleanup\nsetTimeout(() => {\n try {\n // Clean up iconify localStorage\n Object.keys(localStorage).forEach((key) => {\n if (key.startsWith('iconify')) {\n localStorage.removeItem(key);\n }\n });\n Object.keys(sessionStorage).forEach((key) => {\n if (key.startsWith('iconify')) {\n sessionStorage.removeItem(key);\n }\n });\n\n // Clean up old settings key\n localStorage.removeItem('settings:boostsCarousel');\n } catch (e) {}\n}, 5000);\n\nwindow.__CLOAK__ = () => {\n document.body.classList.toggle('cloak');\n};\n"],"names":["usePageVisibility","fn","deps","savedCallback","useRef","useEffect","current","handleVisibilityChange","hidden","document","visibilityState","console","STREAMING_TIMEOUT","POLL_INTERVAL","BackgroundService","memo","isLoggedIn","visible","setVisible","useState","checkLatestNotification","masto","instance","skipCheckMarkers","states","notificationsLast","notificationsIterator","v1","notifications","list","limit","sinceId","id","value","next","length","notificationsShowNew","lastReadId","markers","fetch","timeline","sub","pollNotifications","streaming","api","hasStreaming","setTimeout","user","notification","subscribe","log","entry","_a","checkForUpdates","clearTimeout","clearInterval","r","info","visible2","lastCheckDate","useHotkeys","currentCloakMode","Date","diff","ComposeButton","handleButton","e","shiftKey","openCompose","showCompose","ignoreEventWhen","querySelector","_jsx","type","onClick","children","Icon","icon","size","alt","KeyboardShortcutsHelp","snapStates","useSnapshot","onClose","showKeyboardShortcutsHelp","hasModal","Modal","class","tabindex","action","keys","_jsxs","_Fragment","className","map","Accounts","accounts","store","local","getJSON","currentAccount","session","get","moreThanOneAccount","_","reload","useReducer","x","accountsListParent","useAutoAnimate","tabIndex","ref","account","i","isCurrent","isDefault","Avatar","url","avatarStatic","onDblClick","$select","NameText","test","showAcct","set","Menu2","align","menuButton","title","MenuItem","MenuDivider","disabled","splice","MenuConfirm","subMenu","confirmLabel","menuItemClassName","href","Link","to","logo","createBackendPushSubscription","subscription","push","create","fetchBackendPushSubscription","updateBackendPushSubscription","update","removeBackendPushSubscription","remove","isPushSupported","navigator","window","getRegistration","serviceWorker","getSubscription","registration","pushManager","undefined","urlBase64ToUint8Array","base64String","padding","repeat","base64","replace","rawData","atob","outputArray","Uint8Array","charCodeAt","initSubscription","backendSubscription","err","message","sameEndpoint","vapidKey","sameKey","getCurrentAccount","applicationServerKey","vapidKeyStr","applicationServerKeyStr","updateSubscription","data","policy","removeSubscription","userVisibleOnly","define_import_meta_env_default","focusDeck","timer","columns","getElementById","modals","querySelectorAll","modal","modalFocusElement","focus","backDrop","pages","page","useLocationChange","location","useLocation","currentLocationRef","pathname","ListAddEdit","uiState","setUIState","editMode","nameFieldRef","repliesPolicyFieldRef","exclusiveFieldRef","repliesPolicy","checked","exclusive","supportsExclusive","supports","onSubmit","preventDefault","formData","FormData","target","listResult","replies_policy","alert","MUTE_DURATIONS","MUTE_DURATIONS_LABELS","LIMIT","ACCOUNT_INFO_MAX_AGE","fetchFamiliarFollowers","currentID","familiarFollowers","memFetchFamiliarFollowers","pmem","maxAge","fetchPostingStats","accountID","fetchStatuses","statuses","total","originals","replies","status","stats","boosts","memFetchPostingStats","fetchAccount","standalone","authenticated","currentMasto","currentInstance","isString","useMemo","setInfo","sameCurrentInstance","info2","acct","avatar","bot","createdAt","displayName","emojis","fields","group","lastStatusAt","locked","note","statusesCount","username","memorial","moved","roles","header","headerStatic","headerIsAvatar","isSelf","infoHasEssentials","account2","updated","forEach","headerCornerColors","setHeaderCornerColors","followersIterator","domain","fetchFollowers","firstLoad","familiarFollowersCache","results","familiarFollowers2","newValue","familiar","followingIterator","LinkOrDiv","accountLink","postingStats","setPostingStats","renderFamiliarFollowers","setFamiliarFollowers","postingStatsUIState","setPostingStatsUIState","hasPostingStats","followers","renderPostingStats","onRelationshipChange","AccountBlock","src","canvas","add","pixelDimension","createElement","ctx","g","b","width","height","drawImage","colors","getImageData","a","dataLength","color","lightenRGB","rgbColors","avatarSize","external","role","accountInstance","handleContentLinks","enhanceContent","verifiedAt","__html","EmojiText","name","follower","heading","fetchAccounts","excludeRelationshipAttrs","shortenNumber","followersCount","fetchFollowing","followingCount","niceDateTime","FAMILIAR_FOLLOWERS_LIMIT","currentAuthenticated","relationship","privateNote","following","showingReblogs","notifying","followedBy","blocking","blockedBy","muting","mutingNotifications","requested","domainBlocking","endorsed","currentInfo","setIsSelf","q","fetchRelationships","relationships","setRelationshipUIState","relationship2","updateAccount","setRelationship","loading","relationshipUIState","showTranslatedBio","setShowPrivateNoteModal","showAddRemoveLists","showPrivateNoteModal","dir","setShowTranslatedBio","setShowAddRemoveLists","showToast","clipboard","share","newRelationship","openTrigger","duration","label","counter","Loader","confirm","AddRemoveListsSheet","PrivateNoteSheet","luminence","alpha","urlObj","host","path","TranslatedBioSheet","fieldsText","Math","getHTMLText","text","lists","setLists","listsContainingAccount","setListsContainingAccount","c","style","listsContainingAccount2","lists2","reloadCount","showListAddEditModal","setShowListAddEditModal","sort","l","inList","accountIds","result","abrupt","textareaRef","initialNote","e2","trim","AccountSheet","propInstance","AccountInfo","lookup","skip_webfinger","v2","search","resolve","URL","Drafts","drafts","setDrafts","db","ns","getCurrentAccountNS","ownKeys","filter","key","startsWith","getMany","updatedAt","getTime","hasDrafts","draft","draftStatus","replyTo","updatedAtDate","replyToStatus","MiniDraft","poll","spoilerText","mediaAttachments","hasPoll","options","hasMedia","firstImageMedia","media","image","file","objectURL","createObjectURL","hasPollOrMedia","relationshipsMap","uniqueAccountIds","reduce","acc","includes","GenericAccounts","isCurrentInstance","setAccounts","showMore","setShowMore","showGenericAccounts","staticAccounts","showReactions","setRelationshipsMap","loadRelationships","loadAccounts","done","Array","isArray","theAccount","find","j","_types","prev","newAccounts","reloadGenericAccounts","_b","reblog","favourite","showStats","InView","MediaAltModal","lang","forceTranslate","setForceTranslate","targetLanguage","getTranslateTargetLanguage","contentTranslationHideLanguages","settings","differentLanguage","localeMatch","supportsTTS","speak","whiteSpace","textWrap","TranslationBlock","sourceLanguage","clamp","min","max","gammaToLinear","pow","linearToGamma","rgb2oklab","m","s","cbrt","oklab2rgb","L","round","floatingButtonUrl","multiColumnUrl$1","tabMenuBarUrl","MAX_FETCH","fetchFollowedTags","iterator","followedTags","tags","fetchCount","localeCompare","MAX_AGE","getFollowedTags","fauxDiv","extractTagsFromStatus","content","hashtagLinks","AsyncText","setText","Promise","then","SHORTCUTS_LIMIT","TYPES","TYPE_TEXT","public","bookmarks","favourites","hashtag","trending","mentions","TYPE_PARAMS","placeholder","notRequired","pattern","fetchListTitle","fetchAccountTitle","SHORTCUTS_META","index","subtitle","query","excludeViewMode","split","join","ShortcutsSettings","shortcuts","showForm","setShowForm","showImportExport","setShowImportExport","shortcutsListParent","fontSize","opacity","textTransform","imgURL","multiColumnUrl","shortcutsViewMode","onChange","Boolean","shortcut","Object","values","excludedViewMode","shortcutsArr","from","temp","shortcutIndex","display","justifyContent","alignItems","currentTarget","ShortcutForm","mode","ImportExport","FETCH_MAX_AGE","fetchLists","FORM_NOTES","setFollowedHashtags","currentType","form","formRef","input","setCurrentType","required","defaultValue","switch","autocorrect","followedHashtags","tag","shortcutsStr","compressToEncodedURIComponent","importUIState","setImportUIState","parsedImportShortcutStr","importShortcutStr","parsed","parse","hasCurrentSettings","onInput","nonUniqueShortcuts","every","exceededLimit","newShortcuts","changes","prevValue","Modals","navigate","useNavigate","Compose","__COMPOSE__","editStatus","newStatus","reloadStatusPage","post","reply","edit","delay","toast","hideToast","prevLocation","showSettings","Settings","showAccounts","showAccount","destination","showDrafts","showMediaModal","classList","contains","MediaModal","statusID","showShortcutsSettings","showMediaAlt","FollowRequestButtons","requestState","setRequestState","hasRelationship","rel","followRequests","authorize","Error","NOTIFICATION_ICONS","mention","follow","follow_request","contentText","count","reblog_reply","favourite_reply","targetAccount","AVATARS_LIMIT","Notification","isStatic","disableContextMenu","report","_accounts","_statuses","actualStatus","actualStatusID","isVoted","voted","isReplyToOthers","inReplyToAccountId","favsCount","reblogsCount","showAvatar","formattedCreatedAt","toLocaleString","genericAccountsHeading","handleOpenGenericAccounts","debug","RelativeTime","datetime","format","Fragment","type2","status2","Status","TruncatedLink","onContextMenu","dispatchEvent","clientX","clientY","props","useTruncated","NotificationService","routeNotification","accessToken","setShowNotificationSheet","useLayoutEffect","showNotificationSheet","sameInstance","getAccountByAccessToken","isFollow","notificationAccount","hasAccount","hasStatus","event","id2","hash","warn","accessToken2","handleMessage","clearAppBadge","tagName","instanceURL","SearchForm","forwardRef","searchParams","setSearchParams","useSearchParams","searchMenuOpen","setSearchMenuOpen","setQuery","searchFieldRef","useImperativeHandle","setValue","select","blur","params","encodeURIComponent","autocomplete","autocapitalize","onSearch","onFocus","onBlur","onKeyDown","focusItem","nextItem","nextElementSibling","parentElement","el","firstItem","prevItem","previousElementSibling","lastItem","click","top","SearchCommand","showSearch","setShowSearch","searchFormRef","isSearchPage","closeSearch","enabled","enableOnFormTags","Shortcuts","shortcutsColumnsMode","menuRef","formattedShortcuts","pin","handler","parseInt","closeMenu","updatesButton","instanceRef","overflow","viewScroll","menuClassName","gap","position","MenuLink","groupBoosts","newValues","boostStash","serialBoosts","item","boostStashID","items","half","floor","slice","dedupeBoosts","boostedStatusIDs","filteredItems","statusKey","boosterID","statusKey2","groupContext","contexts","contextIndex","t","repliedItem","self","context","inReplyToId","firstItemAccountID","newItems","appliedContextIndices","contextItems","aDate","bDate","i2","assignFollowedTags","statusFollowedTags","statusWithFollowedTags","sKey","extractedTags","itemFollowedTags","clearFollowedTagsState","useScroll","scrollableRef","distanceFromStart","distanceFromEnd","scrollThresholdStart","scrollThresholdEnd","direction","distanceFromStartPx","_distanceFromStartPx","distanceFromEndPx","_distanceFromEndPx","scrollDirection","setScrollDirection","reachStart","setReachStart","reachEnd","setReachEnd","nearReachStart","setNearReachStart","nearReachEnd","setNearReachEnd","isVertical","scrollableElement","previousScrollStart","scrollTop","scrollLeft","onScroll","scrollHeight","scrollWidth","clientHeight","clientWidth","scrollStart","scrollDimension","clientDimension","scrollDistance","abs","addEventListener","passive","removeEventListener","init","Event","useScrollFn","callback","queueMicrotask","MediaPost","parent","onMediaClick","accountId","accountURL","accountEmojis","repliesCount","reblogged","favourited","favouritesCount","bookmarked","muted","sensitive","visibility","language","editedAt","filtered","card","uri","_deleted","_pinned","debugHover","filterContext","useContext","FilterContext","isFiltered","filterInfo","hasSpoiler","readingExpandMedia","prefs","filterTitleStr","titlesStr","showSpoilerMedia","Media","NavMenu","setCurrentAccount","setMoreThanOneAccount","showFollowing","bindLongPress","useLongPress","threshold","detect","cancelOnMovement","buttonRef","menuState","setMenuState","boundingBoxPadding","safeBoundingBoxPadding","mutesIterator","fetchMutes","mutes","blocksIterator","fetchBlocks","blocks","open","state","squircle","ControlledMenu","anchorRef","containerProps","zIndex","portal","body","unmountOnClose","appVersion","commitHash","__COMMIT_HASH__","scrollIntoViewOptions","block","inline","behavior","Timeline","titleComponent","emptyText","errorText","useItemID","boostsCarousel","fetchItems","checkForUpdatesInterval","headerStart","headerEnd","timelineStart","refresh","view","showFollowedTags","setItems","showNew","setShowNew","allowGrouping","loadItems","useDebouncedCallback","otherPosts","pinnedPosts","items2","itemsSelector","jRef","activeItem","activeItemRect","closest","getBoundingClientRect","allItems","activeItemIndex","indexOf","itemRect","topmostItem","kRef","findLast","oRef","nearReachStart2","headerRef","hiddenUI","prevView","useCallback","disableIdleCheck","loadOrCheckUpdates","inBackground","noPointers","__IDLE__","timeDiff","hasUpdate","useInterval","lastHiddenTime","node","TimelineItem","inView","aFiltered","bFiltered","isCarousel","fItems","StatusCarousel","statusID2","reblog2","actualStatusID2","url2","_pinned2","manyItems","_differentAuthor","isMiddle","isSpoiler","showCompact","isStart","isEnd","itemKey","enableCommentHint","endButtonRef","carouselRef","startButtonRef","left","TimelineStatusCompact","statusPeekText","statusThreadNumber","MIN_YEAR","MIN_YEAR_MONTH","supportsInputMonth","setAttribute","_isSearchEnabled","isSearchEnabled","AccountStatuses","useParams","month","excludeReplies","excludeBoosts","tagged","accountStatusesIterator","allSearchParams","setAccount","searchOffsetRef","searchEnabled","setSearchEnabled","isValidMonth","_year","_month","monthIndex","after","afterStr","before","beforeStr","searchResults","saveStatus","value2","offset","pinnedStatuses","pinnedStatusesIds","exclude_replies","fetchPromise","fetchAccountPromiseRef","setFeaturedTags","useTitle","cachedAccount","featuredTags","accountInfoMemo","filterBarRef","TimelineStart","month2","date","year","validity","valid","active","allowSwitch","offsetLeft","fetchAccountStatuses","masto2","monthFieldRef","checkValidity","minYear","maxYear","maxMonth","minMonth","yearFieldRef","Bookmarks","bookmarksIterator","fetchBookmarks","Favourites","favouritesIterator","fetchFavourites","FollowedHashtags","Following","homeIterator","latestItem","latestItemChanged","payload","fetchHome","TAGS_LIMIT_PER_MODE","TOTAL_TAGS_LIMIT","Hashtags","mediaView","columnMode","hashtags","linkParams","hashtagTitle","hashtagPostTitle","maxID","fetchHashtags","timelines","any","maxId","onlyMedia","skipThreading","since_id","followUIState","setFollowUIState","reachLimit","setDownOverflow","catch","finally","MenuHeader","FocusableItem","newHashtag","MenuGroup","exists","some","newInstance","List","listIterator","fetchList","setList","showManageMembersModal","setShowManageMembersModal","ListManageMembers","MEMBERS_LIMIT","listID","members","setMembers","membersIterator","fetchMembers","member","as","RemoveAddButton","removed","setRemoved","emptySearchParams","URLSearchParams","Mentions","stateType","setStateType","mentionsIterator","fetchMentions","types","conversationsIterator","latestConversationItem","lastStatus","fetchConversations","args","notificationTypeKeys","fixNotifications","groupNotifications","notificationsMap","cleanNotifications","virtualType","mappedNotification","mappedAccount","n","cleanNotifications2","notificationsMap2","Notifications","notificationID","notificationAccessToken","onlyMentions","setOnlyMentions","setFollowRequests","announcements","setAnnouncements","excludeTypes","allNotifications","groupedNotifications","notificationsLastFetchTime","fetchFollowRequests","loadFollowRequests","requests","fetchAnnouncements","loadNotifications","fetchNotificationsPromise","fetchNotifications","announcements2","loadUpdates","autoRefresh","unsub","v","subscribeKey","yesterdayDate","todayDate","currentDay","showTodayEmpty","announcementsListRef","announcement","AnnouncementBlock","notificationDay","differentDay","contact","contactAccount","startsAt","allDay","publishedAt","endsAt","published","read","reactions","publishedAtDate","publishedDateText","updatedAtText","dangerouslySetInnerHTML","staticUrl","me","reaction","Public","isLocal","publicIterator","fetchPublic","prompt","toLowerCase","SHORT_LIMIT","Search","offsetRef","scrollTo","statusResults","setStatusResults","accountResults","setAccountResults","hashtagResults","setHashtagResults","setTypeResultsFunc","loadResults","filterBarParent","link","history","fetchLinks","trends","links","Trending","setHashtags","setLinks","trendIterator","fetchTrend","links2","cur","description","authorName","authorUrl","blurhash","imageDescription","providerName","providerUrl","accentColor","averageColor","labAverageColor","title2","Columns","components","Hashtag","Component","error","Home","NotificationsLink","notificationLinkRef","stopPropagation","matchMedia","matches","NotificationsMenu","NOTIFICATIONS_LIMIT","NOTIFICATIONS_DISPLAY_LIMIT","now","hasFollowRequests","setHasFollowRequests","statusPostRegexes","getInstanceStatusObject","hostname","regex","match","getInstanceStatusURL","HttpRoute","statusObject","statusURL","Lists","instancesListURL","SUBCOMMENTS_OPEN_ALL_LIMIT","MAX_WEIGHT","cachedRepliesToggle","cachedStatusesMap","scrollPositions","resetScrollPosition","STATUSES_SELECTOR","STATUS_URL_REGEX","StatusPage","mediaParam","mediaOnlyParam","mediaIndex","showMedia","mediaStatusID","mediaStatus","getStatus","showMediaOnly","heroStatus","setHeroStatus","closeLink","matchStatusPath","matchPath","handleMediaClose","delete","$carousel","StatusThread","navigation","translate","setStatuses","heroStatusRef","totalDescendants","debounce","scrollOffsets","reloadHero","heroTimer","cachedStatuses","reallyCachedStatuses","heroFetch","pRetry","contextFetch","heroStatus2","_replies","_r","expandReplies","weight","descendants","missingStatuses","ancestors2","ancestors","ancestorsIsThread","nestedDescendants","__replies","ancestor","isThread","allStatuses","offsetTop","heroLimit","setLimit","scrollPosition","threadifyStatus","newScrollTop","newScrollOffsets","contextURL","initContext","statusWeightCache","div","apiCache","heroDisplayName","heroContentText","postInstance","hasDescendants","innerHTML","heroInView","postSameInstance","allStatusLinks","activeStatus","activeStatusIndex","nextStatus","statusLink","onView","setHeroInView","heroPointer","statusLinkRect","topmostStatusLink","activeStatusRect","prevStatus","details","initialPageState","handleMediaClick","handleStatusLinkClick","descendant","thread","isHero","renderStatus","SubComments","withinContext","prevEntry","ids","getIDs","openAll","viewMode","prevLocationIsStatusPage","entries","moreStatusesKeys","arr","setViewMode","button","buttons","level","diveDeep","replies2","replies3","totalComments","accWeight","totalWeight","calcStatusWeight","openBefore","hasParentThread","detailsRef","handleScroll","sameCount","open2","shortReply","dataset","MEDIA_VIRTUAL_LENGTH","CARD_VIRTUAL_LENGTH","WEIGHT_SEGMENT","cachedWeight","htmlContentLength","mediaLength","pollLength","POLL_VIRTUAL_LENGTH","cardLength","StatusRoute","boostsCarouselUrl","groupedNotificationsUrl","multiHashtagTimelineUrl","nestedCommentsThreadUrl","logoText","nativeAlert","__nativeAlert","Toastify","gravity","y","__STATES__","__STATES_STATS__","counts","unmountedPosts","setInterval","unfurledLinks","$post","postInNotifications","unfurled","keysCount","ICONS","nonIdleEvents","setIdle","debouncedSetIdle","onNonIdle","documentElement","isIOS","theme","$meta","tempColor","colorScheme","$manualMeta","themeDarkColor","$autoMetas","textSize","setProperty","$app","$body","setIsLoggedIn","code","decodeURIComponent","clientID","clientSecret","initPreferences","client","initInstance","initStates","PrimaryRoutes","Routes","Route","nonRootLocation","Welcome","element","backgroundLocation","getPrevLocation","isModalPage","timeout","AbortSignal","controller","AbortController","abort","signal","render","HashRouter","App","localStorage","removeItem","sessionStorage","__CLOAK__","toggle"],"mappings":"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"} |