update docs

This commit is contained in:
Sina Atalay 2023-09-13 20:02:27 +02:00
parent 9748912f21
commit cec955d5e8
4 changed files with 136 additions and 56 deletions

View File

@ -8,4 +8,15 @@ hide:
A simple tool to render your $\LaTeX$ CV or resume from a YAML file. A simple tool to render your $\LaTeX$ CV or resume from a YAML file.
It's a work in progress, please come back later. It's a work in progress, please come back later.
# Entry Types
## OneLineEntry
## EducationEntry
## ExperienceEntry
## NormalEntry

View File

@ -1,4 +1,4 @@
site_name: RenderCV site_name: "RenderCV"
site_description: A Python application that creates a CV in PDF from a YAML/JSON input file. site_description: A Python application that creates a CV in PDF from a YAML/JSON input file.
site_author: Sina Atalay site_author: Sina Atalay
copyright: Copyright © 2023 Sina Atalay copyright: Copyright © 2023 Sina Atalay
@ -49,6 +49,18 @@ nav:
- data_model.py: documentation/data_model.md - data_model.py: documentation/data_model.md
- rendering.py: documentation/rendering.md - rendering.py: documentation/rendering.md
markdown_extensions:
# see https://facelessuser.github.io/pymdown-extensions/extensions/inlinehilite/ for more pymdownx info
- pymdownx.highlight:
anchor_linenums: true
line_spans: __span
pygments_lang_class: true
- pymdownx.inlinehilite
- pymdownx.superfences
- toc:
permalink: true
title: Page contents
plugins: plugins:
- search - search
- mkdocstrings: - mkdocstrings:
@ -60,13 +72,13 @@ plugins:
members_order: source members_order: source
show_bases: true show_bases: true
docstring_section_style: list docstring_section_style: list
merge_init_into_class: true # merge_init_into_class: true
show_docstring_attributes: true show_docstring_attributes: true
docstring_style: google docstring_style: google
extra_javascript: extra_javascript:
- javascripts/katex.js - javascripts/katex.js
- https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.7/katex.min.js - https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.7/katex.min.js
- https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.7/contrib/auto-render.min.js - https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.7/contrib/auto-render.min.js
extra_css: extra_css:

View File

@ -51,16 +51,27 @@ dictionary = [
def check_spelling(sentence: str) -> str: def check_spelling(sentence: str) -> str:
""" """Check the spelling of a sentence and give warnings if there are any misspelled
Check the spelling of a sentence and give warnings if there are any misspelled
words. words.
It uses pyspellchecker. It can also guess the correct version of the It uses [pyspellchecker](https://github.com/barrust/pyspellchecker). It can also
misspelled word, but it is not used because it is very slow. guess the correct version of the misspelled word, but it is not used because it is
very slow.
:param sentence: The sentence to be checked. Example:
:type sentence: str ```python
:return: The same sentence. check_spelling("An interesting sentence is akways good.")
```
will print the following warning:
`WARNING - The word "akways" might be misspelled according to the pyspellchecker.`
Args:
sentence (str): The sentence to check.
Returns:
str: The same sentence.
""" """
modifiedSentence = sentence.lower() # convert to lower case modifiedSentence = sentence.lower() # convert to lower case
modifiedSentence = re.sub( modifiedSentence = re.sub(
@ -90,17 +101,24 @@ def check_spelling(sentence: str) -> str:
SpellCheckedString = Annotated[str, AfterValidator(check_spelling)] SpellCheckedString = Annotated[str, AfterValidator(check_spelling)]
def compute_time_span_string(start_date: PastDate, end_date: PastDate) -> str: def compute_time_span_string(start_date: Date, end_date: Date) -> str:
""" """Compute the time span between two dates and return a string that represents it.
Compute the time span between two dates and return a string that represents it. For,
example, if the time span is 1 year and 3 months, it will return "1 year 3 months". Example:
```python
compute_time_span_string(Date(2022,9,24), Date(2025,2,12))
```
:param start_date: The start date. will return:
:type start_date: PastDate
:param end_date: The end date. `#!python "2 years 5 months"`
:type end_date: PastDate
:return: The time span string. Args:
:rtype: str start_date (Date): The start date.
end_date (Date): The end date.
Returns:
str: The time span string.
""" """
# calculate the number of days between start_date and end_date: # calculate the number of days between start_date and end_date:
timeSpanInDays = (end_date - start_date).days timeSpanInDays = (end_date - start_date).days
@ -138,8 +156,24 @@ def compute_time_span_string(start_date: PastDate, end_date: PastDate) -> str:
def format_date(date: Date) -> str: def format_date(date: Date) -> str:
""" """Formats a date to a string in the following format: "Jan. 2021".
To be continued...
It uses month abbreviations, taken from
[Yale University Library](https://web.library.yale.edu/cataloging/months).
Example:
```python
format_date(Date(2024,5,1))
```
will return
`#!python "May 2024"`
Args:
date (Date): The date to format.
Returns:
str: The formatted date.
""" """
# Month abbreviations, # Month abbreviations,
# taken from: https://web.library.yale.edu/cataloging/months # taken from: https://web.library.yale.edu/cataloging/months
@ -177,9 +211,10 @@ def format_date(date: Date) -> str:
class ClassicThemeOptions(BaseModel): class ClassicThemeOptions(BaseModel):
""" """This class stores the options for the classic theme.
In RenderCV, each theme has its own ThemeNameThemeOptions class so that new themes
can be implemented easily. In RenderCV, each theme has its own Pydantic class so that new themes
can be implemented easily in future.
""" """
primary_color: Color = Field(default="blue") primary_color: Color = Field(default="blue")
@ -203,6 +238,8 @@ class ClassicThemeOptions(BaseModel):
class Design(BaseModel): class Design(BaseModel):
"""This class stores the theme name of the CV and the theme's options.
"""
theme: Literal["classic"] = "classic" theme: Literal["classic"] = "classic"
options: ClassicThemeOptions options: ClassicThemeOptions
@ -217,11 +254,11 @@ class Design(BaseModel):
class Event(BaseModel): class Event(BaseModel):
"""s """This class is the parent class for classes like `#!python EducationEntry`,
aa `#!python ExperienceEntry`, `#!python NormalEntry`, and `#!python OneLineEntry`.
Attributes: It stores the common fields between these classes like dates, location, highlights,
test and URL.
""" """
start_date: PastDate = None start_date: PastDate = None
@ -234,8 +271,8 @@ class Event(BaseModel):
@model_validator(mode="after") @model_validator(mode="after")
@classmethod @classmethod
def check_dates(cls, model): def check_dates(cls, model):
""" """Make sure that either `#!python start_date` and `#!python end_date` or only
To be continued... `#!python date`is provided.
""" """
if ( if (
model.start_date is not None model.start_date is not None
@ -317,9 +354,6 @@ class Event(BaseModel):
@computed_field @computed_field
@cached_property @cached_property
def highlight_strings(self) -> list[SpellCheckedString]: def highlight_strings(self) -> list[SpellCheckedString]:
"""
To be continued...
"""
highlight_strings = [] highlight_strings = []
highlight_strings.extend(self.highlights) highlight_strings.extend(self.highlights)
@ -329,9 +363,6 @@ class Event(BaseModel):
@computed_field @computed_field
@cached_property @cached_property
def markdown_url(self) -> str: def markdown_url(self) -> str:
"""
To be continued...
"""
if self.url is None: if self.url is None:
return None return None
else: else:
@ -354,23 +385,28 @@ class Event(BaseModel):
class OneLineEntry(Event): class OneLineEntry(Event):
# 1) Mandotory user inputs: """This class stores [OneLineEntry](../index.md#onelineentry) information.
"""
name: str name: str
details: str details: str
class NormalEntry(Event): class NormalEntry(Event):
# 1) Mandotory user inputs: """This class stores [NormalEntry](../index.md#normalentry) information.
"""
name: str name: str
class ExperienceEntry(Event): class ExperienceEntry(Event):
# 1) Mandotory user inputs: """This class stores [ExperienceEntry](../index.md#experienceentry) information.
"""
company: str company: str
position: str position: str
class EducationEntry(Event): class EducationEntry(Event):
"""This class stores [EducationEntry](../index.md#educationentry) information.
"""
# 1) Mandotory user inputs: # 1) Mandotory user inputs:
institution: str institution: str
area: str area: str
@ -396,18 +432,28 @@ class EducationEntry(Event):
class SocialNetwork(BaseModel): class SocialNetwork(BaseModel):
# 1) Mandotory user inputs: """This class stores a social network information.
Currently, only LinkedIn, Github, and Instagram are supported.
"""
network: Literal["LinkedIn", "GitHub", "Instagram"] network: Literal["LinkedIn", "GitHub", "Instagram"]
username: str username: str
class Connection(BaseModel): class Connection(BaseModel):
# 3) Derived fields (not user inputs): """This class stores a connection/communication information.
Warning:
This class isn't designed for users to use, but it is used by RenderCV to make
the $\LaTeX$ templating easier.
"""
name: Literal["LinkedIn", "GitHub", "Instagram", "phone", "email", "website"] name: Literal["LinkedIn", "GitHub", "Instagram", "phone", "email", "website"]
value: str value: str
class CurriculumVitae(BaseModel): class CurriculumVitae(BaseModel):
"""This class bindes all the information of a CV together.
"""
# 1) Mandotory user inputs: # 1) Mandotory user inputs:
name: str name: str
# 2) Optional user inputs: # 2) Optional user inputs:
@ -452,5 +498,7 @@ class CurriculumVitae(BaseModel):
class RenderCVDataModel(BaseModel): class RenderCVDataModel(BaseModel):
"""This class binds both the CV and the design information together.
"""
design: Design design: Design
cv: CurriculumVitae cv: CurriculumVitae

View File

@ -17,8 +17,13 @@ def markdown_to_latex(markdown_string: str) -> str:
"""Convert a markdown string to LaTeX. """Convert a markdown string to LaTeX.
Example: Example:
>>> markdown_to_latex("This is a **bold** text with an [*italic link*](https://google.com).") ```python
"This is a \\textbf{bold} text with a \\hrefExternal{https://google.com}{\\textit{link}}." markdown_to_latex("This is a **bold** text with an [*italic link*](https://google.com).")
```
will return:
`#!pytjon "This is a \\textbf{bold} text with a \\hrefExternal{https://google.com}{\\textit{link}}."`
Args: Args:
value (str): The markdown string to convert. value (str): The markdown string to convert.
@ -68,8 +73,13 @@ def markdown_url_to_url(value: str) -> bool:
"""Convert a markdown link to a normal string URL. """Convert a markdown link to a normal string URL.
Example: Example:
>>> markdown_url_to_url("[Google](https://google.com)") ```python
"https://google.com" markdown_url_to_url("[Google](https://google.com)")
```
will return:
`#!python "https://google.com"`
Args: Args:
value (str): The markdown link to convert. value (str): The markdown link to convert.
@ -91,10 +101,11 @@ def markdown_url_to_url(value: str) -> bool:
def render_template(data): def render_template(data):
"""Render the template using the given data. """Render the template using the given data.
Example: Args:
>>> render_template(data) data (RenderCVDataModel): The data to use to render the template.
Returns:
str: The path to the rendered LaTeX file.
""" """
# templates_directory = os.path.dirname(os.path.dirname()) # templates_directory = os.path.dirname(os.path.dirname())
@ -137,12 +148,10 @@ def render_template(data):
def run_latex(latexFilePath): def run_latex(latexFilePath):
""" """
Run LuaLateX on the given LaTeX file and generate a PDF. Run TinyTeX with the given LaTeX file and generate a PDF.
:param latexFilePath: The path to the LaTeX file to compile. Args:
:type latexFilePath: str latexFilePath (str): The path to the LaTeX file to compile.
:return: None
:rtype: None
""" """
latexFilePath = os.path.normpath(latexFilePath) latexFilePath = os.path.normpath(latexFilePath)
latexFile = os.path.basename(latexFilePath) latexFile = os.path.basename(latexFilePath)