-
Notifications
You must be signed in to change notification settings - Fork 1.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add bookmarks natively to Bluesky #7383
base: main
Are you sure you want to change the base?
Conversation
that bookmark button location on the post actions should be changed |
Valid point, but also Why would it be a bad idea for them to be public? Your likes are also public. More discussion on that here |
Public everything isn't great and I wish my likes were private but thats more of a protocol issue. Bookmarks being public seems like a poor idea but unfortunately maybe it makes sense but I still think you should change it. Also, move the bookmark button to the far right with only a little big of padding with the menu button. |
I agree that it doesn't make sense for bookmarks to be public and there should be no need for that in the lexicon if it can be avoided |
Count me in for ‘okay with public bookmarks’. Yeah it’s not ideal, but it’s simply the limitation of the platform as it exists right now, and it’s a great start for client convergence. The notion of all-public-activity when using Bluesky is already deeply engrained for me, so my use of bookmarks won’t be any different. Worth noting that the most popular method of bookmarking to date has been to reply with a 📌 to a post. Making that inadvertently noisy practice obsolete would be a big improvement on its own. Also, here’s a workaround that multi-account clients could easily accommodate:
This shouldn’t have to require constant account switching, as there’s already prior art (in Mastodon at least) for clients that have a UI utility like “repost/favorite from: acc1, acc2..” |
I strongly disagree. Likes and blocks are public because they have to be. Bookmarks do not have to be. Parts of Bluesky are "public" because they have to be, it doesn't mean everything is public. Bookmarks being public would allow Cambridge-Analytica like scraping, it would show what a user really liked. It's a very bad idea to make bookmarks public, and the team doesn't seem very interested in that. |
@oracularhades my problem with private bookmarks, rather than using an anonymous account, is that it takes away portability. The data for bookmarks would be stored on a private server, which seems wrong at a protocol level, rather than chats being stored on a private server. If anything, it made sense for blocks to be stored privately. Blocking someone can have real-world implications, and its better for those who are blocked to not know. As for scraping, I don't see a reason why bookmarks are any different than likes or reposts. I could make the argument that reposts are actually what I'm truly interested in and support, and bookmarks are just a way of saving things like recipes to come back to later. That's just the nature of Bluesky, all the data is public. EDIT: |
your entire PDS is the portability. That's its job :) - so no, that's not true |
@oracularhades is right, bookmarks should be private, like mutes are. Users expect this, as this is how bookmarks work elsewhere (most notably on Twitter). We already have a workaround to make public bookmarks, although it's certainly not ideal. However, it would confuse users to add a built-in bookmark function but with everything you bookmark being public. It's possible that once we have private bookmarks an option to share some of them publicly would be a good idea (e.g. here's a curated collection of posts on a certain topic), but it's clear from user feedback that private bookmarks must be the first step.
@ebwinters Portability can be implemented by allowing users to export their bookmarks into a file and that file can then be imported elsewhere.
I understand that you personally would be happy for your bookmarks to be public, but it's clear from feedback that there's a strong desire from many users for a way to save posts privately for future reference. |
I think if we do this it should be "bookmark collections/folders" with an option to make those public, and they can display on the user's profile. EDIT: @surfdude29 sorry it's 5am and I missed your "(e.g. here's a curated collection of posts on a certain topic)," lmao, you already suggested this. |
@surfdude29 I wouldn't be happy with public bookmarks per se, that's just the limits of the protocol right now. I'd rather bookmarks be stored in the PDS for portability, but if private state on the PDS is a thing, that is the ideal solution, and I'd imagine a lexicon/client change would be in store for the |
@ebwinters Based on all the feedback I've seen from users on Bluesky, my view is that a fundamental requirement of any implementation of bookmarks in Therefore, I would suggest that we need to wait until this can be done in a way that's consistent with other goals – private state on the PDS seems a promising way to do that – instead of going ahead with public bookmarks as an interim solution, simply because that's all that can be managed at the moment. I think doing this would be confusing for Bluesky users ("we're releasing a half-finished version of bookmarks, they're all public, but we hope to make them private at some point in the future") and would not meet their expectations. EDIT: To expand further on my point about user expectations, the overwhelming sense I get from the discussion in #1091 – the main issue relating to bookmarks – is that users expect them to be private. This includes the user who opened the issue, who clarified explicitly in this comment that they want private bookmarks. |
What if the (public) bookmarks feature was behind a Labs 🧪 type setting, which also clearly pointed out the public nature of the bookmarks? Wouldn’t that solve for the divergence in public/private expectations, while also satisfying all the people who want a better alternative than the noisy 📌 hack? |
That could work, and fwiw I would use it myself. It would solve the key concern I have of user confusion, which I believe would result from enabling public bookmarks by default. Users would have to opt in to use them and it would be made clear to them when they do so that bookmarks are public information, the same as likes are. Of course, we'll have to wait for someone from the team to weigh in with what their thinking is as that's what will determine what happens with this, but I imagine they would consider issues like:
|
Those are all good points. Well thought out I personally agree that putting bookmarks behind an opt-in experience would be useful, and I'd think enough people want to bookmark recipes or articles which they wouldn't mind being public. As @surfdude29 called out, having a migration path to private state is crucial here. I can't think of how that would work technically, but I think there will be some solution developed since Bluesky wants types like mutes to live on the PDS. At worst there might be some manual migration tool |
If the Bluesky team themselves want mutes to live on the PDS, why not start with bookmarks implemented similarly to mutes as opposed to starting with them implemented publicly? Presumably they'll introduce some way to migrate mutes into the PDS while keeping them private if that's their goal, and we could do the same with bookmarks. If either scenario requires an eventual migration, it feels far more useful to me to start with a feature that behaves in the way people expect. |
This PR adds native bookmarking to Bluesky. I understand it is likely this PR will implement Bluesky's bookmarking feature, so here are the:
Goals
Groundwork for eventual bsky-team supported bookmarks implementation
Personal interest
Non-UI design choices
Using community.lexicon.bookmarks
Implementation was done using
community.lexicon.bookmarks
for the following reasons:at://
URIs are a subset of theuri
type, meaning developers can more easily integrate bookmarks from Bluesky into other appsPublic bookmarking
There is currently no way of making a private lexicon on
atproto
. This is generally a limitation within the protocol and I don't believe it should block development of bookmarks. There are workarounds for privacy, such as creating an anonymous account and bookmarking to that account, as well as extensions and labelers.UI design choices
Putting bookmarks in the side bar
INSERT PICTURE HERE
I put bookmarks in the side bar for easier access. Another placement option is inside of the user profile, next to
your likes
.Potential problems
Hydrating the equivalent of an
isBookmarked
on every postShowing a user if they've already bookmarked a post through icon highlighting is important so they don't make duplicates. However, since bookmarks are not build in to the response of
getPost()
, a post has no notion of a bookmark. To compensate, I fetch all bookmarks by the current user, cache them in memory, and then do abookmarks.contains(post.uri)
for each post rendered to the page. When a bookmark is removed/added, the cache is updated.I can see this becoming a problem if a user has thousands of bookmarks, and am curious about other designs, tradeoffs, or approaches here. Some possibilities I can think of are
PostView
at the protocol level, simiar to likesPagination of bookmarks
On the "my bookmarks" page, rather than fetching the entire list of user bookmarks, they should be paginated and shown on scroll. However, I was not able to figure out pagination, since the
getActorBookmarks
method does not exist on the Bluesky PDS. For this feature to move forward, this is a blocker that I'd need some help on.Future work
Filtering and searching bookmarks
The
community.lexicon.bookmarks.bookmark
allows for tagging bookmarks. This brings up more complicated UI designs that might not be worth fleshing out right now. However, in the future I can some popup when a bookmark is created for adding tags, and then searching/filtering on the "My Bookmarks" page.Screen shots and other links
Bookmarking on a feed:
Bookmarks page
Discord thread with gif