Discourse Topic Quick Switcher

Enhance Discourse forums with instant topic switching, current topic highlighting, and smart theme detection

目前為 2025-09-29 提交的版本,檢視 最新版本

作者
Pipecraft
評價
0 0 0
版本
0.3.0
建立日期
2025-09-28
更新日期
2025-09-29
尺寸
53.2 KB
授權條款
MIT
腳本執行於

Discourse Topic Quick Switcher

A powerful user script that brings seamless topic navigation, intelligent current topic highlighting, and adaptive theme switching to Discourse forums. Browse your favorite forums with unprecedented speed and efficiency.

Features

  • Topic List Caching: Automatically caches the topic list when you visit a list page.
  • Quick Access: Access the cached list from any topic page via:
    • A floating button in the bottom-right corner
    • A keyboard shortcut (backtick key `)
  • User-Friendly Interface:
    • Displays cache time and source information
    • Navigate directly to topics from the popup panel
    • Close with the ESC key, a close button, or by clicking outside the panel
    • Highlights the current topic for easy identification
    • Automatically scrolls to the current topic in the list
    • Quick navigation buttons for previous and next topics
    • Intelligently skips hidden topics during navigation
    • Settings panel to customize language preferences and navigation button visibility
  • Smart Theme Detection:
    • Automatically adapts to light/dark mode based on system and site preferences
  • Cache Management:
    • 1-hour cache expiration with a visual indicator
    • Source link to return to the original list page

How It Works

This script operates entirely on the client-side with a focus on efficiency and minimal resource usage:

  1. Client-Side Caching: When you visit a topic list page, the script captures the HTML content of the topic list and stores it in your browser's local storage.

  2. Zero Additional Server Requests: The script works with content that's already been loaded by your browser, creating no additional load on the Discourse server.

  3. SPA Navigation: The script leverages Discourse's Single Page Application architecture to navigate between topics without full page reloads, making navigation nearly instantaneous.

  4. DOM Manipulation: The cached topic list is displayed through careful DOM manipulation, creating a seamless overlay that matches your forum's current theme.

  5. Event-Based Interaction: All user interactions (keyboard shortcuts, button clicks) are handled through efficient event listeners.

The design philosophy prioritizes performance and server friendliness - the script adds convenient navigation without generating any additional server requests beyond what Discourse normally requires.

Limitations

Due to the caching mechanism used by the script, there are some limitations:

  1. Non-Real-Time Data: The reply counts and view counts displayed in the cached topic list are not real-time data, but rather the data at the time of caching.

  2. Cache Freshness: The topic list is only updated when you visit a list page. If you haven't visited a list page for a long time, the cached data may differ significantly from the actual situation.

  3. New Topics Not Automatically Displayed: New topics posted after you cached the list won't appear in the quick switcher until you visit the list page again to refresh the cache.

  4. Limited Topic Count: The quick switcher can only display topics included in the last list page you visited, typically one page worth of content.

These limitations are design choices made to maintain the script's lightweight nature and zero additional server request advantage.

Installation

  1. Install a user script manager like Tampermonkey or Violentmonkey
  2. Click here to install this script
  3. Visit any Discourse forum and enjoy the enhanced navigation experience!

Usage

  1. Cache a Topic List:

    • Visit any Discourse forum topic list page (Latest, New, Categories, etc.)
    • The script will automatically cache the current list
  2. View the Cached List:

    • While viewing a topic, you can:
      • Click the floating button in the bottom-right corner
      • Press the backtick key (`)
    • A popup will appear showing the cached topic list
  3. Navigate Between Topics:

    • Click any topic in the popup to navigate to it
    • The popup will automatically close after selection
  4. Close the Popup:

    • Click the × button
    • Press the ESC key
    • Click outside the popup

Configuration

You can modify the following settings at the top of the script:

const CONFIG = {
  // Keyboard shortcut (default: backtick key)
  HOTKEY: '`',
  // Cache key name
  CACHE_KEY: 'discourse_topic_list_cache',
  // Cache expiration time (in milliseconds) - 1 hour
  CACHE_EXPIRY: 60 * 60 * 1000,
  // Whether to show the floating button on topic pages
  SHOW_FLOATING_BUTTON: true,
  // Route check interval (in milliseconds)
  ROUTE_CHECK_INTERVAL: 500,
  // Whether to automatically follow system dark mode
  AUTO_DARK_MODE: true,
}

Compatibility

This script is designed for all Discourse forums and has been tested on the following browsers:

  • Chrome
  • Firefox
  • Safari

Release Notes

v0.3.0

  • Added settings dialog for customizing user experience
  • Added language selection option in settings
  • Added toggle for navigation button visibility

v0.2.0

  • Added quick navigation buttons for previous and next topics
  • Intelligently skips hidden topics during navigation

v0.1.1

  • Added internationalization support with English and Chinese translations

v0.1.0

  • Initial release
  • Basic topic list caching functionality
  • Floating button for quick access
  • Keyboard shortcut support
  • Cache expiration indicator
  • Added current topic highlighting
  • Added auto-scrolling to the current topic
  • Added closing the list by clicking outside of it
  • Improved dark mode support with automatic theme detection

License

MIT License - see the LICENSE file for details

Contributing

Contributions are welcome! Please feel free to submit a pull request.

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址