Skip to content

Latest commit

 

History

History
55 lines (35 loc) · 2.6 KB

README.md

File metadata and controls

55 lines (35 loc) · 2.6 KB

HackerNews.app

Screenshot of main window


I couldn't find a HackerNews client that runs on macOS, built with native technologies (AppKit), and has all of the features I was interested in: up/downvote features, commenting, hiding/favoriting, etc...

So I'm building on my own.

⚠️ Warning

This app is still highly WIP, and it's not the best code in the world. If you have any ideas to make the code cleaner, Swiftier, or really have any idea, PRs are welcomed!

Also welcomed is trivial bug reports, I would like to fix bugs that are lying on the ground but as I use the app daily, it's hard for me to find out very obvious bugs because I'm so used to it. Every bug report helps, including very trivial ones. Thanks in advance.

Pre release

I did a pre release, you might want to try it out by downloading it from the releases tab.

If you're getting a warning that says the application is damaged, the temporary solution is to clear the quarantine flag by running xattr -c ~/Downloads/HackerNews.app in the Terminal. Sorry for the inconvenience, will fix this soon.

Development

I wrote the HNAPI package for interfacing with HN. It handles communicating with both the HN official API, the Algolia HN API, and the HackerNews site.

If you're writing a new HN client (for any platform), you might want to gleam the code, I've put in a lot of thoughts in the design. There's probably a bit more design aspects that I have to think about, but it's pretty much the fastest and the most robust approach to interfacing HN that I could think.

Features

Voting stories and comments

A surprising amount of HackerNews clients don't have any functionality related to accounts. That's mostly because the official API only provides methods to view items. In contrast, HackerNews.app loads the HN site, parses it and allows users to vote, favorite, or hide items.

This app tries to be a Mac-assed Mac app. It is developed using the AppKit APIs, and doesn't use webviews or Catalyst.

Thanks to...

Collin Donnell (@collindonnell on Twitter), who has generously provided code review and design advice on this project.