-
-
Notifications
You must be signed in to change notification settings - Fork 23
Options Attributes
This is the only required YAML section for setting up the TitleCardMaker, and lists the primary source directory to use, any number of series YAML files to create cards for, as well as some optional global values that apply to all created cards.
options:
source: /source/
series:
- /series/tv_4k.yml
- /series/tv.yml
- /series/anime.yml
card_type: standard
card_extension: jpg
episode_data_source: sonarr
image_source_priority: tmdb, plex
filename_format: "{full_name} - S{season:02}E{episode:02} - {title}"
card_extension: jpg
validate_fonts: true
zero_pad_seasons: false
hide_season_folders: false
Name | YAML Attribute | Allowed Values | Default Value | Required |
---|---|---|---|---|
Source Directory | source |
Any valid directory | - | ✔️ |
Series YAML Files | series |
Any YAML file, or a list of YAML file(s) | - | ✔️ |
Card Type | card_type |
Any known TitleCard identifier - see here | standard |
❌ |
Episode Data Source | episode_data_source |
Either sonarr , plex , or tmdb
|
sonarr |
❌ |
Image Source Priority | image_source_priority |
Any order/combination of tmdb and plex
|
tmdb, plex |
❌ |
Card Filename Format | filename_format |
A valid Python formatting string | {full_name} - S{season:02}E{episode:02} |
❌ |
Card Extension | card_extension |
One of jpg , jpeg , png , tiff , or gif
|
jpg |
❌ |
Font Validation | validate_fonts |
Boolean (true or false ) |
true |
❌ |
Zero Pad Season Folders | zero_pad_seasons |
Boolean (true or false ) |
false |
❌ |
Hide Season Folders | hide_season_folders |
Boolean (true or false ) |
false |
❌ |
The default location for all source data and images will be searched for and stored by the Maker.
Example
The following example specifies the top-level source folder of /user/source/. For the series Mr. Robot (2015)
, that means the source images and files will be created at /user/source/Mr. Robot (2015)/
.
options:
source: /user/source/
Separate YAML files that specify for which series to create title cards for, as well as outline specifically how those cards are to be created. This can be a single file, or a list of files which will be parsed in the listed order.
The exact structure and contents of this file is outlined here.
Example
The following example lists a single YAML file located at /yaml/all_tv.yml
for which cards will be created for:
options:
series: /yaml/all_tv.yml
While this example defines two files, /yaml/tv.yml
and /yaml/anime.yml
to create cards for.
options:
series:
- /yaml/tv.yml
- /yaml/anime.yml
- ...
The default card type/style to use for title card creation. The default value of standard
uses the StandardTitleCard
class, defined here.
This can be overwritten on a per-series or library basis; see here.
Any valid card type is allowed, but user-created types are not. Those can only be set for a library/series.
Example
The following example sets the global default card type to the RomanNumeralTitleCard:
options:
card_type: roman
The default source to pull episode data from. In this context, episode data refers to episode titles/numbers for a given series. The default value is sonarr
.
If sonarr
is specified, Sonarr must be globally enabled, and the series must be present in Sonarr (not necessarily downloaded, just added to Sonarr). If plex
is specified, Plex must be globally enabled, and only episodes that exist in the given series' library will be downloaded. If tmdb
is specified, TMDb must be globally enabled.
This can be overwritten on a per-series basis, see here.
Example
The following example sets the global default episode data source to plex
, effectively only creating cards for episodes that you "own".
options:
episode_data_source: plex
The Maker will attempt to automatically gather source images (the images used in the title cards) from a variety of sources. This option can be used to specify which sources to look for images from, as well as their relative priority.
Currently there are only two "interfaces" for source images, tmdb
, and plex
- these can be combined in the following configurations:
source_priority |
Description |
---|---|
plex |
Only get sources images from Plex |
tmdb |
Only get source images from TMDb |
plex, tmdb |
Get source images from Plex first, then TMDb |
tmdb, plex |
Get source images from TMDb first, then Plex1 |
1 Plex will only be queried for source images after that episode has been "permanently blacklisted" - i.e. has failed more than the specified retry count.
For obvious reasons, tmdb
is only a valid image source if TMDb is globally enabled, and plex
is only valid if Plex is globally enabled.
If plex
is specified as an image source, the currently selected episode thumbnail will be pulled.
Example
The following example will source images from Plex, and for any episodes either not present in Plex, or that doesn't have a thumbnail, TMDb will be queried instead.
options:
image_source_priority: plex, tmdb
The format for how to name the files of title cards. The default value of {full_name} - S{season:02}E{episode:02}
results in cards titled as ShowName (Year) - SxxEyy
, which is the recommended Plex naming convention for media. If you'd like to modify the names of these cards to match your specific media naming conventions, then the following format options are available:
The example values will be using Mr. Robot Season 4 Episode 1 (absolute episode 33), titled "401 Unauthorized"
Option | Description | Example Value | Notes |
---|---|---|---|
{name} |
The series name | Mr. Robot |
- |
{full_name} |
The series name and year (in parenthesis) | Mr. Robot (2015) |
- |
{year} |
The series year | 2015 |
Can be zero-padded (but why?) |
{season} |
The episode's season number | 4 |
Can be zero-padded like so {season:02}
|
{episode} |
The episode's episode number | 1 |
Can be zero-padded like so {episode:02}
|
{title} |
The episode's title1 | 401 Unauthorized |
- |
{abs_number} |
The episode's absolute episode number2 | 33 |
Can be zero-padded like so {abs_number:02}
|
1The episode title is modified so that any bad characters (like
:
,/
,\
, etc.) are removed/replaced.
2If an episode does not have an absolute ordering, then
0
is used instead.
Example
The following example will name cards in the "recommended" way, but include their episode title:
options:
filename_format: "{full_name} - S{season:02}E{episode:02} - {title}"
For the above example, producing a file like Mr. Robot (2015) - S04E01 - 401 Unauthorized.jpg
.
The image extension to use for all cards created by the TitleCardMaker. I have never tested anything except jpg
, jpeg
, and png
, but theoretically Plex can take any image format when loading these.
There is no real reason, beyond minor performance differences and filesize, to select one extension over another.
Example
The following example sets the global image extension for all title cards to .png
(which, due to it's uncompressed nature, will slow down card creation):
options:
card_extension: png
Whether to globally validate all characters for a font (both custom and generic) before creating a title card. This is enabled by default, but can be overwritten for each series.
This is described in greater detail here.
Example
The following example globally disables font validation, but it can still be enabled for each series individually.
options:
validate_fonts: false
Whether to zero-pad the season folders when creating title cards. This is disabled by default.
The below table shows how season folders will be created depending on if this option is enabled or not.
Season Number | Not Zero-Padded | Zero-Padded |
---|---|---|
0 | Specials |
Specials |
1 | Season 1 |
Season 01 |
2 | Season 2 |
Season 02 |
... | ... | ... |
10 | Season 10 |
Season 10 |
Example
The following example creates folders with zero-padded digits, producing folders like Season 01
, Season 02
, etc.
options:
zero_pad_seasons: true
Whether to omit season sub-folders when creating title cards. This setting applies to the archive folder structure as well. This is disabled by default.
If enabled (i.e. hide_season_folders: true
), then all cards will be created directly under their main media/archive folder.
NOTE: This option overrides whether or not seasons are zero-padded.
Example
The following example disables season folders altogethe.
options:
hide_season_folders: true