monacousa-portal/utils/countries.ts

353 lines
13 KiB
TypeScript

// Complete list of all countries with ISO 3166-1 alpha-2 codes
// This works with the flag-icons library for comprehensive coverage
export const COUNTRIES = [
{ code: 'AD', name: 'Andorra' },
{ code: 'AE', name: 'United Arab Emirates' },
{ code: 'AF', name: 'Afghanistan' },
{ code: 'AG', name: 'Antigua and Barbuda' },
{ code: 'AI', name: 'Anguilla' },
{ code: 'AL', name: 'Albania' },
{ code: 'AM', name: 'Armenia' },
{ code: 'AO', name: 'Angola' },
{ code: 'AQ', name: 'Antarctica' },
{ code: 'AR', name: 'Argentina' },
{ code: 'AS', name: 'American Samoa' },
{ code: 'AT', name: 'Austria' },
{ code: 'AU', name: 'Australia' },
{ code: 'AW', name: 'Aruba' },
{ code: 'AX', name: 'Åland Islands' },
{ code: 'AZ', name: 'Azerbaijan' },
{ code: 'BA', name: 'Bosnia and Herzegovina' },
{ code: 'BB', name: 'Barbados' },
{ code: 'BD', name: 'Bangladesh' },
{ code: 'BE', name: 'Belgium' },
{ code: 'BF', name: 'Burkina Faso' },
{ code: 'BG', name: 'Bulgaria' },
{ code: 'BH', name: 'Bahrain' },
{ code: 'BI', name: 'Burundi' },
{ code: 'BJ', name: 'Benin' },
{ code: 'BL', name: 'Saint Barthélemy' },
{ code: 'BM', name: 'Bermuda' },
{ code: 'BN', name: 'Brunei' },
{ code: 'BO', name: 'Bolivia' },
{ code: 'BQ', name: 'Bonaire, Sint Eustatius and Saba' },
{ code: 'BR', name: 'Brazil' },
{ code: 'BS', name: 'Bahamas' },
{ code: 'BT', name: 'Bhutan' },
{ code: 'BV', name: 'Bouvet Island' },
{ code: 'BW', name: 'Botswana' },
{ code: 'BY', name: 'Belarus' },
{ code: 'BZ', name: 'Belize' },
{ code: 'CA', name: 'Canada' },
{ code: 'CC', name: 'Cocos (Keeling) Islands' },
{ code: 'CD', name: 'Congo - Kinshasa' },
{ code: 'CF', name: 'Central African Republic' },
{ code: 'CG', name: 'Congo - Brazzaville' },
{ code: 'CH', name: 'Switzerland' },
{ code: 'CI', name: 'Côte d\'Ivoire' },
{ code: 'CK', name: 'Cook Islands' },
{ code: 'CL', name: 'Chile' },
{ code: 'CM', name: 'Cameroon' },
{ code: 'CN', name: 'China' },
{ code: 'CO', name: 'Colombia' },
{ code: 'CR', name: 'Costa Rica' },
{ code: 'CU', name: 'Cuba' },
{ code: 'CV', name: 'Cape Verde' },
{ code: 'CW', name: 'Curaçao' },
{ code: 'CX', name: 'Christmas Island' },
{ code: 'CY', name: 'Cyprus' },
{ code: 'CZ', name: 'Czech Republic' },
{ code: 'DE', name: 'Germany' },
{ code: 'DJ', name: 'Djibouti' },
{ code: 'DK', name: 'Denmark' },
{ code: 'DM', name: 'Dominica' },
{ code: 'DO', name: 'Dominican Republic' },
{ code: 'DZ', name: 'Algeria' },
{ code: 'EC', name: 'Ecuador' },
{ code: 'EE', name: 'Estonia' },
{ code: 'EG', name: 'Egypt' },
{ code: 'EH', name: 'Western Sahara' },
{ code: 'ER', name: 'Eritrea' },
{ code: 'ES', name: 'Spain' },
{ code: 'ET', name: 'Ethiopia' },
{ code: 'FI', name: 'Finland' },
{ code: 'FJ', name: 'Fiji' },
{ code: 'FK', name: 'Falkland Islands' },
{ code: 'FM', name: 'Micronesia' },
{ code: 'FO', name: 'Faroe Islands' },
{ code: 'FR', name: 'France' },
{ code: 'GA', name: 'Gabon' },
{ code: 'GB', name: 'United Kingdom' },
{ code: 'GD', name: 'Grenada' },
{ code: 'GE', name: 'Georgia' },
{ code: 'GF', name: 'French Guiana' },
{ code: 'GG', name: 'Guernsey' },
{ code: 'GH', name: 'Ghana' },
{ code: 'GI', name: 'Gibraltar' },
{ code: 'GL', name: 'Greenland' },
{ code: 'GM', name: 'Gambia' },
{ code: 'GN', name: 'Guinea' },
{ code: 'GP', name: 'Guadeloupe' },
{ code: 'GQ', name: 'Equatorial Guinea' },
{ code: 'GR', name: 'Greece' },
{ code: 'GS', name: 'South Georgia and the South Sandwich Islands' },
{ code: 'GT', name: 'Guatemala' },
{ code: 'GU', name: 'Guam' },
{ code: 'GW', name: 'Guinea-Bissau' },
{ code: 'GY', name: 'Guyana' },
{ code: 'HK', name: 'Hong Kong SAR China' },
{ code: 'HM', name: 'Heard & McDonald Islands' },
{ code: 'HN', name: 'Honduras' },
{ code: 'HR', name: 'Croatia' },
{ code: 'HT', name: 'Haiti' },
{ code: 'HU', name: 'Hungary' },
{ code: 'ID', name: 'Indonesia' },
{ code: 'IE', name: 'Ireland' },
{ code: 'IL', name: 'Israel' },
{ code: 'IM', name: 'Isle of Man' },
{ code: 'IN', name: 'India' },
{ code: 'IO', name: 'British Indian Ocean Territory' },
{ code: 'IQ', name: 'Iraq' },
{ code: 'IR', name: 'Iran' },
{ code: 'IS', name: 'Iceland' },
{ code: 'IT', name: 'Italy' },
{ code: 'JE', name: 'Jersey' },
{ code: 'JM', name: 'Jamaica' },
{ code: 'JO', name: 'Jordan' },
{ code: 'JP', name: 'Japan' },
{ code: 'KE', name: 'Kenya' },
{ code: 'KG', name: 'Kyrgyzstan' },
{ code: 'KH', name: 'Cambodia' },
{ code: 'KI', name: 'Kiribati' },
{ code: 'KM', name: 'Comoros' },
{ code: 'KN', name: 'Saint Kitts and Nevis' },
{ code: 'KP', name: 'North Korea' },
{ code: 'KR', name: 'South Korea' },
{ code: 'KW', name: 'Kuwait' },
{ code: 'KY', name: 'Cayman Islands' },
{ code: 'KZ', name: 'Kazakhstan' },
{ code: 'LA', name: 'Laos' },
{ code: 'LB', name: 'Lebanon' },
{ code: 'LC', name: 'Saint Lucia' },
{ code: 'LI', name: 'Liechtenstein' },
{ code: 'LK', name: 'Sri Lanka' },
{ code: 'LR', name: 'Liberia' },
{ code: 'LS', name: 'Lesotho' },
{ code: 'LT', name: 'Lithuania' },
{ code: 'LU', name: 'Luxembourg' },
{ code: 'LV', name: 'Latvia' },
{ code: 'LY', name: 'Libya' },
{ code: 'MA', name: 'Morocco' },
{ code: 'MC', name: 'Monaco' },
{ code: 'MD', name: 'Moldova' },
{ code: 'ME', name: 'Montenegro' },
{ code: 'MF', name: 'Saint Martin' },
{ code: 'MG', name: 'Madagascar' },
{ code: 'MH', name: 'Marshall Islands' },
{ code: 'MK', name: 'North Macedonia' },
{ code: 'ML', name: 'Mali' },
{ code: 'MM', name: 'Myanmar (Burma)' },
{ code: 'MN', name: 'Mongolia' },
{ code: 'MO', name: 'Macao SAR China' },
{ code: 'MP', name: 'Northern Mariana Islands' },
{ code: 'MQ', name: 'Martinique' },
{ code: 'MR', name: 'Mauritania' },
{ code: 'MS', name: 'Montserrat' },
{ code: 'MT', name: 'Malta' },
{ code: 'MU', name: 'Mauritius' },
{ code: 'MV', name: 'Maldives' },
{ code: 'MW', name: 'Malawi' },
{ code: 'MX', name: 'Mexico' },
{ code: 'MY', name: 'Malaysia' },
{ code: 'MZ', name: 'Mozambique' },
{ code: 'NA', name: 'Namibia' },
{ code: 'NC', name: 'New Caledonia' },
{ code: 'NE', name: 'Niger' },
{ code: 'NF', name: 'Norfolk Island' },
{ code: 'NG', name: 'Nigeria' },
{ code: 'NI', name: 'Nicaragua' },
{ code: 'NL', name: 'Netherlands' },
{ code: 'NO', name: 'Norway' },
{ code: 'NP', name: 'Nepal' },
{ code: 'NR', name: 'Nauru' },
{ code: 'NU', name: 'Niue' },
{ code: 'NZ', name: 'New Zealand' },
{ code: 'OM', name: 'Oman' },
{ code: 'PA', name: 'Panama' },
{ code: 'PE', name: 'Peru' },
{ code: 'PF', name: 'French Polynesia' },
{ code: 'PG', name: 'Papua New Guinea' },
{ code: 'PH', name: 'Philippines' },
{ code: 'PK', name: 'Pakistan' },
{ code: 'PL', name: 'Poland' },
{ code: 'PM', name: 'Saint Pierre and Miquelon' },
{ code: 'PN', name: 'Pitcairn Islands' },
{ code: 'PR', name: 'Puerto Rico' },
{ code: 'PS', name: 'Palestinian Territories' },
{ code: 'PT', name: 'Portugal' },
{ code: 'PW', name: 'Palau' },
{ code: 'PY', name: 'Paraguay' },
{ code: 'QA', name: 'Qatar' },
{ code: 'RE', name: 'Réunion' },
{ code: 'RO', name: 'Romania' },
{ code: 'RS', name: 'Serbia' },
{ code: 'RU', name: 'Russia' },
{ code: 'RW', name: 'Rwanda' },
{ code: 'SA', name: 'Saudi Arabia' },
{ code: 'SB', name: 'Solomon Islands' },
{ code: 'SC', name: 'Seychelles' },
{ code: 'SD', name: 'Sudan' },
{ code: 'SE', name: 'Sweden' },
{ code: 'SG', name: 'Singapore' },
{ code: 'SH', name: 'Saint Helena' },
{ code: 'SI', name: 'Slovenia' },
{ code: 'SJ', name: 'Svalbard and Jan Mayen' },
{ code: 'SK', name: 'Slovakia' },
{ code: 'SL', name: 'Sierra Leone' },
{ code: 'SM', name: 'San Marino' },
{ code: 'SN', name: 'Senegal' },
{ code: 'SO', name: 'Somalia' },
{ code: 'SR', name: 'Suriname' },
{ code: 'SS', name: 'South Sudan' },
{ code: 'ST', name: 'São Tomé and Príncipe' },
{ code: 'SV', name: 'El Salvador' },
{ code: 'SX', name: 'Sint Maarten' },
{ code: 'SY', name: 'Syria' },
{ code: 'SZ', name: 'Eswatini' },
{ code: 'TC', name: 'Turks and Caicos Islands' },
{ code: 'TD', name: 'Chad' },
{ code: 'TF', name: 'French Southern Territories' },
{ code: 'TG', name: 'Togo' },
{ code: 'TH', name: 'Thailand' },
{ code: 'TJ', name: 'Tajikistan' },
{ code: 'TK', name: 'Tokelau' },
{ code: 'TL', name: 'Timor-Leste' },
{ code: 'TM', name: 'Turkmenistan' },
{ code: 'TN', name: 'Tunisia' },
{ code: 'TO', name: 'Tonga' },
{ code: 'TR', name: 'Turkey' },
{ code: 'TT', name: 'Trinidad and Tobago' },
{ code: 'TV', name: 'Tuvalu' },
{ code: 'TW', name: 'Taiwan' },
{ code: 'TZ', name: 'Tanzania' },
{ code: 'UA', name: 'Ukraine' },
{ code: 'UG', name: 'Uganda' },
{ code: 'UM', name: 'U.S. Outlying Islands' },
{ code: 'US', name: 'United States' },
{ code: 'UY', name: 'Uruguay' },
{ code: 'UZ', name: 'Uzbekistan' },
{ code: 'VA', name: 'Vatican City' },
{ code: 'VC', name: 'Saint Vincent and the Grenadines' },
{ code: 'VE', name: 'Venezuela' },
{ code: 'VG', name: 'British Virgin Islands' },
{ code: 'VI', name: 'U.S. Virgin Islands' },
{ code: 'VN', name: 'Vietnam' },
{ code: 'VU', name: 'Vanuatu' },
{ code: 'WF', name: 'Wallis and Futuna' },
{ code: 'WS', name: 'Samoa' },
{ code: 'XK', name: 'Kosovo' },
{ code: 'YE', name: 'Yemen' },
{ code: 'YT', name: 'Mayotte' },
{ code: 'ZA', name: 'South Africa' },
{ code: 'ZM', name: 'Zambia' },
{ code: 'ZW', name: 'Zimbabwe' }
];
// Create lookup maps for fast access
const countryNamesByCode = new Map(
COUNTRIES.map(country => [country.code, country.name])
);
const countriesByName = new Map(
COUNTRIES.map(country => [country.name.toLowerCase(), country])
);
/**
* Get country name for a country code
*/
export const getCountryName = (countryCode: string): string => {
if (!countryCode) return 'Unknown';
const upperCode = countryCode.toUpperCase();
return countryNamesByCode.get(upperCode) || countryCode;
};
/**
* Get both flag and name formatted (for display)
*/
export const getCountryDisplay = (countryCode: string): string => {
if (!countryCode) return 'Unknown';
const name = getCountryName(countryCode);
return `${countryCode.toUpperCase()} - ${name}`;
};
/**
* Get all countries sorted by name for dropdowns
*/
export const getAllCountries = (): Array<{ code: string; name: string; display: string }> => {
return COUNTRIES
.map(country => ({
code: country.code,
name: country.name,
display: `${country.name}`
}))
.sort((a, b) => a.name.localeCompare(b.name));
};
/**
* Search countries by name or code (for autocomplete)
*/
export const searchCountries = (query: string): Array<{ code: string; name: string; display: string }> => {
if (!query) return getAllCountries();
const lowerQuery = query.toLowerCase();
return getAllCountries().filter(country =>
country.name.toLowerCase().includes(lowerQuery) ||
country.code.toLowerCase().includes(lowerQuery)
);
};
/**
* Parse country from various input formats
*/
export const parseCountryInput = (input: string): string | null => {
if (!input) return null;
const trimmed = input.trim();
// If it's already a country code and exists
if (trimmed.length === 2 && countryNamesByCode.has(trimmed.toUpperCase())) {
return trimmed.toUpperCase();
}
// Search by name
const found = countriesByName.get(trimmed.toLowerCase());
return found ? found.code : null;
};
/**
* Validate if a country code exists
*/
export const isValidCountryCode = (code: string): boolean => {
if (!code) return false;
return countryNamesByCode.has(code.toUpperCase());
};
/**
* Get countries by region/continent (basic grouping)
*/
export const getCountriesByRegion = (region: 'europe' | 'asia' | 'africa' | 'americas' | 'oceania'): Array<{ code: string; name: string }> => {
// Basic regional groupings - this could be expanded with more detailed data
const regions = {
europe: ['AD', 'AL', 'AM', 'AT', 'AZ', 'BA', 'BE', 'BG', 'BY', 'CH', 'CY', 'CZ', 'DE', 'DK', 'EE', 'ES', 'FI', 'FR', 'GB', 'GE', 'GR', 'HR', 'HU', 'IE', 'IS', 'IT', 'LI', 'LT', 'LU', 'LV', 'MC', 'MD', 'ME', 'MK', 'MT', 'NL', 'NO', 'PL', 'PT', 'RO', 'RS', 'RU', 'SE', 'SI', 'SK', 'SM', 'TR', 'UA', 'VA'],
asia: ['AF', 'BD', 'BH', 'BN', 'BT', 'CN', 'ID', 'IL', 'IN', 'IQ', 'IR', 'JO', 'JP', 'KG', 'KH', 'KP', 'KR', 'KW', 'KZ', 'LA', 'LB', 'LK', 'MM', 'MN', 'MV', 'MY', 'NP', 'OM', 'PH', 'PK', 'QA', 'SA', 'SG', 'SY', 'TH', 'TJ', 'TL', 'TM', 'TW', 'UZ', 'VN', 'YE'],
africa: ['AO', 'BF', 'BI', 'BJ', 'BW', 'CD', 'CF', 'CG', 'CI', 'CM', 'CV', 'DJ', 'DZ', 'EG', 'EH', 'ER', 'ET', 'GA', 'GH', 'GM', 'GN', 'GQ', 'GW', 'KE', 'KM', 'LR', 'LS', 'LY', 'MA', 'MG', 'ML', 'MR', 'MU', 'MW', 'MZ', 'NA', 'NE', 'NG', 'RW', 'SC', 'SD', 'SL', 'SN', 'SO', 'SS', 'ST', 'SZ', 'TD', 'TG', 'TN', 'TZ', 'UG', 'ZA', 'ZM', 'ZW'],
americas: ['AG', 'AR', 'BB', 'BZ', 'BO', 'BR', 'BS', 'CA', 'CL', 'CO', 'CR', 'CU', 'DM', 'DO', 'EC', 'GD', 'GT', 'GY', 'HN', 'HT', 'JM', 'KN', 'LC', 'MX', 'NI', 'PA', 'PE', 'PY', 'SR', 'SV', 'TT', 'US', 'UY', 'VC', 'VE'],
oceania: ['AU', 'FJ', 'KI', 'MH', 'FM', 'NR', 'NZ', 'PW', 'PG', 'SB', 'TO', 'TV', 'VU', 'WS']
};
const regionCodes = regions[region] || [];
return COUNTRIES.filter(country => regionCodes.includes(country.code));
};