8dece7800f
Testing / remote-protocol-compat (0.9.3) (push) Successful in 52s
Testing / test (push) Successful in 1m2s
Testing / remote-protocol-compat (0.9.5) (push) Successful in 1m0s
Package Extension / package-extension (push) Successful in 1m11s
Build & Publish Package / publish (push) Successful in 1m7s
- Add browser source grouping metadata to SDK-created tabs, groups, list results, and aggregate count results. - Render grouped local/remote browser tables consistently for clients, tabs, groups, windows, sessions, and remote status output. - Document remote control, auth, HTTP gateway usage, and the refreshed project structure in the README. - Add coverage for grouped output and BrowserCounts browser_groups. - Bump the Python package, extension manifest, and lockfile to 0.15.6. - Add a just publish helper for building and publishing release artifacts.
95 lines
3.6 KiB
Python
95 lines
3.6 KiB
Python
import click
|
|
from browser_cli.commands import client_from_ctx, gentle_mode_option, handle_errors, print_counts
|
|
from browser_cli.commands.rendering import print_browser_grouped_table_rows
|
|
from rich.console import Console
|
|
|
|
console = Console()
|
|
|
|
def _print_groups(groups, *, show_browser: bool = False) -> None:
|
|
columns = [
|
|
("ID", lambda g: g.id),
|
|
("Name", lambda g: g.title or ""),
|
|
("Color", lambda g: g.color or ""),
|
|
("Collapsed", lambda g: "yes" if g.collapsed else "no"),
|
|
("Tabs", lambda g: g.tab_count),
|
|
]
|
|
print_browser_grouped_table_rows(groups, columns, console=console, empty_message="[yellow]No groups found[/yellow]")
|
|
|
|
@click.group("groups")
|
|
def group_group():
|
|
"""Manage tab groups."""
|
|
|
|
@group_group.command("list")
|
|
@handle_errors
|
|
def group_list():
|
|
"""List all tab groups."""
|
|
groups = client_from_ctx().groups.list()
|
|
_print_groups(groups, show_browser=any(g.browser for g in groups))
|
|
|
|
@group_group.command("tabs")
|
|
@click.argument("group_id", type=int)
|
|
@handle_errors
|
|
def group_tabs(group_id):
|
|
"""List tabs inside a group."""
|
|
from browser_cli.commands.tabs import _print_tabs
|
|
_print_tabs(client_from_ctx().groups.tabs(group_id))
|
|
|
|
@group_group.command("count")
|
|
@handle_errors
|
|
def group_count():
|
|
"""Count all tab groups."""
|
|
print_counts(client_from_ctx().groups.count(), "group")
|
|
|
|
@group_group.command("query")
|
|
@click.argument("search")
|
|
@handle_errors
|
|
def group_query(search):
|
|
"""Search groups by name."""
|
|
_print_groups(client_from_ctx().groups.query(search))
|
|
|
|
@group_group.command("close")
|
|
@click.argument("group_id", type=int)
|
|
@gentle_mode_option("Throttle mode for large group operations.")
|
|
@handle_errors
|
|
def group_close(group_id, gentle_mode):
|
|
"""Close (ungroup and optionally close) a tab group."""
|
|
client_from_ctx().groups.close(group_id, gentle_mode=gentle_mode)
|
|
console.print(f"[green]Group {group_id} closed[/green]")
|
|
|
|
@group_group.command("create")
|
|
@click.argument("name")
|
|
@handle_errors
|
|
def group_create(name):
|
|
"""Create a new tab group with NAME."""
|
|
group = client_from_ctx().groups.create(name)
|
|
console.print(f"[green]Created group '{name}'[/green] (id: {group.id})")
|
|
|
|
@group_group.command("add-tab")
|
|
@click.argument("group")
|
|
@click.argument("url", required=False)
|
|
@handle_errors
|
|
def group_add_tab(group, url):
|
|
"""Open a new tab (optionally at URL) inside GROUP (name or ID)."""
|
|
tab_id = client_from_ctx().groups.add_tab(group, url)
|
|
label = url or "new tab"
|
|
console.print(f"[green]Opened {label}[/green] in group '{group}' (tab id: {tab_id})")
|
|
|
|
@group_group.command("move")
|
|
@click.argument("group")
|
|
@click.option("-f", "--forward", "forward", is_flag=True, help="Move group one position to the right")
|
|
@click.option("-b", "--backward", "backward", is_flag=True, help="Move group one position to the left")
|
|
@click.option("-r", "--right", "forward", is_flag=True, help="Move group one position to the right")
|
|
@click.option("-l", "--left", "backward", is_flag=True, help="Move group one position to the left")
|
|
@handle_errors
|
|
def group_move(group, forward, backward):
|
|
"""Move a tab group forward/backward or right/left (name or ID)."""
|
|
if not forward and not backward:
|
|
console.print("[red]Specify --forward/--right or --backward/--left[/red]")
|
|
raise SystemExit(1)
|
|
result = client_from_ctx().groups.move(group, forward=forward, backward=backward)
|
|
if isinstance(result, dict) and not result.get("moved"):
|
|
console.print(f"[yellow]Group '{group}' is already at the {'end' if forward else 'start'}[/yellow]")
|
|
else:
|
|
direction = "forward" if forward else "backward"
|
|
console.print(f"[green]Group '{group}' moved {direction}[/green]")
|