rendercv/docs/user_guide.md

216 lines
6.0 KiB
Markdown

# RenderCV: User Guide
After you've installed RenderCV with
```bash
pip install rendercv
```
you can start rendering your CV.
Firstly, go to the directory where you want your CV files located and run:
```bash
rendercv new "Your Full Name"
```
This will create a YAML input file for RenderCV called `Your_Name_CV.yaml`. Open this generated file in your favorite IDE and start editing. It governs all the features of RenderCV.
!!! tip
To maximize your productivity while editing the input YAML file, set up RenderCV's JSON Schema in your IDE. It will validate your inputs on the fly and give auto-complete suggestions.
=== "Visual Studio Code"
1. Install [YAML language support](https://marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml) extension.
2. Then the Schema will be automatically set up because the file ends with `_CV.yaml`.
=== "Other"
1. Ensure your editor of choice has support for YAML schema validation.
2. Add the following line at the top of `Your_Name_CV.yaml`:
``` yaml
# yaml-language-server: $schema=https://github.com/sinaatalay/rendercv/blob/main/schema.json?raw=true
```
After you're done editing your input file, run the command below to render your CV:
```bash
rendercv render Your_Name_CV.yaml
```
## Entry Types
There are five entry types in RenderCV:
1. *EducationEntry*
2. *ExperienceEntry*
3. *NormalEntry*
4. *OneLineEntry*
5. *PublicationEntry*
The whole CV consists of these entries. The table below shows what sections of the input file use which entry type.
| YAML section | Entry Type |
| ------------------------------ | -------------------------------- |
| `education` | *EducationEntry* |
| `work_experience` | *ExperienceEntry* |
| `academic_projects` | *NormalEntry* |
| `publications` | *PublicationEntry* |
| `certificates` | *NormalEntry* |
| `skills` | *OneLineEntry* |
| `test_scores` | *OneLineEntry* |
| `personal_projects` | *NormalEntry* |
| `extracurricular_activities` | *ExperienceEntry* |
| `custom_sections` | **They can be any of the five!** |
!!! info
Note that *EducationEntry* is not necessarily for education entries only. It's one of the five entry designs that RenderCV offers, and it could be used for anything (see [custom sections](http://user_guide.md#custom_sections)). *EducationEntry* just happens to be its name. The same goes for other entries, too.
### *EducationEntry*
```yaml
institution: Boğaziçi University
url: https://boun.edu.tr
area: Mechanical Engineering
study_type: BS
location: Istanbul, Turkey
start_date: "2017-09-01"
end_date: "2023-01-01"
transcript_url: https://example.com
gpa: 3.10/4.00
highlights:
- "Class rank: 10 of 62"
```
which renders into
![EducationEntry](images/EducationEntry.png)
### *ExperienceEntry*
```yaml
company: AmIACompany
position: Summer Intern
location: Istanbul, Turkey
url: https://example.com
start_date: "2022-06-15"
end_date: "2022-08-01"
highlights:
- AmIACompany is a technology company that provides web-based engineering
applications that enable the simulation and optimization of products and
manufacturing tools.
- Modeled and simulated a metal-forming process deep drawing using finite element
analysis with open-source software called CalculiX.
```
which renders into
![ExperienceEntry](images/ExperienceEntry.png)
### *NormalEntry*
```yaml
name: Design and Construction of a Dynamometer
location: Istanbul, Turkey
date: Fall 2022
highlights:
- Designed and constructed a controllable dynamometer that measures an electric
motor's torque and power output at different speeds for my senior design project.
url: https://example.com
```
which renders into
![NormalEntry](images/NormalEntry.png)
### *OneLineEntry*
```yaml
name: Programming
details: C++, C, Python, JavaScript, MATLAB, Lua, LaTeX
```
which renders into
![OneLineEntry](images/OneLineEntry.png)
### *PublicationEntry*
```yaml
title: Phononic band gaps induced by inertial amplification in periodic media
authors:
- Author 1
- John Doe
- Author 3
journal: Physical Review B
doi: 10.1103/PhysRevB.76.054309
date: "2007-08-01"
cited_by: 243
```
which renders into
![PublicationEntry](images/PublicationEntry.png)
## Custom Sections
Custom sections with custom titles can be created. Each custom section will be an object that looks like this:
```yaml
title: My Custom Section
entry_type: OneLineEntry
entries:
- name: Testing custom sections
details: Wohooo!
- name: This is a
details: OneLineEntry!
```
And `custom_sections` part of the data model will be a list of customs section objects that look like this:
```yaml
custom_sections:
- title: My Custom Section
entry_type: OneLineEntry
entries:
- name: Testing custom sections
details: Wohooo!
- name: This is a
details: OneLineEntry!
- title: My Other Custom Section
entry_type: EducationEntry
entries:
- institution: Hop!
area: Hop!
study_type: HA
highlights:
- "There are only five types of entries: *EducationEntry*, *ExperienceEntry*,
*NormalEntry*, *OneLineEntry*, and *PublicationEntry*."
- This is an EducationEntry!
start_date: "2022-06-15"
end_date: "2022-08-01"
```
Each custom section needs to have an entry type, and entries should be adjusted according to the entry type selection.
!!! note
Some entry types use links, and all the links have a text placeholder. That placeholder can be changed with `link_text` setting as shown below:
```yaml
title: My Third Custom Section
entry_type: ExperienceEntry
link_text: My Link Text
entries:
- company: Hop!
position: Hop!
date: My Date
location: My Location
url: https://example.com
highlights:
- I think this is really working. This is an *ExperienceEntry*!
```