mirror of https://github.com/eyhc1/rendercv.git
216 lines
6.0 KiB
Markdown
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*!
|
|
```
|
|
|
|
|