cli: add a new command, create-theme

This commit is contained in:
Sina Atalay 2024-04-30 01:30:48 +03:00
parent 15c4557285
commit 900b4a0cc2
1 changed files with 84 additions and 12 deletions

View File

@ -413,7 +413,12 @@ class LiveProgressReporter(rich.live.Live):
) )
def copy_templates(folder_name: str, copy_to: pathlib.Path) -> Optional[pathlib.Path]: def copy_templates(
folder_name: str,
copy_to: pathlib.Path,
new_folder_name: Optional[str] = None,
suppress_warning: bool = False,
) -> Optional[pathlib.Path]:
"""Copy one of the folders found in `rendercv.templates` to `copy_to`. """Copy one of the folders found in `rendercv.templates` to `copy_to`.
Args: Args:
@ -424,12 +429,17 @@ def copy_templates(folder_name: str, copy_to: pathlib.Path) -> Optional[pathlib.
""" """
# copy the package's theme files to the current directory # copy the package's theme files to the current directory
template_directory = pathlib.Path(__file__).parent / "themes" / folder_name template_directory = pathlib.Path(__file__).parent / "themes" / folder_name
if new_folder_name:
destination = copy_to / new_folder_name
else:
destination = copy_to / folder_name destination = copy_to / folder_name
if destination.exists(): if destination.exists():
if not suppress_warning:
if folder_name != "markdown": if folder_name != "markdown":
warning( warning(
f'The theme folder "{folder_name}" already exists! The theme files are' f'The theme folder "{folder_name}" already exists! The theme files'
" not copied." " are not copied."
) )
else: else:
warning( warning(
@ -704,3 +714,65 @@ def cli_command_new(
"The following RenderCV input file and folders have been" "The following RenderCV input file and folders have been"
f" created:\n{created_files_and_folders_string}" f" created:\n{created_files_and_folders_string}"
) )
@app.command(
name="create-theme",
help=(
"Create a custom theme folder based on an existing theme. Example: [bold"
" green]rendercv create-theme --based-on classic customtheme[/bold green]"
),
)
def cli_command_create_theme(
theme_name: Annotated[
str,
typer.Argument(help="The name of the new theme."),
],
based_on: Annotated[
str,
typer.Option(
help=(
"The name of the existing theme to base the new theme on. Available"
f" themes are: {', '.join(dm.available_themes)}."
)
),
] = "classic",
):
"""Create a custom theme folder based on an existing theme."""
if based_on not in dm.available_themes:
error(
f'The theme "{based_on}" is not in the list of available themes:'
f' {", ".join(dm.available_themes)}'
)
return
theme_folder = copy_templates(
based_on, pathlib.Path.cwd(), new_folder_name=theme_name, suppress_warning=True
)
if theme_folder is None:
warning(
f'The theme folder "{theme_name}" already exists! The theme files are not'
" created."
)
return
based_on_theme_directory = pathlib.Path(__file__).parent / "themes" / based_on
based_on_theme_init_file = based_on_theme_directory / "__init__.py"
based_on_theme_init_file_contents = based_on_theme_init_file.read_text()
# generate the new init file:
class_name = f"{theme_name.title()}ThemeOptions"
literal_name = f'Literal["{theme_name}"]'
new_init_file_contents = (
based_on_theme_init_file_contents.replace(
f'Literal["{based_on}"]', literal_name
)
.replace(f"{based_on.title()}ThemeOptions", class_name)
.replace("..", "rendercv.themes")
)
# create the new __init__.py file:
(theme_folder / "__init__.py").write_text(new_init_file_contents)
information(f'The theme folder "{theme_folder.name}" has been created.')