Add pokemon evolution support across the full stack
- Evolution model with trigger, level, item, and condition fields
- Encounter.current_pokemon_id tracks evolved species separately
- Alembic migration for evolutions table and current_pokemon_id column
- Seed pipeline loads evolution data with manual overrides
- GET /pokemon/{id}/evolutions and PATCH /encounters/{id} endpoints
- Evolve button in StatusChangeModal with evolution method details
- PokemonCard shows evolved species with "Originally" label
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
5
backend/src/app/seeds/data/evolution_overrides.json
Normal file
5
backend/src/app/seeds/data/evolution_overrides.json
Normal file
@@ -0,0 +1,5 @@
|
||||
{
|
||||
"remove": [],
|
||||
"add": [],
|
||||
"modify": []
|
||||
}
|
||||
722
backend/src/app/seeds/data/evolutions.json
Normal file
722
backend/src/app/seeds/data/evolutions.json
Normal file
@@ -0,0 +1,722 @@
|
||||
[
|
||||
{
|
||||
"from_national_dex": 10,
|
||||
"to_national_dex": 11,
|
||||
"trigger": "level-up",
|
||||
"min_level": 7,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 11,
|
||||
"to_national_dex": 12,
|
||||
"trigger": "level-up",
|
||||
"min_level": 10,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 13,
|
||||
"to_national_dex": 14,
|
||||
"trigger": "level-up",
|
||||
"min_level": 7,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 14,
|
||||
"to_national_dex": 15,
|
||||
"trigger": "level-up",
|
||||
"min_level": 10,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 16,
|
||||
"to_national_dex": 17,
|
||||
"trigger": "level-up",
|
||||
"min_level": 18,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 19,
|
||||
"to_national_dex": 20,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 21,
|
||||
"to_national_dex": 22,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 23,
|
||||
"to_national_dex": 24,
|
||||
"trigger": "level-up",
|
||||
"min_level": 22,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 27,
|
||||
"to_national_dex": 28,
|
||||
"trigger": "level-up",
|
||||
"min_level": 22,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 27,
|
||||
"to_national_dex": 28,
|
||||
"trigger": "use-item",
|
||||
"min_level": null,
|
||||
"item": "ice-stone",
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 29,
|
||||
"to_national_dex": 30,
|
||||
"trigger": "level-up",
|
||||
"min_level": 16,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 32,
|
||||
"to_national_dex": 33,
|
||||
"trigger": "level-up",
|
||||
"min_level": 16,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 41,
|
||||
"to_national_dex": 42,
|
||||
"trigger": "level-up",
|
||||
"min_level": 22,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 43,
|
||||
"to_national_dex": 44,
|
||||
"trigger": "level-up",
|
||||
"min_level": 21,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 46,
|
||||
"to_national_dex": 47,
|
||||
"trigger": "level-up",
|
||||
"min_level": 24,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 48,
|
||||
"to_national_dex": 49,
|
||||
"trigger": "level-up",
|
||||
"min_level": 31,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 50,
|
||||
"to_national_dex": 51,
|
||||
"trigger": "level-up",
|
||||
"min_level": 26,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 52,
|
||||
"to_national_dex": 53,
|
||||
"trigger": "level-up",
|
||||
"min_level": 28,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 54,
|
||||
"to_national_dex": 55,
|
||||
"trigger": "level-up",
|
||||
"min_level": 33,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 56,
|
||||
"to_national_dex": 57,
|
||||
"trigger": "level-up",
|
||||
"min_level": 28,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 60,
|
||||
"to_national_dex": 61,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 63,
|
||||
"to_national_dex": 64,
|
||||
"trigger": "level-up",
|
||||
"min_level": 16,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 66,
|
||||
"to_national_dex": 67,
|
||||
"trigger": "level-up",
|
||||
"min_level": 28,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 69,
|
||||
"to_national_dex": 70,
|
||||
"trigger": "level-up",
|
||||
"min_level": 21,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 72,
|
||||
"to_national_dex": 73,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 74,
|
||||
"to_national_dex": 75,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 75,
|
||||
"to_national_dex": 76,
|
||||
"trigger": "trade",
|
||||
"min_level": null,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 77,
|
||||
"to_national_dex": 78,
|
||||
"trigger": "level-up",
|
||||
"min_level": 40,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 79,
|
||||
"to_national_dex": 80,
|
||||
"trigger": "level-up",
|
||||
"min_level": 37,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 79,
|
||||
"to_national_dex": 80,
|
||||
"trigger": "use-item",
|
||||
"min_level": null,
|
||||
"item": "galarica-cuff",
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 81,
|
||||
"to_national_dex": 82,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 84,
|
||||
"to_national_dex": 85,
|
||||
"trigger": "level-up",
|
||||
"min_level": 31,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 86,
|
||||
"to_national_dex": 87,
|
||||
"trigger": "level-up",
|
||||
"min_level": 34,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 88,
|
||||
"to_national_dex": 89,
|
||||
"trigger": "level-up",
|
||||
"min_level": 38,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 92,
|
||||
"to_national_dex": 93,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 95,
|
||||
"to_national_dex": 208,
|
||||
"trigger": "trade",
|
||||
"min_level": null,
|
||||
"item": null,
|
||||
"held_item": "metal-coat",
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 96,
|
||||
"to_national_dex": 97,
|
||||
"trigger": "level-up",
|
||||
"min_level": 26,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 98,
|
||||
"to_national_dex": 99,
|
||||
"trigger": "level-up",
|
||||
"min_level": 28,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 100,
|
||||
"to_national_dex": 101,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 104,
|
||||
"to_national_dex": 105,
|
||||
"trigger": "level-up",
|
||||
"min_level": 28,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 109,
|
||||
"to_national_dex": 110,
|
||||
"trigger": "level-up",
|
||||
"min_level": 35,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 116,
|
||||
"to_national_dex": 117,
|
||||
"trigger": "level-up",
|
||||
"min_level": 32,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 118,
|
||||
"to_national_dex": 119,
|
||||
"trigger": "level-up",
|
||||
"min_level": 33,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 129,
|
||||
"to_national_dex": 130,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 147,
|
||||
"to_national_dex": 148,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 161,
|
||||
"to_national_dex": 162,
|
||||
"trigger": "level-up",
|
||||
"min_level": 15,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 163,
|
||||
"to_national_dex": 164,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 165,
|
||||
"to_national_dex": 166,
|
||||
"trigger": "level-up",
|
||||
"min_level": 18,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 167,
|
||||
"to_national_dex": 168,
|
||||
"trigger": "level-up",
|
||||
"min_level": 22,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 170,
|
||||
"to_national_dex": 171,
|
||||
"trigger": "level-up",
|
||||
"min_level": 27,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 177,
|
||||
"to_national_dex": 178,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 179,
|
||||
"to_national_dex": 180,
|
||||
"trigger": "level-up",
|
||||
"min_level": 15,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 187,
|
||||
"to_national_dex": 188,
|
||||
"trigger": "level-up",
|
||||
"min_level": 18,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 194,
|
||||
"to_national_dex": 195,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 216,
|
||||
"to_national_dex": 217,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 218,
|
||||
"to_national_dex": 219,
|
||||
"trigger": "level-up",
|
||||
"min_level": 38,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 223,
|
||||
"to_national_dex": 224,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 231,
|
||||
"to_national_dex": 232,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 246,
|
||||
"to_national_dex": 247,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 261,
|
||||
"to_national_dex": 262,
|
||||
"trigger": "level-up",
|
||||
"min_level": 18,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 263,
|
||||
"to_national_dex": 264,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 265,
|
||||
"to_national_dex": 266,
|
||||
"trigger": "level-up",
|
||||
"min_level": 7,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 265,
|
||||
"to_national_dex": 268,
|
||||
"trigger": "level-up",
|
||||
"min_level": 7,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 270,
|
||||
"to_national_dex": 271,
|
||||
"trigger": "level-up",
|
||||
"min_level": 14,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 273,
|
||||
"to_national_dex": 274,
|
||||
"trigger": "level-up",
|
||||
"min_level": 14,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 276,
|
||||
"to_national_dex": 277,
|
||||
"trigger": "level-up",
|
||||
"min_level": 22,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 278,
|
||||
"to_national_dex": 279,
|
||||
"trigger": "level-up",
|
||||
"min_level": 25,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 293,
|
||||
"to_national_dex": 294,
|
||||
"trigger": "level-up",
|
||||
"min_level": 20,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 296,
|
||||
"to_national_dex": 297,
|
||||
"trigger": "level-up",
|
||||
"min_level": 24,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 304,
|
||||
"to_national_dex": 305,
|
||||
"trigger": "level-up",
|
||||
"min_level": 32,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 309,
|
||||
"to_national_dex": 310,
|
||||
"trigger": "level-up",
|
||||
"min_level": 26,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 318,
|
||||
"to_national_dex": 319,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 320,
|
||||
"to_national_dex": 321,
|
||||
"trigger": "level-up",
|
||||
"min_level": 40,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 333,
|
||||
"to_national_dex": 334,
|
||||
"trigger": "level-up",
|
||||
"min_level": 35,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 339,
|
||||
"to_national_dex": 340,
|
||||
"trigger": "level-up",
|
||||
"min_level": 30,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 343,
|
||||
"to_national_dex": 344,
|
||||
"trigger": "level-up",
|
||||
"min_level": 36,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 353,
|
||||
"to_national_dex": 354,
|
||||
"trigger": "level-up",
|
||||
"min_level": 37,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 360,
|
||||
"to_national_dex": 202,
|
||||
"trigger": "level-up",
|
||||
"min_level": 15,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 363,
|
||||
"to_national_dex": 364,
|
||||
"trigger": "level-up",
|
||||
"min_level": 32,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": null
|
||||
},
|
||||
{
|
||||
"from_national_dex": 433,
|
||||
"to_national_dex": 358,
|
||||
"trigger": "level-up",
|
||||
"min_level": null,
|
||||
"item": null,
|
||||
"held_item": null,
|
||||
"condition": "happiness >= 220, night"
|
||||
}
|
||||
]
|
||||
Reference in New Issue
Block a user