No description
  • TypeScript 94.2%
  • JavaScript 1.7%
  • HTML 1.1%
  • Kotlin 0.9%
  • Go 0.8%
  • Other 1.1%
Find a file
2026-05-11 17:57:15 +10:00
.forgejo/workflows Just directly run the script - fuck the action LOL 2026-05-11 17:57:15 +10:00
.husky chore: switch to pnpm 2026-04-23 00:49:38 -07:00
.jscodeshift Create codemod for updating Toast calls to v2 (#10045) 2026-03-12 11:35:58 -07:00
.tangled/workflows fix: finally update logotype to say Witchsky 2025-12-28 22:02:51 -08:00
__e2e__ merge changes from upstream 2026-03-28 20:14:36 -07:00
__mocks__ iOS 26 (#9047) 2026-02-23 22:34:52 -08:00
__tests__/lib revert "feat: nicer facet parsing" 2026-04-30 02:29:19 -07:00
assets merge(upstream): TSGO TYPECHECK 2026-04-29 23:17:22 -07:00
bskyembed chore: switch to pnpm 2026-04-23 00:49:38 -07:00
bskylink chore: switch to pnpm 2026-04-23 00:49:38 -07:00
bskyogcard chore: switch to pnpm 2026-04-23 00:49:38 -07:00
bskyweb feat: AI preferences settings screen 2026-05-08 18:34:45 -07:00
code-signing add expo-updates github action (#3270) 2024-03-19 11:18:22 -07:00
dev-env chore: switch to pnpm 2026-04-23 00:49:38 -07:00
docs chore: switch to pnpm 2026-04-23 00:49:38 -07:00
eslint Update typescript-eslint, fix up eslint setup (#10150) 2026-03-31 06:00:56 -07:00
functions/profile feat: collapse Also liked posts 2026-04-28 23:41:52 -07:00
jest Replace lande with native language detection (#9974) 2026-04-22 10:26:14 -05:00
modules merge(upstream): TSGO TYPECHECK 2026-04-29 23:17:22 -07:00
patches chore: setup to try making production android builds 2026-05-08 03:17:40 -07:00
plugins merge with upstream! 💫 (1.121.0) 2026-04-17 17:29:35 -07:00
scripts chore: setup to try making production android builds 2026-05-08 03:17:40 -07:00
src fix: profile images using webp (force png/jpeg) 2026-05-09 01:12:21 -07:00
web merge with upstream 👁️ (1.122.0) 2026-04-23 22:14:34 -07:00
witchsky-static-about change Github mentions to Tangled & add files missing from PR 2025-12-01 16:03:37 -08:00
.buckconfig Initial commit 2022-06-07 17:50:05 -05:00
.easignore fix bad bool check in action (#3885) 2024-05-06 20:13:12 -07:00
.editorconfig Lint native files (#4768) 2024-07-11 18:15:35 -07:00
.env.example fix: metrics, scroll state management, style-related console warning 2026-04-29 21:27:20 -07:00
.envrc nix devshell support, pages build support 2025-04-20 17:32:42 -05:00
.gitignore bmw drivers when you try to merge 2026-03-01 20:03:21 -08:00
.npmrc chore: switch to pnpm 2026-04-23 00:49:38 -07:00
.nvmrc Update Node.js to 20.x in Dockerfile (#6099) 2024-11-11 18:58:22 +00:00
.prettierignore Ignore built files (#5572) 2024-10-02 11:18:15 -05:00
.prettierrc.js Add state management 2022-06-09 13:03:25 -05:00
.ruby-version Bump ruby version 2026-05-11 17:57:01 +10:00
.watchmanconfig Initial commit 2022-06-07 17:50:05 -05:00
app.config.js chore: setup to try making production android builds 2026-05-08 03:17:40 -07:00
babel.config.js Upgrade Lingui to v5 (#9905) 2026-02-23 20:28:03 +00:00
CLAUDE.md merge(upstream): TSGO TYPECHECK 2026-04-29 23:17:22 -07:00
conductor.json chore: switch to pnpm 2026-04-23 00:49:38 -07:00
crowdin.yml Release 1.103.0 prep (#8434) 2025-05-30 16:58:23 -07:00
default.nix nix devshell support, pages build support 2025-04-20 17:32:42 -05:00
Dockerfile chore: switch to pnpm 2026-04-23 00:49:38 -07:00
Dockerfile.bskylink chore: switch to pnpm 2026-04-23 00:49:38 -07:00
Dockerfile.bskyogcard chore: switch to pnpm 2026-04-23 00:49:38 -07:00
Dockerfile.embedr chore: switch to pnpm 2026-04-23 00:49:38 -07:00
eas.json chore: setup to try making production android builds 2026-05-08 03:17:40 -07:00
eslint-suppressions.json Enable @typescript-eslint/no-explicit-any (#10383) 2026-04-28 10:59:04 +01:00
eslint.config.mjs merge(upstream): TSGO TYPECHECK 2026-04-29 23:17:22 -07:00
flake.lock chore: update nix flake 2026-03-08 21:39:43 -07:00
flake.nix feat: composer account switcher 2026-04-25 14:07:17 -07:00
Gemfile Improve lightbox... and update to React Native 0.71.0 (#49) 2023-01-17 20:40:02 -06:00
google-services.json.example Replace Bitchsky with Witchsky 2025-11-21 12:26:48 -08:00
index.js Gate bitdrift integration (#7088) 2024-12-13 17:14:41 +00:00
index.web.js Upgrade API, implement XRPC rework (#4857) 2024-08-12 14:00:15 -07:00
justfile chore: update pkgs & add favicon to build step 2026-04-23 21:03:12 -07:00
LICENSE Merge with social-app upstream (before the big change !) 2026-01-24 21:31:35 -08:00
lingui.config.ts Upgrade Lingui to v5 (#9905) 2026-02-23 20:28:03 +00:00
logo_v0.svg The Bitchsky brand 2025-11-09 03:10:32 -08:00
Makefile chore: switch to pnpm 2026-04-23 00:49:38 -07:00
metro.config.js fix: pds badge, relike on autolike on repost, misc errors 2026-04-17 02:28:42 -07:00
package.json chore: setup to try making production android builds 2026-05-08 03:17:40 -07:00
pages_build.sh add opengraph (#38) 2025-04-30 16:51:05 -05:00
pnpm-lock.yaml chore: setup to try making production android builds 2026-05-08 03:17:40 -07:00
pnpm-workspace.yaml restore react-native-mmkv resolution 2026-05-03 07:13:34 +03:00
README.md chore: update readme & sentence-case Settings sync 2026-05-08 20:30:47 -07:00
rspack.config.ts chore: make css go in the css folder & fix console warnings 2026-04-29 22:20:33 -07:00
svgo.config.mjs Upgrade prettier to 3.6 (#8558) 2025-06-23 07:44:40 -07:00
tsconfig.check.json Typecheck app.config.js (#9771) 2026-01-27 09:09:06 -08:00
tsconfig.json Upgrade TypeScript to 6.0 (#10113) 2026-03-25 00:50:26 -07:00
webpack.config.js chore: make profile pages work in dev 2026-04-29 15:20:57 -07:00
wrangler.toml chore: update web build script 2026-04-14 21:09:54 -07:00

Witchsky Social App 🧙 (alpha)

Hey, witches! This is the codebase for the Witchsky app, based on social.daniela.lol and prior Bluesky forks.

Get the app itself:

Improvements on Bluesky

  • Cooler name (and kawaii logo)
  • Themes, hue slider, and Material You support
  • OAuth login option
  • Sort/filter accounts in account switchers
  • Hold/right click on interaction buttons to use another account
  • You can change "post" to any phrase you want in the UI
  • Choose between sharing witchsky.app or bsky.app links
  • Embed player works with stream.place links!
  • Open posts in PDSls and original fedi-bridged pages
  • You can delete and redraft (basically edit!) posts
  • Better defaults (alt text required 😉 autoplay off 🫨)
  • More unique repost icons
  • Can download videos
  • Stay on a page when switching accounts
  • 'Mutuals' in place of 'Following' when relevant
  • Pet label (option to toggle, & visibility for everyone else)
  • Account AI preferences screen
  • No age assurance or blocks based on location
  • No push notifications (hopefully will be added later)
  • Kept as up-to-date as possible (sporadically unstable as a result)

Runes

These are all available as options in the Runes sub-page of the app's settings.

  • Menus
    • Use handles in profile links instead of DIDs
    • Show "Open original post" and "Open post in PDSls" buttons
    • On non-bsky.social handles, show a link to that URL
    • Only show URL on handles with working links
  • Badges
    • Trusted verifiers
      • Use own selection of trusted verifiers
      • Trust verifiers from current AppView
    • PDS badges
      • Show a PDS badge next to the display name on profiles
      • Hide PDS badge for Bluesky-hosted accounts
      • Change favicon service
  • Impressions
    • Posts
      • Remove likes counts
      • Remove reposts counts
      • Remove quotes counts
      • Remove saves counts
      • Remove reply counts
    • Profiles
      • Remove followers counts
      • Remove following counts
      • Remove post counts
      • Remove "followed by" avatars
      • Show "Follows you" badge
  • Usability
    • Feeds
      • Do not fall back to discover feed
      • Hide "Feeds " tab when only one feed is selected
      • Disable composer prompt
      • Disable top-of-feed button
      • Show plus icon on unfollowed feed avatars
      • Hide posts that cannot be replied to from feeds
    • Redirect through go.bsky.app
    • Disable similar accounts recommendations
    • Hide follow button on posts and scrolled profile header
    • Disable verify email reminder
  • Display
    • Also liked
      • Show "Also liked" recommendations under post replies
      • Collapse "Also liked" by default
    • Density
      • Account switcher
        • Use compact account switcher
        • Automatically use compact account switcher with more than 6 accounts
    • Combine reposts into a horizontal carousel
    • Display images in higher quality
    • Show client used to post
    • Change custom post phrase
  • Infrastructure
    • Post translation provider
      • Google Translate
      • Kagi Translate
      • Naver Papago
      • LibreTranslate
      • Change LibreTranslate instance
    • Change image CDN
    • Change PLC directory
    • Change Constellation instance
    • Set custom AppView DID
    • Do not declare any default app labelers
  • Settings sync
    • Sync settings between devices
    • Include OpenRouter API key in synced settings
    • Push settings to cloud
    • Load settings from cloud
  • Extra
    • Fetch records directly from PDS to fix broken quotes
    • Auto-like what you repost
    • Disable via repost notifications
    • Show debug context for posts in Discover feed
    • Don't include the 'via' field in own posts
    • Developer mode

TODO: Xan

  • Setup App Linking for Android (.well-known w/ app package fingerprint)
  • Make fallback email addresses use witchsky.social in Legacy sign-in automatic PDS detection
  • Change followed accounts on onboarding
  • Visual replies indicator like the Firmament userstyle
  • Permit editing Menu options in Runes > Menus (remember Outlinks page?)
    • ShareMenuItems.tsx, ShareMenuItems.web.tsx
  • Add Open bridged OG fedi account page option to ProfileMenu.tsx
  • Witchsky PDS and .social site (list good songs containing 'bitch' in their titles for related site)

Upcoming or wishful features

  • Collapse labels past a customizable number (from the same labeler?) into a labeler clip "(+)"
  • Submit releases to the Google Play Store and iOS App Store
  • Move from Cloudflare Pages to wisp.place (needs serverless for embeds)
  • Move Terms and Privacy policy to Jollywhoppers.com
  • Ignore !no-unauthenticated labels
  • Better OpenGraph support for sharing profiles & posts (including videos & fixing quotes)
  • Seeing past blocks in threads (the nuclear block in reply chains)

Development Resources

This is a React Native application, written in the TypeScript programming language. It builds on the atproto TypeScript packages (like @atproto/api), which are also open source, but in a different git repository.

There is vestigial Go language source code (in ./bskyweb/), for a web service that returns the React Native Web application in the social app deployment. However, it is not used in current Witchsky deployments. For Witchsky, the intended deployment is with a webserver that can serve static files, and reroute to index.html as needed. Witchsky is currently hosted on Cloudflare Pages.

The Build Instructions are a good place to get started with the app itself. If you use nix (and especially direnv) then flake.nix will get you a working environment for the web version of the app.

The Authenticated Transfer Protocol ("AT Protocol" or "atproto") is a decentralized social media protocol. You don't need to understand AT Protocol to work with this application, but it can help. You may wish to reference resources linked in social-app. However, please don't harass the Bluesky team with issues or questions pertaining to Witchsky.

Witchsky is a fork of the official Bluesky client, social-app. It encompasses a set of schemas and APIs built in the overall AT Protocol framework. The namespace for these "Lexicons" is app.bsky.*.

Contributions

Witchsky is a community fork, and we'd love to merge your PR!

As a rule of thumb, the best features for Witchsky are those that have a disproportionately positive impact on the user experience compared to the maintenance overhead. Unlike some open source projects, since Witchsky is a soft fork, any features (patches) we add on top of upstream social-app need to be maintained. For example, a change to the way posts are composed may be very invasive, touching lots of code across the codebase. If upstream refactors this component, we will need to rewrite this feature to be compatible or drop it from the client.

For this reason, only features that require changing only a small amount of code from upstream should be considered.

Without an overriding motivation, opinionated features should exist behind a toggle that is not enabled by default. This allows Witchsky to cater to as many users as possible.

Guidelines

  • Check for existing issues before filing a new one please.
  • Open an issue and give some time for discussion before submitting a PR.
    • This isn't strictly necessary, but the lead developers would love to give their thoughts and scope out your willingness to maintain the feature before you write it.
  • Stay away from PRs like...
    • Changing "Quote" to "Bitch."
    • Refactoring the codebase, e.g., to replace React Query with Redux Toolkit, etc.
  • Include a new toggle and preference for your feature.

If we don't merge your PR for whatever reason, you are welcome to fork and/or self-host:

Forking guidelines

Just like social-app, you have our blessing 🪄 to fork this application! However, it's very important to make it clear to users when you're giving them a fork.

Please be sure to:

  • Change all branding in the repository and UI to clearly differentiate from Witchsky.
  • Change any support links (feedback, email, terms of service, issue tracker, etc) to your own systems.

Self hosting & personal builds

Self hosting is great! It is our intention that Witchsky is easy to self host and build on your own. If you host your own instance of Witchsky, or make your own builds, please make some level of effort to clarify that it is not an "official" build or instance. This can be in the form of a different domain or branding, but can also be as simple as not advertising your hosted instance or builds as "official" releases.

Security disclosures

If you discover any security issues, please privately disclose them to xan.lol. If the issue pertains to infastructure, code, or systems outside the scope of Witchsky, please refer to the disclosure guidelines on social-app if it is hosted by Bluesky PBC. Otherwise, reference the security policy of that system as applicable <3

License (MIT)

See ./LICENSE for the full license.

Bluesky Social PBC has committed to a software patent non-aggression pledge. For details see the original announcement.

P.S.

We ❤️ you and all of the ways you support us. Thank you for making Witchsky so great! ^.^