update docs

This commit is contained in:
Sina Atalay 2024-02-24 16:38:58 +01:00
parent 998da75ed9
commit 3976aa15ee
7 changed files with 46 additions and 23 deletions

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

View File

@ -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

View File

@ -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()

View File

@ -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 *))
``` ```

View File

@ -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