Setting the content type for input fields helps user entering data. For example, an e-mail address and password can be autofilled by a password manager. When the content type has not been set, this might not be possible to do automatically.
Relates to 1.3.5
On Android, you can set a content type by using the android:optimizeForAutoFill
property.
The following values are defined:
creditCardExpirationDate
: auto-fillcredit card expiration datecreditCardExpirationDay
: credit card expiration daycreditCardExpirationMonth
: credit card expiration monthcreditCardExpirationYear
: credit card expiration yearcreditCardNumber
: credit card numbercreditCardSecurityCode
: credit card security codeemailAddress
: email addressname
: namepassword
: passwordphone
: phone numberpostalAddress
: postal addresspostalCode
: postal codeusername
: username
Example of using autofillHints
:
<EditText
android:autofillHints="emailAddress" />
On iOS, you can set a content type by using the textContentType
property.
The following values are defined in UITextContentType
:
addressCity
: entering a cityaddressCityAndState
: entering a city and stateaddressState
: entering a statecountryName
: entering a countrycreditCardNumber
: entering a credit card numberdateTime
: entering a date, time, or durationemailAddress
: entering an email addressfamilyName
: entering a family name, or last nameflightNumber
: entering an airline flight numberfullStreetAddress
: entering a street address that fully identifies a locationgivenName
: entering a first namejobTitle
: entering a job titlelocation
: entering a locationmiddleName
: entering a middle namename
: entering a namenamePrefix
: entering a prefix or titlenameSuffix
: entering a suffixnewPassword
: entering a new passwordnickname
: entering a nicknameoneTimeCode
: entering a one-time codeorganizationName
: entering an organization namepassword
: entering a passwordpostalCode
: entering a postal codeshipmentTrackingNumber
: entering a parcel tracking numberstreetAddressLine1
: entering the first line of an addressstreetAddressLine2
: entering the second line of an addresssublocality
: entering a sublocalitytelephoneNumber
: entering a telephone numberURL
: entering a URLusername
: entering a username
Example of using textContentType
:
emailField.textContentType = .emailAddress
In Flutter, you can set a content type by using the autoFillHints
property.
It's important to note that constants are platform dependent and don't work the same everywhere, or even at all.
The following constants are defined:
addressCity
: The input field expects an address locality (city/town).addressCityAndState
: The input field expects a city name combined with a state name.addressState
: The input field expects a region/state.birthday
: The input field expects a person's full birth date.birthdayDay
: The input field expects a person's birth day(of the month).birthdayMonth
: The input field expects a person's birth month.birthdayYear
: The input field expects a person's birth year.countryCode
: The input field expects an ISO 3166-1-alpha-2 country code.countryName
: The input field expects a country name.creditCardExpirationDate
: The input field expects a credit card expiration date.creditCardExpirationDay
: The input field expects a credit card expiration day.creditCardExpirationMonth
: The input field expects a credit card expiration month.creditCardExpirationYear
: The input field expects a credit card expiration year.creditCardFamilyName
: The input field expects the holder's last/family name as given on a credit card.creditCardGivenName
: The input field expects the holder's first/given name as given on a credit card.creditCardMiddleName
: The input field expects the holder's middle name as given on a credit card.creditCardName
: The input field expects the holder's full name as given on a credit card.creditCardNumber
: The input field expects a credit card number.creditCardSecurityCode
: The input field expects a credit card security code.creditCardType
: The input field expects the type of a credit card, for example "Visa".email
: The input field expects an email address.familyName
: The input field expects a person's last/family name.fullStreetAddress
: The input field expects a street address that fully identifies a location.gender
: The input field expects a gender.givenName
: The input field expects a person's first/given name.impp
: The input field expects a URL representing an instant messaging protocol endpoint.jobTitle
: The input field expects a job title.language
: The input field expects the preferred language of the user.location
: The input field expects a location, such as a point of interest, an address,or another way to identify a location.middleInitial
: The input field expects a person's middle initial.middleName
: The input field expects a person's middle name.name
: The input field expects a person's full name.namePrefix
: The input field expects a person's name prefix or title, such as "Dr.".nameSuffix
: The input field expects a person's name suffix, such as "Jr.".newPassword
: The input field expects a newly created password for save/update.newUsername
: The input field expects a newly created username for save/update.nickname
: The input field expects a nickname.oneTimeCode
: The input field expects a SMS one-time code.organizationName
: The input field expects an organization name corresponding to the person, address, or contact information in the other fields associated with this field.password
: The input field expects a password.photo
: The input field expects a photograph, icon, or other image corresponding to the company, person, address, or contact information in the other fields associated with this field.postalAddress
: The input field expects a postal address.postalAddressExtended
: The input field expects an auxiliary address details.postalAddressExtendedPostalCode
: The input field expects an extended ZIP/POSTAL code.postalCode
: The input field expects a postal code.streetAddressLevel1
: The first administrative level in the address. This is typically the province in which the address is located. In the United States, this would be the state. In Switzerland, the canton. In the United Kingdom, the post town.streetAddressLevel2
: The second administrative level, in addresses with at least two of them. In countries with two administrative levels, this would typically be the city, town, village, or other locality in which the address is located.streetAddressLevel3
: The third administrative level, in addresses with at least three administrative levels.streetAddressLevel4
: The finest-grained administrative level, in addresses which have four levels.streetAddressLine1
: The input field expects the first line of a street address.streetAddressLine2
: The input field expects the second line of a street address.streetAddressLine3
: The input field expects the third line of a street address.sublocality
: The input field expects a sublocality.telephoneNumber
: The input field expects a telephone number.telephoneNumberAreaCode
: The input field expects a phone number's area code, with a country -internal prefix applied if applicable.telephoneNumberCountryCode
: The input field expects a phone number's country code.telephoneNumberDevice
: The input field expects the current device's phone number, usually for Sign Up / OTP flows.telephoneNumberExtension
: The input field expects a phone number's internal extension code.telephoneNumberLocal
: The input field expects a phone number without the country code and area code components.telephoneNumberLocalPrefix
: The input field expects the first part of the component of the telephone number that follows the area code, when that component is split into two components.telephoneNumberLocalSuffix
: The input field expects the second part of the component of the telephone number that follows the area code, when that component is split into two components.telephoneNumberNational
: The input field expects a phone number without country code.transactionAmount
: The amount that the user would like for the transaction (e.g. when entering a bid or sale price).transactionCurrency
: The currency that the user would prefer the transaction to use, in ISO 4217 currency code.url
: The input field expects a URL.username
: The input field expects a username or an account name.
TextFormField(
autofillHints: [AutofillHints.email]
)
In React Native,there are different properties for Android and iOS to set the content type. For Android, you can use the autoComplete
property. For iOS, you can use the textContentType
property.
Available values for autoComplete
on Android:
birthdate-day
birthdate-full
birthdate-month
birthdate-year
cc-csc
cc-exp
cc-exp-day
cc-exp-month
cc-exp-year
cc-number
email
gender
name
name-family
name-given
name-middle
name-middle-initial
name-prefix
name-suffix
password
password-new
postal-address
postal-address-country
postal-address-extended
postal-address-extended-postal-code
postal-address-locality
postal-address-region
postal-code
street-address
sms-otp
tel
tel-country-code
tel-national
tel-device
username
username-new
off
Available values for textContentType
on iOS:
none
URL
addressCity
addressCityAndState
addressState
countryName
creditCardNumber
emailAddress
familyName
fullStreetAddress
givenName
jobTitle
location
middleName
name
namePrefix
nameSuffix
nickname
organizationName
postalCode
streetAddressLine1
streetAddressLine2
sublocality
telephoneNumber
username
password
newPassword
oneTimeCode
<TextInput
autoComplete='email'
textContentType='emailAdress'
/>
Xamarin.Forms does not support content types for input fields. You can create your own autofill effect. Unfortunately, the pull request for adding it to XamarinCommunitToolkit has been closed.
Not available, contribute!