|
|
@ -1,10 +1,11 @@
|
|
|
|
import React, { useEffect, useMemo, useState } from 'react';
|
|
|
|
import React, { useEffect, useMemo, useState } from 'react';
|
|
|
|
import { Listbox, Transition } from '@headlessui/react';
|
|
|
|
import { Listbox, Transition } from '@headlessui/react';
|
|
|
|
import { countryCodeEmoji } from 'country-code-emoji';
|
|
|
|
|
|
|
|
import useSWR from 'swr';
|
|
|
|
import useSWR from 'swr';
|
|
|
|
import type { Region } from '../../../server/lib/settings';
|
|
|
|
import type { Region } from '../../../server/lib/settings';
|
|
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
|
|
import useSettings from '../../hooks/useSettings';
|
|
|
|
import useSettings from '../../hooks/useSettings';
|
|
|
|
|
|
|
|
import { hasFlag } from 'country-flag-icons';
|
|
|
|
|
|
|
|
import 'country-flag-icons/3x2/flags.css';
|
|
|
|
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
const messages = defineMessages({
|
|
|
|
regionDefault: 'All Regions',
|
|
|
|
regionDefault: 'All Regions',
|
|
|
@ -64,9 +65,13 @@ const RegionSelector: React.FC<RegionSelectorProps> = ({
|
|
|
|
<div className="relative">
|
|
|
|
<div className="relative">
|
|
|
|
<span className="inline-block w-full rounded-md shadow-sm">
|
|
|
|
<span className="inline-block w-full rounded-md shadow-sm">
|
|
|
|
<Listbox.Button className="relative flex items-center w-full py-2 pl-3 pr-10 text-left text-white transition duration-150 ease-in-out bg-gray-700 border border-gray-500 rounded-md cursor-default focus:outline-none focus:shadow-outline-blue focus:border-blue-300 sm:text-sm sm:leading-5">
|
|
|
|
<Listbox.Button className="relative flex items-center w-full py-2 pl-3 pr-10 text-left text-white transition duration-150 ease-in-out bg-gray-700 border border-gray-500 rounded-md cursor-default focus:outline-none focus:shadow-outline-blue focus:border-blue-300 sm:text-sm sm:leading-5">
|
|
|
|
{selectedRegion && selectedRegion.iso_3166_1 !== 'all' && (
|
|
|
|
{selectedRegion &&
|
|
|
|
<span className="h-4 mr-2 overflow-hidden text-lg leading-4">
|
|
|
|
selectedRegion.iso_3166_1 !== 'all' &&
|
|
|
|
{countryCodeEmoji(selectedRegion.iso_3166_1)}
|
|
|
|
hasFlag(selectedRegion?.iso_3166_1) && (
|
|
|
|
|
|
|
|
<span className="h-4 mr-2 overflow-hidden text-base leading-4">
|
|
|
|
|
|
|
|
<span
|
|
|
|
|
|
|
|
className={`flag:${selectedRegion?.iso_3166_1}`}
|
|
|
|
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
</span>
|
|
|
|
)}
|
|
|
|
)}
|
|
|
|
<span className="block truncate">
|
|
|
|
<span className="block truncate">
|
|
|
@ -180,7 +185,7 @@ const RegionSelector: React.FC<RegionSelectorProps> = ({
|
|
|
|
<span
|
|
|
|
<span
|
|
|
|
className={`${
|
|
|
|
className={`${
|
|
|
|
selected ? 'font-semibold' : 'font-normal'
|
|
|
|
selected ? 'font-semibold' : 'font-normal'
|
|
|
|
} block truncate`}
|
|
|
|
} block truncate pl-8`}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
{intl.formatMessage(messages.regionDefault)}
|
|
|
|
{intl.formatMessage(messages.regionDefault)}
|
|
|
|
</span>
|
|
|
|
</span>
|
|
|
@ -217,8 +222,14 @@ const RegionSelector: React.FC<RegionSelectorProps> = ({
|
|
|
|
: 'text-gray-300'
|
|
|
|
: 'text-gray-300'
|
|
|
|
} cursor-default select-none relative py-2 pl-8 pr-4 flex items-center`}
|
|
|
|
} cursor-default select-none relative py-2 pl-8 pr-4 flex items-center`}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
<span className="mr-2 text-lg">
|
|
|
|
<span className="mr-2 text-base">
|
|
|
|
{countryCodeEmoji(region.iso_3166_1)}
|
|
|
|
<span
|
|
|
|
|
|
|
|
className={
|
|
|
|
|
|
|
|
hasFlag(region.iso_3166_1)
|
|
|
|
|
|
|
|
? `flag:${region.iso_3166_1}`
|
|
|
|
|
|
|
|
: 'pr-6'
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
</span>
|
|
|
|
<span
|
|
|
|
<span
|
|
|
|
className={`${
|
|
|
|
className={`${
|
|
|
|