mirror of
https://github.com/rendercv/rendercv.git
synced 2025-12-24 05:58:06 -05:00
* Rename `data` folder with schema * Start refactoring data models * Work on entry models * Keep working on entries * Keep working on data models * Push old data files * Keep working on data models * First draft of schema.cv * Keep working on schema * Keep working on schema * Improve schema.models * Keep working on rendercv.schema * Work on schema.design * Keep working on rendercv.schema * Complete variant_class_generator * Keep working rendercv.schema * Keep working on rendercv.schema * Final touches to rendercv.schema * Improve json schema descriptions in rendercv.schema * Start working on rendercv.schema tests * Keep implementing rendercv.schema tests * Add more tests for rendercv.schema * Improve rendercv.schema * Improve docstrings and comments in rendercv.schema * Implement better pydantic error handling in `rendercv.schema` * Improve variant class system * Fix rendercv.schema tests * Start working on rendercv.templater * Update template names * Switching to new rendercv typst template soon * Work on new templater * Rename renderer with renderer_old * Don't use utils in rendercv.schema * Complete connections * Update renderer folder structure * Work on new renderer * Work on new renderer * Date processing on new renderer * Improve date processing, support multiple emails, phones, and websites * Improve markdown to Typst * Complete entry template processing * Time span computation in new renderer * Better entry templates * Setup new templates * Improve rendercv.schema * Start adding tests for rendercv.renderer * New markdown parser! * Improve markdown to typst conversion * Finalize markdown parser * Add new test files for rendercv.renderer * Fix cv and connections * Add connections test * Improve connection tests * Improve entry templates * Add model processor tests * Improve templater * Rename old folders * Improve schema * Add file generation logic to renderer * Fix naming issues * Fix schema tests * Add path type tests * Add font family and typst dimension type tests * Rename old tests * Fix design tests * Start integration testing of renderer * Improve entry tempates * Handle nested highlights properly * Finalize Typst preamble template * Start working on new CLI * Remove old test files * Implement override dictionary in new schema * Start working on new CLI * Better prints on render command * New structure * New render printer * Add all the commands to new CLI * Work on new command in new cli * Improve new command * Add error handler to new cli * Work on create theme command * Complete create theme command * Remove old source files * Improve exceptions * Create new docs * Add writing tests guide * Fix cli printer and write tests * Test copy templates * Add app tests * Bring back accidentally removed files * Imporve cli and tests * Fix path issues * Improve * Improve * Add reference file comparison tests * Fix path resolver * Start working on test_pdf_png * Implement comparison of multiple files (png) * Start testing typst * Fix templating issues * Fix header and entry templates issues * Implement short second rows * Fix date issues * Fix nested bullets and add summary * Update testdata * Implement footer * Update testdata * Reimagined design and locale schema, first iteration * Reimagined design and locale second iteration * Update design and locale schemas * Adapt templater to the new design and locale * Fix tests * Update lib.typ and testdata for the new locale and design * Implement proper tests with all combinations of entries * Remove some docstrings * fix connections logic * Improve * Start working on examples * Update testdata * Fix long second row issue * fix templating issues * Fix lib.typ issues * Update testdata * Fix clean_trailing_parts * Update test cv * update test cv * Update theme defaults * update schema and fix moderncv * Fix moderncv issues * Update testdata * Update testdata and examples * Fix issues about photo * Fix typst photo path issues * improve entry templates from yaml * add new locale * Rename writing tests doc * Update writing tests * Improve tests * Add more cli tests * Increase test coverage * Rename variant pydantic model generator * Improve tests * Update testdata and improve tests * Format, fix pre-commit errors * Fix scripts and update entry figures * Improve tests * Write docstrings of schema * Write schema docstrings * Setup api reference * Start working on new docs * Work on docs * Improve progress panel of render command * Finalize new docs index * Complete CLI docs * Work on YAML input structure page * Finalize user guide * Start working on developer guide * Improve api reference * Improve developer guide * Improve developer guide * Improve developer gide * Improve developer guide * Improve developer guide * Update developer guide * Improve developer guide * Improve developer guide * Improve developer guide * Developer guide first draft * update developer guide * Update examples * Update testdata * Handle wrong installation (rendercv instead of rendercv[full]) * Remove unnecessary files * Write set up vs code page * Update README.md * Change docs description * Compress design options gif * minor updates * Polish all the json schema descriptions * Update testdata and examples * Remove some emdashed from docs * Add whatsapp support * Add TestEscapeTypstCharacters to tests * Implement custom connections * Add page break before sections feature * Revert page break before sections feature * Rebase to main * Fix social network tests, update schema
116 lines
4.0 KiB
Python
116 lines
4.0 KiB
Python
import pathlib
|
|
import tempfile
|
|
|
|
import fitz
|
|
import pdfCropMargins
|
|
|
|
from rendercv.renderer.pdf_png import generate_pdf
|
|
from rendercv.renderer.typst import generate_typst
|
|
from rendercv.schema.models.cv.cv import Cv
|
|
from rendercv.schema.models.design.built_in_design import available_themes
|
|
from rendercv.schema.models.rendercv_model import RenderCVModel
|
|
from rendercv.schema.rendercv_model_builder import build_rendercv_dictionary_and_model
|
|
from rendercv.schema.yaml_reader import read_yaml
|
|
|
|
repository_root = pathlib.Path(__file__).parent.parent
|
|
rendercv_path = repository_root / "rendercv"
|
|
image_assets_directory = repository_root / "docs" / "assets" / "images"
|
|
|
|
|
|
def pdf_to_png(pdf_file_path: pathlib.Path) -> list[pathlib.Path]:
|
|
# check if the file exists:
|
|
if not pdf_file_path.is_file():
|
|
message = f"The file {pdf_file_path} doesn't exist!"
|
|
raise FileNotFoundError(message)
|
|
|
|
# convert the PDF to PNG:
|
|
png_directory = pdf_file_path.parent
|
|
png_file_name = pdf_file_path.stem
|
|
png_files = []
|
|
pdf = fitz.open(pdf_file_path) # open the PDF file
|
|
for page in pdf: # iterate the pages
|
|
image = page.get_pixmap(dpi=300) # type: ignore
|
|
assert page.number is not None
|
|
png_file_path = png_directory / f"{png_file_name}_{page.number + 1}.png"
|
|
image.save(png_file_path)
|
|
png_files.append(png_file_path)
|
|
|
|
return png_files
|
|
|
|
|
|
entries = read_yaml(repository_root / "docs" / "user_guide" / "sample_entries.yaml")
|
|
entry_types = entries.keys()
|
|
themes = available_themes
|
|
|
|
with tempfile.TemporaryDirectory() as temporary_directory:
|
|
# Create temporary directory
|
|
temporary_directory_path = pathlib.Path(temporary_directory)
|
|
for theme in themes:
|
|
design_dictionary = {
|
|
"theme": theme,
|
|
"page": {
|
|
"show_page_numbering": False,
|
|
"show_last_updated_date": False,
|
|
},
|
|
}
|
|
|
|
for entry_type in entry_types:
|
|
# Create data model with only one section and one entry
|
|
typst_path = temporary_directory_path / "typst.typ"
|
|
pdf_path = temporary_directory_path / "pdf.pdf"
|
|
_, model = build_rendercv_dictionary_and_model(
|
|
RenderCVModel(
|
|
cv=Cv(sections={entry_type: [entries[entry_type]]}),
|
|
).model_dump_json(),
|
|
typst_path=typst_path,
|
|
pdf_path=pdf_path,
|
|
overrides={
|
|
"design": { # pyright: ignore[reportArgumentType]
|
|
"theme": theme,
|
|
"page": {"show_footer": False, "show_top_note": False},
|
|
}
|
|
},
|
|
)
|
|
|
|
# Render
|
|
generate_typst(model)
|
|
generate_pdf(model, typst_path)
|
|
|
|
# Prepare output directory and file path
|
|
output_directory = image_assets_directory / theme
|
|
output_directory.mkdir(parents=True, exist_ok=True)
|
|
|
|
output_pdf_file_path = temporary_directory_path / f"{entry_type}.pdf"
|
|
# Crop margins
|
|
pdfCropMargins.crop(
|
|
argv_list=[
|
|
"-p4",
|
|
"100",
|
|
"0",
|
|
"100",
|
|
"0",
|
|
"-a4",
|
|
"0",
|
|
"-30",
|
|
"0",
|
|
"-30",
|
|
"-o",
|
|
str(output_pdf_file_path.absolute()),
|
|
str(pdf_path.absolute()),
|
|
]
|
|
)
|
|
|
|
# Convert PDF to image
|
|
png_file_path = pdf_to_png(output_pdf_file_path)[0]
|
|
desired_png_file_path = image_assets_directory / theme / f"{entry_type}.png"
|
|
|
|
# If image exists, remove it
|
|
if desired_png_file_path.exists():
|
|
desired_png_file_path.unlink()
|
|
|
|
# Move image to desired location
|
|
png_file_path.rename(desired_png_file_path)
|
|
|
|
|
|
print("Entry figures generated successfully.") # NOQA: T201
|