🔀 Fork of Bluesky (https://github.com/bluesky-social/social-app) with minor adjustments for https://zio.blue
 
 
 
 
 
 
Go to file
Eric Bailey 08979f37e7
Movable following feed (#3593)
* Handle home algo with backwards compat

* Remove todo, fix pwi view

* Simplify filter logic

* Handle edge case

* Handle home algo in FeedSourceCard

* Fix handling of pinned feed if home algo is disabled

* Handle home algo on ProfileFeed screen

* Rename

* Fix pinned feeds key

* Improve perf of pinned feeds with primary algo

* Update statsig API

* Revert unneeded changes

* Support following feed as well

* Better formatting

* Clarify primary algo usage

* Better comment

* Handle saved feed screen edge case

* Restore Feeds sparkle, fix line height

* Move gate call down

* Filter out primary algo from feeds page

* Filter dupe from Feeds screen

* Simplify logic

* Missing following handling

* Hide primary feed setting outside exp

* Revert testing change

* Migrate usePinnedFeedInfos

* Migrate FeedSourceCard

* Migrate Feeds screen

* Migrate SavedFeeds screen

* Handle timeline in feed infos

* Finish migrating ProfileFeed, FeedSourceCard

* Migrate ProfileList

* Finalize mutation hooks

* Allow unsaving lists

* Handle following feed on Feeds screen

* Handle following on SavedFeeds

* Get rid of deprecated interface usages

* Handle no pinned feeds

* Handle no feeds on Feeds screen

* Reuse component on SavedFeeds screen

* Handle no following feed

* Remove primary algo references

* Migrate to new plural APIs

* Remove unused event

* Prevent duplicate keys

* Make handling much more clear

* Dedupe useHeaderOffset

* Filter unknown feed types at source

* Use just following

* Immprove key handling

* Resume from last tab

* Bump sdk

* Revert Gemfile

* Additional protection in FeedSourceCard

* Fix ProfileList save/unsave handling

* Translate

* Translate

* Match existing handling post-signup

* Ensure onboarding results in correct selected feeds

* Some testing tweaks on create/onboarding

* Revert primary algo consderations

* Remove comment

* Handle default feed setting

* Rm unnecessary type cast

* Remove premature gate check

* Remove nullable check in onPageSelecting, assume the pager checks bounds

* Use null for default selected feed

* Rm unrelated change

* Remove the concept of __key__

I don't think this concept is consistent.

It's introduced on FeedSourceInfo which is used both by pinned feeds and by useFeedSourceInfoQuery. Pinned feeds use the pinning ID there. But there is no pinning ID for useFeedSourceInfoQuery. So this means this field is sometimes one thing and sometimes some other thing. That is a decent sign that it shouldn't be on that type at all.

It's not used anywhere except the desktop feed enumeration. It seems reasonable to assume there that we wouldn't want to show the same feed URL twice. (And if it does occur in the array twice, IMO we should solve that at the API level and dedupe it on read or next write.) So I think we should just use the URL in that place. (I used the descriptor, which is equivalent.)

* Dedupe pinned feeds by URL on read

* Filter timeline out of mergefeed sources

* Put FeedDescriptor into FeedSourceInfo

* Group saved info with feed for pins

This removes a loop within a loop within a loop.

* Fix Feeds link on native

---------

Co-authored-by: Dan Abramov <dan.abramov@gmail.com>
2024-05-11 04:39:21 +01:00
.bundle Initial commit 2022-06-07 17:50:05 -05:00
.github Use build arg in docker action to correctly pass git commit SHA (#3940) 2024-05-09 17:29:25 -07:00
.husky set up lint-staged via husky 2023-07-13 15:35:56 -07:00
__e2e__ Release 1.80 (#3757) 2024-04-29 15:00:25 -07:00
__mocks__ Use Sentry only for errors (#1776) 2023-11-07 04:30:00 +00:00
__tests__/lib Replace pluralize by plural by @tkusano (#3882) 2024-05-06 16:55:57 -07:00
assets [🐴] Change up icons (#3938) 2024-05-10 10:42:45 -05:00
bskyembed rebased embedr (#3511) 2024-04-13 12:20:06 -07:00
bskyweb use four-digit years for RSS pubDate (#3907) 2024-05-08 09:33:38 -07:00
code-signing add expo-updates github action (#3270) 2024-03-19 11:18:22 -07:00
docs docs(build): update build instructions (#3641) 2024-04-22 10:44:44 -07:00
eslint [Statsig] Make gate checks lazily (#3594) 2024-04-18 04:39:29 +01:00
jest 1.76 release preparations (#3459) 2024-04-09 16:27:39 -07:00
modules Movable following feed (#3593) 2024-05-11 04:39:21 +01:00
patches Patch lexicon for perf (#3733) 2024-04-27 07:54:47 +01:00
plugins android: fix various places still using default Material Teal (#3555) 2024-04-29 11:36:05 -07:00
scripts rebased embedr (#3511) 2024-04-13 12:20:06 -07:00
src Movable following feed (#3593) 2024-05-11 04:39:21 +01:00
web Let React app replace preload (#3900) 2024-05-07 18:29:21 -05:00
.buckconfig Initial commit 2022-06-07 17:50:05 -05:00
.detoxrc.js Update testrunner to use new dev-env [WIP] (#1575) 2023-10-10 15:46:27 -07:00
.easignore fix bad bool check in action (#3885) 2024-05-06 20:13:12 -07:00
.env.example add bundle identifiers to app-info (#3861) 2024-05-04 16:33:10 -07:00
.eslintrc.js [Statsig] Typecheck gates (#3467) 2024-04-10 19:36:37 +01:00
.gitignore Add webpack analyzer, PR comments for webpack bundle size (#3383) 2024-04-03 19:31:29 -07:00
.nvmrc feat(nvm): add support for nvm & minor actions housekeeping (#2979) 2024-02-26 17:35:06 -08:00
.prettierignore Use Prettier at the root (#3375) 2024-04-02 12:02:20 +01:00
.prettierrc.js Add state management 2022-06-09 13:03:25 -05:00
.ruby-version Improve lightbox... and update to React Native 0.71.0 (#49) 2023-01-17 20:40:02 -06:00
.watchmanconfig Initial commit 2022-06-07 17:50:05 -05:00
Dockerfile Use build arg in docker action to correctly pass git commit SHA (#3940) 2024-05-09 17:29:25 -07:00
Dockerfile.embedr Add kawaii mode (#3773) 2024-05-01 08:59:40 +01:00
Gemfile Improve lightbox... and update to React Native 0.71.0 (#49) 2023-01-17 20:40:02 -06:00
LICENSE Update copyright year in LICENSE (#2606) 2024-01-25 12:15:40 -08:00
Makefile rebased embedr (#3511) 2024-04-13 12:20:06 -07:00
README.md Remove invite codes from README (#2988) 2024-02-27 01:24:14 +00:00
app.config.js fix privacy api type (#3903) 2024-05-07 16:35:04 -07:00
babel.config.js Bump react-native to 0.73.1, expo to 50 (#2214) 2023-12-23 15:44:38 -08:00
eas.json Add OTA updates support for `testflight` channel (#3291) 2024-04-03 15:14:44 -07:00
google-services.json.example Add example google-services file (#1545) 2023-09-28 12:22:23 -07:00
index.js E2E 🟢 (#2092) 2023-12-05 14:50:56 -06:00
index.web.js Mark bundle start time on web (#3147) 2024-03-08 04:13:36 +00:00
lingui.config.js Alphabetise languages by language code (#3350) 2024-04-04 10:51:54 -07:00
metro.config.js Let Metro handle import/export instead of Babel (#1772) 2023-10-30 21:54:23 +00:00
package.json Movable following feed (#3593) 2024-05-11 04:39:21 +01:00
tsconfig.check.json [APP-786] Native notifications (#1095) 2023-08-23 16:28:51 -07:00
tsconfig.e2e.json E2E runner fixes (#2428) 2024-01-04 17:33:57 -08:00
tsconfig.json exclude bskyweb bskyembed and web-build (#3790) 2024-05-01 15:29:30 +01:00
webpack.config.js migrate to `expo-linear-gradient` (#3420) 2024-04-04 21:22:13 -07:00
yarn.lock Movable following feed (#3593) 2024-05-11 04:39:21 +01:00

README.md

Bluesky Social App

Welcome friends! This is the codebase for the Bluesky Social app.

Get the app itself:

Development Resources

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

There is a small amount of Go language source code (in ./bskyweb/), for a web service that returns the React Native Web application.

The Build Instructions are a good place to get started with the app itself.

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. Learn more at:

The Bluesky Social application encompasses a set of schemas and APIs built in the overall AT Protocol framework. The namespace for these "Lexicons" is app.bsky.*.

Contributions

While we do accept contributions, we prioritize high quality issues and pull requests. Adhering to the below guidelines will ensure a more timely review.

Rules:

  • We may not respond to your issue or PR.
  • We may close an issue or PR without much feedback.
  • We may lock discussions or contributions if our attention is getting DDOSed.
  • We're not going to provide support for build issues.

Guidelines:

  • Check for existing issues before filing a new one please.
  • Open an issue and give some time for discussion before submitting a PR.
  • Stay away from PRs like...
    • Changing "Post" to "Skeet."
    • Refactoring the codebase, eg to replace mobx with redux or something.
    • Adding entirely new features without prior discussion.

Remember, we serve a wide community of users. Our day to day involves us constantly asking "which top priority is our top priority." If you submit well-written PRs that solve problems concisely, that's an awesome contribution. Otherwise, as much as we'd love to accept your ideas and contributions, we really don't have the bandwidth. That's what forking is for!

Forking guidelines

You have our blessing 🪄 to fork this application! However, it's very important to be 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 Bluesky.
  • Change any support links (feedback, email, terms of service, etc) to your own systems.
  • Replace any analytics or error-collection systems with your own so we don't get super confused.

Security disclosures

If you discover any security issues, please send an email to security@bsky.app. The email is automatically CCed to the entire team and we'll respond promptly.

Are you a developer interested in building on atproto?

Bluesky is an open social network built on the AT Protocol, a flexible technology that will never lock developers out of the ecosystems that they help build. With atproto, third-party can be as seamless as first-party through custom feeds, federated services, clients, and more.

License (MIT)

See ./LICENSE for the full license.

P.S.

We ❤️ you and all of the ways you support us. Thank you for making Bluesky a great place!