mirror of https://github.com/eyhc1/rendercv.git
update docs
This commit is contained in:
parent
998da75ed9
commit
3976aa15ee
Binary file not shown.
Before Width: | Height: | Size: 104 KiB After Width: | Height: | Size: 113 KiB |
Binary file not shown.
Before Width: | Height: | Size: 101 KiB After Width: | Height: | Size: 108 KiB |
Binary file not shown.
Before Width: | Height: | Size: 92 KiB After Width: | Height: | Size: 101 KiB |
|
@ -1,6 +1,6 @@
|
||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project after v1.0 will be documented in this file.
|
||||||
|
|
||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/).
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/).
|
||||||
|
|
||||||
|
@ -25,9 +25,4 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/).
|
||||||
- The reference has been rewritten.
|
- The reference has been rewritten.
|
||||||
- The build system has been changed from `setuptools` to `hatchling`.
|
- The build system has been changed from `setuptools` to `hatchling`.
|
||||||
|
|
||||||
<!-- ### Removed
|
|
||||||
|
|
||||||
- -->
|
|
||||||
|
|
||||||
[unreleased]: https://github.com/sinaatalay/rendercv/compare/v1.0...HEAD
|
|
||||||
[1.0]: https://github.com/sinaatalay/rendercv/releases/tag/v1.0
|
[1.0]: https://github.com/sinaatalay/rendercv/releases/tag/v1.0
|
||||||
|
|
|
@ -76,7 +76,7 @@ publication_entry = {
|
||||||
"Magneto-Thermal Thin Shell Approximation for 3D Finite Element Analysis of"
|
"Magneto-Thermal Thin Shell Approximation for 3D Finite Element Analysis of"
|
||||||
" No-Insulation Coils"
|
" No-Insulation Coils"
|
||||||
),
|
),
|
||||||
"authors": ["John Doe", "Harry Tom"],
|
"authors": ["John Doe", "Harry Tom", "Sina Doe", "Anotherfirstname Andsurname"],
|
||||||
"date": "2023-12-08",
|
"date": "2023-12-08",
|
||||||
"journal": "IEEE Transactions on Applied Superconductivity",
|
"journal": "IEEE Transactions on Applied Superconductivity",
|
||||||
"doi": "10.1109/TASC.2023.3340648",
|
"doi": "10.1109/TASC.2023.3340648",
|
||||||
|
@ -103,6 +103,8 @@ def dictionary_to_yaml(dictionary: dict[str, Any]):
|
||||||
str: The YAML string.
|
str: The YAML string.
|
||||||
"""
|
"""
|
||||||
yaml_object = ruamel.yaml.YAML()
|
yaml_object = ruamel.yaml.YAML()
|
||||||
|
yaml_object.width = 60
|
||||||
|
yaml_object.indent(mapping=2, sequence=4, offset=2)
|
||||||
with io.StringIO() as string_stream:
|
with io.StringIO() as string_stream:
|
||||||
yaml_object.dump(dictionary, string_stream)
|
yaml_object.dump(dictionary, string_stream)
|
||||||
yaml_string = string_stream.getvalue()
|
yaml_string = string_stream.getvalue()
|
||||||
|
|
|
@ -61,7 +61,7 @@ RenderCV's input file consists of two parts: `cv` and `design`.
|
||||||
```yaml
|
```yaml
|
||||||
cv:
|
cv:
|
||||||
...
|
...
|
||||||
YOUR CONTENT]
|
YOUR CONTENT
|
||||||
...
|
...
|
||||||
design:
|
design:
|
||||||
...
|
...
|
||||||
|
@ -69,9 +69,9 @@ design:
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
The `cv` part contains only the content of the CV, and the `design` part contains only the design properties of the CV. That's how the design and content are separated.
|
The `cv` part contains only the **content of the CV**, and the `design` part contains only the **design options of the CV**. That's how the design and content are separated.
|
||||||
|
|
||||||
### `cv` section of the YAML input
|
### "`cv`" section of the YAML input
|
||||||
|
|
||||||
The `cv` section of the YAML input starts with generic information, as shown below:
|
The `cv` section of the YAML input starts with generic information, as shown below:
|
||||||
|
|
||||||
|
@ -83,6 +83,7 @@ cv:
|
||||||
website: https://example.com
|
website: https://example.com
|
||||||
label: Mechanical Engineer
|
label: Mechanical Engineer
|
||||||
location: Istanbul, Türkiye
|
location: Istanbul, Türkiye
|
||||||
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
None of the values above are required. You can omit any or all of them, and RenderCV will adapt to your input.
|
None of the values above are required. You can omit any or all of them, and RenderCV will adapt to your input.
|
||||||
|
@ -103,7 +104,7 @@ cv:
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
The `sections` field is a dictionary where the keys are the section titles, and the values are lists. Each item on the list is an entry in the CV.
|
The `sections` field is a dictionary where the keys are the section titles, and the values are lists. Each item of the list is an entry for that section.
|
||||||
|
|
||||||
Here is an example:
|
Here is an example:
|
||||||
|
|
||||||
|
@ -126,14 +127,14 @@ cv:
|
||||||
- company: Another ExperienceEntry.
|
- company: Another ExperienceEntry.
|
||||||
position: Your position
|
position: Your position
|
||||||
start_date: 2019-01-01
|
start_date: 2019-01-01
|
||||||
end_date: 2020-01
|
end_date: 2020-01-10
|
||||||
location: TX, USA
|
location: TX, USA
|
||||||
highlights:
|
highlights:
|
||||||
- This is a highlight (bullet point).
|
- This is a highlight (bullet point).
|
||||||
- This is another highlight.
|
- This is another highlight.
|
||||||
```
|
```
|
||||||
|
|
||||||
There are six different entry types in RenderCV. You must choose one for each section and cannot mix types within a section.
|
There are six different entry types in RenderCV. Different types of entries cannot be mixed under the same section, so for each section, you can only use one type of entry.
|
||||||
|
|
||||||
The available entry types are: `EducationEntry`, `ExperienceEntry`, `PublicationEntry`, `NormalEntry`, `OneLineEntry`, and `TextEntry`.
|
The available entry types are: `EducationEntry`, `ExperienceEntry`, `PublicationEntry`, `NormalEntry`, `OneLineEntry`, and `TextEntry`.
|
||||||
|
|
||||||
|
@ -150,16 +151,17 @@ Each entry type is a different object (a dictionary). All of the entry types and
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
||||||
### `design` section of the YAML input
|
### "`design`" section of the YAML input
|
||||||
|
|
||||||
The `cv` part of the input contains your content, and the `design` part contains your design. The `design` part starts with the name of the theme. Currently, there are three built-in themes (`classic`, `sb2nov`, and `moderncv`), but custom themes can also be used (see below.)
|
The `cv` part of the input contains your content, and the `design` part contains your design. The `design` part starts with a theme name. Currently, there are three built-in themes (`classic`, `sb2nov`, and `moderncv`), but custom themes can also be used (see [below](#using-custom-themes).)
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
design:
|
design:
|
||||||
theme: classic
|
theme: classic
|
||||||
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
Each theme has different options for design. `classic` and `sb2nov` almost use identical options, but `moderncv` is slightly different. Please use an IDE that supports JSON schema to avoid missing any available options for the theme (see above).
|
Each theme has different options for design. `classic` and `sb2nov` almost use identical options, but `moderncv` is slightly different. Please use an IDE that supports JSON schema to avoid missing any available options for the theme (see [above](#generating-the-input-file)).
|
||||||
|
|
||||||
An example `design` part for a `classic` theme is shown below:
|
An example `design` part for a `classic` theme is shown below:
|
||||||
|
|
||||||
|
@ -201,15 +203,32 @@ design:
|
||||||
|
|
||||||
RenderCV allows you to move your $\LaTeX$ CV code to RenderCV. To do this, you will need to create some files:
|
RenderCV allows you to move your $\LaTeX$ CV code to RenderCV. To do this, you will need to create some files:
|
||||||
|
|
||||||
BURAYA FOLDER STRUCTURE GOSTERE, INPUT FILE I DA BELIRTEREK, YOUR_THEME SEKLINDE BIR DIRECTORY ALTINDA ZORUNLU TUM DOSYALARI GOSTER.
|
``` { .sh .no-copy }
|
||||||
|
├── yourcustomtheme
|
||||||
|
│ ├── Preamble.j2.tex
|
||||||
|
│ ├── Header.j2.tex
|
||||||
|
│ ├── EducationEntry.j2.tex
|
||||||
|
│ ├── ExperienceEntry.j2.tex
|
||||||
|
│ ├── NormalEntry.j2.tex
|
||||||
|
│ ├── OneLineEntry.j2.tex
|
||||||
|
│ ├── PublicationEntry.j2.tex
|
||||||
|
│ ├── TextEntry.j2.tex
|
||||||
|
│ ├── SectionBeginning.j2.tex
|
||||||
|
│ └── SectionEnding.j2.tex
|
||||||
|
└── Your_Full_Name_CV.yaml
|
||||||
|
```
|
||||||
|
|
||||||
Each of these files is LaTeX code with some Python in it. These files allow RenderCV to create your CV out of the YAML input.
|
Each of these `*.j2.tex` files is $\LaTeX$ code with some Python in it. These files allow RenderCV to create your CV out of the YAML input.
|
||||||
|
|
||||||
The best way to understand how they work is to look at the source code of built-in themes. For example, the content of `ExperienceEntry.j2.tex` for the `moderncv` theme is shown below:
|
The best way to understand how they work is to look at the source code of built-in themes. For example, the content of `ExperienceEntry.j2.tex` for the `moderncv` theme is shown below:
|
||||||
|
|
||||||
```latex
|
```latex
|
||||||
\cventry{
|
\cventry{
|
||||||
((* if design.show_only_years *))<<entry.date_string_only_years>>((* else *))<<entry.date_string>>((* endif *))
|
((* if design.show_only_years *))
|
||||||
|
<<entry.date_string_only_years>>
|
||||||
|
((* else *))
|
||||||
|
<<entry.date_string>>
|
||||||
|
((* endif *))
|
||||||
}{
|
}{
|
||||||
<<entry.position>>
|
<<entry.position>>
|
||||||
}{
|
}{
|
||||||
|
@ -222,7 +241,9 @@ The best way to understand how they work is to look at the source code of built-
|
||||||
((* endfor *))
|
((* endfor *))
|
||||||
```
|
```
|
||||||
|
|
||||||
The values between `<<` and `>>` are the names of Python variables, allowing you to write a LaTeX CV without writing any content. Those will be replaced with the values found in the YAML input. Also, the values between `((*` and `*))` are Python blocks, allowing you to use loops and conditional statements. The process of generating LaTeX files like this is called "templating," and it's achieved with a Python package called [Jinja](https://jinja.palletsprojects.com/en/3.1.x/).
|
The values between `<<` and `>>` are the names of Python variables, allowing you to write a $\\LaTeX$ CV without writing any content. Those will be replaced with the values found in the YAML input. Also, the values between `((*` and `*))` are Python blocks, allowing you to use loops and conditional statements.
|
||||||
|
|
||||||
|
The process of generating $\\LaTeX$ files like this is called "templating," and it's achieved with a Python package called [Jinja](https://jinja.palletsprojects.com/en/3.1.x/).
|
||||||
|
|
||||||
### Creating custom theme options
|
### Creating custom theme options
|
||||||
|
|
||||||
|
@ -245,5 +266,10 @@ class YourcustomthemeThemeOptions(pydantic.BaseModel):
|
||||||
|
|
||||||
Then, RenderCV will parse your custom design options, and you can use these variables inside your `*.j2.tex` as shown below:
|
Then, RenderCV will parse your custom design options, and you can use these variables inside your `*.j2.tex` as shown below:
|
||||||
|
|
||||||
```
|
```latex
|
||||||
|
<<design.option1>>
|
||||||
|
<<design.option2>>
|
||||||
|
((* if design.option4 *))
|
||||||
|
<<design.option3>>
|
||||||
|
((* endif *))
|
||||||
```
|
```
|
|
@ -1,7 +1,7 @@
|
||||||
"""RenderCV package.
|
"""RenderCV package.
|
||||||
|
|
||||||
RenderCV is a LaTeX CV generator from a JSON/YAML input file. It is a LaTeX framework,
|
RenderCV is a $\\LaTeX$ CV generator from a JSON/YAML input file. It is a $\\LaTeX$ framework,
|
||||||
and users can use RenderCV with their custom LaTeX CVs. It allows you to separate your
|
and users can use RenderCV with their custom $\\LaTeX$ CVs. It allows you to separate your
|
||||||
CV's content from its design.
|
CV's content from its design.
|
||||||
|
|
||||||
Write your content, and get a high-quality, professional-looking CV as a PDF with its
|
Write your content, and get a high-quality, professional-looking CV as a PDF with its
|
||||||
|
|
Loading…
Reference in New Issue