mirror of
https://github.com/rendercv/rendercv.git
synced 2026-01-03 10:58:08 -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
92 lines
3.6 KiB
Markdown
92 lines
3.6 KiB
Markdown
---
|
|
toc_depth: 3
|
|
---
|
|
|
|
# Documentation
|
|
|
|
## The Goal
|
|
|
|
We want documentation at `docs.rendercv.com`, a proper website with navigation, search, theming, and interactive features.
|
|
|
|
**What is a website?** A collection of HTML, CSS, and JavaScript files. Browsers download these files and render them as the pages you see. To have a website, you need:
|
|
|
|
1. HTML/CSS/JavaScript files
|
|
2. A server hosting those files
|
|
3. A domain pointing to that server
|
|
|
|
**The problem:** Writing HTML/CSS/JavaScript manually for documentation is impractical. You want to write content in Markdown and have it become a professional website automatically.
|
|
|
|
**The solution:** [`mkdocs`](https://github.com/mkdocs/mkdocs) with [Material theme](https://github.com/squidfunk/mkdocs-material). You write Markdown in `docs/`, `mkdocs` generates HTML/CSS/JavaScript, and GitHub Pages hosts it at `docs.rendercv.com`.
|
|
|
|
```mermaid
|
|
flowchart LR
|
|
A[Markdown in docs/] --> B[MkDocs + Material]
|
|
B --> C[HTML/CSS/JS files]
|
|
C --> D[GitHub Pages hosting]
|
|
D --> E[docs.rendercv.com]
|
|
```
|
|
|
|
**This means:** Editing Markdown files in `docs/` updates the website at `docs.rendercv.com`.
|
|
|
|
## Configuration: [`mkdocs.yaml`](https://github.com/rendercv/rendercv/blob/main/mkdocs.yaml)
|
|
|
|
`mkdocs.yaml` controls how `mkdocs` builds the website:
|
|
|
|
- **Site metadata:** name, description, repository
|
|
- **Theme:** Material theme with colors and features
|
|
- **Navigation:** sidebar structure
|
|
- **Plugins:** see below
|
|
|
|
## Plugins
|
|
|
|
`mkdocs` plugins extend functionality beyond Markdown → HTML conversion.
|
|
|
|
### [`mkdocstrings`](https://github.com/mkdocstrings/mkdocstrings): API Reference
|
|
|
|
Generates API reference from Python docstrings. The entire [API Reference](../api_reference/index.md) section is auto-generated from `src/rendercv/`.
|
|
|
|
### [`mkdocs-macros-plugin`](https://mkdocs-macros-plugin.readthedocs.io/): Dynamic Content
|
|
|
|
Lets you inject code-generated values into Markdown. [`docs/docs_templating.py`](https://github.com/rendercv/rendercv/blob/main/docs/docs_templating.py) runs during build. It imports values directly from RenderCV's code and exposes them as variables. It's heavily used in [YAML Input Structure](../user_guide/yaml_input_structure.md) page.
|
|
|
|
## Entry Type Figures
|
|
|
|
The [YAML Input Structure](../user_guide/yaml_input_structure.md) page shows visual examples of each entry type rendered in each theme.
|
|
|
|
These are auto-generated PNG images. Run `just update-entry-figures` to regenerate them from [`docs/user_guide/sample_entries.yaml`](https://github.com/rendercv/rendercv/blob/main/docs/user_guide/sample_entries.yaml).
|
|
|
|
## Local Preview
|
|
|
|
```bash
|
|
just serve-docs
|
|
```
|
|
|
|
Starts a local server at `http://127.0.0.1:8000` with live reload. Edit Markdown files and see changes instantly.
|
|
|
|
```bash
|
|
just build-docs
|
|
```
|
|
|
|
Generates the final website in `site/` directory. Mainly used by GitHub workflows for final deployment (see [GitHub Workflows](github_workflows.md)).
|
|
|
|
## Deployment
|
|
|
|
Every push to `main` triggers automatic deployment.
|
|
|
|
**The workflow** ([`.github/workflows/deploy-docs.yaml`](https://github.com/rendercv/rendercv/blob/main/.github/workflows/deploy-docs.yaml)):
|
|
|
|
1. **Trigger:** Runs on every push to `main`
|
|
2. **Build step:**
|
|
- Installs dependencies (`uv`, `just`)
|
|
- Runs `just build-docs` to generate the website
|
|
- Uploads the `site/` directory as an artifact
|
|
3. **Deploy step:**
|
|
- Takes the uploaded artifact
|
|
- Deploys it to GitHub Pages (a free static website hosting service)
|
|
- Makes it available at `docs.rendercv.com`
|
|
|
|
## Learn More
|
|
|
|
See the [MkDocs Material documentation](https://squidfunk.github.io/mkdocs-material/) for more information.
|
|
|