Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mrusme/neonmodem
Neon Modem Overdrive
https://github.com/mrusme/neonmodem
api api-client ascii-art bbs bulletin-board bulletin-board-system bulletinboard cli command-line command-line-tool discourse discourse-api forum forum-application hacker-news hackernews lemmy terminal terminal-app tui
Last synced: 1 day ago
JSON representation
Neon Modem Overdrive
- Host: GitHub
- URL: https://github.com/mrusme/neonmodem
- Owner: mrusme
- License: gpl-3.0
- Created: 2022-12-30T04:03:34.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2024-08-22T18:07:33.000Z (5 months ago)
- Last Synced: 2024-10-29T15:48:36.000Z (2 months ago)
- Topics: api, api-client, ascii-art, bbs, bulletin-board, bulletin-board-system, bulletinboard, cli, command-line, command-line-tool, discourse, discourse-api, forum, forum-application, hacker-news, hackernews, lemmy, terminal, terminal-app, tui
- Language: Go
- Homepage: https://neonmodem.com
- Size: 2.39 MB
- Stars: 567
- Watchers: 7
- Forks: 22
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- charm-in-the-wild - Neon Modem Overdrive - A BBS-style TUI client for Discourse, Lemmy, Lobste.rs and Hacker News. (_built with Bubble Tea_) (Applications / RSS and News)
- awesome-lemmy - **neonmodem** - activity/y/mrusme/neonmodem) | Linux (Projects / Mobile / Desktop apps)
README
Neon Modem Overdrive
--------------------![Neon Modem Overdrive](splashscreen.png)
[![Static
Badge](https://img.shields.io/badge/Join_on_Matrix-green?style=for-the-badge&logo=element&logoColor=%23ffffff&label=Chat&labelColor=%23333&color=%230DBD8B&link=https%3A%2F%2Fmatrix.to%2F%23%2F%2521PHlbgZTdrhjkCJrfVY%253Amatrix.org)](https://matrix.to/#/%21PHlbgZTdrhjkCJrfVY%3Amatrix.org)[*Neon Modem Overdrive*][neonmodem] is a [BBS][wiki-bbs]-style command line client that
supports [Discourse][discourse], [Lemmy][lemmy], [Lobsters][lobsters] and
[Hacker News][hackernews] as backends, and seamlessly integrates all of them
into a streamlined TUI. And yes, you heard that right, I really did call it
*Neon Modem Overdrive*.*Neon Modem* is built in Go, using [Charm's Bubble Tea][bubbletea] TUI
framework, but implements an own *window manager* (or *compositor* if you want)
that allows it to use a third dimension, on top of the two dimensional rendering
that Bubble Tea offers today. With that it is possible to display dialogs on top
of one another, in order to offer a smoother UI experience.[More info here!](https://xn--gckvb8fzb.com/get-the-bbs-scene-vibes-back-with-neonmodem-overdrive/)
## Support
| System | Available | List Forums | List Posts | List Replies | Create Post | Create Reply |
| :----------------- | :----------------: | :----------------: | :----------------: | :----------------: | :----------------: | :----------------: |
| Discourse | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
| Lemmy | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: |
| Lobsters | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | | |
| Hacker News | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | | |
| RSS+Disqus/Isso(?) | | | | | | |
| Superhighway84 | | | | | | |
| NNTP | | | | | | |[neonmodem]: https://neonmodem.com
[wiki-bbs]: https://en.wikipedia.org/wiki/Bulletin_board_system
[discourse]: https://github.com/discourse
[lemmy]: https://github.com/LemmyNet
[lobsters]: https://github.com/lobsters/lobsters
[hackernews]: https://news.ycombinator.com
[bubbletea]: https://github.com/charmbracelet/bubbletea## Installation
### From Release
Download the [latest
release](https://github.com/mrusme/neonmodem/releases/latest) and unpack
it:```sh
$ tar -xzf ./neonmodem_*.tar.gz
```The binary is called `neonmodem`. Feel free to move it to e.g. `/usr/local/bin`.
### From Sauce
Clone this repository
- from [GitHub](https://github.com/mrusme/neonmodem)
```sh
$ git clone [email protected]:mrusme/neonmodem.git
```
- from
[Radicle](https://app.radicle.xyz/nodes/seed.xn--gckvb8fzb.com/rad:z4GExf1wpsyn6WDc2dNAxVc6LPS9G)
```sh
$ rad clone rad:z4GExf1wpsyn6WDc2dNAxVc6LPS9G
```Then cd into the cloned directory and run:
```sh
make
```The binary is called `neonmodem`. Feel free to move it to e.g. `/usr/local/bin`.
For Arch Linux an AUR package is available here: https://aur.archlinux.org/packages/neonmodem
Install with your favorite AUR helper.
On NetBSD, a package is available from the official repositories.
To install it, simply run `pkgin install neonmodem`.## Configuration
Before launching *Neon Modem Overdrive* it requires initial setup of the
services (a.k.a. *systems*). Run `neonmodem connect --help` to find out more.Connecting a service will add it to the configuration TOML. The configuration
file location depends on the operating system. On Unix systems, it is in
`$XDG_CONFIG_HOME/neonmodem.toml` if `$XDG_CONFIG_HOME` is non-empty, otherwise
`$HOME/.config/neonmodem.toml` is used. On Darwin, the configuration is in
`$HOME/Library/Application Support/neonmodem.toml`. On Windows, it is in
`%AppData%\neonmodem.toml`.### Systems
#### Discourse
For connecting to a Discourse instance you'll need to have an active account on
that instance. *Neon Modem* will store the instance URL, username and a user
key, but no password.```sh
neonmodem connect --type discourse --url https://www.keebtalk.com
```#### Lemmy
For connecting to a Lemmy instance you'll need to have an active account on that
instance. *Neon Modem* will store the instance URL, username and password.```sh
neonmodem connect --type lemmy --url https://lemmy.ml
```#### Lobsters
For connecting to a Lobsters instance you won't need an account, as the
integration is read-only. *Neon Modem* will store the instance URL.```sh
neonmodem connect --type lobsters --url https://lobste.rs
```#### Hacker News
For connecting to Hacker News you won't need an account, as the integration is
read-only.```sh
neonmodem connect --type hackernews
```### UI
The UI can be fully customized via the `Theme` section in the configuration
file. To reset settings, all theme related configurations can simply be deleted
from the configuration.## Run
After setup *Neon Modem* can be launched by calling `neonmodem` without any
arguments. It will briefly display a splash screen, then switch to the posts
list, which will aggregate the latest posts from all connected systems. A
progress icon will be visible in the header while network requests are loading.### Usage
![Neon Modem Overdrive](neonmodem.gif)
#### Navigation
In the posts list:
- `j`: Scroll down
- `k`: Scroll up
- `r`/`enter`: Open selected post
- `n`: Write new post in on the system/forum of the current selected post
- `C-e`: Open system selector
- `C-t`: Open forum selector
- `esc`: QuitIn the post view dialog:
- `r`: Reply to post
- `#r`: Reply to specific comment # in post, e.g. `3r` to reply to the reply #3
- `z`: Load older replies (if available)
- `esc`: Close dialogIn the new post / new reply dialog:
- `tab`: Switch between elements (only in new post dialog)
- `C-s`: Submit post/reply
- `esc`: Close dialog## FAQ
- **Q:** The post view is really slow when using a large terminal.\
**A:** Turning off image rendering will improve performance significantly on
very large terminal windows and can be done by setting `RenderImages = false`
in the configuration.
- **Q:** Can I haz Reddit?\
**A:** I won't do the heavy lifting of integrating a proprietary platform with
a $15 billion valuation that can't even be bothered to maintain a solid set of
client API libraries. If you feel like, go ahead and PR!