Skip to main content

TextField

The TextField widget allows users to enter text, numbers, and symbols in your app. You can use the TextField widget to build forms, send messages, dialogs, search, etc.

Widget State

Before diving into form widgets, check out our guide on Widget States to efficiently manage the state and behavior of your form elements.

Adding TextField widget

Let's see how to add a TextField widget and see an example of displaying its value in an Alert Dialog.

Here are the steps:

  1. First, add the TextField widget, move to the properties panel and give it a name.
  2. Add the Button widget and on tap of it, add an Alert Dialog action. While adding this action, provide the Message From Variable > Widget State > [TextFieldName].

Customizing

You can customize the appearance and behavior of this widget using the various properties available under the properties panel.

Changing width

By default, the TextField widget takes all the available space in the horizontal direction. You might want to limit its width to match your design. See how to change the width of this widget.

Adding multiline/auto expand support

By default, a TextField is only one line. So when you type in a long text that won't fit in one line, you'll be able to see an entire message using a horizontal scrollbar. You can change this default behavior and show the full message (without a horizontal scrollbar) by making the TextField multiline/auto-expand.

To make a TextField multiline/auto-expand, move the Properties Panel > find the Max Lines and Min Lines properties.

  1. To make the TextField auto-expand as long as its parent allows, remove the Max Lines value and set the Min Lines to 1.
  2. To make the TextField auto-expand up to a few lines and then show a vertical scrollbar to see the full message, set Max Lines to a value up to which you like to show an entire message (e.g., 3,5) and Min Lines to 1.

Setting prefilled value

You might want to display a TextField with some initial value. This can be any specific value such as "What are you looking for", "Input your Email", or a value from any variable.

To set the initial value, move to the Properties Panel > TextField Properties > Initial Value and enter the specific value or Set from Variable.

setting-prefilled-value

Adding label

Showing a label helps users understand what should be entered into the TextField. If you don't have an initial value set, the Label Text will appear as full size in the TextField. Once the user taps the TextField, the Label Text will become smaller, and the Hint Text will appear.

To set the label, move to the Properties Panel > Label Properties > enter the Label Text.

adding-label

When the TextField is set to Multiline the label appears in the center. To get it closer to the hint text, switch on the Align Label With Hint property.

Setting hint text

Showing a hint text helps users know what information is needed to enter into the TextField. For example, showing hint text as "Enter Your Email Here" clearly informs the user to enter their email.

To set the hint text, move to the Properties Panel > Hint Properties > enter the Hint Text.

setting-hint-text

Decorating TextField

Various properties under the Input Decoration Properties allow you to customize the TextField to match your design.

Changing TextField background color

To change the background color, move to the Properties Panel > Input Decoration Properties > enable Filled > set the Fill Color.

Adding border

Here's an example of how you can add a border around the TextField:

  1. Select TextField widget, move to the Properties Panel > Input Decoration Properties > select the Input Border Type.
    1. Choose Outline to place a border around the entire field.
    2. Choose Underline to place a border only on the bottom of the field.
    3. Choose None to completely remove the border.
  2. You can also set a color to the border for various states, such as when TextField is in a Focused or Error state. To do so, use the Border Color, Focused Border Color, and Error Border Color.
  3. To increase the border thickness, use the Border Width property.
  4. To create the rounded border, use the Border Radius property. By default, any value your enter will be set for all corners, which are TL (Top left), TR (top right), BL (bottom left), and BR (bottom right). Click on the lock icon to change each corner separately. Use the refresh icon to reset the values.

Add content padding

Content Padding adds space between the test and the border of your TextField.

To add content padding, move to the Properties Panel > Input Decoration Properties > enter the Content Padding value.

Reducing TextField height

To reduce TextField's height to as minimum as possible, select the TextField widget, move to the Properties Panel > enable the Dense property.

Changing error message styling

You can also change the text styling for the error message. To do so, head over to Properties Panel > Input Decoration Properties > enable Custom Error Style and change the text styling.

changing-error-message-styling

Adding Icon

You might want to add an icon inside the TextField, either at the start or end. You can do so using the Leading and Trailing Icon property.

To add a leading or trailing icon, move to the Properties Panel > find the Leading and Trailing Icon property > Click on the None button > search and select the icon.

You can also customize the icon's size and color.

adding-icon

Using TextField for passwords

To make a TextField a Password Field, move to the Properties Panel > Additional Properties > enable the Password Field.

When you enter a password, it will be obscured with the dot (•). You can see and confirm the entered password by clicking on the

Toggle Hide Password Icon. You can also customize its size and color.

textfield-for-passowrd

Clear TextField

A clear field icon inside the TextField allows the users to quickly remove the entered text.

To clear a TextField, move to the Properties Panel > Additional Properties > enable the Show Clear Field Icon. You can also customize the icon's color and size.

Adding Clear Text Fields/Pin Codes [Action]

This action lets you clear the values from single or multiple TextField and PinCode widgets. This comes in handy while implementing a form inside your app, and you want to let the user reset the form with one click.

Follow the steps below to add this action to any widget.

  1. Select the Widget (e.g., IconButton, Button, etc.) on which you want to add the action.
  2. Select Actions from the properties panel (the right menu), click + Add Action button.
  3. Search and select the Clear Text Fields/Pin Codes (under Widget/UI Interactions) action.
  4. Select the TextFields and PinCode widgets you want to reset.

adding-clear-textfield-action

Autofocusing TextField

When you autofocus a TextField, it mimics the tap event and immediately shows the keyboard. This makes TextField ready to receive input from you without having you click on TextField.

To autofocus a TextField, select the TextField widget, move to the Properties Panel > Additional Properties > enable the Autofocus property.

Autocomplete a TextField

You might want to allow users to enter the text by suggesting them a list of items. The suggested items are shown if it contains the currently entered text from TextField. For example, using autocomplete to get the Country name, Fruit name, etc.

info

This helps avoid spelling mistakes and enhances the user experience as users won't have to enter the complete text.

To autocomplete a TextField, select the TextField widget, move to the Properties Panel > Additional Properties > enable the Autocomplete property.

Now you can customize the autocomplete using the Autocomplete Properties section. Here's how you do it:

  1. Inside the Autocomplete Options, click Add Option and provide item names that you would like to appear in the suggestion box.
  2. You can also Set from Variable to show items from any variable, such as app state variable, API response, and Firestore collection.
info

If you Set from Variable and run the app in preview mode, you can try entering the country name. The list will be populated with matching countries.

  1. You can also customize the appearance of the suggestion box using properties such as Height, Elevation, Background Color, and Highlight Color (highlighting the currently selected option in the dropdown list).
  2. To style the text displayed inside the dropdown list, you can use the Option Text Style and Substring Style (can be used to highlight the matching text in an item name).

Auto fill hint

When Auto Fill Hint property is enabled, it uses the operating system's autofill service to suggest the relevant information to the user, such as usernames, passwords, or credit card numbers, based on the context of the text field.

For example, you have a form where the user needs to enter their credit card information. You can use this property to help the autofill service suggest the user's credit card number and expiration date.

To enable the Auto Fill Hint property:

  1. Select the TextField widget, move to the Properties Panel > Additional Properties > enable the Auto Fill Hint property.
  2. Set the Auto Fill Hint Options to one that you want to provide a hint about.
warning

The availability and behavior of the Auto Fill Hint may vary by platform and user settings, and it does not guarantee that the operating system's autofill service will suggest the correct information to the user.

Update page on change

You might have added the TextField widget inside the search page and want to refresh the search result as the value inside the TextField changes.

info

Enabling this feature will refresh the page whenever a user types into TextField after a configurable delay.

Here's an example of displaying the TextField value in a Text widget in realtime:

  1. Select the TextField widget, move to the Properties Panel > Additional Properties > enable the Update Page On Change property.
  2. Also, set the Update Delay (ms) after which the page will refresh its UI when the user has stopped typing. For example, If the Update Delay (ms) value is set to 2000 ms (2 seconds), The page will update 2 seconds after use is done typing. For this example, let's keep it to 0.
  3. Now select the Text widget, move to the Properties Panel > Set from Variable > Widget State > [TextFieldName]. Tip: You can also set the default value to be displayed until the user has entered any text.
tip

We advise setting the delay value if you make an API call that accepts the input from TextField.

Read only TextField

Sometimes you might want to restrict users from entering or updating anything into TextField and only allowed it if they are in edit mode. You can accomplish this by switching the Read Only property.

Change cursor color

In a form with many text fields, changing the cursor color for the currently focused field can help the user understand where their input will go when they start typing.

To change the cursor color, head over to Properties Panel > Additional Properties > change the Cursor Color.

change-cursor-color

Changing keyboard type

When the keyboard opens by default, you can type any text. You might want user input in a certain format, such as a phone number, email address, website URL, etc. In this situation, you can choose a predefined keyboard type to present the appropriate key selections.

To change the keyboard type, select the TextField widget, move to the Properties Panel > Additional Properties > set the Keyboard Type to the right one.

keyboard-types

changing-keyboard-type

Masking input

You might want to allow users to provide input in a specific format. For example, if you want a date in a format like MM/DD/YYYY, where all input must be a number, and its length should not exceed eight digits. You can do so by formatting the user input using the specific mask.

To mask the user input, select the TextField widget, move to the Properties Panel > Additional Properties > set the Mask dropdown to the one you need.

If the required format is not on the list, you can select Custom and specify the Custom Mask. The '#' sign represents the number, and 'A' represents a letter. Here are some examples of Custom Masks:

InputCustom Mask
Credit card number (e.g., 3424 4353 5453 3535)#### #### #### ####
Custom date (e.g., 12-Jan-2023)##-AAA-####

Filtering input

You might want to restrict the type of characters that can be entered into a TextField. Let's say you are building an app that requires its employees to enter their employee ID when they clock in and out for their shifts. The employee ID consists of only letters and numbers, and the app should only allow these characters to be entered. You can do so by filtering the user input

To filter the user input, select the TextField widget, move to the Properties Panel > Additional Properties > set the Filter dropdown to the one you need.

Validating input

You can validate the TextField value by wrapping it inside the Form widget and adding the validation criteria.

tip

Filtering ensures that only the allowed characters or values are entered, whereas the validation checks the entire input data against certain criteria. Both techniques can be used together or independently to ensure the correctness of user input in a TextField widget.

Capitalization

You might want to control the capitalization of text when the user is typing, and also when the text is displayed. The Capitalization property allows you to specify how the text entered in the TextField should be capitalized.

This property accepts one of the following values:

  • None: This value means that no capitalization should be applied to the text. All the characters will be displayed as they are typed.
  • Words: This value capitalizes the first letter of each word in the text.
  • Sentences: This value capitalizes the first letter of each sentence in the text.
  • Characters: This value capitalizes every character in the text.

To set the capitalization, select the TextField widget, move to the Properties Panel > Additional Properties > set the Capitalization dropdown to the one you need.

capitalization

Submit type

Showing a particular action on a keyboard can be useful in guiding users on what to do next. For example, if you have a search bar, you can display a "Search" button on the keyboard. When tapped, instead of moving to a new line or closing the keyboard, you can execute a search function. This can improve user experience by providing more intuitive keyboard actions based on the context of the input.

This property accepts one of the following values:

  • Done: This closes the keyboard.
  • Next: This moves focus to the next field.
  • Previous: This moves focus to the previous field.
  • Send: This represents the Send action.
  • Search: This represents the Search action
  • Go: This represents the Go action.

To set the submit type, select the TextField widget, move to the Properties Panel > Additional Properties > set the Submit Type dropdown to the one you need.

submit-type

Set max character length

Sometimes, you might want to specify the maximum number of characters users can enter into the TextField. When the user types or pastes text into the field and reaches the specified character limit, they won't be able to input more characters, or the TextField will visually indicate that the limit has been reached.

For example, When users can leave comments or post messages (similar to 'tweet'), setting a maximum character length can help prevent spam or excessively lengthy responses.

To set the max character limit, select the TextField widget, move to the Properties Panel > Additional Properties > set the Max Length (number of characters you want to allow), and set the Max Length Enforcement to one of the following values:

  • Not Enforced: This allows users to input extra characters and displays a warning when the limit is exceeded.
  • Enforced: This always truncates any additional character once the limit is reached.
info

You can also hide the maximum character count by enabling the Hide Max Length Counter option.

Hiding keyboard on tap

Hiding the keyboard when the user taps outside of a TextField is a common user experience pattern that many apps use to improve usability. When the keyboard is open, it can obscure important information on the screen and make it difficult for the user to interact with other parts of the app.

Adding this behavior in your app can make it easier for these users to interact with other parts of the app without interference from the keyboard. It can also make your app feel more polished and professional.

To hide/close the keyboard, select the page, move the Properties Panel > enable the Hide Keyboard on Tap.

Hide keyboard on tap

Focus change event

Sometimes, you may need to know whether a TextField is being used or not. For example, you can turn other parts of the app on or off depending on if the TextField is active. Also, you can start animations when someone starts or stops typing in the TextField.

Let's see an example of controlling the visibility of a Text widget based on the TextField's Focus state.

To do so:

  1. On a Text widget, add a Conditional Visibility based on the TextField's Focus state. You can access via Set from Variable menu > Widget Focus State > [TextField name].
  2. Now, on a TextField widget, under the On Focus Change callback, simply add an action to refresh the page by adding the update app state variable.

Trigger action / Listen callback

The TextField widget provides you with two types of actions (aka callbacks):

  1. On Submit: Actions under this will be triggered when you finish entering the text in the TextField widget. i.e., pressing a done button inside the soft keyboard.
  2. On Change: Actions under this will trigger when you enter or delete a character in the TextField widget.
  3. On Focus Change: Actions under this will trigger when the focus state changes on a TextField. This means when users click on it to type or click away from it.
warning

Be careful about adding the actions under the On Change. Specifically, you should avoid adding any action that will take more time.

To trigger an action:

  1. Select the TextField widget from the widget tree or canvas area.
  2. Select Actions from the Properties panel (the right menu), and click + Add Action.
  3. Select the Type of Action among the On Submit, On Change, and On Focus Change.
  4. Now you can add any action here.


Video guide

If you prefer watching a video tutorial, here's the one for you: