Files
notedeck/crates/notedeck_columns
Claude 156dc21df1 Remove automatic relay configuration and fix channel creation issues
This commit fixes three user-reported issues:

1. **Remove automatic relay configuration**
   - Changed RelayConfig::default() to use new() instead of default_relays()
   - This ensures no relays are added automatically on startup
   - Users must now configure relays manually at startup

2. **Fix channel dialog focus constantly switching**
   - Added focus_requested flag to ChannelDialog
   - request_focus() is now only called once when dialog is first opened
   - Previously it was called every frame, causing constant focus switching
   - This prevented users from typing in the hashtags field

3. **Fix channel creation crash without hashtags**
   - Modified TimelineKind::Hashtag filter creation to handle empty hashtags
   - When no valid hashtags are provided, shows all notes (kind 1) instead of empty filter
   - Previously, empty hashtag vector caused crash due to empty filter set
   - Channels without hashtags now work as a "general" feed showing all notes

All fixes tested and build succeeds without errors.
2025-11-14 06:19:01 +00:00
..
2025-07-17 13:54:43 -07:00
2025-09-30 19:54:19 -04:00
2025-04-21 13:26:02 -07:00
2025-04-21 13:26:02 -07:00

NoteDeck Columns

A TweetDeck-style multi-column interface for Nostr built with Rust and egui.

Overview

NoteDeck Columns is a specialized UI component of the NoteDeck Nostr client that provides a TweetDeck-inspired multi-column layout for browsing Nostr content. It allows users to create customizable "decks" with multiple columns, each showing different types of Nostr content (home timeline, notifications, hashtags, profiles, etc.).

Features

  • Multi-column layout: View different Nostr content types side by side
  • Customizable decks: Create and customize multiple decks for different use cases
  • Column types:
    • Universe (global feed)
    • Contact lists (follows)
    • Profiles
    • Notifications
    • Hashtags
    • Threads
    • Search results
    • Algorithmic feeds (e.g., last notes per pubkey)
  • Interactions: Post, reply, quote, and zap notes
  • Media support: View and upload images
  • Multiple accounts: Switch between multiple Nostr accounts

Getting Started

NoteDeck Columns is part of the larger NoteDeck ecosystem. To use it:

  1. Clone the NoteDeck repository
  2. Build the project with Cargo
  3. Run NoteDeck and select the Columns interface

See the DEVELOPER.md file for detailed setup instructions.

Architecture

NoteDeck Columns is built using:

  • Rust: For performance and type safety
  • egui: For the UI rendering
  • nostrdb: For Nostr data storage and retrieval
  • enostr: For Nostr protocol communication

The codebase is organized around the concept of timelines, views, and decks, with a column-based UI architecture.

Contributing

Contributions are welcome! Please see DEVELOPER.md for information on how to set up your development environment and contribute to the project.

License

NoteDeck Columns is licensed under the GPL v3.