PhoneInput: improve styles

This commit is contained in:
Alex Gleason 2022-07-13 18:45:42 -05:00
parent 0591bf72a5
commit 7f7edf9162
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
3 changed files with 17 additions and 7 deletions

View file

@ -52,7 +52,7 @@ const Input = React.forwardRef<HTMLInputElement, IInput>(
}, []); }, []);
return ( return (
<div className={classNames('mt-1 relative rounded-md shadow-sm', outerClassName)}> <div className={classNames('mt-1 relative shadow-sm', outerClassName)}>
{icon ? ( {icon ? (
<div className='absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none'> <div className='absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none'>
<Icon src={icon} className='h-4 w-4 text-gray-400' aria-hidden='true' /> <Icon src={icon} className='h-4 w-4 text-gray-400' aria-hidden='true' />

View file

@ -1,5 +1,6 @@
import React from 'react'; import React from 'react';
import { Icon, HStack } from 'soapbox/components/ui';
import DropdownMenu from 'soapbox/containers/dropdown_menu_container'; import DropdownMenu from 'soapbox/containers/dropdown_menu_container';
import { COUNTRY_CODES, CountryCode } from 'soapbox/utils/phone'; import { COUNTRY_CODES, CountryCode } from 'soapbox/utils/phone';
@ -26,7 +27,12 @@ const CountryCodeDropdown: React.FC<ICountryCodeDropdown> = ({ countryCode, onCh
return ( return (
<DropdownMenu items={menu}> <DropdownMenu items={menu}>
<button className='px-4'>+{countryCode}</button> <button className='px-4 items-center'>
<HStack space={1} alignItems='center'>
<div>+{countryCode}</div>
<Icon className='w-4 h-4 stroke-primary-600' src={require('@tabler/icons/chevron-down.svg')} />
</HStack>
</button>
</DropdownMenu> </DropdownMenu>
); );
}; };

View file

@ -57,14 +57,18 @@ const PhoneInput: React.FC<IPhoneInput> = (props) => {
}, [countryCode, nationalNumber]); }, [countryCode, nationalNumber]);
return ( return (
<HStack alignItems='center'> <HStack className='mt-1 shadow-sm'>
<CountryCodeDropdown <div className='dark:bg-slate-800 border border-solid border-r-0 border-gray-300 dark:border-gray-600 flex items-center rounded-l-md'>
countryCode={countryCode} <CountryCodeDropdown
onChange={setCountryCode} countryCode={countryCode}
/> onChange={setCountryCode}
/>
</div>
<Input <Input
type='text' type='text'
outerClassName='mt-0 shadow-none'
className='rounded-l-none'
onChange={handleChange} onChange={handleChange}
value={nationalNumber} value={nationalNumber}
{...rest} {...rest}