APL EditText
The EditText
component displays text in an editable box that supports modifying a single line of text.
EditText
requires APL 1.4 or later. Provide an alternate experience for devices running older versions of APL.Some environments might not allow editable text. Use the environment
property disallowEditText
to determine whether the current device and configuration supports editable text.
Properties
The EditText component has the following properties:
- All actionable component properties
- All base component properties
- The
EditText
properties listed in following table. See the meaning of the columns.
Property | Type | Default | Styled | Dynamic | Description | |
---|---|---|---|---|---|---|
|
<none> |
Yes |
Yes |
Color of the border around the text box. | ||
|
Non-negative Absolute Dimension |
<borderWidth> |
Yes |
Yes |
Width of the border stroke around the text box. | |
|
Non-negative Absolute Dimension |
0 |
Yes |
Yes |
Width of the border. | |
|
Depends on the theme |
Yes |
Yes |
Color of the text the user enters or the text provided in the | ||
|
String |
sans-serif |
Yes |
Yes |
The name of the font family. | |
|
Positive Absolute Dimension |
40dp |
Yes |
Yes |
The size of the text | |
|
normal, italic |
normal |
Yes |
Yes |
The style of the font | |
|
normal, bold, 100, 200, 300, 400, 500, 600, 700, 800, 900 |
normal |
Yes |
Yes |
The weight of the font | |
|
Depends on the theme |
Yes |
Yes |
The highlight color to show behind selected text. | ||
|
String |
"" |
Yes |
Yes |
Hint text to display when no text has been entered. Not shown when the | |
|
Depends on the theme |
Yes |
Yes |
The color of the hint text. | ||
|
normal, italic |
normal |
Yes |
Yes |
The style of the hint font | |
|
normal, bold, 100, 200, 300, 400, 500, 600, 700, 800, 900 |
normal |
Yes |
Yes |
The weight of the hint font | |
|
KeyboardType |
normal |
Yes |
No |
| |
|
String |
"" |
Yes |
Yes |
The language of the text. When set, APL attempts to find a language-specific version of the | |
|
Non-negative integer |
0 |
Yes |
No |
The maximum number of characters the user can enter in the edit box. | |
|
Array of Commands |
[] |
No |
No |
Command to run when the text changes from a user event. | |
|
Array of Commands |
[] |
No |
No |
Command to run when the user submits the update by pressing the specified submit key ( | |
|
Boolean |
false |
Yes |
Yes |
Hide characters as they are typed if true. | |
|
Boolean |
false |
Yes |
No |
| |
|
Positive integer |
8 |
Yes |
No |
Specifies approximately the number of characters to display. | |
|
SubmitKeyType |
done |
Yes |
No |
The type of the return key. The specified key sends an | |
|
String |
"" |
No |
Yes |
The text to display. | |
|
String |
"" |
Yes |
No |
Restrict the characters that can be entered |
When the EditText
is the source or target of an event, the following values are reported in event.source
or event.target
:
{
// EditText-specific values
"type": "EditText",
"text": String, // Displayed text (never the hint text)
"color": Color, // The text color
// General component values
"bind": Map, // Access to component data-binding context
"checked": Boolean, // Checked state
"disabled": Boolean, // Disabled state
"focused": Boolean, // Focused state
"height": Number, // Height of the component, in dp (includes the padding)
"id": ID, // ID of the component
"opacity": Number, // Opacity of the component [0-1]
"pressed": Boolean, // Pressed state
"uid": UID, // Runtime-generated unique ID of the component
"width": Number // Width of the component, in dp (includes the padding)
}
layoutDirection component property
The component layoutDirection
property determines the starting point and direction of the cursor for editing text:
LTR
: the cursor in theEditText
component starts from the left and moves to the right.RTL
: the cursor in theEditText
component starts from the right and moves to the left.
borderColor
The color of the border surrounding the EditText
box.
borderStrokeWidth
The width of the drawn border around the text box. When not specified, borderStrokeWidth
defaults to the specified borderWidth
. When specified, the actual width of the drawn border is the smaller value of the borderStrokeWidth
and borderWidth
. You can't draw a border outside of the border width.
Set this property separately from borderWidth
when you want to vary the width of the drawn border without re-laying out the positions of components in their parent. For example, assume you set borderWidth
to 2
and borderStrokeWidth
to 1
. The component displays with a one-pixel border, but occupies enough space on the viewport for a two-pixel border. When you change borderStrokeWidth
to 2
, the component displays with a two-pixel border without changing the amount of space the component occupies.
In contrast, if you use borderWidth
on its own and change it from 1
to 2
, the components displayed on the screen shift to accommodate the larger border.
borderWidth
The width of the border around the text box. Specify borderWidth
in an absolute dimension. You can't use relative dimensions. The border width does not affect the padding of the EditText
component.
color
The color of the displayed text. Defaults to #FAFAFA for a dark theme and #1E2222 for a light theme.
fontFamily
Specifies the font for the displayed text. The fontFamily
property takes a single font name or a string containing a comma-separated list of font names. The APL runtime searches the list for the first named font installed on the device. If no valid font is found, the runtime defaults to the sans-serif font.
Font names can contain spaces. APL supports two types of font names:
- The specific name of an installed font such as "amazon-ember", "times", "times new roman".
- A generic name - either "serif" or "sans-serif".
Alexa devices don't guarantee a specific set of fonts. End your fontFamily
list with either "serif" or "sans-serif" to make sure that a valid font is available.
{
"type": "Text",
"fontFamily", "times new roman, times, georgia, serif"
}
On many Alexa devices, "sans-serif" defaults to "Amazon Ember Display" and "serif" defaults to "Bookerly". In some Asian markets they default to "Noto Sans CJK".
For details about font styles available in the alexa-styles
package, see Font family.
fontSize
The size of the font. Defaults to 40dp. Specify the font size in absolute dimensions, not relative.
fontStyle
The style of the font, either normal
or italic
. Defaults to normal
.
fontWeight
The font weight for the displayed text. Defaults to normal
. The normal
and bold
values are assigned at runtime. The integer values 100 through 900 correspond to progressively darker variations of the font. Most fonts don't support this many variations. For example, Amazon Ember Display has five weights (Thin, Light, Regular, Medium, Bold) which are assigned 100, 300, 500, 700, and 900 respectively.
Note that fontWeight
represents an enumerated set, not integers or strings. For example, the value 750 is invalid and doesn't set the font to a weight between 700 and 800.
When you create a resource for a fontWeight
, use a string
resource. The following example resource block creates two resources for fontWeight
called myMidFontWeight
and myLightFontWeight
.
{
"resources": [
{
"strings": {
"myMidFontWeight": "500",
"myLightFontWeight": "100"
}
}
]
}
highlightColor
The color of the highlight shown behind a selected region of text. Defaults to #00CAFF4D for a dark theme and #0070BA4D for a light theme.
hint
A text string to display in the text block when there is no text to display. The hint
displays when text
is not set, or when the user deletes any text from the text block.
hintColor
The color of the hint text. Defaults to a theme-dependent and device-dependent value when not specified.
hintStyle
The style of the hint font – either normal or italic.
hintWeight
The weight of the hint font. This property works the same as the fontWeight
property.
keyboardType
Specifies the type of keyboard to display for the component. Accepts one of the following values.
Type | Description |
---|---|
|
Numbers and a decimal point |
|
Optimized for e-mail addresses, including the "@", ".", and space character. |
|
Default keyboard |
|
Numbers only (good for PIN codes) |
|
Numbers and the "*" and "#" characters |
|
Optimized for entering URLs |
The component defaults to the normal
(default) keyboard when the APL runtime doesn't support the requested keyboard.
lang
The language of the text. When set, APL attempts to find a language-specific version of the fontFamily
for displaying the text.
If no valid font is found, APL ignores this property and uses the specified fontFamily
.
Set the lang
property to a BCP-47 string (for example, "en-US").
The following example displays an EditText
component with a Japanese-style version of the NotoSans-CJK font:
{
"type": "APL",
"version": "2024.2",
"mainTemplate": {
"item": {
"type": "EditText",
"lang": "ja-JP",
"fontFamily": "Noto Sans CJK"
}
}
}
Note: Alexa devices might not have the font in specific language installed. Test the experience on the device or devices to confirm that it works.
maxLength
The maximum length of the text permitted in the edit text component, in characters. Set to 0 to allow an unrestricted number of characters. Specific implementations may find it necessary to limit the maximum text length internally; it is recommended that they support at least 1024 characters.
onTextChange
Commands to run when the user changes the text displayed in the component. This action sets event.source.text
to the text
content of the EditText
component.
This handler generates an event with the following form.
"event": {
"source": {
"type": "EditText",
"handler": "TextChange",
... // Component source properties
}
}
Refer to Event source for a description of event.source
properties.
The onTextChange
event handler runs in normal mode in the component data-binding context.
The following example shows an EditText
component with an onTextChange
handler that updates the text
property of a Text
component with the entered data. The onSubmit
handler updates a component to indicate that the results are "final" and also runs the SendEvent
command. On a device such as an Echo Show, tap the EditText
component to open an on-screen keyboard. In the code sandbox, click in the field and type with your normal keyboard, then press Enter to see the results of the onSubmit
handler. Copy the example to a skill to test the SendEvent
command.
onSubmit
Commands to run when the user presses the defined submit key. Configure the key that means "submit" with the submitKeyType
property.
This handler generates an event with the following form.
"event": {
"source": {
"type": "EditText",
"handler": "Submit",
... // Component source properties
}
}
Refer to Event source for a description of event.source
properties.
The onSubmit
event handler runs in normal mode in the component data-binding context.
secureInput
When true, the component obscures all characters as the user enters a value. Use this for sensitive text. This following keyboard types support secureInput
:
decimalPad
normal
numberPad
selectOnFocus
When true, the component highlights the text in the text block when the component gains focus. The user can delete all of the existing text in the component with a single backspace keystroke. When false, the cursor insertion point displays at the end of the text. This property defaults to false.
size
Specifies the default width of the EditText
component assuming that there are size
-number of "normal-width" characters in the current font. The actual number of characters that fit in the EditText
component depends on the width of the actual characters.
submitKeyType
Specifies the type of the submit key. The label of the key depends on the underlying platform. The following types are available:
Type | Example Label on Echo Show Devices (in en-US) |
---|---|
done |
Done |
go |
Go |
next |
Next |
search |
Search |
send |
Send |
No matter what the label
of the submit key, the onSubmit
event runs when the user presses the key.
text
Text string to display in the text block. If set to an empty string, no text displays. Setting to null
is equivalent to an empty string (""
).
When text
is empty or null, the EditText
component displays the hintText. The text the user enters replaces the displayed text
.
The character restrictions set in validCharacters
apply to the text
property. For example, if you set validCharacters
to restrict the set of characters the user can enter, you must set text
to a value meets those same restrictions.
validCharacters
When set, the characters that users can enter in the EditText
component are restricted to the characters provided. When empty or not set, there aren't any restrictions on characters.
The restrictions apply to the text
property. This includes all the scenarios in which you set or change the text
property:
- You set an initial value for the
text
property in your APL document - You use the
SetValue
command to set or change the value of thetext
property - The user selects the
EditText
component and types a value
The validCharacters
property doesn't apply to the hintText
property.
The following example restricts the component to hexadecimal characters.
{
"type": "EditText",
"validCharacters": "0-9a-fA-F"
}
The validCharacters
property is not a regular expression. The purpose of the validCharacters
property is to restrict character entry, not to validate the correctness of the final expression. The following table lists the rules for special characters:
Characters | Meaning |
---|---|
|
Specifies a range for Unicode code points. To include a hyphen ( |
|
Four hex digits, specifying a specific Unicode code point. Code points outside the Basic Multilingual Plane should be written using UTF-16 surrogate pairs. |
|
Quotation mark |
|
Reverse solidus |
Examples:
"0-9" // Pin-pad keyboard
"0-9." // Cash amount in US (good for an ATM)
"-+a-zA-Z0-9_@." // Classic e-mail address
EditText height and width
Set the component height and width properties. When you leave height and width not set, EditText
calculates the height and width.
The height of the component is set to display a single line of characters in the specified font. The width of the edit text component is calculated using the size
property.
EditText focus state
The EditText
component doesn't automatically show focus state. Use APL styles and the borderWidth
and borderColor
properties to highlight the component when it gains focus.
The following example uses a conditional style to change both the border color and the border width when the EditText
component gets the focus.
On a device such as an Echo Show, tap the EditText
component to open an on-screen keyboard. In the code sandbox, click in the field and type with your normal keyboard, then press Enter to see the results of the onSubmit
handler. Click the Set Focus and Clear Focus to see the effects of the defined style.
Related topics
Last updated: Feb 29, 2024