rendercv/schema.json

1280 lines
36 KiB
JSON

{
"$defs": {
"ClassicThemeEntryAreaMargins": {
"properties": {
"left_and_right": {
"default": "0.2 cm",
"description": "The left margin of entry areas.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Left Margin",
"type": "string"
},
"vertical_between": {
"default": "0.12 cm",
"description": "The vertical margin between entry areas.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Vertical Margin Between Entry Areas",
"type": "string"
}
},
"title": "ClassicThemeEntryAreaMargins",
"type": "object",
"additionalProperties": false
},
"ClassicThemeHeaderMargins": {
"properties": {
"vertical_between_name_and_connections": {
"default": "0.2 cm",
"description": "The vertical margin between the name of the person and the connections.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Vertical Margin Between the Name and Connections",
"type": "string"
},
"bottom": {
"default": "0.2 cm",
"description": "The bottom margin of the header, i.e., the vertical margin between the connections and the first section title.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Bottom Margin",
"type": "string"
}
},
"title": "ClassicThemeHeaderMargins",
"type": "object",
"additionalProperties": false
},
"ClassicThemeHighlightsAreaMargins": {
"properties": {
"top": {
"default": "0.10 cm",
"description": "The top margin of highlights areas.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Top Margin",
"type": "string"
},
"left": {
"default": "0.4 cm",
"description": "The left margin of highlights areas.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Left Margin",
"type": "string"
},
"vertical_between_bullet_points": {
"default": "0.10 cm",
"description": "The vertical margin between bullet points.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Vertical Margin Between Bullet Points",
"type": "string"
}
},
"title": "ClassicThemeHighlightsAreaMargins",
"type": "object",
"additionalProperties": false
},
"ClassicThemeMargins": {
"properties": {
"page": {
"allOf": [
{
"$ref": "#/$defs/ClassicThemePageMargins"
}
],
"default": {
"top": "2 cm",
"bottom": "2 cm",
"left": "1.24 cm",
"right": "1.24 cm"
},
"description": "Page margins for the classic theme.",
"title": "Page Margins"
},
"section_title": {
"allOf": [
{
"$ref": "#/$defs/ClassicThemeSectionTitleMargins"
}
],
"default": {
"top": "0.2 cm",
"bottom": "0.2 cm"
},
"description": "Section title margins for the classic theme.",
"title": "Section Title Margins"
},
"entry_area": {
"allOf": [
{
"$ref": "#/$defs/ClassicThemeEntryAreaMargins"
}
],
"default": {
"left_and_right": "0.2 cm",
"vertical_between": "0.12 cm"
},
"description": "Entry area margins for the classic theme.",
"title": "Entry Area Margins"
},
"highlights_area": {
"allOf": [
{
"$ref": "#/$defs/ClassicThemeHighlightsAreaMargins"
}
],
"default": {
"top": "0.10 cm",
"left": "0.4 cm",
"vertical_between_bullet_points": "0.10 cm"
},
"description": "Highlights area margins for the classic theme.",
"title": "Highlights Area Margins"
},
"header": {
"allOf": [
{
"$ref": "#/$defs/ClassicThemeHeaderMargins"
}
],
"default": {
"vertical_between_name_and_connections": "0.2 cm",
"bottom": "0.2 cm"
},
"description": "Header margins for the classic theme.",
"title": "Header Margins"
}
},
"title": "ClassicThemeMargins",
"type": "object",
"additionalProperties": false
},
"ClassicThemeOptions": {
"description": "",
"properties": {
"theme": {
"const": "classic",
"title": "Theme"
},
"font": {
"default": "SourceSans3",
"description": "The font of the CV.",
"enum": [
"SourceSans3",
"Roboto",
"EBGaramond"
],
"title": "Font",
"type": "string"
},
"font_size": {
"default": "10pt",
"description": "The font size of the CV. It can be 10pt, 11pt, or 12pt.",
"enum": [
"10pt",
"11pt",
"12pt"
],
"title": "Font Size",
"type": "string"
},
"page_size": {
"default": "a4paper",
"description": "The page size of the CV. It can be a4paper or letterpaper.",
"enum": [
"a4paper",
"letterpaper"
],
"title": "Page Size",
"type": "string"
},
"primary_color": {
"default": "rgb(0,79,144)",
"description": "The primary color of Classic Theme. It is used for the section titles, heading, and the links.\nThe color can be specified either with their [name](https://www.w3.org/TR/SVG11/types.html#ColorKeywords), hexadecimal value, RGB value, or HSL value.",
"examples": [
"Black",
"7fffd4",
"rgb(0,79,144)",
"hsl(270, 60%, 70%)"
],
"format": "color",
"title": "Primary Color",
"type": "string"
},
"date_and_location_width": {
"default": "4.1 cm",
"description": "The width of the date and location column.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Date and Location Column Width",
"type": "string"
},
"text_alignment": {
"default": "left-aligned",
"description": "The alignment of the text.",
"enum": [
"left-aligned",
"justified"
],
"title": "Text Alignment",
"type": "string"
},
"show_timespan_in": {
"default": [],
"description": "The time span will be shown in the date and location column in these sections. The input should be a list of strings.",
"items": {
"type": "string"
},
"title": "Show Time Span in These Sections",
"type": "array"
},
"show_last_updated_date": {
"default": true,
"description": "If this option is set to true, then the last updated date will be shown in the header.",
"title": "Show Last Updated Date",
"type": "boolean"
},
"header_font_size": {
"default": "30 pt",
"description": "The font size of the header (the name of the person).",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Header Font Size",
"type": "string"
},
"margins": {
"allOf": [
{
"$ref": "#/$defs/ClassicThemeMargins"
}
],
"default": {
"page": {
"bottom": "2 cm",
"left": "1.24 cm",
"right": "1.24 cm",
"top": "2 cm"
},
"section_title": {
"bottom": "0.2 cm",
"top": "0.2 cm"
},
"entry_area": {
"left_and_right": "0.2 cm",
"vertical_between": "0.12 cm"
},
"highlights_area": {
"left": "0.4 cm",
"top": "0.10 cm",
"vertical_between_bullet_points": "0.10 cm"
},
"header": {
"bottom": "0.2 cm",
"vertical_between_name_and_connections": "0.2 cm"
}
},
"description": "Page, section title, entry field, and highlights field margins.",
"title": "Margins"
}
},
"required": [
"theme"
],
"title": "ClassicThemeOptions",
"type": "object",
"additionalProperties": false
},
"ClassicThemePageMargins": {
"properties": {
"top": {
"default": "2 cm",
"description": "The top margin of the page with units.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Top Margin",
"type": "string"
},
"bottom": {
"default": "2 cm",
"description": "The bottom margin of the page with units.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Bottom Margin",
"type": "string"
},
"left": {
"default": "1.24 cm",
"description": "The left margin of the page with units.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Left Margin",
"type": "string"
},
"right": {
"default": "1.24 cm",
"description": "The right margin of the page with units.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Right Margin",
"type": "string"
}
},
"title": "ClassicThemePageMargins",
"type": "object",
"additionalProperties": false
},
"ClassicThemeSectionTitleMargins": {
"properties": {
"top": {
"default": "0.2 cm",
"description": "The top margin of section titles.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Top Margin",
"type": "string"
},
"bottom": {
"default": "0.2 cm",
"description": "The bottom margin of section titles.",
"pattern": "\\d+\\.?\\d* *(cm|in|pt|mm|ex|em)",
"title": "Bottom Margin",
"type": "string"
}
},
"title": "ClassicThemeSectionTitleMargins",
"type": "object",
"additionalProperties": false
},
"CurriculumVitae": {
"additionalProperties": false,
"description": "This class is the data model of the CV.",
"properties": {
"name": {
"description": "The name of the person.",
"title": "Name",
"type": "string"
},
"label": {
"default": null,
"description": "The label of the person.",
"title": "Label",
"allOf": [
{
"type": "string"
}
]
},
"location": {
"default": null,
"description": "The location of the person. This is not rendered currently.",
"title": "Location",
"allOf": [
{
"type": "string"
}
]
},
"email": {
"default": null,
"description": "The email of the person. It will be rendered in the heading.",
"title": "Email",
"allOf": [
{
"format": "email",
"type": "string"
}
]
},
"phone": {
"default": null,
"title": "Phone",
"allOf": [
{
"format": "phone",
"maxLength": 64,
"minLength": 7,
"type": "string"
}
]
},
"website": {
"default": null,
"title": "Website",
"allOf": [
{
"format": "uri",
"maxLength": 2083,
"minLength": 1,
"type": "string"
}
]
},
"social_networks": {
"default": null,
"description": "The social networks of the person. They will be rendered in the heading.",
"title": "Social Networks",
"allOf": [
{
"items": {
"$ref": "#/$defs/SocialNetwork"
},
"type": "array"
}
]
},
"sections": {
"additionalProperties": {
"anyOf": [
{
"discriminator": {
"mapping": {
"EducationEntry": "#/$defs/SectionWithEducationEntries",
"ExperienceEntry": "#/$defs/SectionWithExperienceEntries",
"NormalEntry": "#/$defs/SectionWithNormalEntries",
"OneLineEntry": "#/$defs/SectionWithOneLineEntries",
"PublicationEntry": "#/$defs/SectionWithPublicationEntries",
"TextEntry": "#/$defs/SectionWithTextEntries"
},
"propertyName": "entry_type"
},
"oneOf": [
{
"$ref": "#/$defs/SectionWithEducationEntries"
},
{
"$ref": "#/$defs/SectionWithExperienceEntries"
},
{
"$ref": "#/$defs/SectionWithNormalEntries"
},
{
"$ref": "#/$defs/SectionWithOneLineEntries"
},
{
"$ref": "#/$defs/SectionWithPublicationEntries"
},
{
"$ref": "#/$defs/SectionWithTextEntries"
}
]
},
{
"items": {
"anyOf": [
{
"$ref": "#/$defs/EducationEntry"
},
{
"$ref": "#/$defs/ExperienceEntry"
},
{
"$ref": "#/$defs/PublicationEntry"
},
{
"$ref": "#/$defs/NormalEntry"
},
{
"$ref": "#/$defs/OneLineEntry"
},
{
"type": "string"
}
]
},
"type": "array"
}
]
},
"default": null,
"description": "The sections of the CV.",
"title": "Sections",
"type": "object"
}
},
"required": [
"name"
],
"title": "CurriculumVitae",
"type": "object"
},
"EducationEntry": {
"additionalProperties": false,
"description": "This class is the data model of `EducationEntry`.",
"properties": {
"start_date": {
"default": null,
"description": "The start date of the event in YYYY-MM-DD, YYYY-MM, or YYYY format.",
"examples": [
"2020-09-24"
],
"title": "Start Date",
"oneOf": [
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "null"
}
]
},
"end_date": {
"default": null,
"description": "The end date of the event in YYYY-MM-DD, YYYY-MM, or YYYY format. If the event is still ongoing, then type \"present\" or provide only the start date.",
"examples": [
"2020-09-24",
"present"
],
"title": "End Date",
"oneOf": [
{
"const": "present"
},
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "null"
}
]
},
"date": {
"default": null,
"description": "If the event is a one-day event, then this field should be filled in YYYY-MM-DD format. If the event is a multi-day event, then the start date and end date should be provided instead. All of them can't be provided at the same time.",
"examples": [
"2020-09-24",
"My Custom Date"
],
"title": "Date",
"oneOf": [
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "integer"
},
{
"type": "string"
},
{
"type": "null"
}
]
},
"highlights": {
"default": null,
"description": "The highlights of the event as a list of strings.",
"examples": [
"Did this.",
"Did that."
],
"title": "Highlights",
"allOf": [
{
"items": {
"type": "string"
},
"type": "array"
}
]
},
"location": {
"default": null,
"description": "The location of the event.",
"examples": [
"Istanbul, Turkey"
],
"title": "Location",
"allOf": [
{
"type": "string"
}
]
},
"url": {
"default": null,
"title": "Url",
"allOf": [
{
"format": "uri",
"maxLength": 2083,
"minLength": 1,
"type": "string"
}
]
},
"url_text": {
"default": null,
"title": "Url Text",
"allOf": [
{
"type": "string"
}
]
},
"institution": {
"description": "The institution name. It will be shown as bold text.",
"examples": [
"Bogazici University"
],
"title": "Institution",
"type": "string"
},
"area": {
"description": "The area of study. It will be shown as normal text.",
"title": "Area",
"type": "string"
},
"degree": {
"default": null,
"description": "The type of the degree.",
"examples": [
"BS",
"BA",
"PhD",
"MS"
],
"title": "Degree",
"allOf": [
{
"type": "string"
}
]
}
},
"required": [
"institution",
"area"
],
"title": "EducationEntry",
"type": "object"
},
"ExperienceEntry": {
"additionalProperties": false,
"description": "This class is the data model of `ExperienceEntry`.",
"properties": {
"start_date": {
"default": null,
"description": "The start date of the event in YYYY-MM-DD, YYYY-MM, or YYYY format.",
"examples": [
"2020-09-24"
],
"title": "Start Date",
"oneOf": [
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "null"
}
]
},
"end_date": {
"default": null,
"description": "The end date of the event in YYYY-MM-DD, YYYY-MM, or YYYY format. If the event is still ongoing, then type \"present\" or provide only the start date.",
"examples": [
"2020-09-24",
"present"
],
"title": "End Date",
"oneOf": [
{
"const": "present"
},
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "null"
}
]
},
"date": {
"default": null,
"description": "If the event is a one-day event, then this field should be filled in YYYY-MM-DD format. If the event is a multi-day event, then the start date and end date should be provided instead. All of them can't be provided at the same time.",
"examples": [
"2020-09-24",
"My Custom Date"
],
"title": "Date",
"oneOf": [
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "integer"
},
{
"type": "string"
},
{
"type": "null"
}
]
},
"highlights": {
"default": null,
"description": "The highlights of the event as a list of strings.",
"examples": [
"Did this.",
"Did that."
],
"title": "Highlights",
"allOf": [
{
"items": {
"type": "string"
},
"type": "array"
}
]
},
"location": {
"default": null,
"description": "The location of the event.",
"examples": [
"Istanbul, Turkey"
],
"title": "Location",
"allOf": [
{
"type": "string"
}
]
},
"url": {
"default": null,
"title": "Url",
"allOf": [
{
"format": "uri",
"maxLength": 2083,
"minLength": 1,
"type": "string"
}
]
},
"url_text": {
"default": null,
"title": "Url Text",
"allOf": [
{
"type": "string"
}
]
},
"company": {
"description": "The company name. It will be shown as bold text.",
"title": "Company",
"type": "string"
},
"position": {
"description": "The position. It will be shown as normal text.",
"title": "Position",
"type": "string"
}
},
"required": [
"company",
"position"
],
"title": "ExperienceEntry",
"type": "object"
},
"NormalEntry": {
"additionalProperties": false,
"description": "This class is the data model of `NormalEntry`.",
"properties": {
"start_date": {
"default": null,
"description": "The start date of the event in YYYY-MM-DD, YYYY-MM, or YYYY format.",
"examples": [
"2020-09-24"
],
"title": "Start Date",
"oneOf": [
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "null"
}
]
},
"end_date": {
"default": null,
"description": "The end date of the event in YYYY-MM-DD, YYYY-MM, or YYYY format. If the event is still ongoing, then type \"present\" or provide only the start date.",
"examples": [
"2020-09-24",
"present"
],
"title": "End Date",
"oneOf": [
{
"const": "present"
},
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "null"
}
]
},
"date": {
"default": null,
"description": "If the event is a one-day event, then this field should be filled in YYYY-MM-DD format. If the event is a multi-day event, then the start date and end date should be provided instead. All of them can't be provided at the same time.",
"examples": [
"2020-09-24",
"My Custom Date"
],
"title": "Date",
"oneOf": [
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
},
{
"type": "integer"
},
{
"type": "string"
},
{
"type": "null"
}
]
},
"highlights": {
"default": null,
"description": "The highlights of the event as a list of strings.",
"examples": [
"Did this.",
"Did that."
],
"title": "Highlights",
"allOf": [
{
"items": {
"type": "string"
},
"type": "array"
}
]
},
"location": {
"default": null,
"description": "The location of the event.",
"examples": [
"Istanbul, Turkey"
],
"title": "Location",
"allOf": [
{
"type": "string"
}
]
},
"url": {
"default": null,
"title": "Url",
"allOf": [
{
"format": "uri",
"maxLength": 2083,
"minLength": 1,
"type": "string"
}
]
},
"url_text": {
"default": null,
"title": "Url Text",
"allOf": [
{
"type": "string"
}
]
},
"name": {
"description": "The name of the entry. It will be shown as bold text.",
"title": "Name",
"type": "string"
}
},
"required": [
"name"
],
"title": "NormalEntry",
"type": "object"
},
"OneLineEntry": {
"additionalProperties": false,
"description": "This class is the data model of `OneLineEntry`.",
"properties": {
"name": {
"description": "The name of the entry. It will be shown as bold text.",
"title": "Name",
"type": "string"
},
"details": {
"description": "The details of the entry. It will be shown as normal text.",
"title": "Details",
"type": "string"
}
},
"required": [
"name",
"details"
],
"title": "OneLineEntry",
"type": "object"
},
"PublicationEntry": {
"additionalProperties": false,
"description": "This class is the data model of `PublicationEntry`.",
"properties": {
"title": {
"description": "The title of the publication. It will be shown as bold text.",
"title": "Title of the Publication",
"type": "string"
},
"authors": {
"description": "The authors of the publication in order as a list of strings.",
"items": {
"type": "string"
},
"title": "Authors",
"type": "array"
},
"doi": {
"description": "The DOI of the publication.",
"examples": [
"10.48550/arXiv.2310.03138"
],
"title": "DOI",
"type": "string"
},
"date": {
"description": "The date of the publication in YYYY-MM-DD, YYYY-MM, or YYYY format.",
"examples": [
"2021-10-31",
"2010"
],
"title": "Publication Date",
"oneOf": [
{
"type": "integer"
},
{
"pattern": "\\d{4}-\\d{2}(-\\d{2})?",
"type": "string"
}
]
},
"journal": {
"default": null,
"description": "The journal or the conference name.",
"title": "Journal",
"allOf": [
{
"type": "string"
}
]
}
},
"required": [
"title",
"authors",
"doi",
"date"
],
"title": "PublicationEntry",
"type": "object"
},
"SectionWithEducationEntries": {
"additionalProperties": false,
"description": "This class is the data model of the section with `EducationEntry`s.",
"properties": {
"title": {
"default": null,
"title": "Title",
"allOf": [
{
"type": "string"
}
]
},
"entry_type": {
"const": "EducationEntry",
"description": "The type of the entries in the section.",
"title": "Entry Type"
},
"entries": {
"description": "The entries of the section. The format depends on the entry type.",
"items": {
"$ref": "#/$defs/EducationEntry"
},
"title": "Entries",
"type": "array"
}
},
"required": [
"entry_type",
"entries"
],
"title": "SectionWithEducationEntries",
"type": "object"
},
"SectionWithExperienceEntries": {
"additionalProperties": false,
"description": "This class is the data model of the section with `ExperienceEntry`s.",
"properties": {
"title": {
"default": null,
"title": "Title",
"allOf": [
{
"type": "string"
}
]
},
"entry_type": {
"const": "ExperienceEntry",
"description": "The type of the entries in the section.",
"title": "Entry Type"
},
"entries": {
"description": "The entries of the section. The format depends on the entry type.",
"items": {
"$ref": "#/$defs/ExperienceEntry"
},
"title": "Entries",
"type": "array"
}
},
"required": [
"entry_type",
"entries"
],
"title": "SectionWithExperienceEntries",
"type": "object"
},
"SectionWithNormalEntries": {
"additionalProperties": false,
"description": "This class is the data model of the section with `NormalEntry`s.",
"properties": {
"title": {
"default": null,
"title": "Title",
"allOf": [
{
"type": "string"
}
]
},
"entry_type": {
"const": "NormalEntry",
"description": "The type of the entries in the section.",
"title": "Entry Type"
},
"entries": {
"description": "The entries of the section. The format depends on the entry type.",
"items": {
"$ref": "#/$defs/NormalEntry"
},
"title": "Entries",
"type": "array"
}
},
"required": [
"entry_type",
"entries"
],
"title": "SectionWithNormalEntries",
"type": "object"
},
"SectionWithOneLineEntries": {
"additionalProperties": false,
"description": "This class is the data model of the section with `OneLineEntry`s.",
"properties": {
"title": {
"default": null,
"title": "Title",
"allOf": [
{
"type": "string"
}
]
},
"entry_type": {
"const": "OneLineEntry",
"description": "The type of the entries in the section.",
"title": "Entry Type"
},
"entries": {
"description": "The entries of the section. The format depends on the entry type.",
"items": {
"$ref": "#/$defs/OneLineEntry"
},
"title": "Entries",
"type": "array"
}
},
"required": [
"entry_type",
"entries"
],
"title": "SectionWithOneLineEntries",
"type": "object"
},
"SectionWithPublicationEntries": {
"additionalProperties": false,
"description": "This class is the data model of the section with `PublicationEntry`s.",
"properties": {
"title": {
"default": null,
"title": "Title",
"allOf": [
{
"type": "string"
}
]
},
"entry_type": {
"const": "PublicationEntry",
"description": "The type of the entries in the section.",
"title": "Entry Type"
},
"entries": {
"description": "The entries of the section. The format depends on the entry type.",
"items": {
"$ref": "#/$defs/PublicationEntry"
},
"title": "Entries",
"type": "array"
}
},
"required": [
"entry_type",
"entries"
],
"title": "SectionWithPublicationEntries",
"type": "object"
},
"SectionWithTextEntries": {
"additionalProperties": false,
"description": "This class is the data model of the section with `TextEntry`s.",
"properties": {
"title": {
"default": null,
"title": "Title",
"allOf": [
{
"type": "string"
}
]
},
"entry_type": {
"const": "TextEntry",
"description": "The type of the entries in the section.",
"title": "Entry Type"
},
"entries": {
"description": "The entries of the section. The format depends on the entry type.",
"items": {
"type": "string"
},
"title": "Entries",
"type": "array"
}
},
"required": [
"entry_type",
"entries"
],
"title": "SectionWithTextEntries",
"type": "object"
},
"SocialNetwork": {
"additionalProperties": false,
"description": "This class is the data model of a social network.",
"properties": {
"network": {
"description": "The social network name.",
"enum": [
"LinkedIn",
"GitHub",
"Instagram",
"Orcid",
"Mastodon",
"Twitter"
],
"title": "Social Network",
"type": "string"
},
"username": {
"description": "The username of the social network. The link will be generated.",
"title": "Username",
"type": "string"
}
},
"required": [
"network",
"username"
],
"title": "SocialNetwork",
"type": "object"
}
},
"additionalProperties": false,
"description": "RenderCV data model.",
"properties": {
"cv": {
"allOf": [
{
"$ref": "#/$defs/CurriculumVitae"
}
],
"description": "The data of the CV.",
"title": "Curriculum Vitae"
},
"design": {
"description": "The design information of the CV.",
"discriminator": {
"mapping": {
"classic": "#/$defs/ClassicThemeOptions"
},
"propertyName": "theme"
},
"oneOf": [
{
"$ref": "#/$defs/ClassicThemeOptions"
}
],
"title": "Design"
}
},
"required": [
"cv",
"design"
],
"title": "RenderCV",
"type": "object",
"$id": "https://raw.githubusercontent.com/sinaatalay/rendercv/main/schema.json",
"$schema": "http://json-schema.org/draft-07/schema#"
}