# Dynamic Collections
Plex Meta Manager can dynamically create collections based on different criteria, such as
* Collections based on the Collections from TMDb for every item in the library. ([Star Wars](https://www.themoviedb.org/collection/10-star-wars-collection), [The Lord of the Rings](https://www.themoviedb.org/collection/119), etc...)
* Collections based on each of a Users Trakt Lists
* Collections for the top `X` popular people on TMDb (Bruce Willis, Tom Hanks, etc...)
* Collections for each decade represented in the library (Best of 1990s, Best of 2000s, etc...)
* Collections for each of the moods/styles within a Music library (A Cappella, Pop Rock, etc...)
The main purpose of dynamic collections is to automate the creation of collections which would otherwise require considerable user input and repetition (such as creating a collection for every genre).
Each dynamic collection must have a mapping name (just like standard collections), which is also attached to the collection as a label to mark it as having been created by this dynamic collection.
This example will create a collection for every TMDb Collection associated with items in the library.
```yaml
dynamic_collections:
TMDb Collections: # This name is the mapping name
type: tmdb_collections
remove_suffix: "Collection"
```
## Collection Naming
By default, the collections generated will be named for the thing being used to create them; things like genres, countries, actors or even Trakt List Names.
There are many attributes that can change the titles, including `title_format`, `remove_suffix`, `remove_prefix`, `pre_format_override`, and `post_format_override` all detailed below.
## Dynamic Keys & Titles
A `dynamic key` or `key` for short is used to refer to a specific value/result from the dynamic collection criteria that will be used to create the collection.
A `title` in this case is the name that replaces `<
>` in `title_format` to create the collection titles for each key.
An example of some keys that would be generated from a `genre` dynamic collection are; "Animation", "Horror" and "Comedy"
### Example Key Usage
Keys can be used for a number of purposes, examples can be found throughout this page. A few examples are shown below:
* Excluding the "Horror" key from the `Genre` dynamic collection definition
```yaml
dynamic_collections:
Genres: # mapping name does not matter, just needs to be unique
type: genre
exclude:
- Horror
```
* Using the `keys` attribute to change the formatting of "France" to "French" so that a collection can be named "French Cinema" instead of simply "France"
* This particular example also uses the `title_format` attribute to manipulate the naming convention of the collections.
```yaml
dynamic_collections:
Countries: # mapping name does not matter, just needs to be unique
type: country
title_format: <> Cinema
pre_format_override:
France: French
```
* Using the `addons` attribute to combine multiple `keys`, i.e. merging "MTV", "MTV2", "MTV3" and "MTV (UK)" into one "MTV Worldwide" collection.
* When doing this, individual collections will not be created for the individual MTV collections, instead they will be merged within the "MTV Worldwide" collection.
```yaml
dynamic_collections:
networks:
type: network
addons:
MTV Worldwide:
- MTV
- MTV2
- MTV3
- MTV (UK)
```
## Attributes
| Attribute | Description | Required |
|:------------------------------------------------|:-------------------------------------------------------------------------------------------------------------------------------|:-----------------:|
| [`type`](#type--data) | Type of Dynamic Collection to be created. | ✅ |
| [`data`](#type--data) | Data to determine how dynamic collections with a certain `type` are created. | Depends on `type` |
| [`exclude`](#exclude) | Exclude this list of keys from being created into collections. | ❌ |
| [`addons`](#addons) | Defines how multiple keys can be combined under a parent key. | ❌ |
| [`template`](#template) | Name of the template to use for these dynamic collections. | ❌ |
| [`template_variables`](#template-variables) | Defines how template variables can be defined by key. | ❌ |
| [`remove_suffix`](#remove-prefixsuffix) | Removes the defined suffixes from the key before it's used in the collection title. | ❌ |
| [`remove_prefix`](#remove-prefixsuffix) | Removes the defined prefixes from the key before it's used in the collection title. | ❌ |
| [`title_format`](#title-format) | This is the format for the collection titles. | ❌ |
| [`pre_format_override`](#pre-format-override) | Defines how titles can be overridden before they are formatted into collection titles. | ❌ |
| [`post_format_override`](#post-format-override) | Defines how collection titles can be overridden ignoring title formatting. | ❌ |
| [`test`](#test) | Will add `test: true` to all collections for test runs. | ❌ |
| [`sync`](#sync) | Will remove dynamic collections that are no longer in the creation list. | ❌ |
| [`include`](#include) | Define a list of keys to be made into collections. | ❌ |
| [`other_name`](#other-name) | Used in combination with `include`. When defined, all keys not in `include` or `addons` will be combined into this collection. | ❌ |
## Type & Data
Specifies the type of dynamic collection to be created.
Depending on the `type` of dynamic collection, `data` is used to specify the options that are required to fulfill the requirements of creating the collection.
| Type Option | Description | Uses
`data` | Movies | Shows | Music | Video |
|:----------------------------------------------|:------------------------------------------------------------------------------------------------------------|:--------------:|:--------:|:--------:|:--------:|:--------:|
| [`tmdb_collection`](#tmdb-collection) | Create a collection for each TMDb Collection associated with an item in the library | ❌ | ✅ | ❌ | ❌ | ❌ |
| [`tmdb_popular_people`](#tmdb-popular-people) | Create a collection for each actor found on [TMDb's Popular People List](https://www.themoviedb.org/person) | ✅ | ✅ | ✅ | ❌ | ❌ |
| [`original_language`](#original-language) | Create a collection for each TMDb original language associated with an item in the library | ❌ | ✅ | ✅ | ❌ | ❌ |
| [`trakt_user_lists`](#trakt-user-lists) | Create a collection for each list from specific trakt users | ✅ | ✅ | ✅ | ❌ | ❌ |
| [`trakt_liked_lists`](#trakt-liked-lists) | Create a collection for each list the authenticated trakt user likes | ❌ | ✅ | ✅ | ❌ | ❌ |
| [`trakt_people_list`](#trakt-people-lists) | Create a collection for each actor found in the trakt list | ✅ | ✅ | ✅ | ❌ | ❌ |
| [`actor`](#actor) | Create a collection for each actor found in the library | ✅ | ✅ | ✅ | ❌ | ❌ |
| [`genre`](#genre) | Create a collection for each genre found in the library | ❌ | ✅ | ✅ | ✅ | ✅ |
| [`year`](#year) | Create a collection for each year found in the library | ❌ | ✅ | ✅ | ❌ | ❌ |
| [`decade`](#decade) | Create a collection for each decade found in the library | ❌ | ✅ | ❌ | ❌ | ❌ |
| [`country`](#country) | Create a collection for each country found in the library | ❌ | ✅ | ❌ | ✅ | ✅ |
| [`network`](#network) | Create a collection for each network found in the library | ❌ | ❌ | ✅ | ❌ | ❌ |
| [`mood`](#mood) | Create a collection for each mood found in the library | ❌ | ❌ | ❌ | ✅ | ❌ |
| [`style`](#style) | Create a collection for each style found in the library | ❌ | ❌ | ❌ | ✅ | ❌ |
### TMDb Collection
Create collections based on the TMDb Collections associated with items in the library.
type Option |
tmdb_collection |
data Value |
Not Used |
Keys |
TMDb Collection ID |
Titles |
TMDb Collection Title |
Default title_format |
<<title>> |
Default Template |
```yaml
default_template:
tmdb_collection_details: <>
```
|
#### Example: Create collection for every TMDb Collection found in the library.
```yaml
dynamic_collections:
TMDb Collections: # This name is the mapping name
type: tmdb_collections
remove_suffix: Collection
remove_prefix: The
```
### TMDb Popular People
Create collections based on each actor found on [TMDb's Popular People List](https://www.themoviedb.org/person).
type Option |
tmdb_popular_people |
data Value |
Number greater then 0 |
Keys |
TMDb Person ID |
Titles |
TMDb Person Name |
Default title_format |
<<title>> |
Default Template |
```yaml
default_template:
tmdb_person: <>
plex_search:
all:
actor: tmdb
```
|
#### Example: Create collection for the top 10 popular people
```yaml
dynamic_collections:
TMDb Popular People: # This name is the mapping name
type: tmdb_popular_people
data: 10
```
### Original Language
Create collections based on the TMDb original language associated with items in the library.
type Option |
original_language |
data Value |
Not Used |
Keys |
ISO 639-1 Code |
Titles |
ISO Language Name |
Default title_format |
<<title>> <<library_type>>s |
Default Template |
```yaml
default_template:
plex_all: true
filters:
original_language: <>
```
|
#### Example: Create collection for every TMDb Original Language found in the library.
```yaml
dynamic_collections:
TMDb Languages: # This name is the mapping name
type: original_language
```
### Trakt User Lists
Create collections for each of the Trakt lists for the specified users. Use `me` to reference the authenticated user.
* Requires [Trakt Authentication](../config/trakt) to be configured within the Configuration File
type Option |
trakt_user_lists |
data Value |
List of Trakt Users |
Keys |
Trakt List URL |
Titles |
Trakt List Title |
Default title_format |
<<title>> |
Default Template |
```yaml
default_template:
trakt_list_details: <>
```
|
#### Example: Create collections for each of the lists that the users have created
```yaml
dynamic_collections:
Trakt User Lists: # This name is the mapping name
type: trakt_user_lists
data:
- me
- yozoraxcii
```
### Trakt Liked Lists
Create collections for each of the Trakt lists that the authenticated user has liked.
* Requires [Trakt Authentication](../config/trakt) to be configured within the Configuration File
type Option |
trakt_liked_lists |
data Value |
Not Used |
Keys |
Trakt List URL |
Titles |
Trakt List Title |
Default title_format |
<<title>> |
Default Template |
```yaml
default_template:
trakt_list_details: <>
```
|
#### Example: Create collections for each of the lists that the user has liked within Trakt
```yaml
dynamic_collections:
Trakt Liked Lists: # This name is the mapping name
type: trakt_liked_lists
```
### Trakt People Lists
Create collections for each of the people found within Trakt lists that the user specifies.
* Requires [Trakt Authentication](../config/trakt) to be configured within the Configuration File
type Option |
trakt_user_lists |
data Value |
List of Trakt URLs |
Keys |
TMDb Person ID |
Titles |
TMDb Person Name |
Default title_format |
<<title>> |
Default Template |
```yaml
default_template:
tmdb_person: <>
plex_search:
all:
actor: tmdb
```
|
#### Example: Create a collection for each of the people on the trakt list
```yaml
dynamic_collections:
Trakt User Lists:
type: trakt_people_lists
data:
- https://trakt.tv/users/ash9001/lists/all-time-top-actors
```
### Actor
Create a collection for each actor found in the library.
type Option |
actor |
data Values |
Attribute |
Description & Values |
actor_depth |
Values: Number greater then 0 |
Default: 3 |
actor_minimum |
Values: Number greater then 0 |
Default: 3 |
number_of_actors |
Values: Number greater then 0 |
Default: None |
|
Keys |
TMDb Person ID |
Titles |
TMDb Person Name |
Default title_format |
<<title>> |
Default Template |
```yaml
default_template:
tmdb_person: <>
plex_search:
all:
actor: tmdb
```
|
* `actor_depth` determines how many top billed actor per item they are in. (i.e. if they play a cameo role, this is unlikely to be counted)
* `actor_minimum` determines the minimum number of times the actor must appear within `actor_depth` for the collection to be created.
* `number_of_actors` determines the number of actor collection to max out at. (i.e. if to make collections for the top 25 actors)
#### Example:
* Create a collection for the top 25 actors who appear in the top 5 billing credits of movies
```yaml
dynamic_collections:
Top Actors: # mapping name does not matter just needs to be unique
type: actor
data:
actor_depth: 5
number_of_actors: 25
```
#### Example:
* Create a collection for actors who appear in the top 5 billing credits of movies
* Only create the collection if they are in the top 5 billing credits of at least 20 movies
```yaml
dynamic_collections:
Actors: # mapping name does not matter just needs to be unique
type: actor
data:
actor_depth: 5
actor_minimum: 20
```
### Genre
Create a collection for each genre found in the library.
type Option |
genre |
data Value |
Not Used |
Keys |
Genre |
Titles |
Genre |
Default title_format |
Top <<title>> <<library_type>>s |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: critic_rating.desc
any:
genre: <>
```
|
#### Example:
* Create dynamic collections based on each genre found in the library (TV and Movies)
* Amend the template to increase the limit from 50 to 100
* Exclude the "Talk Show" genre
* Name the collection Top [Genre] Movies or Top [Genre] Shows
```yaml
templates:
genre collection:
smart_filter:
limit: 100
sort_by: critic_rating.desc
all:
genre: <>
dynamic_collections:
Genres: # mapping name does not matter just needs to be unique
type: genre
exclude:
- Talk Show
title_format: Top <> <>s
template: genre collection
```
### Year
Create a collection for each year found in the library.
type Option |
year |
data Value |
Not Used |
Keys |
Year |
Titles |
Year |
Default title_format |
Best <<library_type>>s of <<title>> |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: critic_rating.desc
any:
year: <>
```
|
#### Example
* Create dynamic collections based on each year found in the library (TV and Movies)
* Use the `include` attribute to only show collections for years "2020", "2021" and "2022"
* Name the collection "Best of (year)"
```yaml
dynamic_collections:
Years: # mapping name does not matter just needs to be unique
type: year
include:
- 2020
- 2021
- 2022
title_format: Best of <<title>>
```
### Decade
Create a collection for each decade found in the library
type Option |
decade |
data Value |
Not Used |
Keys |
Decade |
Titles |
Decade |
Default title_format |
Best <<library_type>>s of <<title>> |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: critic_rating.desc
any:
decade: <>
```
|
### Example:
* Create a collection for each decade found in the library (TV and Movies)
* Name the collection Top [Decade] Movies
* Rename the `2020` collection name to "Top 2020 Movies (so far)"
```yaml
dynamic_collections:
Decades: # mapping name does not matter just needs to be unique
type: decade
title_format: Top <> <>s
post_format_override:
2020: Top 2020 Movies (so far)
```
### Country
Create a collection for each country found in the library
type Option |
country |
data Value |
Not Used |
Keys |
Country |
Titles |
Country |
Default title_format |
Top <<title>> <<library_type>>s |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: critic_rating.desc
any:
country: <>
```
|
#### Example:
* Create a collection for the top movies from each country found in the library
* Name the collection Top [Country] Cinema
* The `keys` attribute is used here in combination with the `title_format` to change the collection name from "France" which would be the default title, to "Top French Cinema"
```yaml
dynamic_collections:
Countries: # mapping name does not matter just needs to be unique
type: country
title_format: Top <> Cinema
pre_format_override:
France: French
Germany: German
India: Indian
```
### Network
Create a collection for each network found in the library.
type Option |
network |
data Value |
Not Used |
Keys |
Network |
Titles |
Network |
Default title_format |
Top <<title>> <<library_type>>s |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: critic_rating.desc
any:
network: <>
```
|
#### Example:
* Create a collection for each network found in a TV Shows library
```yaml
templates:
network collection:
smart_filter:
sort_by: critic_rating.desc
all:
network: <>
dynamic_collections:
Networks: # mapping name does not matter just needs to be unique
type: network
title_format: <>
template: network collection
```
### Mood
Create a collection for each mood found in the library.
type Option |
mood |
data Value |
Not Used |
Keys |
Mood |
Titles |
Mood |
Default title_format |
Most Played <<title>> <<library_type>>s |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: plays.desc
any:
artist_mood: <>
```
|
#### Example:
* Create a collection for the top 100 items for each mood found in the Music library
* Name the collection Top [Mood] Tracks
```yaml
templates:
mood collection:
smart_filter:
limit: 100
sort_by: plays.desc
type: tracks
all:
track_mood: <>
dynamic_collections:
Moods: # mapping name does not matter just needs to be unique
type: mood
title_format: Top <> Tracks
template: mood collection
```
### Style
Create a collection for each style found in the library.
type Option |
style |
data Value |
Not Used |
Keys |
Style |
Titles |
Style |
Default title_format |
Most Played <<title>> <<library_type>>s |
Default Template |
```yaml
default_template:
smart_filter:
limit: 50
sort_by: plays.desc
any:
artist_style: < |