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": [
"United States",
"Switzerland",
"Colombia",
"Romania"
]
},
{
"name": "Group B",
"teams": [
"Cameroon",
"Sweden",
"Brazil",
"Russia"
]
},
{
"name": "Group C",
"teams": [
"Germany",
"Bolivia",
"Spain",
"South Korea"
]
},
{
"name": "Group D",
"teams": [
"Argentina",
"Greece",
"Nigeria",
"Bulgaria"
]
},
{
"name": "Group E",
"teams": [
"Italy",
"Republic of Ireland",
"Norway",
"Mexico"
]
},
{
"name": "Group F",
"teams": [
"Belgium",
"Morocco",
"Netherlands",
"Saudi Arabia"
]
}
]
}
File diff suppressed because it is too large Load Diff
File diff suppressed because it is too large Load Diff
@@ -0,0 +1,40 @@
{
"stadiums": [
{
"name": "Soldier Field",
"city": "Chicago"
},
{
"name": "RFK Stadium",
"city": "Washington, D.C."
},
{
"name": "Cotton Bowl",
"city": "Dallas"
},
{
"name": "Rose Bowl",
"city": "Pasadena"
},
{
"name": "Citrus Bowl",
"city": "Orlando"
},
{
"name": "Stanford Stadium",
"city": "Stanford"
},
{
"name": "Foxboro Stadium",
"city": "Foxborough"
},
{
"name": "Giants Stadium",
"city": "East Rutherford"
},
{
"name": "Pontiac Silverdome",
"city": "Pontiac"
}
]
}