Added Notifications

This commit is contained in:
2026-05-10 22:42:37 +10:00
parent 016e752dcd
commit c7fe3268c7
18 changed files with 1386 additions and 50 deletions
+154 -41
View File
@@ -2,17 +2,111 @@
namespace App\Console\Commands;
use App\DTOs\FlightStatData;
use App\Models\Aircraft;
use App\Models\IataEquipmentCode;
use App\Models\Notification;
use App\Models\UserFlight;
use Carbon\Carbon;
use Carbon\CarbonImmutable;
use Illuminate\Console\Attributes\Description;
use Illuminate\Console\Attributes\Signature;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\Http;
use Illuminate\Support\Facades\Log;
#[Signature('app:update-departed-flights')]
#[Description('Command description')]
class UpdateDepartedFlights extends Command
{
/**
* Fetch live flight data from FlightStats.
* Returns null if the request fails or no data is found.
*/
protected function fetchFlightData(string $airlineCode, string $flightNumber, CarbonImmutable $date): ?FlightStatData
{
$url = sprintf(
'https://www.flightstats.com/v2/api-next/flight-tracker/%s/%s/%d/%d/%d',
$airlineCode,
$flightNumber,
$date->year,
$date->month,
$date->day,
);
$response = Http::withOptions([
'verify' => config('app.verify_ssl'),
])->get($url);
if (!$response->successful()) {
Log::warning("FlightStats request failed for {$airlineCode}{$flightNumber}: HTTP {$response->status()}");
return null;
}
$flightData = $response->json('data');
if (empty($flightData)) {
return null;
}
return FlightStatData::fromApiResponse($flightData);
}
/**
* Attempt to resolve the best matching Aircraft record for a given IATA equipment code.
* Prefers passenger variants over freighters/BBJs where multiple matches exist.
*/
protected function guessAircraftFromIata(string $iataCode): ?Aircraft
{
$equipment = IataEquipmentCode::where('iata_code', $iataCode)->first();
if (!$equipment) {
Log::info("Unknown IATA equipment code: {$iataCode}");
return null;
}
$candidates = Aircraft::where('designator', $equipment->icao_code)->get();
if ($candidates->isEmpty()) {
Log::info("No aircraft found for ICAO: {$equipment->icao_code} (IATA: {$iataCode})");
return null;
}
if ($candidates->count() === 1) {
return $candidates->first();
}
// Prefer passenger variants — deprioritise freighters, BBJs, and convertibles
$deprioritised = ['freighter', 'bbj', 'combi', 'mixed', 'cargo', 'prestige', 'winglet', 'sharklet', 'freight'];
$pattern = implode('|', $deprioritised);
$passengerVariants = $candidates->filter(
fn(Aircraft $a) => !preg_match("/({$pattern})/i", $a->display_name_short)
);
if ($passengerVariants->count() === 1) {
return $passengerVariants->first();
}
if ($passengerVariants->isNotEmpty()) {
return $passengerVariants->first();
}
return $candidates->first();
}
protected function notifyDataError(UserFlight $flight): void
{
Notification::create([
'user_id' => $flight->user_id,
'title' => "Auto update failed for {$flight->flight_number}",
'body' => "There was an error fetching flight data for {$flight->flight_number}. Please manually check the aircraft type, registration and departure/arrival times.",
'url' => '/flights/' . $flight->id . '/edit'
]);
$flight->update(['auto_update' => false]);
}
/**
* Execute the console command.
*/
@@ -21,10 +115,7 @@ class UpdateDepartedFlights extends Command
$now = now()->utc();
$oneHourAgo = $now->copy()->subHours(1);
$userFlights = UserFlight::whereBetween('arrival_date', [
$oneHourAgo->toDateTimeString(),
$now->toDateTimeString(),
])
$userFlights = UserFlight::where('arrival_date', '<=', $now->copy()->subHour()->toDateTimeString())
->where('auto_update', true)
->whereNotNull('flight_number')
->get();
@@ -36,72 +127,94 @@ class UpdateDepartedFlights extends Command
if (empty($matches)) {
$this->warn("Could not parse flight number: {$flight->flight_number}");
$this->notifyDataError($flight);
continue;
}
$airlineCode = strtoupper($matches[1]);
$airlineCode = strtoupper($matches[1]);
$flightNumber = $matches[2];
$arrivalDate = $flight->arrival_date->setTimezone($flight->arrivalAirport->timezone);
$year = $arrivalDate->year;
$month = $arrivalDate->month;
$day = $arrivalDate->day;
$url = "https://www.flightstats.com/v2/api-next/flight-tracker/{$airlineCode}/{$flightNumber}/{$year}/{$month}/{$day}";
$data = $this->fetchFlightData($airlineCode, $flightNumber, $arrivalDate);
$response = Http::get($url);
if (!$response->successful()) {
$this->warn("Failed to fetch data for {$flight->flight_number}: HTTP {$response->status()}");
continue;
}
$data = $response->json();
$flightData = $data['data'] ?? [];
if (empty($flightData)) {
if (!$data) {
$this->warn("No flight data returned for {$airlineCode}{$flightNumber}");
$this->notifyDataError($flight);
continue;
}
if ($data->departure_iata !== $flight->departureAirport->iata_code ||
$data->arrival_iata !== $flight->arrivalAirport->iata_code) {
$this->warn("Airport mismatch for {$airlineCode}{$flightNumber} — API: {$data->departure_iata}{$data->arrival_iata}, expected: {$flight->departureAirport->iata_code}{$flight->arrivalAirport->iata_code}");
$this->notifyDataError($flight);
$tailNumber = $flightData['positional']['flexTrack']['tailNumber'] ?? null;
$estimatedDepartureUtc = $flightData['schedule']['estimatedActualDepartureUTC'] ?? null;
$estimatedArrivalUtc = $flightData['schedule']['estimatedActualArrivalUTC'] ?? null;
$equipmentCode = $flightData['additionalFlightInfo']['equipment']['iata'] ?? null;
$apiDepartureIata = $data['data']['departureAirport']['iata'] ?? null;
$apiArrivalIata = $data['data']['arrivalAirport']['iata'] ?? null;
if ($apiDepartureIata !== $flight->departureAirport->iata_code ||
$apiArrivalIata !== $flight->arrivalAirport->iata_code) {
$this->warn("Airport mismatch for {$airlineCode}{$flightNumber} — API: {$apiDepartureIata}{$apiArrivalIata}, expected: {$flight->departureAirport->iata_code}{$flight->arrivalAirport->iata_code}");
continue;
}
$updates = [];
if ($tailNumber && $tailNumber !== $flight->aircraft_registration) {
$updates['aircraft_registration'] = $tailNumber;
if ($data->aircraft_registration && $data->aircraft_registration !== $flight->aircraft_registration) {
$updates['aircraft_registration'] = $data->aircraft_registration;
}
if ($estimatedDepartureUtc && Carbon::parse($estimatedDepartureUtc)->ne($flight->departure_date)) {
$updates['departure_date'] = Carbon::parse($estimatedDepartureUtc);
if ($data->estimated_departure_utc?->ne($flight->departure_date)) {
$updates['departure_date'] = $data->estimated_departure_utc;
}
if ($estimatedArrivalUtc && Carbon::parse($estimatedArrivalUtc)->ne($flight->arrival_date)) {
$updates['arrival_date'] = Carbon::parse($estimatedArrivalUtc);
if ($data->estimated_arrival_utc?->ne($flight->arrival_date)) {
$updates['arrival_date'] = $data->estimated_arrival_utc;
}
if ($data->equipment_iata) {
$currentAircraft = $flight->aircraft;
if ($currentAircraft?->iata_code !== $data->equipment_iata) {
$match = $this->guessAircraftFromIata($data->equipment_iata);
if ($match) {
$updates['aircraft_id'] = $match->id;
} else {
Log::info("No aircraft match for IATA code {$data->equipment_iata} on flight {$airlineCode}{$flightNumber}");
}
}
}
if (!empty($updates)) {
$flight->update($updates);
$this->info("Updated flight {$airlineCode}{$flightNumber}: " . implode(', ', array_keys($updates)));
$changeDescriptions = [];
if (isset($updates['aircraft_registration'])) {
$changeDescriptions[] = "Registration updated to {$updates['aircraft_registration']}";
}
if (isset($updates['departure_date'])) {
$changeDescriptions[] = "Departure updated to {$updates['departure_date']}";
}
if (isset($updates['arrival_date'])) {
$changeDescriptions[] = "Arrival updated to {$updates['arrival_date']}";
}
if (isset($updates['aircraft_id'])) {
$aircraft = Aircraft::find($updates['aircraft_id']);
$changeDescriptions[] = "Aircraft type updated to {$aircraft->display_name_short}";
}
Notification::create([
'user_id' => $flight->user_id,
'title' => "Flight {$airlineCode}{$flightNumber} updated",
'body' => implode("\n", $changeDescriptions),
]);
} else {
$this->info("No changes for {$airlineCode}{$flightNumber}");
Notification::create([
'user_id' => $flight->user_id,
'title' => "Flight {$airlineCode}{$flightNumber} updated — no changes",
'body' => "Your flight was completed and no updates were made to aircraft, registration, or departure/arrival times.",
]);
}
$this->info("Flight {$airlineCode}{$flightNumber} — Tail: {$tailNumber}, Equipment: {$equipmentCode}");
$this->info("Departure: {$estimatedDepartureUtc} | Arrival: {$estimatedArrivalUtc}");
$flight->update(['auto_update' => false]);
}
}
}
+33
View File
@@ -0,0 +1,33 @@
<?php
namespace App\DTOs;
use Carbon\Carbon;
readonly class FlightStatData
{
public function __construct(
public ?string $aircraft_registration,
public ?Carbon $estimated_departure_utc,
public ?Carbon $estimated_arrival_utc,
public ?string $equipment_iata,
public ?string $departure_iata,
public ?string $arrival_iata,
) {}
public static function fromApiResponse(array $flightData): self
{
return new self(
aircraft_registration: $flightData['positional']['flexTrack']['tailNumber'] ?? null,
estimated_departure_utc: isset($flightData['schedule']['estimatedActualDepartureUTC'])
? Carbon::parse($flightData['schedule']['estimatedActualDepartureUTC'])
: null,
estimated_arrival_utc: isset($flightData['schedule']['estimatedActualArrivalUTC'])
? Carbon::parse($flightData['schedule']['estimatedActualArrivalUTC'])
: null,
equipment_iata: $flightData['additionalFlightInfo']['equipment']['iata'] ?? null,
departure_iata: $flightData['departureAirport']['iata'] ?? null,
arrival_iata: $flightData['arrivalAirport']['iata'] ?? null,
);
}
}
@@ -4,11 +4,34 @@ namespace App\Http\Controllers;
use App\Models\Notification;
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
class NotificationController extends Controller
{
use AuthorizesRequests;
public function index(Request $request): JsonResponse
{
$user = $request->user();
$unread = $user->notifications()
->whereNull('read_at')
->latest()
->get();
if ($unread->isNotEmpty()) {
return response()->json($unread);
}
$recent = $user->notifications()
->latest()
->limit(10)
->get();
return response()->json($recent);
}
public function markRead(Request $request, Notification $notification)
{
$this->authorize('update', $notification);
@@ -29,6 +29,7 @@ class HandleInertiaRequests extends Middleware
*/
public function share(Request $request): array
{
return [
...parent::share($request),
'logo_api_url' => config('app.logo_api_url'),
@@ -44,6 +45,11 @@ class HandleInertiaRequests extends Middleware
->latest()
->get()
: [],
'unread_notification_count' => $request->user()?->notifications()
->whereNull('read_at')
->whereNull('expires_at')
->orWhere('expires_at', '>', now())
->count(),
];
}
}
+1
View File
@@ -27,6 +27,7 @@ use Illuminate\Database\Eloquent\Relations\HasMany;
*/
class Achievement extends Model
{
public $timestamps = false;
protected $fillable = [
'name',
'internal_name',
+5
View File
@@ -26,6 +26,11 @@ class Aircraft extends Model
'display_name_short'
];
const array IATA_ALIAS_MAP = [
'7S8' => '73H',
'7S9' => '73J'
];
protected function displayName() : Attribute{
return Attribute::make(
get: function () {
+22
View File
@@ -0,0 +1,22 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\HasMany;
class IataEquipmentCode extends Model
{
public $timestamps = false;
protected $fillable = [
'iata_code',
'icao_code',
'description',
];
public function aircraft(): HasMany
{
return $this->hasMany(Aircraft::class, 'designator', 'icao_code');
}
}
+1
View File
@@ -40,6 +40,7 @@ return [
*/
'debug' => (bool) env('APP_DEBUG', false),
'verify_ssl' => env('VERIFY_SSL', true),
/*
|--------------------------------------------------------------------------
@@ -1,17 +1,472 @@
<?php
use App\Models\Achievement;
use App\Models\Aircraft;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
protected array $aircraft_codes = [
'100' => ['icao' => 'F100', 'description' => 'Fokker 100', 'wtc' => 'M'],
'141' => ['icao' => 'B461', 'description' => 'BAe 146-100 Pax', 'wtc' => 'M'],
'142' => ['icao' => 'B462', 'description' => 'BAe 146-200 Pax', 'wtc' => 'M'],
'143' => ['icao' => 'B463', 'description' => 'BAe 146-300 Pax', 'wtc' => 'M'],
'146' => ['icao' => '', 'description' => 'BAe 146 all pax models', 'wtc' => 'M'],
'14F' => ['icao' => '', 'description' => 'BAe 146 Freighter (-100/200/300QT & QC)', 'wtc' => 'M'],
'14X' => ['icao' => 'B461', 'description' => 'BAe 146 Freighter (-100QT & QC)', 'wtc' => 'M'],
'14Y' => ['icao' => 'B462', 'description' => 'BAe 146 Freighter (-200QT & QC)', 'wtc' => 'M'],
'14Z' => ['icao' => 'B463', 'description' => 'BAe 146 Freighter (-200QT & QC)', 'wtc' => 'M'],
'290' => ['icao' => 'E290', 'description' => 'Embraer E190-E2', 'wtc' => 'M'],
'295' => ['icao' => 'E295', 'description' => 'Embraer E195-E2', 'wtc' => 'M'],
'221' => ['icao' => 'BCS1', 'description' => 'Airbus A220-100', 'wtc' => 'M'],
'223' => ['icao' => 'BCS3', 'description' => 'Airbus A220-200', 'wtc' => 'M'],
'310' => ['icao' => 'A310', 'description' => 'Airbus A310 all pax models', 'wtc' => 'H'],
'312' => ['icao' => 'A310', 'description' => 'Airbus A310-200 pax', 'wtc' => 'H'],
'313' => ['icao' => 'A310', 'description' => 'Airbus A310-300 pax', 'wtc' => 'H'],
'318' => ['icao' => 'A318', 'description' => 'Airbus A318', 'wtc' => 'M'],
'319' => ['icao' => 'A319', 'description' => 'Airbus A319 Ceo', 'wtc' => 'M'],
'31F' => ['icao' => 'A310', 'description' => 'Airbus A310 Freighter', 'wtc' => 'M'],
'31N' => ['icao' => 'A19N', 'description' => 'Airbus A319 Neo', 'wtc' => 'M'],
'31X' => ['icao' => 'A310', 'description' => 'Airbus A310-200 Freighter', 'wtc' => 'M'],
'31Y' => ['icao' => 'A310', 'description' => 'Airbus A310-300 Freighter', 'wtc' => 'M'],
'320' => ['icao' => 'A320', 'description' => 'Airbus A320-100/200 Ceo', 'wtc' => 'M'],
'321' => ['icao' => 'A321', 'description' => 'Airbus A321-100/200 Ceo', 'wtc' => 'M'],
'32A' => ['icao' => 'A320', 'description' => 'Airbus A320-200 Ceo (Sharklets)', 'wtc' => 'M'],
'32C' => ['icao' => 'A318', 'description' => 'Airbus A318 (Sharklets)', 'wtc' => 'M'],
'32D' => ['icao' => 'A319', 'description' => 'Airbus A319 Ceo (Sharklets)', 'wtc' => 'M'],
'32N' => ['icao' => 'A20N', 'description' => 'Airbus A320-200 Neo', 'wtc' => 'M'],
'32Q' => ['icao' => 'A21N', 'description' => 'Airbus A321-200 Neo', 'wtc' => 'M'],
'32S' => ['icao' => 'n/a', 'description' => 'Airbus A318/319/320/321', 'wtc' => 'M'],
'330' => ['icao' => 'A330', 'description' => 'Airbus A330 all models', 'wtc' => 'H'],
'332' => ['icao' => 'A332', 'description' => 'Airbus A330-200', 'wtc' => 'H'],
'333' => ['icao' => 'A333', 'description' => 'Airbus A330-300', 'wtc' => 'H'],
'338' => ['icao' => 'A338', 'description' => 'Airbus A330-800 Neo', 'wtc' => 'H'],
'339' => ['icao' => 'A339', 'description' => 'Airbus A330-900 Neo', 'wtc' => 'H'],
'33X' => ['icao' => 'A332', 'description' => 'Airbus A330-200 Freighter', 'wtc' => 'H'],
'340' => ['icao' => 'A340', 'description' => 'Airbus A340 all models', 'wtc' => 'H'],
'342' => ['icao' => 'A342', 'description' => 'Airbus A340-200', 'wtc' => 'H'],
'343' => ['icao' => 'A343', 'description' => 'Airbus A340-300', 'wtc' => 'H'],
'345' => ['icao' => 'A345', 'description' => 'Airbus A340-500', 'wtc' => 'H'],
'346' => ['icao' => 'A346', 'description' => 'Airbus A340-600', 'wtc' => 'H'],
'351' => ['icao' => 'A35K', 'description' => 'Airbus A350-1000', 'wtc' => 'H'],
'359' => ['icao' => 'A359', 'description' => 'Airbus A350-900', 'wtc' => 'H'],
'380' => ['icao' => 'A388', 'description' => 'Airbus A380 pax', 'wtc' => 'J'],
'38F' => ['icao' => '', 'description' => 'Airbus A380 Freighter', 'wtc' => 'J'],
'703' => ['icao' => 'B703', 'description' => 'Boeing 707-300 pax', 'wtc' => 'H'],
'707' => ['icao' => 'n/a', 'description' => 'Boeing 707/720 all pax models', 'wtc' => 'H'],
'70F' => ['icao' => 'B703', 'description' => 'Boeing 707 Freighter', 'wtc' => 'H'],
'70M' => ['icao' => 'B703', 'description' => 'Boeing 707 Combi', 'wtc' => 'H'],
'717' => ['icao' => 'B712', 'description' => 'Boeing 717', 'wtc' => 'M'],
'721' => ['icao' => 'B721', 'description' => 'Boeing 727-100 pax', 'wtc' => 'M'],
'722' => ['icao' => 'B722', 'description' => 'Boeing 727-200 pax', 'wtc' => 'M'],
'727' => ['icao' => 'n/a', 'description' => 'Boeing 727 all pax models', 'wtc' => 'M'],
'72B' => ['icao' => 'B721', 'description' => 'Boeing 727-100 Mixed Configuration', 'wtc' => 'M'],
'72C' => ['icao' => 'B722', 'description' => 'Boeing 727-200 Mixed Configuration', 'wtc' => 'M'],
'72F' => ['icao' => 'n/a', 'description' => 'Boeing 727 Freighter (-100/200)', 'wtc' => 'M'],
'72M' => ['icao' => 'n/a', 'description' => 'Boeing 727 Combi', 'wtc' => 'M'],
'72S' => ['icao' => 'B722', 'description' => 'Boeing 727-200 Advanced pax', 'wtc' => 'M'],
'72W' => ['icao' => 'B721', 'description' => 'Boeing 727-200 (winglets) pax', 'wtc' => 'M'],
'72X' => ['icao' => 'B721', 'description' => 'Boeing 727-100 Freighter', 'wtc' => 'M'],
'72Y' => ['icao' => 'B722', 'description' => 'Boeing 727-200 Freighter', 'wtc' => 'M'],
'731' => ['icao' => 'B731', 'description' => 'Boeing 737-100 pax', 'wtc' => 'M'],
'732' => ['icao' => 'B732', 'description' => 'Boeing 737-200 pax', 'wtc' => 'M'],
'733' => ['icao' => 'B733', 'description' => 'Boeing 737-300 pax', 'wtc' => 'M'],
'734' => ['icao' => 'B734', 'description' => 'Boeing 737-400 pax', 'wtc' => 'M'],
'735' => ['icao' => 'B735', 'description' => 'Boeing 737-500 pax', 'wtc' => 'M'],
'736' => ['icao' => 'B736', 'description' => 'Boeing 737-600 pax', 'wtc' => 'M'],
'737' => ['icao' => 'n/a', 'description' => 'Boeing 737 all pax models', 'wtc' => 'M'],
'738' => ['icao' => 'B738', 'description' => 'Boeing 737-800 pax', 'wtc' => 'M'],
'739' => ['icao' => 'B739', 'description' => 'Boeing 737-900 pax', 'wtc' => 'M'],
'73C' => ['icao' => 'B733', 'description' => 'Boeing 737-300 (winglets) pax', 'wtc' => 'M'],
'73E' => ['icao' => 'B735', 'description' => 'Boeing 737-500 (winglets) pax', 'wtc' => 'M'],
'73F' => ['icao' => 'n/a', 'description' => 'Boeing 737 all Freighter models', 'wtc' => 'M'],
'73G' => ['icao' => 'B737', 'description' => 'Boeing 737-700 pax', 'wtc' => 'M'],
'73H' => ['icao' => 'B738', 'description' => 'Boeing 737-800 (winglets) pax', 'wtc' => 'M'],
'73J' => ['icao' => 'B739', 'description' => 'Boeing 737-900 (winglets) pax', 'wtc' => 'M'],
'73L' => ['icao' => 'B732', 'description' => 'Boeing 737-200 Combi', 'wtc' => 'M'],
'73M' => ['icao' => 'n/a', 'description' => 'Boeing 737 Combi', 'wtc' => 'M'],
'73P' => ['icao' => 'B734', 'description' => 'Boeing 737-400 Freighter', 'wtc' => 'M'],
'73Q' => ['icao' => 'B734', 'description' => 'Boeing 737-400 Combi', 'wtc' => 'M'],
'73R' => ['icao' => 'B737', 'description' => 'Boeing 737-700 Combi', 'wtc' => 'M'],
'73W' => ['icao' => 'B737', 'description' => 'Boeing 737-700 (winglets) pax', 'wtc' => 'M'],
'73X' => ['icao' => 'B732', 'description' => 'Boeing 737-200 Freighter', 'wtc' => 'M'],
'73Y' => ['icao' => 'B733', 'description' => 'Boeing 737-300 Freighter', 'wtc' => 'M'],
'741' => ['icao' => 'B741', 'description' => 'Boeing 747-100 pax', 'wtc' => 'H'],
'742' => ['icao' => 'B742', 'description' => 'Boeing 747-200 pax', 'wtc' => 'H'],
'743' => ['icao' => 'B743', 'description' => 'Boeing 747-300 pax', 'wtc' => 'H'],
'744' => ['icao' => 'B744', 'description' => 'Boeing 747-400 pax', 'wtc' => 'H'],
'747' => ['icao' => 'n/a', 'description' => 'Boeing 747 all pax models', 'wtc' => 'H'],
'748' => ['icao' => 'B748', 'description' => 'Boeing 747-8 pax', 'wtc' => 'H'],
'74B' => ['icao' => 'B744', 'description' => 'Boeing 747-400 Swingtail Freighter', 'wtc' => 'H'],
'74C' => ['icao' => 'B742', 'description' => 'Boeing 747-200 Combi', 'wtc' => 'H'],
'74D' => ['icao' => 'B743', 'description' => 'Boeing 747-300 Combi', 'wtc' => 'H'],
'74E' => ['icao' => 'B744', 'description' => 'Boeing 747-400 Combi', 'wtc' => 'H'],
'74F' => ['icao' => 'n/a', 'description' => 'Boeing 747 all Freighter models', 'wtc' => 'H'],
'74H' => ['icao' => 'n/a', 'description' => 'Boeing 747-8I Passenger', 'wtc' => 'H'],
'74J' => ['icao' => 'B744', 'description' => 'Boeing 747-400 (Domestic) pax', 'wtc' => 'H'],
'74L' => ['icao' => 'B74S', 'description' => 'Boeing 747SP', 'wtc' => 'H'],
'74M' => ['icao' => 'n/a', 'description' => 'Boeing 747 all Combi models', 'wtc' => 'H'],
'74N' => ['icao' => 'n/a', 'description' => 'Boeing 747-8F', 'wtc' => 'H'],
'74R' => ['icao' => 'B74R', 'description' => 'Boeing 747SR pax', 'wtc' => 'H'],
'74T' => ['icao' => 'B741', 'description' => 'Boeing 747-100 Freighter', 'wtc' => 'H'],
'74U' => ['icao' => 'B743', 'description' => 'Boeing 747-300 / 747-200 SUD Freighter', 'wtc' => 'H'],
'74V' => ['icao' => 'B74R', 'description' => 'Boeing 747SR Freighter', 'wtc' => 'H'],
'74X' => ['icao' => 'B742', 'description' => 'Boeing 747-200 Freighter', 'wtc' => 'H'],
'74Y' => ['icao' => 'B744', 'description' => 'Boeing 747-400 Freighter', 'wtc' => 'H'],
'752' => ['icao' => 'B752', 'description' => 'Boeing 757-200 pax', 'wtc' => 'H'],
'753' => ['icao' => 'B753', 'description' => 'Boeing 757-300 pax', 'wtc' => 'H'],
'757' => ['icao' => 'n/a', 'description' => 'Boeing 757 all pax models', 'wtc' => 'H'],
'75F' => ['icao' => 'B752', 'description' => 'Boeing 757 Freighter', 'wtc' => 'H'],
'75M' => ['icao' => 'B752', 'description' => 'Boeing 757 Mixed Configuration', 'wtc' => 'H'],
'75T' => ['icao' => 'B753', 'description' => 'Boeing 757-300 (winglets) pax', 'wtc' => 'H'],
'75W' => ['icao' => 'B752', 'description' => 'Boeing 757-200 (winglets) pax', 'wtc' => 'H'],
'762' => ['icao' => 'B762', 'description' => 'Boeing 767-200 pax', 'wtc' => 'H'],
'763' => ['icao' => 'B763', 'description' => 'Boeing 767-300 pax', 'wtc' => 'H'],
'764' => ['icao' => 'B764', 'description' => 'Boeing 767-400 pax', 'wtc' => 'H'],
'767' => ['icao' => 'n/a', 'description' => 'Boeing 767 all pax models', 'wtc' => 'H'],
'76F' => ['icao' => 'n/a', 'description' => 'Boeing 767 all Freighter models', 'wtc' => 'H'],
'76W' => ['icao' => 'B763', 'description' => 'Boeing 767-300 (winglets) pax', 'wtc' => 'H'],
'76V' => ['icao' => 'B763', 'description' => 'Boeing 767-300 (winglets) Freighter', 'wtc' => 'H'],
'76X' => ['icao' => 'B762', 'description' => 'Boeing 767-200 Freighter', 'wtc' => 'H'],
'76Y' => ['icao' => 'B763', 'description' => 'Boeing 767-300 Freighter', 'wtc' => 'H'],
'772' => ['icao' => 'B772', 'description' => 'Boeing 777-200 pax', 'wtc' => 'H'],
'773' => ['icao' => 'B773', 'description' => 'Boeing 777-300 pax', 'wtc' => 'H'],
'777' => ['icao' => 'n/a', 'description' => 'Boeing 777 all pax models', 'wtc' => 'H'],
'77F' => ['icao' => 'n/a', 'description' => 'Boeing 777 Freighter', 'wtc' => 'H'],
'77L' => ['icao' => 'B772', 'description' => 'Boeing 777-200LR pax', 'wtc' => 'H'],
'77W' => ['icao' => 'B77W', 'description' => 'Boeing 777-300ER pax', 'wtc' => 'H'],
'77X' => ['icao' => 'B77L', 'description' => 'Boeing 777-200 Freighter', 'wtc' => 'H'],
'781' => ['icao' => 'B78X', 'description' => 'Boeing 787-10 pax', 'wtc' => 'H'],
'788' => ['icao' => 'B788', 'description' => 'Boeing 787-8 pax', 'wtc' => 'H'],
'789' => ['icao' => 'B789', 'description' => 'Boeing 787-9 pax', 'wtc' => 'H'],
'7M7' => ['icao' => 'B37M', 'description' => 'Boeing 737 MAX 7 pax', 'wtc' => 'M'],
'7M8' => ['icao' => 'B38M', 'description' => 'Boeing 737 MAX 8 pax', 'wtc' => 'M'],
'7M9' => ['icao' => 'B39M', 'description' => 'Boeing 737 MAX 9 pax', 'wtc' => 'M'],
'7MJ' => ['icao' => 'B3XM', 'description' => 'Boeing 737 MAX 10 pax', 'wtc' => 'M'],
'A22' => ['icao' => 'AN22', 'description' => 'Antonov AN-22', 'wtc' => 'L'],
'A26' => ['icao' => 'AN26', 'description' => 'Antonov AN-26', 'wtc' => 'L'],
'A28' => ['icao' => 'AN28', 'description' => 'Antonov AN-28 / PZL Miele M-28 Skytruck', 'wtc' => 'L'],
'A30' => ['icao' => 'AN30', 'description' => 'Antonov AN-30', 'wtc' => 'L'],
'A32' => ['icao' => 'AN32', 'description' => 'Antonov AN-32', 'wtc' => 'L'],
'A38' => ['icao' => 'AN38', 'description' => 'Antonov AN-38', 'wtc' => 'L'],
'A40' => ['icao' => 'A140', 'description' => 'Antonov AN-140', 'wtc' => 'M'],
'A4F' => ['icao' => 'A124', 'description' => 'Antonov AN-124 Ruslan', 'wtc' => 'H'],
'A5F' => ['icao' => 'A225', 'description' => 'Antonov AN-225', 'wtc' => 'H'],
'A81' => ['icao' => 'A148', 'description' => 'Antonov AN-148-100', 'wtc' => 'M'],
'AB3' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300 pax', 'wtc' => 'H'],
'AB4' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300B2/B4/C4 pax', 'wtc' => 'H'],
'AB6' => ['icao' => 'A306', 'description' => 'Airbus Industrie A300-600 pax', 'wtc' => 'H'],
'ABB' => ['icao' => 'A3ST', 'description' => 'Airbus Industrie A300-600ST Beluga Freighter', 'wtc' => 'H'],
'ABF' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300 Freighter', 'wtc' => 'H'],
'ABX' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300C4/F4 Freighter', 'wtc' => 'H'],
'ABY' => ['icao' => 'A306', 'description' => 'Airbus Industrie A300-600 Freighter', 'wtc' => 'H'],
'ACD' => ['icao' => 'n/a', 'description' => 'Gulfstream/Rockwell (Aero) Commander/Turbo Commander', 'wtc' => 'L'],
'ACP' => ['icao' => 'AC68', 'description' => 'Gulfstream/Rockwell (Aero) Commander', 'wtc' => 'L'],
'ACT' => ['icao' => 'AC90', 'description' => 'Gulfstream/Rockwell (Aero) Turbo Commander', 'wtc' => 'L'],
'AGH' => ['icao' => 'A109', 'description' => 'Agusta A109', 'wtc' => 'n/a'],
'ALM' => ['icao' => 'LOAD', 'description' => 'Ayres LM-200 Loadmaster', 'wtc' => 'M'],
'AN4' => ['icao' => 'AN24', 'description' => 'Antonov AN-24', 'wtc' => 'M'],
'AN6' => ['icao' => 'n/a', 'description' => 'Antonov AN-26 / AN-30 / AN-32', 'wtc' => 'M'],
'AN7' => ['icao' => 'AN72', 'description' => 'Antonov AN-72 / AN-74', 'wtc' => 'M'],
'ANF' => ['icao' => 'AN12', 'description' => 'Antonov AN-12', 'wtc' => 'M'],
'APH' => ['icao' => 'n/a', 'description' => 'Eurocopter (Aerospatiale) SA330 Puma / AS332 Super Puma', 'wtc' => 'n/a'],
'AR1' => ['icao' => 'RJ1H', 'description' => 'Avro RJ100 Avroliner', 'wtc' => 'M'],
'AR7' => ['icao' => 'RJ70', 'description' => 'Avro RJ70 Avroliner', 'wtc' => 'M'],
'AR8' => ['icao' => 'RJ85', 'description' => 'Avro RJ85 Avroliner', 'wtc' => 'M'],
'ARJ' => ['icao' => 'n/a', 'description' => 'Avro RJ70 / RJ85 / RJ100 Avroliner', 'wtc' => 'M'],
'ARX' => ['icao' => 'n/a', 'description' => 'Avro RJX85 / RJX100', 'wtc' => 'M'],
'AT4' => ['icao' => 'AT43', 'description' => 'Aerospatiale/Alenia ATR 42-300 / 320', 'wtc' => 'M'],
'AT5' => ['icao' => 'AT45', 'description' => 'Aerospatiale/Alenia ATR 42-500', 'wtc' => 'M'],
'AT7' => ['icao' => 'AT72', 'description' => 'Aerospatiale/Alenia ATR 72', 'wtc' => 'M'],
'ATD' => ['icao' => 'AT44', 'description' => 'Aerospatiale/Alenia ATR 42-400', 'wtc' => 'M'],
'ATF' => ['icao' => 'AT72', 'description' => 'Aerospatiale/Alenia ATR 72 Freighter', 'wtc' => 'M'],
'ATP' => ['icao' => 'ATP', 'description' => 'British Aerospace ATP', 'wtc' => 'M'],
'ATR' => ['icao' => 'n/a', 'description' => 'Aerospatiale/Alenia ATR 42 / ATR 72', 'wtc' => 'M'],
'AX1' => ['icao' => 'RX1H', 'description' => 'Avro RJX100', 'wtc' => 'M'],
'AX8' => ['icao' => 'RX85', 'description' => 'Avro RJX85', 'wtc' => 'M'],
'B11' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven / RomBAC One Eleven', 'wtc' => 'M'],
'B12' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 200', 'wtc' => 'M'],
'B13' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 300', 'wtc' => 'M'],
'B14' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 400/475', 'wtc' => 'M'],
'B15' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 500 / RomBAC One Eleven', 'wtc' => 'M'],
'B72' => ['icao' => 'B720', 'description' => 'Boeing 720B pax', 'wtc' => 'M'],
'BE1' => ['icao' => 'B190', 'description' => 'Beechcraft 1900/1900C/1900D', 'wtc' => 'M'],
'BE2' => ['icao' => 'n/a', 'description' => 'Beechcraft twin piston engines', 'wtc' => 'L'],
'BEC' => ['icao' => 'n/a', 'description' => 'Beechcraft light aircraft', 'wtc' => 'L'],
'BEH' => ['icao' => 'B190', 'description' => 'Beechcraft 1900D', 'wtc' => 'M'],
'BEP' => ['icao' => 'n/a', 'description' => 'Beechcraft light aircraft - single engine', 'wtc' => 'L'],
'BES' => ['icao' => 'B190', 'description' => 'Beechcraft 1900/1900C', 'wtc' => 'M'],
'BET' => ['icao' => 'n/a', 'description' => 'Beechcraft light aircraft - twin turboprop engine', 'wtc' => 'L'],
'BH2' => ['icao' => 'n/a', 'description' => 'Bell Helicopters', 'wtc' => 'n/a'],
'BNI' => ['icao' => 'BN2P', 'description' => 'Pilatus Britten-Norman BN-2A/B Islander', 'wtc' => 'L'],
'BNT' => ['icao' => 'TRIS', 'description' => 'Pilatus Britten-Norman BN-2A Mk III Trislander', 'wtc' => 'L'],
'BUS' => ['icao' => 'n/a', 'description' => 'Bus', 'wtc' => 'n/a'],
'C27' => ['icao' => 'AJ27', 'description' => 'COMAC ARJ21', 'wtc' => 'M'],
'CCJ' => ['icao' => 'CL60', 'description' => 'Canadair Challenger', 'wtc' => 'M'],
'CCX' => ['icao' => 'GLEX', 'description' => 'Canadair Global Express', 'wtc' => 'M'],
'CD2' => ['icao' => 'NOMA', 'description' => 'Government Aircraft Factories N22B / N24A Nomad', 'wtc' => 'L'],
'CL4' => ['icao' => 'CL44', 'description' => 'Canadair CL-44', 'wtc' => 'M'],
'919' => ['icao' => 'C919', 'description' => 'Comac C919 Passenger', 'wtc' => 'M'],
'CN1' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - single piston engine', 'wtc' => 'L'],
'CN2' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - twin piston engines', 'wtc' => 'L'],
'CN7' => ['icao' => 'C750', 'description' => 'Cessna 750 Citation X', 'wtc' => 'M'],
'CNA' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft', 'wtc' => 'L'],
'CNC' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - single turboprop engine', 'wtc' => 'L'],
'CNJ' => ['icao' => 'n/a', 'description' => 'Cessna Citation', 'wtc' => 'L'],
'CNT' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - twin turboprop engines', 'wtc' => 'L'],
'CR1' => ['icao' => 'CRJ1', 'description' => 'Canadair Regional Jet 100', 'wtc' => 'M'],
'CR2' => ['icao' => 'CRJ2', 'description' => 'Canadair Regional Jet 200', 'wtc' => 'M'],
'CR7' => ['icao' => 'CRJ7', 'description' => 'Canadair Regional Jet 700', 'wtc' => 'M'],
'CR9' => ['icao' => 'CRJ9', 'description' => 'Canadair Regional Jet 900', 'wtc' => 'M'],
'CRA' => ['icao' => 'CRJ9', 'description' => 'Canadair Regional Jet 705', 'wtc' => 'M'],
'CRF' => ['icao' => 'n/a', 'description' => 'Canadair Regional Jet Freighter', 'wtc' => 'M'],
'CRJ' => ['icao' => 'n/a', 'description' => 'Canadair Regional Jet', 'wtc' => 'M'],
'CRK' => ['icao' => 'CRJX', 'description' => 'Canadair Regional Jet 1000', 'wtc' => 'M'],
'CRV' => ['icao' => 'S210', 'description' => 'Aerospatiale (Sud Aviation) Se.210 Caravelle', 'wtc' => 'M'],
'CS1' => ['icao' => 'BCS1', 'description' => 'Bombardier C Series CS100', 'wtc' => 'M'],
'CS2' => ['icao' => 'C212', 'description' => 'CASA / IPTN 212 Aviocar', 'wtc' => 'M'],
'CS3' => ['icao' => 'BCS3', 'description' => 'Bombardier C Series CS300', 'wtc' => 'M'],
'CS5' => ['icao' => 'CN35', 'description' => 'CASA / IPTN CN-235', 'wtc' => 'M'],
'CV2' => ['icao' => 'CVLP', 'description' => 'Convair CV-240 pax', 'wtc' => 'M'],
'CV4' => ['icao' => 'CVLP', 'description' => 'Convair CV-440 Metropolitan pax', 'wtc' => 'M'],
'CV5' => ['icao' => 'CVLT', 'description' => 'Convair CV-580 pax', 'wtc' => 'M'],
'CVF' => ['icao' => 'n/a', 'description' => 'Convair CV-240 / 440 / 580 / 600 / 640 Freighter', 'wtc' => 'M'],
'CVR' => ['icao' => 'n/a', 'description' => 'Convair CV-240 / 440 / 580 / 600 / 640 pax', 'wtc' => 'M'],
'CVV' => ['icao' => 'CVLP', 'description' => 'Convair CV-240 Freighter', 'wtc' => 'M'],
'CVX' => ['icao' => 'CVLP', 'description' => 'Convair CV-440 Freighter', 'wtc' => 'M'],
'CVY' => ['icao' => 'CVLT', 'description' => 'Convair CV-580 / 600 / 640 Freighter', 'wtc' => 'M'],
'CWC' => ['icao' => 'C46', 'description' => 'Curtiss C-46 Commando', 'wtc' => 'M'],
'D10' => ['icao' => 'DC10', 'description' => 'Douglas DC-10 pax', 'wtc' => 'H'],
'D11' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-10/15 pax', 'wtc' => 'H'],
'D1C' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-30/40 pax', 'wtc' => 'H'],
'D1F' => ['icao' => 'DC10', 'description' => 'Douglas DC-10 all Freighters', 'wtc' => 'H'],
'D1M' => ['icao' => 'DC10', 'description' => 'Douglas DC-10 all Combi models', 'wtc' => 'H'],
'D1X' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-10 Freighter', 'wtc' => 'H'],
'D1Y' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-30 / 40 Freighters', 'wtc' => 'H'],
'D28' => ['icao' => 'D228', 'description' => 'Fairchild Dornier Do.228', 'wtc' => 'L'],
'D38' => ['icao' => 'D328', 'description' => 'Fairchild Dornier Do.328', 'wtc' => 'M'],
'D3F' => ['icao' => 'DC3', 'description' => 'Douglas DC-3 Freighter', 'wtc' => 'M'],
'D6F' => ['icao' => 'DC6', 'description' => 'Douglas DC-6A/B/C Freighter', 'wtc' => 'M'],
'D8F' => ['icao' => 'n/a', 'description' => 'Douglas DC-8 all Freighters', 'wtc' => 'H'],
'D8L' => ['icao' => 'DC86', 'description' => 'Douglas DC-8-62 pax', 'wtc' => 'H'],
'D8M' => ['icao' => 'n/a', 'description' => 'Douglas DC-8 all Combi models', 'wtc' => 'H'],
'D8Q' => ['icao' => 'DC87', 'description' => 'Douglas DC-8-72 pax', 'wtc' => 'H'],
'D8T' => ['icao' => 'DC85', 'description' => 'Douglas DC-8-50 Freighter', 'wtc' => 'H'],
'D8X' => ['icao' => 'n/a', 'description' => 'Douglas DC-8-61 / 62 / 63 Freighters', 'wtc' => 'H'],
'D8Y' => ['icao' => 'DC87', 'description' => 'Douglas DC-8-71 / 72 / 73 Freighters', 'wtc' => 'H'],
'D91' => ['icao' => 'DC91', 'description' => 'Douglas DC-9-10 pax', 'wtc' => 'M'],
'D92' => ['icao' => 'DC92', 'description' => 'Douglas DC-9-20 pax', 'wtc' => 'M'],
'D93' => ['icao' => 'DC93', 'description' => 'Douglas DC-9-30 pax', 'wtc' => 'M'],
'D94' => ['icao' => 'DC94', 'description' => 'Douglas DC-9-40 pax', 'wtc' => 'M'],
'D95' => ['icao' => 'DC95', 'description' => 'Douglas DC-9-50 pax', 'wtc' => 'M'],
'D9C' => ['icao' => 'DC93', 'description' => 'Douglas DC-9-30 Freighter', 'wtc' => 'M'],
'D9D' => ['icao' => 'DC94', 'description' => 'Douglas DC-9-40 Freighter', 'wtc' => 'M'],
'D9F' => ['icao' => 'n/a', 'description' => 'Douglas DC-9 all Freighters', 'wtc' => 'M'],
'D9X' => ['icao' => 'DC91', 'description' => 'Douglas DC-9-10 Freighter', 'wtc' => 'M'],
'DC3' => ['icao' => 'DC3', 'description' => 'Douglas DC-3 pax', 'wtc' => 'M'],
'DC4' => ['icao' => 'DC4', 'description' => 'Douglas DC-4 pax', 'wtc' => 'M'],
'DC6' => ['icao' => 'DC6', 'description' => 'Douglas DC6A/B pax', 'wtc' => 'M'],
'DC8' => ['icao' => 'n/a', 'description' => 'Douglas DC-8 all pax models', 'wtc' => 'H'],
'DC9' => ['icao' => 'DC9', 'description' => 'Douglas DC-9 all pax models', 'wtc' => 'M'],
'DF2' => ['icao' => 'n/a', 'description' => 'Dassault (Breguet Mystere) Falcon 10 / 100 / 20 / 200 / 2000', 'wtc' => 'M'],
'DF3' => ['icao' => 'n/a', 'description' => 'Dassault (Breguet Mystere) Falcon 50 / 900', 'wtc' => 'M'],
'DFL' => ['icao' => 'n/a', 'description' => 'Dassault (Breguet Mystere) Falcon', 'wtc' => 'M'],
'DH1' => ['icao' => 'DH8A', 'description' => 'De Havilland Canada DHC-8-100 Dash 8 / 8Q', 'wtc' => 'M'],
'DH2' => ['icao' => 'DH8B', 'description' => 'De Havilland Canada DHC-8-200 Dash 8 / 8Q', 'wtc' => 'M'],
'DH3' => ['icao' => 'DH8C', 'description' => 'De Havilland Canada DHC-8-300 Dash 8 / 8Q', 'wtc' => 'M'],
'DH4' => ['icao' => 'DH8D', 'description' => 'De Havilland Canada DHC-8-400 Dash 8Q', 'wtc' => 'M'],
'DH7' => ['icao' => 'DHC7', 'description' => 'De Havilland Canada DHC-7 Dash 7', 'wtc' => 'M'],
'DH8' => ['icao' => 'n/a', 'description' => 'De Havilland Canada DHC-8 Dash 8 all models', 'wtc' => 'M'],
'DHB' => ['icao' => 'n/a', 'description' => 'De Havilland Canada DHC-2 Beaver / Turbo Beaver', 'wtc' => 'L'],
'DHC' => ['icao' => 'DHC4', 'description' => 'De Havilland Canada DHC-4 Caribou', 'wtc' => 'M'],
'DHD' => ['icao' => 'DOVE', 'description' => 'De Havilland DH.104 Dove', 'wtc' => 'L'],
'DHH' => ['icao' => 'HERN', 'description' => 'De Havilland DH.114 Heron', 'wtc' => 'L'],
'DHL' => ['icao' => 'DHC3', 'description' => 'De Havilland Canada DHC-3 Turbo Otter', 'wtc' => 'L'],
'DHO' => ['icao' => 'DHC3', 'description' => 'De Havilland Canada DHC-3 Otter / Turbo Otter', 'wtc' => 'L'],
'DHP' => ['icao' => 'DHC2', 'description' => 'De Havilland Canada DHC-2 Beaver', 'wtc' => 'L'],
'DHR' => ['icao' => 'DH2T', 'description' => 'De Havilland Canada DHC-2 Turbo-Beaver', 'wtc' => 'L'],
'DHS' => ['icao' => 'DHC3', 'description' => 'De Havilland Canada DHC-3 Otter', 'wtc' => 'L'],
'DHT' => ['icao' => 'DHC6', 'description' => 'De Havilland Canada DHC-6 Twin Otter', 'wtc' => 'L'],
'E70' => ['icao' => 'E170', 'description' => 'Embraer 170', 'wtc' => 'M'],
'E75' => ['icao' => 'E75L', 'description' => 'Embraer 175 (Short wing / Long Wing)', 'wtc' => 'M'],
'E90' => ['icao' => 'E190', 'description' => 'Embraer 190', 'wtc' => 'M'],
'E95' => ['icao' => 'E195', 'description' => 'Embraer 195', 'wtc' => 'M'],
'EC3' => ['icao' => 'EC30', 'description' => 'Eurocopter EC.130', 'wtc' => 'n/a'],
'EM2' => ['icao' => 'E120', 'description' => 'Embraer EMB.120 Brasilia', 'wtc' => 'L'],
'EMB' => ['icao' => 'E110', 'description' => 'Embraer EMB.110 Bandeirnate', 'wtc' => 'M'],
'EMJ' => ['icao' => 'n/a', 'description' => 'Embraer 170/190', 'wtc' => 'M'],
'ER3' => ['icao' => 'E135', 'description' => 'Embraer RJ135 / Legacy 600 / Legacy 650', 'wtc' => 'M'],
'ER4' => ['icao' => 'E145', 'description' => 'Embraer RJ145 Amazon', 'wtc' => 'M'],
'ERD' => ['icao' => 'n/a', 'description' => 'Embraer RJ140', 'wtc' => 'M'],
'ERJ' => ['icao' => 'n/a', 'description' => 'Embraer RJ135 / RJ140 / RJ145', 'wtc' => 'M'],
'F21' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 1000', 'wtc' => 'M'],
'F22' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 2000', 'wtc' => 'M'],
'F23' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 3000', 'wtc' => 'M'],
'F24' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 4000', 'wtc' => 'M'],
'F27' => ['icao' => 'F27', 'description' => 'Fokker F.27 Friendship / Fairchild F.27', 'wtc' => 'M'],
'F28' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship', 'wtc' => 'M'],
'F50' => ['icao' => 'F50', 'description' => 'Fokker 50', 'wtc' => 'M'],
'F5F' => ['icao' => 'F50', 'description' => 'Fokker 50 Freighter', 'wtc' => 'M'],
'F70' => ['icao' => 'F70', 'description' => 'Fokker 70', 'wtc' => 'M'],
'FA7' => ['icao' => 'n/a', 'description' => 'Fairchild Dornier 728JET', 'wtc' => 'M'],
'FK7' => ['icao' => 'F27', 'description' => 'Fairchild FH.227', 'wtc' => 'M'],
'FRJ' => ['icao' => 'J328', 'description' => 'Fairchild Dornier 328JET', 'wtc' => 'M'],
'GRG' => ['icao' => 'G21', 'description' => 'Grumman G.21 Goose', 'wtc' => 'L'],
'GRJ' => ['icao' => 'n/a', 'description' => 'Gulfstream Aerospace G-1159 Gulfstream II / III / IV / V', 'wtc' => 'M'],
'GRM' => ['icao' => 'G73T', 'description' => 'Grumman G.73 Turbo Mallard', 'wtc' => 'L'],
'GRS' => ['icao' => 'G159', 'description' => 'Gulfstream Aerospace G-159 Gulfstream I', 'wtc' => 'M'],
'H25' => ['icao' => 'n/a', 'description' => 'British Aerospace (Hawker Siddeley) HS.125', 'wtc' => 'M'],
'HEC' => ['icao' => 'COUC', 'description' => 'Helio H-250 Courier / H-295 / 385 Super Courier', 'wtc' => 'L'],
'HOV' => ['icao' => 'n/a', 'description' => 'Hovercraft', 'wtc' => 'n/a'],
'HS7' => ['icao' => 'A748', 'description' => 'Hawker Siddeley HS.748', 'wtc' => 'M'],
'I14' => ['icao' => 'I114', 'description' => 'Ilyushin IL114', 'wtc' => 'M'],
'I93' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96-300 pax', 'wtc' => 'H'],
'I9F' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96 Freighters', 'wtc' => 'H'],
'I9M' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96M pax', 'wtc' => 'H'],
'I9X' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96-300 Freighter', 'wtc' => 'H'],
'I9Y' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96T Freighter', 'wtc' => 'H'],
'IL6' => ['icao' => 'IL62', 'description' => 'Ilyushin IL62', 'wtc' => 'H'],
'IL7' => ['icao' => 'IL76', 'description' => 'Ilyushin IL76', 'wtc' => 'H'],
'IL8' => ['icao' => 'IL18', 'description' => 'Ilyushin IL18', 'wtc' => 'M'],
'IL9' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96 pax', 'wtc' => 'H'],
'ILW' => ['icao' => 'IL86', 'description' => 'Ilyushin IL86', 'wtc' => 'H'],
'J31' => ['icao' => 'JS31', 'description' => 'British Aerospace Jetstream 31', 'wtc' => 'L'],
'J32' => ['icao' => 'JS32', 'description' => 'British Aerospace Jetstream 32', 'wtc' => 'L'],
'J41' => ['icao' => 'JS41', 'description' => 'British Aerospace Jetstream 41', 'wtc' => 'M'],
'JST' => ['icao' => 'n/a', 'description' => 'British Aerospace Jetstream 31 / 32 / 41', 'wtc' => 'L/M'],
'JU5' => ['icao' => 'JU52', 'description' => 'Junkers Ju52/3M', 'wtc' => 'M'],
'L10' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 Tristar pax', 'wtc' => 'H'],
'L11' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 1 / 50 / 100 / 150 / 200 / 250 Tristar pax', 'wtc' => 'H'],
'L15' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 500 Tristar pax', 'wtc' => 'H'],
'L1F' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 Tristar Freighter', 'wtc' => 'H'],
'L49' => ['icao' => 'CONI', 'description' => 'Lockheed L-1049 Super Constellation', 'wtc' => 'M'],
'L4T' => ['icao' => 'L410', 'description' => 'LET 410', 'wtc' => 'L'],
'LCH' => ['icao' => 'n/a', 'description' => 'Launch - Boat', 'wtc' => 'n/a'],
'LMO' => ['icao' => 'n/a', 'description' => 'Limousine', 'wtc' => 'n/a'],
'LOE' => ['icao' => 'L188', 'description' => 'Lockheed L-188 Electra pax', 'wtc' => 'M'],
'LOF' => ['icao' => 'L188', 'description' => 'Lockheed L-188 Electra Freighter', 'wtc' => 'M'],
'LOH' => ['icao' => 'C130', 'description' => 'Lockheed L-182 / 282 / 382 (L-100) Hercules', 'wtc' => 'M'],
'LOM' => ['icao' => 'L188', 'description' => 'Lockheed L-188 Electra Mixed Configuration', 'wtc' => 'M'],
'LRJ' => ['icao' => 'n/a', 'description' => 'Gates Learjet', 'wtc' => 'M'],
'M11' => ['icao' => 'MD11', 'description' => 'McDonnell Douglas MD11 pax', 'wtc' => 'H'],
'M1F' => ['icao' => 'MD11', 'description' => 'McDonnell Douglas MD11 Freighter', 'wtc' => 'H'],
'M1M' => ['icao' => 'MD11', 'description' => 'McDonnell Douglas MD11 Mixed Configuration', 'wtc' => 'H'],
'M80' => ['icao' => 'MD80', 'description' => 'McDonnell Douglas MD80', 'wtc' => 'M'],
'M81' => ['icao' => 'MD81', 'description' => 'McDonnell Douglas MD81', 'wtc' => 'M'],
'M82' => ['icao' => 'MD82', 'description' => 'McDonnell Douglas MD82', 'wtc' => 'M'],
'M83' => ['icao' => 'MD83', 'description' => 'McDonnell Douglas MD83', 'wtc' => 'M'],
'M87' => ['icao' => 'MD87', 'description' => 'McDonnell Douglas MD87', 'wtc' => 'M'],
'M88' => ['icao' => 'MD88', 'description' => 'McDonnell Douglas MD88', 'wtc' => 'M'],
'M90' => ['icao' => 'MD90', 'description' => 'McDonnell Douglas MD90', 'wtc' => 'M'],
'MBH' => ['icao' => 'B105', 'description' => 'Eurocopter (MBB) Bo.105', 'wtc' => 'n/a'],
'MD9' => ['icao' => 'EXPL', 'description' => 'MD Helicopters MD900 Explorer', 'wtc' => 'n/a'],
'MIH' => ['icao' => 'MI8', 'description' => 'MIL Mi-8 / Mi-17 / Mi-171 / Mil-172', 'wtc' => 'n/a'],
'MU2' => ['icao' => 'MU2', 'description' => 'Mitsubishi Mu-2', 'wtc' => 'L'],
'ND2' => ['icao' => 'N262', 'description' => 'Aerospatiale (Nord) 262', 'wtc' => 'M'],
'NDC' => ['icao' => 'S601', 'description' => 'Aerospatiale SN.601 Corvette', 'wtc' => 'L'],
'NDE' => ['icao' => 'n/a', 'description' => 'Eurocopter (Aerospatiale) AS350 Ecureuil / AS355 Ecureuil 2', 'wtc' => 'n/a'],
'NDH' => ['icao' => 'S65C', 'description' => 'Eurocopter (Aerospatiale) SA365C / SA365N Dauphin 2', 'wtc' => 'n/a'],
'PA1' => ['icao' => 'n/a', 'description' => 'Piper light aircraft - single piston engine', 'wtc' => 'L'],
'PA2' => ['icao' => 'n/a', 'description' => 'Piper light aircraft - twin piston engines', 'wtc' => 'L'],
'PAG' => ['icao' => 'n/a', 'description' => 'Piper light aircraft', 'wtc' => 'L'],
'PAT' => ['icao' => 'n/a', 'description' => 'Piper light aircraft - twin turboprop engines', 'wtc' => 'L'],
'PL2' => ['icao' => 'PC12', 'description' => 'Pilatus PC-12', 'wtc' => 'L'],
'PL6' => ['icao' => 'PC6T', 'description' => 'Pilatus PC-6 Turbo Porter', 'wtc' => 'L'],
'PN6' => ['icao' => 'P68', 'description' => 'Partenavia P.68', 'wtc' => 'L'],
'RFS' => ['icao' => 'n/a', 'description' => 'Road Feeder Service - Cargo Truck', 'wtc' => 'n/a'],
'S20' => ['icao' => 'SB20', 'description' => 'Saab 2000', 'wtc' => 'M'],
'S58' => ['icao' => 'S58T', 'description' => 'Sikorsky S-58T', 'wtc' => 'n/a'],
'S61' => ['icao' => 'S61', 'description' => 'Sikorsky S-61', 'wtc' => 'n/a'],
'S76' => ['icao' => 'S76', 'description' => 'Sikorsky S-76', 'wtc' => 'n/a'],
'SF3' => ['icao' => 'SF34', 'description' => 'Saab SF340', 'wtc' => 'M'],
'SFB' => ['icao' => 'SF34', 'description' => 'Saab SF340B', 'wtc' => 'M'],
'SFF' => ['icao' => 'SF34', 'description' => 'Saab SF340 Freighter', 'wtc' => 'M'],
'SH3' => ['icao' => 'SH33', 'description' => 'Shorts SD.330', 'wtc' => 'M'],
'SH6' => ['icao' => 'SH36', 'description' => 'Shorts SD.360', 'wtc' => 'M'],
'SHB' => ['icao' => 'BELF', 'description' => 'Shorts SC-5 Belfast', 'wtc' => 'M'],
'SHS' => ['icao' => 'SC7', 'description' => 'Shorts SC-7 Skyvan', 'wtc' => 'L'],
'SSC' => ['icao' => 'CONC', 'description' => 'Aerospatiale/BAC Concorde', 'wtc' => 'H'],
'SU1' => ['icao' => '', 'description' => 'Sukhoi Superjet 100', 'wtc' => 'M'],
'SU7' => ['icao' => '', 'description' => 'Sukhoi Superjet 100-75', 'wtc' => 'M'],
'SU9' => ['icao' => 'SU95', 'description' => 'Sukhoi Superjet 100-95', 'wtc' => 'M'],
'SWM' => ['icao' => 'n/a', 'description' => 'Fairchild (Swearingen) SA26 / SA226 / SA227 Metro / Merlin / Expediter', 'wtc' => 'L'],
'T20' => ['icao' => 'T204', 'description' => 'Tupolev Tu-204 / Tu-214', 'wtc' => 'M'],
'T2F' => ['icao' => 'T204', 'description' => 'Tupolev Tu-204 Freighter', 'wtc' => 'M'],
'TRN' => ['icao' => 'n/a', 'description' => 'Train', 'wtc' => 'n/a'],
'TU3' => ['icao' => 'T134', 'description' => 'Tupolev Tu134', 'wtc' => 'M'],
'TU5' => ['icao' => 'T154', 'description' => 'Tupolev Tu154', 'wtc' => 'M'],
'VCV' => ['icao' => 'VISC', 'description' => 'Vickers Viscount', 'wtc' => 'M'],
'WWP' => ['icao' => 'WW24', 'description' => 'Israel Aircraft Industries 1124 Westwind', 'wtc' => 'M'],
'YK2' => ['icao' => 'YK42', 'description' => 'Yakovlev Yak 42', 'wtc' => 'M'],
'YK4' => ['icao' => 'YK40', 'description' => 'Yakovlev Yak 40', 'wtc' => 'M'],
'YN2' => ['icao' => 'Y12', 'description' => 'Harbin Yunshuji Y12', 'wtc' => 'M'],
'YN7' => ['icao' => 'AN24', 'description' => 'Xian Yunshuji Y7', 'wtc' => 'M'],
'YS1' => ['icao' => 'YS11', 'description' => 'NAMC YS-11', 'wtc' => 'M'],
];
/**
* Run the migrations.
*/
public function up(): void
{
//
Achievement::whereInternalName('fun_challenges.canadian_provinces')->update(['difficulty_description' => null]);
Aircraft::create([
'designator' => 'A330',
'manufacturer_code' => 'AIRBUS',
'model_full_name' => 'A-330 Family',
'aircraft_description' => 'LandPlane',
'engine_type' => 'Jet',
'engine_count' => 2,
'wtc' => 'H',
]);
Aircraft::create([
'designator' => 'A340',
'manufacturer_code' => 'AIRBUS',
'model_full_name' => 'A-340 Family',
'aircraft_description' => 'LandPlane',
'engine_type' => 'Jet',
'engine_count' => 4,
'wtc' => 'H',
]);
Schema::table('aircraft', function (Blueprint $table) {
$table->string('iata_code', 10)->nullable()->after('designator');
});
$updated = 0;
$unmatched = [];
foreach ($this->aircraft_codes as $iata => $data) {
$icao = $data['icao'];
if (empty($icao) || $icao === 'n/a') {
continue;
}
$rows = DB::table('aircraft')->where('designator', $icao)->update([
'iata_code' => $iata,
]);
if ($rows === 0) {
$unmatched[] = "{$iata}{$icao} ({$data['description']})";
}
$updated += $rows;
}
echo "Updated {$updated} aircraft record(s) with IATA codes.\n";
if (!empty($unmatched)) {
echo "\n=== IATA codes with no matching ICAO in aircraft table ===\n";
foreach ($unmatched as $line) {
echo " {$line}\n";
}
echo "==========================================================\n";
}
}
/**
@@ -0,0 +1,496 @@
<?php
use App\Models\IataEquipmentCode;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
protected array $aircraft_codes = [
'100' => ['icao' => 'F100', 'description' => 'Fokker 100', 'wtc' => 'M'],
'141' => ['icao' => 'B461', 'description' => 'BAe 146-100 Pax', 'wtc' => 'M'],
'142' => ['icao' => 'B462', 'description' => 'BAe 146-200 Pax', 'wtc' => 'M'],
'143' => ['icao' => 'B463', 'description' => 'BAe 146-300 Pax', 'wtc' => 'M'],
'146' => ['icao' => '', 'description' => 'BAe 146 all pax models', 'wtc' => 'M'],
'14F' => ['icao' => '', 'description' => 'BAe 146 Freighter (-100/200/300QT & QC)', 'wtc' => 'M'],
'14X' => ['icao' => 'B461', 'description' => 'BAe 146 Freighter (-100QT & QC)', 'wtc' => 'M'],
'14Y' => ['icao' => 'B462', 'description' => 'BAe 146 Freighter (-200QT & QC)', 'wtc' => 'M'],
'14Z' => ['icao' => 'B463', 'description' => 'BAe 146 Freighter (-200QT & QC)', 'wtc' => 'M'],
'290' => ['icao' => 'E290', 'description' => 'Embraer E190-E2', 'wtc' => 'M'],
'295' => ['icao' => 'E295', 'description' => 'Embraer E195-E2', 'wtc' => 'M'],
'221' => ['icao' => 'BCS1', 'description' => 'Airbus A220-100', 'wtc' => 'M'],
'223' => ['icao' => 'BCS3', 'description' => 'Airbus A220-200', 'wtc' => 'M'],
'310' => ['icao' => 'A310', 'description' => 'Airbus A310 all pax models', 'wtc' => 'H'],
'312' => ['icao' => 'A310', 'description' => 'Airbus A310-200 pax', 'wtc' => 'H'],
'313' => ['icao' => 'A310', 'description' => 'Airbus A310-300 pax', 'wtc' => 'H'],
'318' => ['icao' => 'A318', 'description' => 'Airbus A318', 'wtc' => 'M'],
'319' => ['icao' => 'A319', 'description' => 'Airbus A319 Ceo', 'wtc' => 'M'],
'31F' => ['icao' => 'A310', 'description' => 'Airbus A310 Freighter', 'wtc' => 'M'],
'31N' => ['icao' => 'A19N', 'description' => 'Airbus A319 Neo', 'wtc' => 'M'],
'31X' => ['icao' => 'A310', 'description' => 'Airbus A310-200 Freighter', 'wtc' => 'M'],
'31Y' => ['icao' => 'A310', 'description' => 'Airbus A310-300 Freighter', 'wtc' => 'M'],
'320' => ['icao' => 'A320', 'description' => 'Airbus A320-100/200 Ceo', 'wtc' => 'M'],
'321' => ['icao' => 'A321', 'description' => 'Airbus A321-100/200 Ceo', 'wtc' => 'M'],
'32A' => ['icao' => 'A320', 'description' => 'Airbus A320-200 Ceo (Sharklets)', 'wtc' => 'M'],
'32C' => ['icao' => 'A318', 'description' => 'Airbus A318 (Sharklets)', 'wtc' => 'M'],
'32D' => ['icao' => 'A319', 'description' => 'Airbus A319 Ceo (Sharklets)', 'wtc' => 'M'],
'32N' => ['icao' => 'A20N', 'description' => 'Airbus A320-200 Neo', 'wtc' => 'M'],
'32Q' => ['icao' => 'A21N', 'description' => 'Airbus A321-200 Neo', 'wtc' => 'M'],
'32S' => ['icao' => 'n/a', 'description' => 'Airbus A318/319/320/321', 'wtc' => 'M'],
'330' => ['icao' => 'A330', 'description' => 'Airbus A330 all models', 'wtc' => 'H'],
'332' => ['icao' => 'A332', 'description' => 'Airbus A330-200', 'wtc' => 'H'],
'333' => ['icao' => 'A333', 'description' => 'Airbus A330-300', 'wtc' => 'H'],
'338' => ['icao' => 'A338', 'description' => 'Airbus A330-800 Neo', 'wtc' => 'H'],
'339' => ['icao' => 'A339', 'description' => 'Airbus A330-900 Neo', 'wtc' => 'H'],
'33X' => ['icao' => 'A332', 'description' => 'Airbus A330-200 Freighter', 'wtc' => 'H'],
'340' => ['icao' => 'A340', 'description' => 'Airbus A340 all models', 'wtc' => 'H'],
'342' => ['icao' => 'A342', 'description' => 'Airbus A340-200', 'wtc' => 'H'],
'343' => ['icao' => 'A343', 'description' => 'Airbus A340-300', 'wtc' => 'H'],
'345' => ['icao' => 'A345', 'description' => 'Airbus A340-500', 'wtc' => 'H'],
'346' => ['icao' => 'A346', 'description' => 'Airbus A340-600', 'wtc' => 'H'],
'351' => ['icao' => 'A35K', 'description' => 'Airbus A350-1000', 'wtc' => 'H'],
'359' => ['icao' => 'A359', 'description' => 'Airbus A350-900', 'wtc' => 'H'],
'380' => ['icao' => 'A388', 'description' => 'Airbus A380 pax', 'wtc' => 'J'],
'38F' => ['icao' => '', 'description' => 'Airbus A380 Freighter', 'wtc' => 'J'],
'703' => ['icao' => 'B703', 'description' => 'Boeing 707-300 pax', 'wtc' => 'H'],
'707' => ['icao' => 'n/a', 'description' => 'Boeing 707/720 all pax models', 'wtc' => 'H'],
'70F' => ['icao' => 'B703', 'description' => 'Boeing 707 Freighter', 'wtc' => 'H'],
'70M' => ['icao' => 'B703', 'description' => 'Boeing 707 Combi', 'wtc' => 'H'],
'717' => ['icao' => 'B712', 'description' => 'Boeing 717', 'wtc' => 'M'],
'721' => ['icao' => 'B721', 'description' => 'Boeing 727-100 pax', 'wtc' => 'M'],
'722' => ['icao' => 'B722', 'description' => 'Boeing 727-200 pax', 'wtc' => 'M'],
'727' => ['icao' => 'n/a', 'description' => 'Boeing 727 all pax models', 'wtc' => 'M'],
'72B' => ['icao' => 'B721', 'description' => 'Boeing 727-100 Mixed Configuration', 'wtc' => 'M'],
'72C' => ['icao' => 'B722', 'description' => 'Boeing 727-200 Mixed Configuration', 'wtc' => 'M'],
'72F' => ['icao' => 'n/a', 'description' => 'Boeing 727 Freighter (-100/200)', 'wtc' => 'M'],
'72M' => ['icao' => 'n/a', 'description' => 'Boeing 727 Combi', 'wtc' => 'M'],
'72S' => ['icao' => 'B722', 'description' => 'Boeing 727-200 Advanced pax', 'wtc' => 'M'],
'72W' => ['icao' => 'B721', 'description' => 'Boeing 727-200 (winglets) pax', 'wtc' => 'M'],
'72X' => ['icao' => 'B721', 'description' => 'Boeing 727-100 Freighter', 'wtc' => 'M'],
'72Y' => ['icao' => 'B722', 'description' => 'Boeing 727-200 Freighter', 'wtc' => 'M'],
'731' => ['icao' => 'B731', 'description' => 'Boeing 737-100 pax', 'wtc' => 'M'],
'732' => ['icao' => 'B732', 'description' => 'Boeing 737-200 pax', 'wtc' => 'M'],
'733' => ['icao' => 'B733', 'description' => 'Boeing 737-300 pax', 'wtc' => 'M'],
'734' => ['icao' => 'B734', 'description' => 'Boeing 737-400 pax', 'wtc' => 'M'],
'735' => ['icao' => 'B735', 'description' => 'Boeing 737-500 pax', 'wtc' => 'M'],
'736' => ['icao' => 'B736', 'description' => 'Boeing 737-600 pax', 'wtc' => 'M'],
'737' => ['icao' => 'n/a', 'description' => 'Boeing 737 all pax models', 'wtc' => 'M'],
'738' => ['icao' => 'B738', 'description' => 'Boeing 737-800 pax', 'wtc' => 'M'],
'739' => ['icao' => 'B739', 'description' => 'Boeing 737-900 pax', 'wtc' => 'M'],
'73C' => ['icao' => 'B733', 'description' => 'Boeing 737-300 (winglets) pax', 'wtc' => 'M'],
'73E' => ['icao' => 'B735', 'description' => 'Boeing 737-500 (winglets) pax', 'wtc' => 'M'],
'73F' => ['icao' => 'n/a', 'description' => 'Boeing 737 all Freighter models', 'wtc' => 'M'],
'73G' => ['icao' => 'B737', 'description' => 'Boeing 737-700 pax', 'wtc' => 'M'],
'73H' => ['icao' => 'B738', 'description' => 'Boeing 737-800 (winglets) pax', 'wtc' => 'M'],
'73J' => ['icao' => 'B739', 'description' => 'Boeing 737-900 (winglets) pax', 'wtc' => 'M'],
'73L' => ['icao' => 'B732', 'description' => 'Boeing 737-200 Combi', 'wtc' => 'M'],
'73M' => ['icao' => 'n/a', 'description' => 'Boeing 737 Combi', 'wtc' => 'M'],
'73P' => ['icao' => 'B734', 'description' => 'Boeing 737-400 Freighter', 'wtc' => 'M'],
'73Q' => ['icao' => 'B734', 'description' => 'Boeing 737-400 Combi', 'wtc' => 'M'],
'73R' => ['icao' => 'B737', 'description' => 'Boeing 737-700 Combi', 'wtc' => 'M'],
'73W' => ['icao' => 'B737', 'description' => 'Boeing 737-700 (winglets) pax', 'wtc' => 'M'],
'73X' => ['icao' => 'B732', 'description' => 'Boeing 737-200 Freighter', 'wtc' => 'M'],
'73Y' => ['icao' => 'B733', 'description' => 'Boeing 737-300 Freighter', 'wtc' => 'M'],
'741' => ['icao' => 'B741', 'description' => 'Boeing 747-100 pax', 'wtc' => 'H'],
'742' => ['icao' => 'B742', 'description' => 'Boeing 747-200 pax', 'wtc' => 'H'],
'743' => ['icao' => 'B743', 'description' => 'Boeing 747-300 pax', 'wtc' => 'H'],
'744' => ['icao' => 'B744', 'description' => 'Boeing 747-400 pax', 'wtc' => 'H'],
'747' => ['icao' => 'n/a', 'description' => 'Boeing 747 all pax models', 'wtc' => 'H'],
'748' => ['icao' => 'B748', 'description' => 'Boeing 747-8 pax', 'wtc' => 'H'],
'74B' => ['icao' => 'B744', 'description' => 'Boeing 747-400 Swingtail Freighter', 'wtc' => 'H'],
'74C' => ['icao' => 'B742', 'description' => 'Boeing 747-200 Combi', 'wtc' => 'H'],
'74D' => ['icao' => 'B743', 'description' => 'Boeing 747-300 Combi', 'wtc' => 'H'],
'74E' => ['icao' => 'B744', 'description' => 'Boeing 747-400 Combi', 'wtc' => 'H'],
'74F' => ['icao' => 'n/a', 'description' => 'Boeing 747 all Freighter models', 'wtc' => 'H'],
'74H' => ['icao' => 'n/a', 'description' => 'Boeing 747-8I Passenger', 'wtc' => 'H'],
'74J' => ['icao' => 'B744', 'description' => 'Boeing 747-400 (Domestic) pax', 'wtc' => 'H'],
'74L' => ['icao' => 'B74S', 'description' => 'Boeing 747SP', 'wtc' => 'H'],
'74M' => ['icao' => 'n/a', 'description' => 'Boeing 747 all Combi models', 'wtc' => 'H'],
'74N' => ['icao' => 'n/a', 'description' => 'Boeing 747-8F', 'wtc' => 'H'],
'74R' => ['icao' => 'B74R', 'description' => 'Boeing 747SR pax', 'wtc' => 'H'],
'74T' => ['icao' => 'B741', 'description' => 'Boeing 747-100 Freighter', 'wtc' => 'H'],
'74U' => ['icao' => 'B743', 'description' => 'Boeing 747-300 / 747-200 SUD Freighter', 'wtc' => 'H'],
'74V' => ['icao' => 'B74R', 'description' => 'Boeing 747SR Freighter', 'wtc' => 'H'],
'74X' => ['icao' => 'B742', 'description' => 'Boeing 747-200 Freighter', 'wtc' => 'H'],
'74Y' => ['icao' => 'B744', 'description' => 'Boeing 747-400 Freighter', 'wtc' => 'H'],
'752' => ['icao' => 'B752', 'description' => 'Boeing 757-200 pax', 'wtc' => 'H'],
'753' => ['icao' => 'B753', 'description' => 'Boeing 757-300 pax', 'wtc' => 'H'],
'757' => ['icao' => 'n/a', 'description' => 'Boeing 757 all pax models', 'wtc' => 'H'],
'75F' => ['icao' => 'B752', 'description' => 'Boeing 757 Freighter', 'wtc' => 'H'],
'75M' => ['icao' => 'B752', 'description' => 'Boeing 757 Mixed Configuration', 'wtc' => 'H'],
'75T' => ['icao' => 'B753', 'description' => 'Boeing 757-300 (winglets) pax', 'wtc' => 'H'],
'75W' => ['icao' => 'B752', 'description' => 'Boeing 757-200 (winglets) pax', 'wtc' => 'H'],
'762' => ['icao' => 'B762', 'description' => 'Boeing 767-200 pax', 'wtc' => 'H'],
'763' => ['icao' => 'B763', 'description' => 'Boeing 767-300 pax', 'wtc' => 'H'],
'764' => ['icao' => 'B764', 'description' => 'Boeing 767-400 pax', 'wtc' => 'H'],
'767' => ['icao' => 'n/a', 'description' => 'Boeing 767 all pax models', 'wtc' => 'H'],
'76F' => ['icao' => 'n/a', 'description' => 'Boeing 767 all Freighter models', 'wtc' => 'H'],
'76W' => ['icao' => 'B763', 'description' => 'Boeing 767-300 (winglets) pax', 'wtc' => 'H'],
'76V' => ['icao' => 'B763', 'description' => 'Boeing 767-300 (winglets) Freighter', 'wtc' => 'H'],
'76X' => ['icao' => 'B762', 'description' => 'Boeing 767-200 Freighter', 'wtc' => 'H'],
'76Y' => ['icao' => 'B763', 'description' => 'Boeing 767-300 Freighter', 'wtc' => 'H'],
'772' => ['icao' => 'B772', 'description' => 'Boeing 777-200 pax', 'wtc' => 'H'],
'773' => ['icao' => 'B773', 'description' => 'Boeing 777-300 pax', 'wtc' => 'H'],
'777' => ['icao' => 'n/a', 'description' => 'Boeing 777 all pax models', 'wtc' => 'H'],
'77F' => ['icao' => 'n/a', 'description' => 'Boeing 777 Freighter', 'wtc' => 'H'],
'77L' => ['icao' => 'B772', 'description' => 'Boeing 777-200LR pax', 'wtc' => 'H'],
'77W' => ['icao' => 'B77W', 'description' => 'Boeing 777-300ER pax', 'wtc' => 'H'],
'77X' => ['icao' => 'B77L', 'description' => 'Boeing 777-200 Freighter', 'wtc' => 'H'],
'781' => ['icao' => 'B78X', 'description' => 'Boeing 787-10 pax', 'wtc' => 'H'],
'788' => ['icao' => 'B788', 'description' => 'Boeing 787-8 pax', 'wtc' => 'H'],
'789' => ['icao' => 'B789', 'description' => 'Boeing 787-9 pax', 'wtc' => 'H'],
'7M7' => ['icao' => 'B37M', 'description' => 'Boeing 737 MAX 7 pax', 'wtc' => 'M'],
'7M8' => ['icao' => 'B38M', 'description' => 'Boeing 737 MAX 8 pax', 'wtc' => 'M'],
'7M9' => ['icao' => 'B39M', 'description' => 'Boeing 737 MAX 9 pax', 'wtc' => 'M'],
'7MJ' => ['icao' => 'B3XM', 'description' => 'Boeing 737 MAX 10 pax', 'wtc' => 'M'],
'A22' => ['icao' => 'AN22', 'description' => 'Antonov AN-22', 'wtc' => 'L'],
'A26' => ['icao' => 'AN26', 'description' => 'Antonov AN-26', 'wtc' => 'L'],
'A28' => ['icao' => 'AN28', 'description' => 'Antonov AN-28 / PZL Miele M-28 Skytruck', 'wtc' => 'L'],
'A30' => ['icao' => 'AN30', 'description' => 'Antonov AN-30', 'wtc' => 'L'],
'A32' => ['icao' => 'AN32', 'description' => 'Antonov AN-32', 'wtc' => 'L'],
'A38' => ['icao' => 'AN38', 'description' => 'Antonov AN-38', 'wtc' => 'L'],
'A40' => ['icao' => 'A140', 'description' => 'Antonov AN-140', 'wtc' => 'M'],
'A4F' => ['icao' => 'A124', 'description' => 'Antonov AN-124 Ruslan', 'wtc' => 'H'],
'A5F' => ['icao' => 'A225', 'description' => 'Antonov AN-225', 'wtc' => 'H'],
'A81' => ['icao' => 'A148', 'description' => 'Antonov AN-148-100', 'wtc' => 'M'],
'AB3' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300 pax', 'wtc' => 'H'],
'AB4' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300B2/B4/C4 pax', 'wtc' => 'H'],
'AB6' => ['icao' => 'A306', 'description' => 'Airbus Industrie A300-600 pax', 'wtc' => 'H'],
'ABB' => ['icao' => 'A3ST', 'description' => 'Airbus Industrie A300-600ST Beluga Freighter', 'wtc' => 'H'],
'ABF' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300 Freighter', 'wtc' => 'H'],
'ABX' => ['icao' => 'A30B', 'description' => 'Airbus Industrie A300C4/F4 Freighter', 'wtc' => 'H'],
'ABY' => ['icao' => 'A306', 'description' => 'Airbus Industrie A300-600 Freighter', 'wtc' => 'H'],
'ACD' => ['icao' => 'n/a', 'description' => 'Gulfstream/Rockwell (Aero) Commander/Turbo Commander', 'wtc' => 'L'],
'ACP' => ['icao' => 'AC68', 'description' => 'Gulfstream/Rockwell (Aero) Commander', 'wtc' => 'L'],
'ACT' => ['icao' => 'AC90', 'description' => 'Gulfstream/Rockwell (Aero) Turbo Commander', 'wtc' => 'L'],
'AGH' => ['icao' => 'A109', 'description' => 'Agusta A109', 'wtc' => 'n/a'],
'ALM' => ['icao' => 'LOAD', 'description' => 'Ayres LM-200 Loadmaster', 'wtc' => 'M'],
'AN4' => ['icao' => 'AN24', 'description' => 'Antonov AN-24', 'wtc' => 'M'],
'AN6' => ['icao' => 'n/a', 'description' => 'Antonov AN-26 / AN-30 / AN-32', 'wtc' => 'M'],
'AN7' => ['icao' => 'AN72', 'description' => 'Antonov AN-72 / AN-74', 'wtc' => 'M'],
'ANF' => ['icao' => 'AN12', 'description' => 'Antonov AN-12', 'wtc' => 'M'],
'APH' => ['icao' => 'n/a', 'description' => 'Eurocopter (Aerospatiale) SA330 Puma / AS332 Super Puma', 'wtc' => 'n/a'],
'AR1' => ['icao' => 'RJ1H', 'description' => 'Avro RJ100 Avroliner', 'wtc' => 'M'],
'AR7' => ['icao' => 'RJ70', 'description' => 'Avro RJ70 Avroliner', 'wtc' => 'M'],
'AR8' => ['icao' => 'RJ85', 'description' => 'Avro RJ85 Avroliner', 'wtc' => 'M'],
'ARJ' => ['icao' => 'n/a', 'description' => 'Avro RJ70 / RJ85 / RJ100 Avroliner', 'wtc' => 'M'],
'ARX' => ['icao' => 'n/a', 'description' => 'Avro RJX85 / RJX100', 'wtc' => 'M'],
'AT4' => ['icao' => 'AT43', 'description' => 'Aerospatiale/Alenia ATR 42-300 / 320', 'wtc' => 'M'],
'AT5' => ['icao' => 'AT45', 'description' => 'Aerospatiale/Alenia ATR 42-500', 'wtc' => 'M'],
'AT7' => ['icao' => 'AT72', 'description' => 'Aerospatiale/Alenia ATR 72', 'wtc' => 'M'],
'ATD' => ['icao' => 'AT44', 'description' => 'Aerospatiale/Alenia ATR 42-400', 'wtc' => 'M'],
'ATF' => ['icao' => 'AT72', 'description' => 'Aerospatiale/Alenia ATR 72 Freighter', 'wtc' => 'M'],
'ATP' => ['icao' => 'ATP', 'description' => 'British Aerospace ATP', 'wtc' => 'M'],
'ATR' => ['icao' => 'n/a', 'description' => 'Aerospatiale/Alenia ATR 42 / ATR 72', 'wtc' => 'M'],
'AX1' => ['icao' => 'RX1H', 'description' => 'Avro RJX100', 'wtc' => 'M'],
'AX8' => ['icao' => 'RX85', 'description' => 'Avro RJX85', 'wtc' => 'M'],
'B11' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven / RomBAC One Eleven', 'wtc' => 'M'],
'B12' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 200', 'wtc' => 'M'],
'B13' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 300', 'wtc' => 'M'],
'B14' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 400/475', 'wtc' => 'M'],
'B15' => ['icao' => 'BA11', 'description' => 'British Aerospace (BAC) One Eleven 500 / RomBAC One Eleven', 'wtc' => 'M'],
'B72' => ['icao' => 'B720', 'description' => 'Boeing 720B pax', 'wtc' => 'M'],
'BE1' => ['icao' => 'B190', 'description' => 'Beechcraft 1900/1900C/1900D', 'wtc' => 'M'],
'BE2' => ['icao' => 'n/a', 'description' => 'Beechcraft twin piston engines', 'wtc' => 'L'],
'BEC' => ['icao' => 'n/a', 'description' => 'Beechcraft light aircraft', 'wtc' => 'L'],
'BEH' => ['icao' => 'B190', 'description' => 'Beechcraft 1900D', 'wtc' => 'M'],
'BEP' => ['icao' => 'n/a', 'description' => 'Beechcraft light aircraft - single engine', 'wtc' => 'L'],
'BES' => ['icao' => 'B190', 'description' => 'Beechcraft 1900/1900C', 'wtc' => 'M'],
'BET' => ['icao' => 'n/a', 'description' => 'Beechcraft light aircraft - twin turboprop engine', 'wtc' => 'L'],
'BH2' => ['icao' => 'n/a', 'description' => 'Bell Helicopters', 'wtc' => 'n/a'],
'BNI' => ['icao' => 'BN2P', 'description' => 'Pilatus Britten-Norman BN-2A/B Islander', 'wtc' => 'L'],
'BNT' => ['icao' => 'TRIS', 'description' => 'Pilatus Britten-Norman BN-2A Mk III Trislander', 'wtc' => 'L'],
'BUS' => ['icao' => 'n/a', 'description' => 'Bus', 'wtc' => 'n/a'],
'C27' => ['icao' => 'AJ27', 'description' => 'COMAC ARJ21', 'wtc' => 'M'],
'CCJ' => ['icao' => 'CL60', 'description' => 'Canadair Challenger', 'wtc' => 'M'],
'CCX' => ['icao' => 'GLEX', 'description' => 'Canadair Global Express', 'wtc' => 'M'],
'CD2' => ['icao' => 'NOMA', 'description' => 'Government Aircraft Factories N22B / N24A Nomad', 'wtc' => 'L'],
'CL4' => ['icao' => 'CL44', 'description' => 'Canadair CL-44', 'wtc' => 'M'],
'919' => ['icao' => 'C919', 'description' => 'Comac C919 Passenger', 'wtc' => 'M'],
'CN1' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - single piston engine', 'wtc' => 'L'],
'CN2' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - twin piston engines', 'wtc' => 'L'],
'CN7' => ['icao' => 'C750', 'description' => 'Cessna 750 Citation X', 'wtc' => 'M'],
'CNA' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft', 'wtc' => 'L'],
'CNC' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - single turboprop engine', 'wtc' => 'L'],
'CNJ' => ['icao' => 'n/a', 'description' => 'Cessna Citation', 'wtc' => 'L'],
'CNT' => ['icao' => 'n/a', 'description' => 'Cessna light aircraft - twin turboprop engines', 'wtc' => 'L'],
'CR1' => ['icao' => 'CRJ1', 'description' => 'Canadair Regional Jet 100', 'wtc' => 'M'],
'CR2' => ['icao' => 'CRJ2', 'description' => 'Canadair Regional Jet 200', 'wtc' => 'M'],
'CR7' => ['icao' => 'CRJ7', 'description' => 'Canadair Regional Jet 700', 'wtc' => 'M'],
'CR9' => ['icao' => 'CRJ9', 'description' => 'Canadair Regional Jet 900', 'wtc' => 'M'],
'CRA' => ['icao' => 'CRJ9', 'description' => 'Canadair Regional Jet 705', 'wtc' => 'M'],
'CRF' => ['icao' => 'n/a', 'description' => 'Canadair Regional Jet Freighter', 'wtc' => 'M'],
'CRJ' => ['icao' => 'n/a', 'description' => 'Canadair Regional Jet', 'wtc' => 'M'],
'CRK' => ['icao' => 'CRJX', 'description' => 'Canadair Regional Jet 1000', 'wtc' => 'M'],
'CRV' => ['icao' => 'S210', 'description' => 'Aerospatiale (Sud Aviation) Se.210 Caravelle', 'wtc' => 'M'],
'CS1' => ['icao' => 'BCS1', 'description' => 'Bombardier C Series CS100', 'wtc' => 'M'],
'CS2' => ['icao' => 'C212', 'description' => 'CASA / IPTN 212 Aviocar', 'wtc' => 'M'],
'CS3' => ['icao' => 'BCS3', 'description' => 'Bombardier C Series CS300', 'wtc' => 'M'],
'CS5' => ['icao' => 'CN35', 'description' => 'CASA / IPTN CN-235', 'wtc' => 'M'],
'CV2' => ['icao' => 'CVLP', 'description' => 'Convair CV-240 pax', 'wtc' => 'M'],
'CV4' => ['icao' => 'CVLP', 'description' => 'Convair CV-440 Metropolitan pax', 'wtc' => 'M'],
'CV5' => ['icao' => 'CVLT', 'description' => 'Convair CV-580 pax', 'wtc' => 'M'],
'CVF' => ['icao' => 'n/a', 'description' => 'Convair CV-240 / 440 / 580 / 600 / 640 Freighter', 'wtc' => 'M'],
'CVR' => ['icao' => 'n/a', 'description' => 'Convair CV-240 / 440 / 580 / 600 / 640 pax', 'wtc' => 'M'],
'CVV' => ['icao' => 'CVLP', 'description' => 'Convair CV-240 Freighter', 'wtc' => 'M'],
'CVX' => ['icao' => 'CVLP', 'description' => 'Convair CV-440 Freighter', 'wtc' => 'M'],
'CVY' => ['icao' => 'CVLT', 'description' => 'Convair CV-580 / 600 / 640 Freighter', 'wtc' => 'M'],
'CWC' => ['icao' => 'C46', 'description' => 'Curtiss C-46 Commando', 'wtc' => 'M'],
'D10' => ['icao' => 'DC10', 'description' => 'Douglas DC-10 pax', 'wtc' => 'H'],
'D11' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-10/15 pax', 'wtc' => 'H'],
'D1C' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-30/40 pax', 'wtc' => 'H'],
'D1F' => ['icao' => 'DC10', 'description' => 'Douglas DC-10 all Freighters', 'wtc' => 'H'],
'D1M' => ['icao' => 'DC10', 'description' => 'Douglas DC-10 all Combi models', 'wtc' => 'H'],
'D1X' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-10 Freighter', 'wtc' => 'H'],
'D1Y' => ['icao' => 'DC10', 'description' => 'Douglas DC-10-30 / 40 Freighters', 'wtc' => 'H'],
'D28' => ['icao' => 'D228', 'description' => 'Fairchild Dornier Do.228', 'wtc' => 'L'],
'D38' => ['icao' => 'D328', 'description' => 'Fairchild Dornier Do.328', 'wtc' => 'M'],
'D3F' => ['icao' => 'DC3', 'description' => 'Douglas DC-3 Freighter', 'wtc' => 'M'],
'D6F' => ['icao' => 'DC6', 'description' => 'Douglas DC-6A/B/C Freighter', 'wtc' => 'M'],
'D8F' => ['icao' => 'n/a', 'description' => 'Douglas DC-8 all Freighters', 'wtc' => 'H'],
'D8L' => ['icao' => 'DC86', 'description' => 'Douglas DC-8-62 pax', 'wtc' => 'H'],
'D8M' => ['icao' => 'n/a', 'description' => 'Douglas DC-8 all Combi models', 'wtc' => 'H'],
'D8Q' => ['icao' => 'DC87', 'description' => 'Douglas DC-8-72 pax', 'wtc' => 'H'],
'D8T' => ['icao' => 'DC85', 'description' => 'Douglas DC-8-50 Freighter', 'wtc' => 'H'],
'D8X' => ['icao' => 'n/a', 'description' => 'Douglas DC-8-61 / 62 / 63 Freighters', 'wtc' => 'H'],
'D8Y' => ['icao' => 'DC87', 'description' => 'Douglas DC-8-71 / 72 / 73 Freighters', 'wtc' => 'H'],
'D91' => ['icao' => 'DC91', 'description' => 'Douglas DC-9-10 pax', 'wtc' => 'M'],
'D92' => ['icao' => 'DC92', 'description' => 'Douglas DC-9-20 pax', 'wtc' => 'M'],
'D93' => ['icao' => 'DC93', 'description' => 'Douglas DC-9-30 pax', 'wtc' => 'M'],
'D94' => ['icao' => 'DC94', 'description' => 'Douglas DC-9-40 pax', 'wtc' => 'M'],
'D95' => ['icao' => 'DC95', 'description' => 'Douglas DC-9-50 pax', 'wtc' => 'M'],
'D9C' => ['icao' => 'DC93', 'description' => 'Douglas DC-9-30 Freighter', 'wtc' => 'M'],
'D9D' => ['icao' => 'DC94', 'description' => 'Douglas DC-9-40 Freighter', 'wtc' => 'M'],
'D9F' => ['icao' => 'n/a', 'description' => 'Douglas DC-9 all Freighters', 'wtc' => 'M'],
'D9X' => ['icao' => 'DC91', 'description' => 'Douglas DC-9-10 Freighter', 'wtc' => 'M'],
'DC3' => ['icao' => 'DC3', 'description' => 'Douglas DC-3 pax', 'wtc' => 'M'],
'DC4' => ['icao' => 'DC4', 'description' => 'Douglas DC-4 pax', 'wtc' => 'M'],
'DC6' => ['icao' => 'DC6', 'description' => 'Douglas DC6A/B pax', 'wtc' => 'M'],
'DC8' => ['icao' => 'n/a', 'description' => 'Douglas DC-8 all pax models', 'wtc' => 'H'],
'DC9' => ['icao' => 'DC9', 'description' => 'Douglas DC-9 all pax models', 'wtc' => 'M'],
'DF2' => ['icao' => 'n/a', 'description' => 'Dassault (Breguet Mystere) Falcon 10 / 100 / 20 / 200 / 2000', 'wtc' => 'M'],
'DF3' => ['icao' => 'n/a', 'description' => 'Dassault (Breguet Mystere) Falcon 50 / 900', 'wtc' => 'M'],
'DFL' => ['icao' => 'n/a', 'description' => 'Dassault (Breguet Mystere) Falcon', 'wtc' => 'M'],
'DH1' => ['icao' => 'DH8A', 'description' => 'De Havilland Canada DHC-8-100 Dash 8 / 8Q', 'wtc' => 'M'],
'DH2' => ['icao' => 'DH8B', 'description' => 'De Havilland Canada DHC-8-200 Dash 8 / 8Q', 'wtc' => 'M'],
'DH3' => ['icao' => 'DH8C', 'description' => 'De Havilland Canada DHC-8-300 Dash 8 / 8Q', 'wtc' => 'M'],
'DH4' => ['icao' => 'DH8D', 'description' => 'De Havilland Canada DHC-8-400 Dash 8Q', 'wtc' => 'M'],
'DH7' => ['icao' => 'DHC7', 'description' => 'De Havilland Canada DHC-7 Dash 7', 'wtc' => 'M'],
'DH8' => ['icao' => 'n/a', 'description' => 'De Havilland Canada DHC-8 Dash 8 all models', 'wtc' => 'M'],
'DHB' => ['icao' => 'n/a', 'description' => 'De Havilland Canada DHC-2 Beaver / Turbo Beaver', 'wtc' => 'L'],
'DHC' => ['icao' => 'DHC4', 'description' => 'De Havilland Canada DHC-4 Caribou', 'wtc' => 'M'],
'DHD' => ['icao' => 'DOVE', 'description' => 'De Havilland DH.104 Dove', 'wtc' => 'L'],
'DHH' => ['icao' => 'HERN', 'description' => 'De Havilland DH.114 Heron', 'wtc' => 'L'],
'DHL' => ['icao' => 'DHC3', 'description' => 'De Havilland Canada DHC-3 Turbo Otter', 'wtc' => 'L'],
'DHO' => ['icao' => 'DHC3', 'description' => 'De Havilland Canada DHC-3 Otter / Turbo Otter', 'wtc' => 'L'],
'DHP' => ['icao' => 'DHC2', 'description' => 'De Havilland Canada DHC-2 Beaver', 'wtc' => 'L'],
'DHR' => ['icao' => 'DH2T', 'description' => 'De Havilland Canada DHC-2 Turbo-Beaver', 'wtc' => 'L'],
'DHS' => ['icao' => 'DHC3', 'description' => 'De Havilland Canada DHC-3 Otter', 'wtc' => 'L'],
'DHT' => ['icao' => 'DHC6', 'description' => 'De Havilland Canada DHC-6 Twin Otter', 'wtc' => 'L'],
'E70' => ['icao' => 'E170', 'description' => 'Embraer 170', 'wtc' => 'M'],
'E75' => ['icao' => 'E75L', 'description' => 'Embraer 175 (Short wing / Long Wing)', 'wtc' => 'M'],
'E90' => ['icao' => 'E190', 'description' => 'Embraer 190', 'wtc' => 'M'],
'E95' => ['icao' => 'E195', 'description' => 'Embraer 195', 'wtc' => 'M'],
'EC3' => ['icao' => 'EC30', 'description' => 'Eurocopter EC.130', 'wtc' => 'n/a'],
'EM2' => ['icao' => 'E120', 'description' => 'Embraer EMB.120 Brasilia', 'wtc' => 'L'],
'EMB' => ['icao' => 'E110', 'description' => 'Embraer EMB.110 Bandeirnate', 'wtc' => 'M'],
'EMJ' => ['icao' => 'n/a', 'description' => 'Embraer 170/190', 'wtc' => 'M'],
'ER3' => ['icao' => 'E135', 'description' => 'Embraer RJ135 / Legacy 600 / Legacy 650', 'wtc' => 'M'],
'ER4' => ['icao' => 'E145', 'description' => 'Embraer RJ145 Amazon', 'wtc' => 'M'],
'ERD' => ['icao' => 'n/a', 'description' => 'Embraer RJ140', 'wtc' => 'M'],
'ERJ' => ['icao' => 'n/a', 'description' => 'Embraer RJ135 / RJ140 / RJ145', 'wtc' => 'M'],
'F21' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 1000', 'wtc' => 'M'],
'F22' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 2000', 'wtc' => 'M'],
'F23' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 3000', 'wtc' => 'M'],
'F24' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship 4000', 'wtc' => 'M'],
'F27' => ['icao' => 'F27', 'description' => 'Fokker F.27 Friendship / Fairchild F.27', 'wtc' => 'M'],
'F28' => ['icao' => 'F28', 'description' => 'Fokker F.28 Fellowship', 'wtc' => 'M'],
'F50' => ['icao' => 'F50', 'description' => 'Fokker 50', 'wtc' => 'M'],
'F5F' => ['icao' => 'F50', 'description' => 'Fokker 50 Freighter', 'wtc' => 'M'],
'F70' => ['icao' => 'F70', 'description' => 'Fokker 70', 'wtc' => 'M'],
'FA7' => ['icao' => 'n/a', 'description' => 'Fairchild Dornier 728JET', 'wtc' => 'M'],
'FK7' => ['icao' => 'F27', 'description' => 'Fairchild FH.227', 'wtc' => 'M'],
'FRJ' => ['icao' => 'J328', 'description' => 'Fairchild Dornier 328JET', 'wtc' => 'M'],
'GRG' => ['icao' => 'G21', 'description' => 'Grumman G.21 Goose', 'wtc' => 'L'],
'GRJ' => ['icao' => 'n/a', 'description' => 'Gulfstream Aerospace G-1159 Gulfstream II / III / IV / V', 'wtc' => 'M'],
'GRM' => ['icao' => 'G73T', 'description' => 'Grumman G.73 Turbo Mallard', 'wtc' => 'L'],
'GRS' => ['icao' => 'G159', 'description' => 'Gulfstream Aerospace G-159 Gulfstream I', 'wtc' => 'M'],
'H25' => ['icao' => 'n/a', 'description' => 'British Aerospace (Hawker Siddeley) HS.125', 'wtc' => 'M'],
'HEC' => ['icao' => 'COUC', 'description' => 'Helio H-250 Courier / H-295 / 385 Super Courier', 'wtc' => 'L'],
'HOV' => ['icao' => 'n/a', 'description' => 'Hovercraft', 'wtc' => 'n/a'],
'HS7' => ['icao' => 'A748', 'description' => 'Hawker Siddeley HS.748', 'wtc' => 'M'],
'I14' => ['icao' => 'I114', 'description' => 'Ilyushin IL114', 'wtc' => 'M'],
'I93' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96-300 pax', 'wtc' => 'H'],
'I9F' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96 Freighters', 'wtc' => 'H'],
'I9M' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96M pax', 'wtc' => 'H'],
'I9X' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96-300 Freighter', 'wtc' => 'H'],
'I9Y' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96T Freighter', 'wtc' => 'H'],
'IL6' => ['icao' => 'IL62', 'description' => 'Ilyushin IL62', 'wtc' => 'H'],
'IL7' => ['icao' => 'IL76', 'description' => 'Ilyushin IL76', 'wtc' => 'H'],
'IL8' => ['icao' => 'IL18', 'description' => 'Ilyushin IL18', 'wtc' => 'M'],
'IL9' => ['icao' => 'IL96', 'description' => 'Ilyushin IL96 pax', 'wtc' => 'H'],
'ILW' => ['icao' => 'IL86', 'description' => 'Ilyushin IL86', 'wtc' => 'H'],
'J31' => ['icao' => 'JS31', 'description' => 'British Aerospace Jetstream 31', 'wtc' => 'L'],
'J32' => ['icao' => 'JS32', 'description' => 'British Aerospace Jetstream 32', 'wtc' => 'L'],
'J41' => ['icao' => 'JS41', 'description' => 'British Aerospace Jetstream 41', 'wtc' => 'M'],
'JST' => ['icao' => 'n/a', 'description' => 'British Aerospace Jetstream 31 / 32 / 41', 'wtc' => 'L/M'],
'JU5' => ['icao' => 'JU52', 'description' => 'Junkers Ju52/3M', 'wtc' => 'M'],
'L10' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 Tristar pax', 'wtc' => 'H'],
'L11' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 1 / 50 / 100 / 150 / 200 / 250 Tristar pax', 'wtc' => 'H'],
'L15' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 500 Tristar pax', 'wtc' => 'H'],
'L1F' => ['icao' => 'L101', 'description' => 'Lockheed L-1011 Tristar Freighter', 'wtc' => 'H'],
'L49' => ['icao' => 'CONI', 'description' => 'Lockheed L-1049 Super Constellation', 'wtc' => 'M'],
'L4T' => ['icao' => 'L410', 'description' => 'LET 410', 'wtc' => 'L'],
'LCH' => ['icao' => 'n/a', 'description' => 'Launch - Boat', 'wtc' => 'n/a'],
'LMO' => ['icao' => 'n/a', 'description' => 'Limousine', 'wtc' => 'n/a'],
'LOE' => ['icao' => 'L188', 'description' => 'Lockheed L-188 Electra pax', 'wtc' => 'M'],
'LOF' => ['icao' => 'L188', 'description' => 'Lockheed L-188 Electra Freighter', 'wtc' => 'M'],
'LOH' => ['icao' => 'C130', 'description' => 'Lockheed L-182 / 282 / 382 (L-100) Hercules', 'wtc' => 'M'],
'LOM' => ['icao' => 'L188', 'description' => 'Lockheed L-188 Electra Mixed Configuration', 'wtc' => 'M'],
'LRJ' => ['icao' => 'n/a', 'description' => 'Gates Learjet', 'wtc' => 'M'],
'M11' => ['icao' => 'MD11', 'description' => 'McDonnell Douglas MD11 pax', 'wtc' => 'H'],
'M1F' => ['icao' => 'MD11', 'description' => 'McDonnell Douglas MD11 Freighter', 'wtc' => 'H'],
'M1M' => ['icao' => 'MD11', 'description' => 'McDonnell Douglas MD11 Mixed Configuration', 'wtc' => 'H'],
'M80' => ['icao' => 'MD80', 'description' => 'McDonnell Douglas MD80', 'wtc' => 'M'],
'M81' => ['icao' => 'MD81', 'description' => 'McDonnell Douglas MD81', 'wtc' => 'M'],
'M82' => ['icao' => 'MD82', 'description' => 'McDonnell Douglas MD82', 'wtc' => 'M'],
'M83' => ['icao' => 'MD83', 'description' => 'McDonnell Douglas MD83', 'wtc' => 'M'],
'M87' => ['icao' => 'MD87', 'description' => 'McDonnell Douglas MD87', 'wtc' => 'M'],
'M88' => ['icao' => 'MD88', 'description' => 'McDonnell Douglas MD88', 'wtc' => 'M'],
'M90' => ['icao' => 'MD90', 'description' => 'McDonnell Douglas MD90', 'wtc' => 'M'],
'MBH' => ['icao' => 'B105', 'description' => 'Eurocopter (MBB) Bo.105', 'wtc' => 'n/a'],
'MD9' => ['icao' => 'EXPL', 'description' => 'MD Helicopters MD900 Explorer', 'wtc' => 'n/a'],
'MIH' => ['icao' => 'MI8', 'description' => 'MIL Mi-8 / Mi-17 / Mi-171 / Mil-172', 'wtc' => 'n/a'],
'MU2' => ['icao' => 'MU2', 'description' => 'Mitsubishi Mu-2', 'wtc' => 'L'],
'ND2' => ['icao' => 'N262', 'description' => 'Aerospatiale (Nord) 262', 'wtc' => 'M'],
'NDC' => ['icao' => 'S601', 'description' => 'Aerospatiale SN.601 Corvette', 'wtc' => 'L'],
'NDE' => ['icao' => 'n/a', 'description' => 'Eurocopter (Aerospatiale) AS350 Ecureuil / AS355 Ecureuil 2', 'wtc' => 'n/a'],
'NDH' => ['icao' => 'S65C', 'description' => 'Eurocopter (Aerospatiale) SA365C / SA365N Dauphin 2', 'wtc' => 'n/a'],
'PA1' => ['icao' => 'n/a', 'description' => 'Piper light aircraft - single piston engine', 'wtc' => 'L'],
'PA2' => ['icao' => 'n/a', 'description' => 'Piper light aircraft - twin piston engines', 'wtc' => 'L'],
'PAG' => ['icao' => 'n/a', 'description' => 'Piper light aircraft', 'wtc' => 'L'],
'PAT' => ['icao' => 'n/a', 'description' => 'Piper light aircraft - twin turboprop engines', 'wtc' => 'L'],
'PL2' => ['icao' => 'PC12', 'description' => 'Pilatus PC-12', 'wtc' => 'L'],
'PL6' => ['icao' => 'PC6T', 'description' => 'Pilatus PC-6 Turbo Porter', 'wtc' => 'L'],
'PN6' => ['icao' => 'P68', 'description' => 'Partenavia P.68', 'wtc' => 'L'],
'RFS' => ['icao' => 'n/a', 'description' => 'Road Feeder Service - Cargo Truck', 'wtc' => 'n/a'],
'S20' => ['icao' => 'SB20', 'description' => 'Saab 2000', 'wtc' => 'M'],
'S58' => ['icao' => 'S58T', 'description' => 'Sikorsky S-58T', 'wtc' => 'n/a'],
'S61' => ['icao' => 'S61', 'description' => 'Sikorsky S-61', 'wtc' => 'n/a'],
'S76' => ['icao' => 'S76', 'description' => 'Sikorsky S-76', 'wtc' => 'n/a'],
'SF3' => ['icao' => 'SF34', 'description' => 'Saab SF340', 'wtc' => 'M'],
'SFB' => ['icao' => 'SF34', 'description' => 'Saab SF340B', 'wtc' => 'M'],
'SFF' => ['icao' => 'SF34', 'description' => 'Saab SF340 Freighter', 'wtc' => 'M'],
'SH3' => ['icao' => 'SH33', 'description' => 'Shorts SD.330', 'wtc' => 'M'],
'SH6' => ['icao' => 'SH36', 'description' => 'Shorts SD.360', 'wtc' => 'M'],
'SHB' => ['icao' => 'BELF', 'description' => 'Shorts SC-5 Belfast', 'wtc' => 'M'],
'SHS' => ['icao' => 'SC7', 'description' => 'Shorts SC-7 Skyvan', 'wtc' => 'L'],
'SSC' => ['icao' => 'CONC', 'description' => 'Aerospatiale/BAC Concorde', 'wtc' => 'H'],
'SU1' => ['icao' => '', 'description' => 'Sukhoi Superjet 100', 'wtc' => 'M'],
'SU7' => ['icao' => '', 'description' => 'Sukhoi Superjet 100-75', 'wtc' => 'M'],
'SU9' => ['icao' => 'SU95', 'description' => 'Sukhoi Superjet 100-95', 'wtc' => 'M'],
'SWM' => ['icao' => 'n/a', 'description' => 'Fairchild (Swearingen) SA26 / SA226 / SA227 Metro / Merlin / Expediter', 'wtc' => 'L'],
'T20' => ['icao' => 'T204', 'description' => 'Tupolev Tu-204 / Tu-214', 'wtc' => 'M'],
'T2F' => ['icao' => 'T204', 'description' => 'Tupolev Tu-204 Freighter', 'wtc' => 'M'],
'TRN' => ['icao' => 'n/a', 'description' => 'Train', 'wtc' => 'n/a'],
'TU3' => ['icao' => 'T134', 'description' => 'Tupolev Tu134', 'wtc' => 'M'],
'TU5' => ['icao' => 'T154', 'description' => 'Tupolev Tu154', 'wtc' => 'M'],
'VCV' => ['icao' => 'VISC', 'description' => 'Vickers Viscount', 'wtc' => 'M'],
'WWP' => ['icao' => 'WW24', 'description' => 'Israel Aircraft Industries 1124 Westwind', 'wtc' => 'M'],
'YK2' => ['icao' => 'YK42', 'description' => 'Yakovlev Yak 42', 'wtc' => 'M'],
'YK4' => ['icao' => 'YK40', 'description' => 'Yakovlev Yak 40', 'wtc' => 'M'],
'YN2' => ['icao' => 'Y12', 'description' => 'Harbin Yunshuji Y12', 'wtc' => 'M'],
'YN7' => ['icao' => 'AN24', 'description' => 'Xian Yunshuji Y7', 'wtc' => 'M'],
'YS1' => ['icao' => 'YS11', 'description' => 'NAMC YS-11', 'wtc' => 'M'],
];
public function up(): void
{
Schema::table('aircraft', function (Blueprint $table) {
$table->dropColumn('iata_code');
});
Schema::create('iata_equipment_codes', function (Blueprint $table) {
$table->id();
$table->string('iata_code', 10)->unique();
$table->string('icao_code', 10)->index();
$table->string('description')->nullable();
});
foreach ($this->aircraft_codes as $iata => $data) {
$icao = $data['icao'];
if (empty($icao) || $icao === 'n/a') {
continue;
}
IataEquipmentCode::create([
'iata_code' => $iata,
'icao_code' => $icao,
'description' => $data['description'],
]);
}
$extras = [
// Boeing 737 NG — Scimitar Winglets
'7S7' => ['icao' => 'B737', 'description' => 'Boeing 737-700 (Scimitar Winglets)'],
'7S8' => ['icao' => 'B738', 'description' => 'Boeing 737-800 (Scimitar Winglets)'],
'7S9' => ['icao' => 'B739', 'description' => 'Boeing 737-900 (Scimitar Winglets)'],
// Boeing 737 NG — Freighter/combi variants
'73K' => ['icao' => 'B738', 'description' => 'Boeing 737-800 Freighter (Winglets)'],
'73S' => ['icao' => 'B737', 'description' => 'Boeing 737-700 Freighter'],
'73T' => ['icao' => 'B737', 'description' => 'Boeing 737-700 Freighter (Winglets)'],
'73U' => ['icao' => 'B738', 'description' => 'Boeing 737-800 Freighter'],
'7F8' => ['icao' => 'B738', 'description' => 'Boeing 737-800 Freighter (Scimitar Winglets)'],
// Boeing 737 MAX — alternate code from slot coordination data
'7M1' => ['icao' => 'B3XM', 'description' => 'Boeing 737 MAX 10'],
// Boeing 757 — Freighter variants
'75C' => ['icao' => 'B752', 'description' => 'Boeing 757-200 Freighter'],
'75V' => ['icao' => 'B752', 'description' => 'Boeing 757-200 Freighter (Winglets)'],
// Airbus A318/319/321 — additional sharklet codes
'31A' => ['icao' => 'A318', 'description' => 'Airbus A318 (Sharklets, alternate code)'],
'31B' => ['icao' => 'A319', 'description' => 'Airbus A319 (Sharklets, alternate code)'],
'32B' => ['icao' => 'A321', 'description' => 'Airbus A321 (Sharklets)'],
// Airbus A320 family — Freighter variants
'32F' => ['icao' => 'A320', 'description' => 'Airbus A320 Freighter'],
'32X' => ['icao' => 'A321', 'description' => 'Airbus A321 Freighter'],
// Airbus A330 — additional variants
'33B' => ['icao' => 'A332', 'description' => 'Airbus A330-700 Beluga XL Freighter'],
'33Y' => ['icao' => 'A333', 'description' => 'Airbus A330-300 Freighter'],
// Embraer — Enhanced Winglets
'E7W' => ['icao' => 'E75L', 'description' => 'Embraer 175 (Enhanced Winglets)'],
// Sukhoi Superjet — Saberlets
'S9S' => ['icao' => 'SU95', 'description' => 'Sukhoi Superjet 100-95 (Saberlets)'],
// COMAC C919 — alternate code
'C19' => ['icao' => 'C919', 'description' => 'COMAC C919 (alternate IATA code)'],
];
foreach ($extras as $iata => $data) {
IataEquipmentCode::create([
'iata_code' => $iata,
'icao_code' => $data['icao'],
'description' => $data['description'],
]);
}
}
/**
* Reverse the migrations.
*/
public function down(): void
{
//
}
};

Before

Width:  |  Height:  |  Size: 628 KiB

After

Width:  |  Height:  |  Size: 628 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 492 KiB

@@ -3,6 +3,7 @@ import { Link, useForm } from "@inertiajs/vue3";
import { usePage } from '@inertiajs/vue3'
import type { SharedProps } from '@/Types/types'
import { ref, onMounted, onUnmounted } from 'vue'
import NotificationMenu from "@/Components/FlightsGoneBy/NotificationMenu.vue";
const props = usePage<SharedProps>().props
const menuOpen = ref(false)
@@ -26,14 +27,7 @@ onUnmounted(() => document.removeEventListener('click', handleClickOutside))
<header class="glass">
<Link href="/" class="brand">FlightsGoneBy</Link>
<button v-if="props.auth.user" class="notif-btn" aria-label="Notifications">
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none"
stroke="currentColor" stroke-width="1.75" stroke-linecap="round" stroke-linejoin="round">
<path d="M6 8a6 6 0 0 1 12 0c0 7 3 9 3 9H3s3-2 3-9" />
<path d="M10.3 21a1.94 1.94 0 0 0 3.4 0" />
</svg>
<span class="notif-dot" />
</button>
<NotificationMenu v-if="props.auth.user" :unread-count="props.unread_notification_count" />
<!-- Desktop nav -->
<nav class="nav-desktop">
@@ -0,0 +1,181 @@
<script setup lang="ts">
import {ref, watch} from 'vue'
import axios from "axios";
import {Notification} from "@/Types/types";
import {Link} from "@inertiajs/vue3";
const props = defineProps<{
unreadCount: number
}>()
const open = ref(false)
const notifications = ref<Notification[]>([])
const loading = ref(false)
const markAllRead = async (notifications: Notification[]) => {
const unread = notifications.filter(n => !n.read_at)
await Promise.all(
unread.map(n => axios.patch(`/notifications/${n.id}/read`))
)
unread.forEach(n => n.read_at = new Date().toISOString())
}
watch(open, async (isOpen) => {
if (!isOpen || notifications.value.length) return
loading.value = true
const { data } = await axios.get('/notifications')
notifications.value = data
loading.value = false
await markAllRead(notifications.value)
})
</script>
<template>
<div class="notif-wrapper">
<v-btn icon variant="text" @click="open = !open" aria-label="Notifications">
<v-badge :content="unreadCount" :model-value="unreadCount > 0" color="primary">
<v-icon>mdi-bell-outline</v-icon>
</v-badge>
</v-btn>
<div v-if="open" class="notif-menu">
<div class="notif-header">
<span>Notifications</span>
</div>
<div v-if="loading" class="notif-empty">
<v-progress-circular indeterminate size="20" width="2" />
</div>
<div v-else-if="notifications.length === 0" class="notif-empty">
No notifications yet.
</div>
<div v-else class="notif-list">
<Link
v-for="notification in notifications"
:key="notification.id"
class="notif-item"
:class="{ 'notif-item--unread': !notification.read_at }"
>
<v-icon v-if="notification.is_achievement" size="18" color="amber" class="notif-icon">
mdi-trophy-outline
</v-icon>
<v-icon v-else size="18" class="notif-icon">
mdi-information-outline
</v-icon>
<div class="notif-content">
<p class="notif-title">{{ notification.title }}</p>
<p class="notif-body">{{ notification.body }}</p>
</div>
</Link>
</div>
</div>
</div>
</template>
<style scoped>
.notif-wrapper {
position: relative;
}
.notif-menu {
position: absolute;
top: calc(100% + 0.4rem);
right: 0;
width: 320px;
background: var(--bg);
border: 1px solid rgba(56, 189, 248, 0.12);
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
z-index: 30;
overflow: hidden;
}
.notif-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.6rem 0.75rem;
font-size: 0.8rem;
font-weight: 600;
letter-spacing: 0.06em;
text-transform: uppercase;
opacity: 0.5;
border-bottom: 1px solid rgba(56, 189, 248, 0.1);
}
.notif-empty {
display: flex;
align-items: center;
justify-content: center;
font-size: 0.875rem;
opacity: 0.5;
padding: 1.5rem;
}
.notif-list {
max-height: 400px;
overflow-y: auto;
}
.notif-item {
display: flex;
gap: 0.6rem;
padding: 0.65rem 0.75rem;
border-bottom: 1px solid rgba(56, 189, 248, 0.06);
transition: background 0.15s ease;
}
.notif-item:last-child {
border-bottom: none;
}
.notif-item:hover {
background: rgba(56, 189, 248, 0.04);
}
.notif-item--unread {
background: rgba(56, 189, 248, 0.05);
}
.notif-item--unread:hover {
background: rgba(56, 189, 248, 0.09);
}
.notif-icon {
flex-shrink: 0;
margin-top: 2px;
opacity: 0.7;
}
.notif-content {
display: flex;
flex-direction: column;
gap: 0.15rem;
min-width: 0;
}
.notif-title {
margin: 0;
font-size: 0.875rem;
font-weight: 600;
color: var(--text);
}
.notif-body {
margin: 0;
font-size: 0.8rem;
opacity: 0.7;
color: var(--text);
white-space: pre-line;
}
.notif-time {
margin: 0;
font-size: 0.72rem;
opacity: 0.4;
color: var(--text);
}
</style>
@@ -17,6 +17,7 @@ defineProps<{
</div>
<PanelHeader>{{ flight.aircraft?.display_name_short }}</PanelHeader>
<PanelSubHeader v-if="flight.aircraft?.manufacturer_code">{{ flight.aircraft.manufacturer_code }}</PanelSubHeader>
<PanelSubHeader v-if="!flight.aircraft && !flight.aircraft_registration">No Aircraft Information Found</PanelSubHeader>
<DetailRows>
<DetailRow v-if="flight.aircraft?.designator" label="Designator" :value="flight.aircraft.designator" variant="Badge" />
<DetailRow v-if="flight.aircraft_registration" label="Registration" :value="flight.aircraft_registration" />
@@ -17,6 +17,7 @@ defineProps<{
</div>
<DetailRows>
<DetailRow label="Distance" :value="flight.distance + 'km'" />
<DetailRow label="Duration" :value="flight.duration_display" />
</DetailRows>
</Panel>
</template>
+1
View File
@@ -64,6 +64,7 @@ export type SharedProps = import('@inertiajs/core').PageProps & {
},
logo_api_url: string
achievement_notifications: Notification[]
unread_notification_count: number
}
export interface AchievementDifficulty {
id: number
+3
View File
@@ -50,6 +50,8 @@ Route::domain(config('app.domain'))->group(
Route::put('/flights/{flight}', [FlightController::class, 'update'])->name('flights.update');
Route::delete('/flights/{flight}', [FlightController::class, 'delete'])->name('flights.delete');
Route::get('/reconcile', function () {
$flight = new FlightImportController()->reconcile(request());
@@ -68,6 +70,7 @@ Route::domain(config('app.domain'))->group(
Route::post('/u/{user}/follow', [UserController::class, 'follow'])->name('profile.follow');
Route::get('/notifications', [NotificationController::class, 'index'])->name('notifications.get');
Route::patch('/notifications/{notification}/read', [NotificationController::class, 'markRead']);
Route::get('/feed', [FeedController::class, 'view'])->name('feed');