mirror of
https://github.com/onyx-and-iris/obsws-cli.git
synced 2025-06-27 14:00:30 +01:00
print colourless check/cross marks if NO_COLOR is set
patch bump
This commit is contained in:
parent
85b653891d
commit
fd2e629ec2
@ -5,7 +5,7 @@ All notable changes to this project will be documented in this file.
|
|||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
# [0.17.0] - 2025-06-20
|
# [0.17.3] - 2025-06-20
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
@ -15,6 +15,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- scene list no longer prints the UUIDs by default, enable it with the --uuid flag.
|
- scene list no longer prints the UUIDs by default, enable it with the --uuid flag.
|
||||||
|
- if NO_COLOR is set, print colourless check and cross marks in tables.
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2025-present onyx-and-iris <code@onyxandiris.online>
|
# SPDX-FileCopyrightText: 2025-present onyx-and-iris <code@onyxandiris.online>
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
__version__ = "0.17.2"
|
__version__ = "0.17.3"
|
||||||
|
@ -65,7 +65,7 @@ def list_(
|
|||||||
table.add_row(
|
table.add_row(
|
||||||
filter['filterName'],
|
filter['filterName'],
|
||||||
util.snakecase_to_titlecase(filter['filterKind']),
|
util.snakecase_to_titlecase(filter['filterKind']),
|
||||||
':white_heavy_check_mark:' if filter['filterEnabled'] else ':x:',
|
util.check_mark(filter['filterEnabled']),
|
||||||
'\n'.join(
|
'\n'.join(
|
||||||
[
|
[
|
||||||
f'{util.snakecase_to_titlecase(k):<20} {v:>10}'
|
f'{util.snakecase_to_titlecase(k):<20} {v:>10}'
|
||||||
|
@ -5,7 +5,7 @@ from typing import Annotated, Optional
|
|||||||
import typer
|
import typer
|
||||||
from rich.table import Table
|
from rich.table import Table
|
||||||
|
|
||||||
from . import console, validate
|
from . import console, util, validate
|
||||||
from .alias import AliasGroup
|
from .alias import AliasGroup
|
||||||
from .protocols import DataclassProtocol
|
from .protocols import DataclassProtocol
|
||||||
|
|
||||||
@ -61,7 +61,7 @@ def list_(
|
|||||||
table.add_row(
|
table.add_row(
|
||||||
str(item_id),
|
str(item_id),
|
||||||
group_name,
|
group_name,
|
||||||
':white_heavy_check_mark:' if is_enabled else ':x:',
|
util.check_mark(is_enabled),
|
||||||
)
|
)
|
||||||
|
|
||||||
console.out.print(table)
|
console.out.print(table)
|
||||||
|
@ -81,7 +81,7 @@ def list_(
|
|||||||
input_mark = ''
|
input_mark = ''
|
||||||
try:
|
try:
|
||||||
input_muted = ctx.obj.get_input_mute(name=input_name).input_muted
|
input_muted = ctx.obj.get_input_mute(name=input_name).input_muted
|
||||||
input_mark = ':white_heavy_check_mark:' if input_muted else ':x:'
|
input_mark = util.check_mark(input_muted)
|
||||||
except obsws.error.OBSSDKRequestError as e:
|
except obsws.error.OBSSDKRequestError as e:
|
||||||
if e.code == 604: # Input does not support audio
|
if e.code == 604: # Input does not support audio
|
||||||
input_mark = 'N/A'
|
input_mark = 'N/A'
|
||||||
|
@ -5,7 +5,7 @@ from typing import Annotated
|
|||||||
import typer
|
import typer
|
||||||
from rich.table import Table
|
from rich.table import Table
|
||||||
|
|
||||||
from . import console, validate
|
from . import console, util, validate
|
||||||
from .alias import AliasGroup
|
from .alias import AliasGroup
|
||||||
|
|
||||||
app = typer.Typer(cls=AliasGroup)
|
app = typer.Typer(cls=AliasGroup)
|
||||||
@ -32,7 +32,7 @@ def list_(ctx: typer.Context):
|
|||||||
for profile in resp.profiles:
|
for profile in resp.profiles:
|
||||||
table.add_row(
|
table.add_row(
|
||||||
profile,
|
profile,
|
||||||
':white_heavy_check_mark:' if profile == resp.current_profile_name else '',
|
util.check_mark(profile == resp.current_profile_name),
|
||||||
)
|
)
|
||||||
|
|
||||||
console.out.print(table)
|
console.out.print(table)
|
||||||
|
@ -5,7 +5,7 @@ from typing import Annotated
|
|||||||
import typer
|
import typer
|
||||||
from rich.table import Table
|
from rich.table import Table
|
||||||
|
|
||||||
from . import console, validate
|
from . import console, util, validate
|
||||||
from .alias import AliasGroup
|
from .alias import AliasGroup
|
||||||
|
|
||||||
app = typer.Typer(cls=AliasGroup)
|
app = typer.Typer(cls=AliasGroup)
|
||||||
@ -55,13 +55,13 @@ def list_(
|
|||||||
if uuid:
|
if uuid:
|
||||||
table.add_row(
|
table.add_row(
|
||||||
scene_output,
|
scene_output,
|
||||||
':white_heavy_check_mark:' if scene_name == active_scene else '',
|
util.check_mark(scene_name == active_scene),
|
||||||
scene_uuid,
|
scene_uuid,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
table.add_row(
|
table.add_row(
|
||||||
scene_output,
|
scene_output,
|
||||||
':white_heavy_check_mark:' if scene_name == active_scene else '',
|
util.check_mark(scene_name == active_scene),
|
||||||
)
|
)
|
||||||
|
|
||||||
console.out.print(table)
|
console.out.print(table)
|
||||||
|
@ -5,7 +5,7 @@ from typing import Annotated, Optional
|
|||||||
import typer
|
import typer
|
||||||
from rich.table import Table
|
from rich.table import Table
|
||||||
|
|
||||||
from . import console, validate
|
from . import console, util, validate
|
||||||
from .alias import AliasGroup
|
from .alias import AliasGroup
|
||||||
|
|
||||||
app = typer.Typer(cls=AliasGroup)
|
app = typer.Typer(cls=AliasGroup)
|
||||||
@ -102,9 +102,7 @@ def list_(
|
|||||||
str(group_item_id),
|
str(group_item_id),
|
||||||
group_item_name,
|
group_item_name,
|
||||||
item_name,
|
item_name,
|
||||||
':white_heavy_check_mark:'
|
util.check_mark(is_enabled and group_item_enabled),
|
||||||
if is_enabled and group_item_enabled
|
|
||||||
else ':x:',
|
|
||||||
group_item_source_uuid,
|
group_item_source_uuid,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
@ -112,9 +110,7 @@ def list_(
|
|||||||
str(group_item_id),
|
str(group_item_id),
|
||||||
group_item_name,
|
group_item_name,
|
||||||
item_name,
|
item_name,
|
||||||
':white_heavy_check_mark:'
|
util.check_mark(is_enabled and group_item_enabled),
|
||||||
if is_enabled and group_item_enabled
|
|
||||||
else ':x:',
|
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
if uuid:
|
if uuid:
|
||||||
@ -122,7 +118,7 @@ def list_(
|
|||||||
str(item_id),
|
str(item_id),
|
||||||
item_name,
|
item_name,
|
||||||
'',
|
'',
|
||||||
':white_heavy_check_mark:' if is_enabled else ':x:',
|
util.check_mark(is_enabled),
|
||||||
source_uuid,
|
source_uuid,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
@ -130,7 +126,7 @@ def list_(
|
|||||||
str(item_id),
|
str(item_id),
|
||||||
item_name,
|
item_name,
|
||||||
'',
|
'',
|
||||||
':white_heavy_check_mark:' if is_enabled else ':x:',
|
util.check_mark(is_enabled),
|
||||||
)
|
)
|
||||||
|
|
||||||
console.out.print(table)
|
console.out.print(table)
|
||||||
|
@ -1,6 +1,15 @@
|
|||||||
"""module contains utility functions for the obsws_cli package."""
|
"""module contains utility functions for the obsws_cli package."""
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
def snakecase_to_titlecase(snake_str):
|
|
||||||
|
def snakecase_to_titlecase(snake_str: str) -> str:
|
||||||
"""Convert a snake_case string to a title case string."""
|
"""Convert a snake_case string to a title case string."""
|
||||||
return snake_str.replace('_', ' ').title()
|
return snake_str.replace('_', ' ').title()
|
||||||
|
|
||||||
|
|
||||||
|
def check_mark(value: bool) -> str:
|
||||||
|
"""Return a check mark or cross mark based on the boolean value."""
|
||||||
|
if os.getenv('NO_COLOR') is not None:
|
||||||
|
return '✓' if value else '✗'
|
||||||
|
return '✅' if value else '❌'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user