feat: replace Kaggle CSV with Wikipedia scraper for historical match data

Add scripts/scrape-wikipedia.ts that fetches all 22 World Cups (1930–2022)
from English Wikipedia via MediaWiki API, handles group sub-pages, AET/penalty
detection, and goal parsing, writing openfootball-format JSON to app/data/openfootball/.

Rewrite scripts/seed.ts to read these local JSON files instead of the Kaggle
CSV, producing 965 matches and 2716 goals with per-group assignments for all
historical tournaments (enabling group standings on tournament pages).

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-06-15 11:39:53 +02:00
parent 83b1ad3e35
commit 5dcd22ad22
88 changed files with 95625 additions and 127 deletions
@@ -0,0 +1,58 @@
{
"groups": [
{
"name": "Group A",
"teams": [
"Bulgaria",
"Italy",
"Argentina",
"South Korea"
]
},
{
"name": "Group B",
"teams": [
"Belgium",
"Mexico",
"Paraguay",
"Iraq"
]
},
{
"name": "Group C",
"teams": [
"Canada",
"France",
"Soviet Union",
"Hungary"
]
},
{
"name": "Group D",
"teams": [
"Spain",
"Brazil",
"Algeria",
"Northern Ireland"
]
},
{
"name": "Group E",
"teams": [
"Uruguay",
"West Germany",
"Scotland",
"Denmark"
]
},
{
"name": "Group F",
"teams": [
"Morocco",
"Poland",
"Portugal",
"England"
]
}
]
}
File diff suppressed because it is too large Load Diff
File diff suppressed because it is too large Load Diff
@@ -0,0 +1,52 @@
{
"stadiums": [
{
"name": "Estadio Azteca",
"city": "Mexico City"
},
{
"name": "Estadio Nou Camp",
"city": "León"
},
{
"name": "Estadio Jalisco",
"city": "Guadalajara"
},
{
"name": "Estadio Cuauhtémoc",
"city": "Puebla"
},
{
"name": "Estadio Olímpico Universitario",
"city": "Mexico City"
},
{
"name": "Estadio Universitario",
"city": "San Nicolás de los Garza"
},
{
"name": "Estadio La Corregidora",
"city": "Querétaro"
},
{
"name": "Estadio Toluca 7086",
"city": "Toluca"
},
{
"name": "Estadio Sergio León Chavez",
"city": "Irapuato"
},
{
"name": "Estadio Tres de Marzo",
"city": "Zapopan"
},
{
"name": "Estadio Tecnológico",
"city": "Monterrey"
},
{
"name": "Estadio Neza 86",
"city": "Nezahualcóyotl"
}
]
}