UI Components
Dialogs
UI for grabbing the users attention, prompting for confirmation, choice, input, or credentials.
NativeScript offers various dialogs, available via the Dialogs
import from @nativescript/core
, or globally.
ts
import { Dialogs } from '@nativescript/core'
Dialogs.alert(options)
Dialogs.action(options)
Dialogs.confirm(options)
Dialogs.prompt(options)
Dialogs.login(options)
// is the same as:
alert(options)
action(options)
confirm(options)
prompt(options)
login(options)
All dialogs take a DialogOptions
object with the properties:
title
: Sets the dialog title.message
: Sets the dialog message.cancelable
(Android only): Sets if the dialog can be canceled by taping outside of the dialog.theme
(Android only): Sets the theme of the Dialog. Usable themes can be found in R.style
See DialogOptions, R.style.
Avialable Dialogs
Alert
data:image/s3,"s3://crabby-images/a3fc0/a3fc07e6924f6c6f20623cbc58ba9e009d7f410b" alt=""
data:image/s3,"s3://crabby-images/53b81/53b8141c6f9c82c647c7b47253b2bffaae6eb2ce" alt=""
ts
Dialogs.alert({
title: 'Alert!',
message: 'Please try again later.',
okButtonText: 'OK',
cancelable: true,
})
A dialog for alerting the user.
See alert().
Action
data:image/s3,"s3://crabby-images/a0db5/a0db54429535e0c4430fc9cfcb70157e5669bda2" alt=""
data:image/s3,"s3://crabby-images/be299/be29911ef9901a3b67623421cffd7180a6ddabe6" alt=""
ts
Dialogs.action({
title: 'Action!',
message: 'Choose your language:',
cancelButtonText: 'Cancel',
actions: ['TypeScript', 'JavaScript', 'Neither'],
cancelable: true,
destructiveActionsIndexes: [2],
}).then((result) => {
console.log(result)
})
A dialog for prompting the user to choose.
Note: destructiveActionsIndexes
allows setting some actions as destructive - shown in red. iOS only.
See action().
Confirm
data:image/s3,"s3://crabby-images/d5d8e/d5d8e95e5241e208078de7dea74c3343c591d919" alt=""
data:image/s3,"s3://crabby-images/8847f/8847f17fe2958110cbb03dfed5624085d22373df" alt=""
ts
Dialogs.confirm({
title: 'Confirm!',
message: 'Are you sure you want to do this?',
okButtonText: 'Yes',
cancelButtonText: 'No',
neutralButtonText: 'Cancel',
}).then((result) => {
console.log(result)
})
A dialog for prompting the user to confirm.
See confirm().
Prompt
data:image/s3,"s3://crabby-images/96df1/96df13e726a39d0b56c7416aa3d6f7743351bb1b" alt=""
data:image/s3,"s3://crabby-images/8abd9/8abd9f64ee5e17c230c63a8a2ae0de800c829992" alt=""
ts
Dialogs.prompt({
title: 'Prompt!',
message: 'Enter the name of this framework:',
defaultText: 'NativeScript',
okButtonText: 'OK',
neutralButtonText: 'Cancel',
// cancelable: true,
// cancelButtonText: 'Cancel',
// capitalizationType: 'none',
// inputType: 'email',
}).then((result) => {
console.log(result)
})
A dialog for prompting the user for input.
defaultText
: Sets the default text to display in the input box.inputType
: Sets the prompt input type:email
,decimal
,phone
,number
,text
,password
, oremail
capitalizationType
: Sets the prompt capitalization type. Avalable options:none
,allCharacters
,sentences
, orwords
.
See prompt(), CoreTypes.AutocapitalizationType
Login
data:image/s3,"s3://crabby-images/f161f/f161fc33a47973d3e6cd24a44e26595d9e3ffde1" alt=""
data:image/s3,"s3://crabby-images/57cfa/57cfa3b2721bc4b9cc535b50d606e35364e7d589" alt=""
ts
Dialogs.login({
title: 'Login!',
message: 'Enter your credentials',
okButtonText: 'Login',
cancelButtonText: 'Cancel',
userName: 'NativeScript',
password: 'hunter2',
// neutralButtonText: 'Neutral',
// cancelable: true,
// passwordHint: 'Your password',
// userNameHint: 'Your username',
}).then((result) => {
console.log(result)
})
A dialog for prompting the user for credentials.
See login().
Native Component
- Android: android.app.AlertDialog.Builder
- iOS: UIAlertController
- Previous
- NavigationButton
- Next
- Alert