Lightning Component Developer Guide
Lightning Component Developer Guide
Developer Guide
Version 36.0, Spring 16
@salesforcedocs
Last updated: January 26, 2016
Copyright 20002016 salesforce.com, inc. All rights reserved. Salesforce is a registered trademark of salesforce.com, inc.,
as are other names and marks. Other marks appearing herein may be trademarks of their respective owners.
CONTENTS
Chapter 1: What is the Lightning Component Framework? . . . . . . . . . . . . . . . . . . . . . . 1
What is Salesforce Lightning? . . . . . . . . . . . . .
Why Use the Lightning Component Framework?
Open Source Aura Framework . . . . . . . . . . . .
Components . . . . . . . . . . . . . . . . . . . . . . . .
Events . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Using the Developer Console . . . . . . . . . . . . .
Online Version of this Guide . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
2
2
3
3
3
4
5
Contents
Component Body . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
Component Facets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
Best Practices for Conditional Markup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
Component Versioning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
Using Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
Dynamic Output in Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
Conditional Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
Value Providers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
Expression Evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
Expression Operators Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
Expression Functions Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
Using Labels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
Using Custom Labels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
Input Component Labels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
Dynamically Populating Label Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
Setting Label Values via a Parent Attribute . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
Localization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
Providing Component Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
Working with UI Components . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
UI Events . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
Using the UI Components . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
Supporting Accessibility . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
Button Labels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
Help and Error Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
Audio Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
Forms, Fields, and Labels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
Events . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
Menus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
Contents
Contents
Contents
aura:expression . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219
aura:html . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219
aura:if . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220
aura:iteration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220
aura:renderIf . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 221
aura:template . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 222
aura:text . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 222
aura:unescapedHtml . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 222
force:canvasApp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223
force:inputField . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224
force:outputField . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225
force:recordEdit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226
force:recordView . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226
forceChatter:feed . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227
ltng:require . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228
ui:actionMenuItem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229
ui:button . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230
ui:checkboxMenuItem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232
ui:inputCheckbox . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234
ui:inputCurrency . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
ui:inputDate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 238
ui:inputDateTime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 241
ui:inputDefaultError . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244
ui:inputEmail . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246
ui:inputNumber . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248
ui:inputPhone . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 251
ui:inputRadio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 253
ui:inputRichText . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 256
ui:inputSecret . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258
ui:inputSelect . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 260
ui:inputSelectOption . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 264
ui:inputText . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 265
ui:inputTextArea . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267
ui:inputURL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 270
ui:menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 272
ui:menuItem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 276
ui:menuItemSeparator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 277
ui:menuList . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 277
ui:menuTrigger . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 279
ui:menuTriggerLink . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 280
ui:message . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 281
ui:outputCheckbox . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 282
ui:outputCurrency . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 284
ui:outputDate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285
Contents
ui:outputDateTime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 287
ui:outputEmail . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 289
ui:outputNumber . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290
ui:outputPhone . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 291
ui:outputRichText . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 293
ui:outputText . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 294
ui:outputTextArea . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 295
ui:outputURL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 297
ui:radioMenuItem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 298
ui:spinner . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 300
Event Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
force:createRecord . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
force:editRecord . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302
force:navigateToList . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302
force:navigateToObjectHome . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303
force:navigateToRelatedList . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304
force:navigateToSObject . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304
force:navigateToURL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 305
force:recordSave . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 306
force:recordSaveSuccess . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 306
force:refreshView . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 307
force:showToast . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 307
lntg:selectSObject . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
lntg:sendMessage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308
ui:clearErrors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
ui:collapse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309
ui:expand . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310
ui:menuFocusChange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 310
ui:menuSelect . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 311
ui:menuTriggerPress . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 312
ui:validationError . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 312
System Event Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313
aura:doneRendering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313
aura:doneWaiting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 314
aura:locationChange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
aura:systemError . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
aura:valueChange . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 316
aura:valueDestroy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 317
aura:valueInit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 318
aura:waiting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 318
Supported HTML Tags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319
Supported aura:attribute Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319
Basic Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 320
Object Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 322
Contents
INDEX
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
323
323
324
325
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 326
CHAPTER 1
In this chapter ...
What is Salesforce
Lightning?
Components
Events
Components
Components are the self-contained and reusable units of an app. They represent a reusable section of the UI, and can range in granularity
from a single line of text to an entire app.
The framework includes a set of prebuilt components. You can assemble and configure components to form new components in an
app. Components are rendered to produce HTML DOM elements within the browser.
A component can contain other components, as well as HTML, CSS, JavaScript, or any other Web-enabled code. This enables you to
build apps with sophisticated UIs.
The details of a component's implementation are encapsulated. This allows the consumer of a component to focus on building their
app, while the component author can innovate and make changes without breaking consumers. You configure components by setting
the named attributes that they expose in their definition. Components interact with their environment by listening to or publishing
events.
SEE ALSO:
Creating Components
Events
Event-driven programming is used in many languages and frameworks, such as JavaScript and Java Swing. The idea is that you write
handlers that respond to interface events as they occur.
A component registers that it may fire an event in its markup. Events are fired from JavaScript controller actions that are typically triggered
by a user interacting with the user interface.
There are two types of events in the framework:
Component events are handled by the component itself or a component that instantiates or contains the component.
Application events are handled by all components that are listening to the event. These events are essentially a traditional
publish-subscribe model.
CHAPTER 2
In this chapter ...
Create a Standalone
Lightning App
Create a Component
for Salesforce1 and
Lightning Experience
Quick Start
The quick start steps you through building and running two simple apps: a standalone Lightning app
for tracking expenses and a Lightning component to manage selected contacts in Salesforce1. Youll
create all components from the Developer Console. A standalone app is directly accessible by going to
the URL:
https://<myDomain>.lightning.force.com/<namespace>/<appName>.app,
where <myDomain> is the name of your custom Salesforce domain
The standalone app youre creating accesses a custom object and displays its records. It enables you to
edit a field on the records, capturing changes in a client-side controller and passing that information
using a component event to an Apex controller, which then persists the data.
The Lightning component youre creating accesses the contact object and displays its records in
Salesforce1. Youll use built-in Salesforce1 events to create or edit contact records, and view related
cases.
Quick Start
Quick Start
8. Click Save.
Your namespace is used as a prefix to the components and Apex classes you are creating. In addition, use the namespace to address
any apps you create by accessing:
https://<myDomain>.lightning.force.com/<namespace>/<appName>.app, where <myDomain> is the
Quick Start
1. The form contains Lightning input components (1) that update the view and expense records when the Submit button is pressed.
2. Counters are initialized (2) with total amount of expenses and number of expenses, and updated on record creation or deletion. The
counter turns red when the sum exceeds $100.
3. Display of expense list (3) uses Lightning output components and are updated as more expenses are added.
4. User interaction on the expense list (4) triggers an update event that saves the record changes.
These are the resources you are creating for the expense tracker app.
Resources
Description
expenseTracker Bundle
expenseTracker.app
Form Bundle
form.cmp
formController.js
formHelper.js
form.css
expenseList Bundle
expenseList.cmp
expenseListController.js
Quick Start
Resources
Description
Apex Class
ExpenseController.apxc
Event
updateExpenseItem.evt
The event fired when an expense item is updated from the display of the expense list
The Expenses menu item on the Salesforce1 navigation menu. If you dont see the menu item in Salesforce1, you must create a Lightning
Components tab for expenses and include it in the Salesforce1 navigation menu. See Add Lightning Components to Salesforce1 for
more information.
Note: The Lightning component tab isnt available if you dont have a custom domain enabled in your org. Verify that you have
a custom domain and that the Expenses tab is available in the Lightning Components Tabs section of the Tabs page.
Salesforce1 Navigation.
10
Quick Start
For Lightning Experience, the Expenses tab is available via the App Launcher in the custom app titled Lightning.
Next, you can modify the code in the Developer Console or explore the standalone app at
https://<myDomain>.lightning.force.com/<namespace>/expenseTracker.app, where <myDomain>
11
Quick Start
Field Type
Field Label
Number(16, 2)
Amount
Text (20)
Client
Date/Time
Date
Checkbox
Reimbursed?
When you finish creating the custom object, your Expense definition detail page should look similar to this.
12
Quick Start
) and then the Other Items icon. You should see Expenses in the Items list.
Amount
Lunch
21
Dinner
70
Client
ABC Co.
Date
Reimbursed?
4/1/2015 12:00 PM
Unchecked
3/30/2015 7:00 PM
Checked
13
Quick Start
This tutorial uses the Lightning Design System CSS framework, which provides a look and feel thats consistent with Lightning Experience.
1. Go to https://www.lightningdesignsystem.com/resources/downloads and download Version 0.9.0 of the
Design System Unmanaged Package. At the prompt, install the unmanaged package in your organization. Your installation is
successful when you see the SLDS090 package on the Installed Packages page.
2. Open the Developer Console.
a. In Salesforce Classic, click Your Name > Developer Console.
b.
14
Quick Start
3. Create a new Lightning app. In the Developer Console, click File > New > Lightning Application.
4. Enter expenseTracker for the Name field in the New Lightning Bundle popup window. This creates a new app,
expenseTracker.app.
5. In the source code editor, enter this code.
<aura:application>
<!-- Define the Design System static resource (version 0.9.0) -->
<ltng:require
styles="/resource/slds090/assets/styles/salesforce-lightning-design-system.min.css"/>
<div class="slds">
<div class="slds-page-header">
<div class="slds-grid">
<div class="slds-col slds-has-flexi-truncate">
<p class="slds-text-heading--label">Expenses</p>
<div class="slds-grid">
<div class="slds-grid slds-type-focus slds-no-space">
<h1 class="slds-text-heading--medium slds-truncate" title="My
Expenses">My Expenses</h1>
</div>
</div>
</div>
</div>
</div>
</div>
</aura:application>
An application is a top-level component and the main entry point to your components. It can include components and HTML markup,
such as <div> and <header> tags. The CSS classes are provided by the Lightning Design System CSS framework.
6. Save your changes and click Preview in the sidebar to preview your app. Alternatively, navigate to
https://<myDomain>.lightning.force.com/<namespace>/expenseTracker.app, where <myDomain>
is the name of your custom Salesforce domain. If youre not using a namespace, your app is available at
/c/expenseTracker.app.
You should see the header My Expenses.
SEE ALSO:
Salesforce Help: Open the Developer Console
aura:application
15
Quick Start
Note: The following code creates an input form that takes in user input to create an expense, which works in both a standalone
app, and in Salesforce1 and Lightning Experience. For apps specific to Salesforce1 and Lightning Experience, you can use
force:createRecord to open the create record page.
<aura:component implements="force:appHostable">
<ltng:require
styles="/resource/slds090/assets/styles/salesforce-lightning-design-system.min.css"/>
<aura:attribute name="expenses" type="Expense__c[]"/>
<aura:attribute name="newExpense" type="Expense__c"
default="{ 'sobjectType': 'Expense__c',
'Name': '',
'Amount__c': 0,
'Client__c': '',
'Date__c': '',
'Reimbursed__c': false
}"/>
<!-- If you registered a namespace, replace the previous aura:attribute tags with the
following -->
<!-- <aura:attribute name="expenses" type="myNamespace.Expense__c[]"/>
<aura:attribute name="newExpense" type="myNamespace__Expense__c"
default="{ 'sobjectType': 'myNamespace__Expense__c',
'Name': '',
'myNamespace__Amount__c': 0,
'myNamespace__Client__c': '',
'myNamespace__Date__c': '',
'myNamespace__Reimbursed__c': false
}"/> -->
<!-- Attributes for Expense Counters -->
<aura:attribute name="total" type="Double" default="0.00" />
<aura:attribute name="exp" type="Double" default="0" />
<!-- Input Form using components -->
<div class="container">
<form class="slds-form--stacked">
<div class="slds-form-element slds-is-required">
<div class="slds-form-element__control">
<!-- If you registered a namespace,
the attributes include your namespace.
For example, value="{!v.newExpense.myNamespace__Amount__c}" -->
<ui:inputText aura:id="expname" label="Expense Name"
class="slds-input"
labelClass="slds-form-element__label"
value="{!v.newExpense.Name}"
required="true"/>
</div>
</div>
<div class="slds-form-element slds-is-required">
<div class="slds-form-element__control">
<ui:inputNumber aura:id="amount" label="Amount"
class="slds-input"
labelClass="slds-form-element__label"
value="{!v.newExpense.Amount__c}"
16
Quick Start
placeholder="20.80" required="true"/>
</div>
</div>
<div class="slds-form-element">
<div class="slds-form-element__control">
<ui:inputText aura:id="client" label="Client"
class="slds-input"
labelClass="slds-form-element__label"
value="{!v.newExpense.Client__c}"
placeholder="ABC Co."/>
</div>
</div>
<div class="slds-form-element">
<div class="slds-form-element__control">
<ui:inputDateTime aura:id="expdate" label="Expense Date"
class="slds-input"
labelClass="slds-form-element__label"
value="{!v.newExpense.Date__c}"
displayDatePicker="true"/>
</div>
</div>
<div class="slds-form-element">
<ui:inputCheckbox aura:id="reimbursed" label="Reimbursed?"
class="slds-checkbox"
labelClass="slds-form-element__label"
value="{!v.newExpense.Reimbursed__c}"/>
<ui:button label="Submit"
class="slds-button slds-button--neutral"
labelClass="label"
press="{!c.createExpense}"/>
</div>
</form>
</div><!-- ./container-->
<!-- Expense Counters -->
<div class="container slds-p-top--medium">
<div class="row">
<div class="slds-tile ">
<!-- Make the counter red if total amount is more than 100 -->
<div class="{!v.total >= 100
? 'slds-notify slds-notify--toast slds-theme--error
slds-theme--alert-texture'
: 'slds-notify slds-notify--toast slds-theme--alert-texture'}">
<p class="slds-tile__title slds-truncate">Total Expenses</p>
$<ui:outputNumber class="slds-truncate" value="{!v.total}"
format=".00"/>
</div>
</div>
<div class="slds-tile ">
<div class="slds-notify slds-notify--toast slds-theme--alert-texture">
<p class="slds-tile__title slds-truncate">No. of Expenses</p>
<ui:outputNumber class="slds-truncate" value="{!v.exp}"/>
</div>
</div>
17
Quick Start
</div>
</div>
<!-- Display expense records -->
<div class="container slds-p-top--medium">
<div id="list" class="row">
<aura:iteration items="{!v.expenses}" var="expense">
<!-- If youre using a namespace,
use the format
{!expense.myNamespace__myField__c} instead. -->
<p>{!expense.Name}, {!expense.Client__c},
{!expense.Amount__c}, {!expense.Date__c},
{!expense.Reimbursed__c}</p>
</aura:iteration>
</div>
</div>
</aura:component>
Components provide a rich set of attributes and browser event support. Attributes are typed fields that are set on a specific instance
of a component, and can be referenced using an expression syntax. All aura:attribute tags have name and type values. For
more information, see Supported aura:attribute Types on page 319.
The attributes and expressions here will become clearer as you build the app. {!v.exp} evaluates the number of expenses records
and {!v.total} evaluates the total amount. {!c.createExpense} represents the client-side controller action that runs
when the Submit button (1) is clicked, which creates a new expense. The press event in ui:button enables you to wire up
the action when the button is pressed.
The expression {!v.expenses} wires up the component to the expenses object. var="expense" denotes the name of
the variable to use for each item inside the iteration. {!expense.Client__c} represents data binding to the client field in
the expense object.
Note: The default value for newExpense of type Expense__c must be initialized with the correct fields, including
sobjectType. Initializing the default value ensures that the expense is saved in the correct format.
18
Quick Start
4. Click STYLE in the sidebar to create a new resource named form.css. Enter these CSS rule sets.
.THIS .uiInputDateTime .datePicker-openIcon {
position: absolute;
left: 45%;
top: 45%;
}
.THIS .uiInputDateTime .timePicker-openIcon {
position: absolute;
left: 95%;
top: 70%;
}
.THIS .uiInputDefaultError li {
list-style: none;
}
Note: THIS is a keyword that adds namespacing to CSS to prevent any conflicts with another components styling. The
.uiInputDefaultError selector styles the default error component when you add field validation in Step 5: Enable
Input for New Expenses on page 24.
5. Add the component to the app. In expenseTracker.app, add the new component to the markup.
This step adds <c:form /> to the markup. If youre using a namespace, you can use <myNamespace:form /> instead. If
you havent set a namespace prefix for your organization, use the default namespace c when referencing components that youve
created.
<aura:application>
<ltng:require
styles="/resource/slds090/assets/styles/salesforce-lightning-design-system.min.css"/>
<div class="slds">
<div class="slds-page-header">
<div class="slds-grid">
<div class="slds-col slds-has-flexi-truncate">
<p class="slds-text-heading--label">Expenses</p>
<div class="slds-grid">
<div class="slds-grid slds-type-focus slds-no-space">
<h1 class="slds-text-heading--medium slds-truncate" title="My
Expenses">My Expenses</h1>
</div>
</div>
</div>
</div>
</div>
<div class="slds-col--padded slds-p-top--large">
<c:form />
</div>
</div>
</aura:application>
6. Save your changes and click Update Preview in the sidebar to preview your app. Alternatively, reload your browser.
19
Quick Start
Note: In this step, the component you created doesnt display any data since you havent created the Apex controller class
yet.
Good job! You created a component that provides an input form and view of your expenses. Next, youll create the logic to display your
expenses.
SEE ALSO:
Component Markup
Component Body
The getExpenses() method contains a SOQL query to return all expense records. Recall the syntax {!v.expenses} in
form.cmp, which displays the result of the getExpenses() method in the component markup.
Note: For more information on using SOQL, see the Force.com SOQL and SOSL Reference.
@AuraEnabled enables client- and server-side access to the controller method. Server-side controllers must be static and all
instances of a given component share one static controller. They can return or take in any types, such as a List or Map.
Note: For more information on server-side controllers, see Apex Server-Side Controller Overview on page 182.
3. In form.cmp, update the aura:component tag to include the controller attribute.
<aura:component controller="ExpenseController">
20
Quick Start
On initialization, this event handler runs the doInit action that youre creating next. This init event is fired before component
rendering.
5. Add the client-side controller action for the init handler. In the sidebar, click CONTROLLER to create a new resource,
formController.js. Enter this code.
({
doInit : function(component, event, helper) {
//Update expense counters
helper.getExpenses(component);
},//Delimiter for future code
})
During component initialization, the expense counters should reflect the latest sum and total number of expenses, which youre
adding next using a helper function, getExpenses(component).
Note: A client-side controller handles events within a component and can take in three parameters: the component to which
the controller belongs, the event that the action is handling, and the helper if its used. A helper is a resource for storing code
that you want to reuse in your component bundle, providing better code reusability and specialization. For more information
about using client-side controllers and helpers, see Handling Events with Client-Side Controllers on page 113 and Sharing
JavaScript Code in a Component Bundle on page 162.
6. Create the helper function to display the expense records and dynamically update the counters. Click HELPER to create a new
resource, formHelper.js and enter this code.
({
getExpenses: function(component) {
var action = component.get("c.getExpenses");
action.setCallback(this, function(response) {
var state = response.getState();
if (component.isValid() && state === "SUCCESS") {
component.set("v.expenses", response.getReturnValue());
this.updateTotal(component);
}
});
$A.enqueueAction(action);
},
updateTotal : function(component) {
var expenses = component.get("v.expenses");
var total = 0;
for(var i=0; i<expenses.length; i++){
var e = expenses[i];
//If youre using a namespace, use e.myNamespace__Amount__c instead
total += e.Amount__c;
}
//Update counters
component.set("v.total", total);
component.set("v.exp", expenses.length);
},//Delimiter for future code
})
21
Quick Start
Note: $A.enqueueAction(action) adds the action to the queue. All the action calls are asynchronous and run in
batches. For more information about server-side actions, see Calling a Server-Side Action on page 183.
7. Save your changes and reload your browser.
You should see the expense records created in Create an Expense Object on page 11. The counters arent working at this point as
youll be adding the programmatic logic later.
Your app now retrieves the expense object and displays its records as a list, iterated over by aura:iteration. The counters now
reflect the total sum and number of expenses.
In this step, you created an Apex controller class to load expense data. getExpenses() returns the list of expense records. By default,
the framework doesnt call any getters. To access a method, annotate the method with @AuraEnabled, which exposes the data in
that method. Only methods that are annotated with @AuraEnabled in the controller class are accessible to the components.
Component markup that uses the ExpenseController class can display the expense name or id with the {!expense.name}
or {!expense.id} expression, as shown in Step 2: Create A Component for User Input on page 15.
Beyond the Basics
Client-side controller definitions are surrounded by brackets and curly braces. The curly braces denotes a JSON object, and
everything inside the object is a map of name-value pairs. For example, updateTotal is a name that corresponds to a
client-side action, and the value is a function. The function is passed around in JavaScript like any other object.
SEE ALSO:
CRUD and Field-Level Security (FLS)
22
Quick Start
Instead of using {!expense.Amount__c}, youre now using {!v.expense.Amount__c}. This expression accesses the
expense object and the amount values on it.
Additionally, href="{!'/' + v.expense.Id}" uses the expense ID to set the link to the detail page of each expense
record.
4. In form.cmp, update the aura:iteration tag to use the new nested component, expenseList. Locate the existing
aura:iteration tag.
<aura:iteration items="{!v.expenses}" var="expense">
<p>{!expense.Name}, {!expense.Client__c}, {!expense.Amount__c}, {!expense.Date__c},
{!expense.Reimbursed__c}</p>
</aura:iteration>
Notice how the markup is simpler as youre just passing each expense record to the expenseList component, which handles
the display of the expense details.
5. Save your changes and reload your browser.
You created a nested component and passed its attributes to a parent component. Next, youll learn how to process user input and
update the expense object.
23
Quick Start
24
Quick Start
First, update the Apex controller with a new method that inserts or updates the records.
1. In the ExpenseController class, enter this code below the getExpenses() method.
@AuraEnabled
public static Expense__c saveExpense(Expense__c expense) {
// Perform isUpdateable() check here
upsert expense;
25
Quick Start
return expense;
}
The saveExpense() method enables you to insert or update an expense record using the upsert operation.
Note: Fore more information about the upsert operation, see the Apex Developer Guide.
2. Create the client-side controller action to create a new expense record when the Submit button is pressed. In
formController.js, add this code after the doInit action.
createExpense : function(component, event, helper) {
var amtField = component.find("amount");
var amt = amtField.get("v.value");
if (isNaN(amt)||amt==''){
amtField.set("v.errors", [{message:"Enter an expense amount."}]);
}
else {
amtField.set("v.errors", null);
var newExpense = component.get("v.newExpense");
helper.createExpense(component, newExpense);
}
},//Delimiter for future code
createExpense validates the amount field using the default error handling of input components. If the validation fails, we set
an error message in the errors attribute of the input component. For more information on field validation, see Validating Fields
on page 168.
Notice that youre passing in the arguments to a helper function helper.createExpense(), which then triggers the Apex
class saveExpense.
Note: Recall that you specified the aura:id attributes in Step 2: Create A Component for User Input on page 15. aura:id
enables you to find the component by name using the syntax component.find("amount") within the scope of this
component and its controller.
3. Create the helper function to handle the record creation. In formHelper.js, add these helper functions after the updateTotal
function.
createExpense: function(component, expense) {
this.upsertExpense(component, expense, function(a) {
var expenses = component.get("v.expenses");
expenses.push(a.getReturnValue());
component.set("v.expenses", expenses);
this.updateTotal(component);
});
},
upsertExpense : function(component, expense, callback) {
var action = component.get("c.saveExpense");
action.setParams({
"expense": expense
});
if (callback) {
action.setCallback(this, callback);
}
$A.enqueueAction(action);
}
26
Quick Start
createExpense calls upsertExpense, which defines an instance of the saveExpense server-side action and sets the
expense object as a parameter. The callback is executed after the server-side action returns, which updates the records, view,
and counters. $A.enqueueAction(action) adds the server-side action to the queue of actions to be executed.
Note: Different possible action states are available and you can customize their behaviors in your callback. For more information
on action callbacks, see Calling a Server-Side Action.
4. Save your changes and reload your browser.
5. Test your app by entering a new expense record with field values: Breakfast, 10, ABC Co., Apr 30, 2014
9:00:00 AM. For the date field, you can also use the date picker to set a date and time value. Click the Submit button. The record
is added to both your component view and records, and the counters are updated.
Note: To debug your Apex code, use the Logs tab in the Developer Console. For example, if you dont have input validation
for the date time field and entered an invalid date time format, you might get an INVALID_TYPE_ON_FIELD_IN_RECORD
exception, which is listed both on the Logs tab in the Developer Console and in the response header on your browser. Otherwise,
you might see an Apex error displayed in your browser. For more information on debugging your JavaScript code, see Debug
JavaScript Code on page 209.
Congratulations! You have successfully created a simple expense tracker app that includes several components, client- and server-side
controllers, and helper functions. Your app now accepts user input, which updates the view and database. The counters are also
dynamically updated as you enter new user input. The next step shows you how to add a layer of interactivity using events.
SEE ALSO:
Handling Events with Client-Side Controllers
Calling a Server-Side Action
CRUD and Field-Level Security (FLS)
27
Quick Start
Lets start by creating the event and its handler before firing it and handling the event in the parent component.
1. Click File > New > Lightning Event.
2. Enter updateExpenseItem in the New Event window. This creates a new event, updateExpenseItem.evt.
3. In updateExpenseItem.evt, enter this code.
The attribute youre defining in the event is passed from the firing component to the handlers.
<aura:event type="COMPONENT">
<!-- If youre using a namespace, use myNamespace.Expense__c instead. -->
28
Quick Start
The framework has two types of events: component events and application events.
Note: Always try to use a component event instead of an application event, if possible. Component events can only be
handled by components above them in the containment hierarchy so their usage is more localized to the components that
need to know about them. Application events are best used for something that should be handled at the application level,
such as navigating to a specific record.
Well use a component event. Recall that expenseList.cmp contains the Reimbursed? checkbox.
4. Update expenseList.cmp to register that it fires the event. Add this tag after the <aura:attribute> tag.
<aura:registerEvent name="updateExpense" type="c:updateExpenseItem"/>
The Reimbursed? checkbox is wired up to a client-side controller action, denoted by change="{!c.update}". Youll set up
the update action next.
5. In the expenseList sidebar, click CONTROLLER. This creates a new resource, expenseListController.js. Enter this
code.
({
update: function(component, evt, helper) {
var expense = component.get("v.expense");
// Note that updateExpense matches the name attribute in <aura:registerEvent>
var updateEvent = component.getEvent("updateExpense");
updateEvent.setParams({ "expense": expense }).fire();
}
})
When the checkbox is checked or unchecked, the update action runs, setting the reimbursed parameter value to true or
false. The updateExpenseItem.evt event is fired with the updated expense object .
6. In the handler component, form.cmp, add this handler code before the <aura:attribute> tags.
<aura:handler name="updateExpense" event="c:updateExpenseItem" action="{!c.updateEvent}"
/>
This event handler runs the updateEvent action when the component event you created is fired. The <aura:handler>
tag uses the same value of the name attribute, updateExpense, from the <aura:registerEvent> tag in
c:expenseList
7. Wire up the updateEvent action to handle the event. In formController.js, enter this code after the createExpense
controller action.
updateEvent : function(component, event, helper) {
helper.upsertExpense(component, event.getParam("expense"));
}
This action calls a helper function and passes in event.getParam("expense"), which contains the expense object with its
parameters and values in this format: { Name : "Lunch" , Client__c : "ABC Co." , Reimbursed__c :
true , CreatedDate : "2014-08-12T20:53:09.000Z" , Amount__c : 20}.
8. Save your changes and reload your browser.
9. Click the Reimbursed? checkbox for one of the records.
29
Quick Start
Summary
Note that the background color for the record changes. When you change the reimbursed status on the view, the update event
is fired, handled by the parent component, which then updates the expense record by running the server-side controller action
saveExpense.
Thats it! You have successfully added a layer of interaction in your expense tracker app using a component event.
Beyond the Basics
The framework fires several events during the rendering lifecycle, such as the init event you used in this tutorial. For example,
you can also customize the app behavior during the waiting event when the client is waiting for a server response and when
the doneWaiting event is fired to signal that the response has been received. This example shows how you can add text in
the app during the waiting event, and remove it when the doneWaiting event is fired.
<!-- form.cmp markup -->
<aura:handler event="aura:waiting" action="{!c.waiting}"/>
<aura:handler event="aura:doneWaiting" action="{!c.doneWaiting}"/>
<aura:attribute name="wait" type="String"/>
<div class="wait">
{!v.wait}
</div>
/** formController.js **/
waiting : function(component, event, helper) {
component.set("v.wait", "updating...");
},
doneWaiting : function(component, event, helper) {
component.set("v.wait", "");
}
The app displays this text when you click the Submit button to create a new record or when you click the checkbox on an
expense item. For more information, see Events Fired During the Rendering Lifecycle on page 135.
The app you just created is currently accessible as a standalone app by accessing
https://<myDomain>.lightning.force.com/<namespace>/expenseTracker.app, where <myDomain>
is the name of your custom Salesforce domain. To make it accessible in Salesforce1, see Add Lightning Components to Salesforce1 on
page 102. To package and distribute your app on AppExchange, see Distributing Applications and Components on page 206.
SEE ALSO:
Component Events
Event Handling Lifecycle
Summary
You created several components with controllers and events that interact with your expense records. The expense tracker app performs
three distinct tasks: load the expense data and counters on app initialization, take in user input to create a new record and update the
view, and handle user interactions by communicating relevant component data via events.
30
Quick Start
Summary
When form.cmp is initialized, the init handler triggers the doInit client-side controller, which calls the getExpenses
helper function. getExpenses calls the getExpenses server-side controller to load the expenses. The callback sets the expenses
data on the v.expenses attribute and calls updateTotal to update the counters.
Clicking the Submit button triggers the createExpense client-side controller. After field validation, the createExpense helper
function is run, in which the upsertExpense helper function calls the saveExpense server-side controller to save the record.
The callback pushes the new expense to the list of expenses and updates the attribute v.expenses in form.cmp, which in turn
updates the expenses in expenseList.cmp. Finally, the helper calls updateTotal to update the counters represented by the
v.total and v.exp attributes.
expenseList.cmp displays the list of expenses. When the Reimbursed? checkbox is selected or deselected, the click event
triggers the update client-side controller. The updateExpenseItem event is fired with the relevant expense passed in as a
31
Quick Start
parameter. form.cmp handles the event, triggering the updateEvent client-side controller. This controller action then calls the
upsertExpense helper function, which calls the saveExpense server-side controller to save the relevant record.
32
Quick Start
Opens the create record page to create a new contact when the New Contact button (3) is clicked
Opens the edit record page to update the selected contact when the Edit button (4) is clicked
Navigates to the record when the contact (5) is clicked
Navigates to related cases when the View Cases button (6) is clicked
Youll create the following resources.
Resource
Description
Contacts Bundle
contacts.cmp
contactsController.js The client-side controller actions that loads contact data, handles input select change event, and opens
The helper function that retrieves contact data and display toast messages based on the loading status
contactList Bundle
contactList.cmp
contactListController.js The client-side controller actions that opens the edit record page, and navigates to a contact record,
Apex Controller
ContactController.apxc The Apex controller that queries the contact records
33
Quick Start
List<Contact> primaryContacts =
[SELECT Id, Name, MailingStreet, Phone, Email, Level__c FROM Contact WHERE
Level__c = 'Primary'];
//Add isAccessible() check
return primaryContacts;
}
}
2. Click File > New > Lightning Component, and then enter contactList for the Name field in the New Lightning Bundle
popup window. This creates a new component, contactList.cmp. Enter this code and then save.
<aura:component>
<aura:attribute name="contact" type="Contact"/>
<!-- If youre using a namespace,
use {!v.contact.myNamespace__Level__c} instead -->
<div class="{!v.contact.Level__c == 'Primary'
? 'row primary' : 'row '}" >
<div onclick="{!c.gotoRecord}">
<force:recordView recordId="{!v.contact.Id}" type="MINI"/>
</div>
<!-- Open the record edit page when the button is clicked -->
<ui:button label="Edit" press="{!c.editRecord}"/>
<!-- Navigate to the related list when the button is clicked -->
<ui:button label="View Cases" press="{!c.relatedList}"/>
</div>
</aura:component>
3. In the contactList sidebar, click STYLE to create a new resource named contactList.css. Replace the placeholder code with
the following code and then save.
.THIS.primary{
background: #4ECDC4
}
!important;
.THIS.row {
background: #fff;
max-width:90%;
border-bottom: 2px solid #f0f1f2;
padding: 10px;
margin-left: 2%;
margin-bottom: 10px;
min-height: 70px;
border-radius: 4px;
}
34
Quick Start
4. Click File > New > Lightning Component, and then enter contacts for the Name field in the New Lightning Bundle popup
window. This creates a new component, contacts.cmp. Enter this code and then save. If youre using a namespace in your
organization, replace ContactController with myNamespace.ContactController.
<aura:component controller="ContactController" implements="force:appHostable">
<!-- Handle component initialization in a client-side controller -->
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<!-- Dynamically load the list of contacts -->
<aura:attribute name="contacts" type="Contact[]"/>
<!-- Create a drop-down list with two options -->
<ui:inputSelect aura:id="selection" change="{!c.select}">
<ui:inputSelectOption text="All Contacts" label="All Contacts"/>
<ui:inputSelectOption text="All Primary" label="All Primary"/>
</ui:inputSelect>
<!-- Display record create page when button is clicked -->
<ui:button label="New Contact" press="{!c.createRecord}"/>
<!-- Iterate over the list of contacts and display them -->
<aura:iteration var="contact" items="{!v.contacts}">
<!-- If youre using a namespace, replace with myNamespace:contactList -->
<c:contactList contact="{!contact}"/>
</aura:iteration>
</aura:component>
5. In the contacts sidebar, click CONTROLLER to create a new resource named contactsController.js. Replace the
placeholder code with the following code and then save.
({
doInit : function(component, event, helper) {
// Retrieve contacts during component initialization
helper.getContacts(component);
},//Delimiter for future code
})
6. In the contacts sidebar, click HELPER to create a new resource named contactsHelper.js. Replace the placeholder code
with the following code and then save.
({
getContacts : function(cmp) {
// Load all contact data
var action = cmp.get("c.getContacts");
action.setCallback(this, function(response) {
var state = response.getState();
if (cmp.isValid() && state === "SUCCESS") {
cmp.set("v.contacts", response.getReturnValue());
}
// Display toast message to indicate load status
var toastEvent = $A.get("e.force:showToast");
if (state === 'SUCCESS'){
toastEvent.setParams({
"title": "Success!",
35
Quick Start
7. Create a new Lightning Component tab by following the steps on Add Lightning Components to Salesforce1 on page 102. Make
sure you include the component in the Salesforce1 navigation menu.
Finally, you can go to the Salesforce1 mobile browser app to check your output. When your component is loaded, you should see a toast
message that indicates your contacts are loaded successfully.
Next, well wire up the other events so that your input select displays either all contacts or only primary contacts that are colored green.
Well also wire up events for opening the create record and edit record pages, and events for navigating to a record and a URL.
36
Quick Start
2. Refresh the Salesforce1 mobile browser app, and click these elements to test the events.
Contact: force:navigateToSObject is fired, which updates the view with the contact record page. The contact name
corresponds to the following component.
<div onclick="{!c.gotoRecord}">
<force:recordView recordId="{!v.contact.Id}" type="MINI"/>
</div>
Edit Contact button: force:editRecord is fired, which opens the edit record page. The Edit Contact icon corresponds to
the following component.
<ui:button label="Edit" press="{!c.editRecord}"/>
3. Open contactsController.js. After the doInit controller, enter this code and then save.
createRecord : function (component, event, helper) {
// Open the create record page
var createRecordEvent = $A.get("e.force:createRecord");
createRecordEvent.setParams({
"entityApiName": "Contact"
});
createRecordEvent.fire();
},
select : function(component, event, helper){
// Get the selected value of the ui:inputSelect component
var selectCmp = component.find("selection");
var selectVal = selectCmp.get("v.value");
// Display all primary contacts or all contacts
if (selectVal==="All Primary"){
var action = component.get("c.getPrimary");
action.setCallback(this, function(response){
var state = response.getState();
if (component.isValid() && state === "SUCCESS") {
component.set("v.contacts", response.getReturnValue());
}
});
$A.enqueueAction(action);
}
else {
// Return all contacts
helper.getContacts(component);
}
}
37
Quick Start
Notice that if you pull down the page and release it, the page refreshes all data in the view. Now you can test your components by
clicking on the areas highlighted in Create a Component for Salesforce1 and Lightning Experience on page 32.
For an example on creating a standalone app that can be used independent of Salesforce1, see Create a Standalone Lightning App on
page 8.
38
CHAPTER 3
Creating Components
Component Markup
Component
Namespace
A component encapsulates a modular and potentially reusable section of UI, and can range in granularity
from a single line of text to an entire application.
Component Bundles
Component IDs
HTML in Components
CSS in Components
Component
Attributes
Component
Composition
Component Body
Component Facets
Component
Versioning
Using Expressions
Using Labels
Localization
Providing
Component
Documentation
Working with UI
Components
Supporting
Accessibility
39
Creating Components
Component Markup
Component Markup
Component resources contain markup and have a .cmp suffix. The markup can contain text or references to other components, and
also declares metadata about the component.
Let's start with a simple "Hello, world!" example in a helloWorld.cmp component.
<aura:component>
Hello, world!
</aura:component>
This is about as simple as a component can get. The "Hello, world!" text is wrapped in the <aura:component> tags, which appear
at the beginning and end of every component definition.
Components can contain most HTML tags so you can use markup, such as <div> and <span>. HTML5 tags are also supported.
<aura:component>
<div class="container">
<!--Other HTML tags or components here-->
</div>
</aura:component>
Note: Case sensitivity should be respected as your markup interacts with JavaScript, CSS, and Apex.
Use the Developer Console to create components.
aura:component has the following optional attributes.
Attribute
Type
Description
access
String
controller
String
description
String
extends
Component
extensible
Boolean
implements
String
isTemplate
Boolean
template
Component
40
Creating Components
Attribute
Component Namespace
Type
Description
You can customize the template by creating your own component
that extends the default template. For example:
<aura:component extends="aura:template" ...
>
aura:component also includes a body attribute defined in a <aura:attribute> tag. Attributes usually control the output
Type
Description
body
Component[]
SEE ALSO:
Using the Developer Console
Component Access Control
Client-Side Rendering to the DOM
Dynamically Creating Components
Component Namespace
Every component is part of a namespace, which is used to group related components together. If your organization has a namespace
prefix set, use that namespace to access your components. Otherwise, use the default namespace to access your components.
Another component or application can reference a component by adding <myNamespace:myComponent> in its markup. For
example, the helloWorld component is in the docsample namespace. Another component can reference it by adding
<docsample:helloWorld /> in its markup.
Lightning components that Salesforce provides are grouped into several namespaces, such as aura, ui, and force. Components
from third-party managed packages have namespaces from the providing organizations.
In your organization, you can choose to set a namespace prefix. If you do, that namespace is used for all of your Lightning components.
A namespace prefix is required if you plan to offer managed packages on the AppExchange.
If you havent set a namespace prefix for your organization, use the default namespace c when referencing components that youve
created.
41
Creating Components
42
Creating Components
Example
<c:myComponent />
<aura:component extends="c:myComponent">
<aura:component
implements="c:myInterface">
Apex controller
<aura:component
controller="ExpenseController">
43
type="Expense__c" />
Creating Components
Referenced Item
Custom object or custom field in
attribute defaults
Example
<aura:attribute name="newExpense" type="Expense__c"
default="{ 'sobjectType': 'Expense__c',
'Name': '',
'Amount__c': 0,
}" />
<ui:inputNumber
/>
value="{!v.newExpense.Amount__c}" label=
updateTotal: function(component) {
<aura:registerEvent
Event handler
<aura:handler event="c:updateExpenseItem"
Explicit dependency
Static resources
<ltng:require scripts="/resource/resourceName"
styles="/resource/resourceName" />
Example
<yournamespace:myComponent />
44
Creating Components
Referenced Item
Example
<aura:component
Apex controller
<aura:component controller="yournamespace.ExpenseController">
extends="yournamespace:myComponent">
<aura:component implements="yournamespace:myInterface">
<aura:attribute name="newExpense"
type="yournamespace__Expense__c"
default="{ 'sobjectType': 'yournamespace__Expense__c',
'Name': '',
'yournamespace__Amount__c': 0,
}" />
<ui:inputNumber
value="{!v.newExpense.yournamespace__Amount__c}" label= />
updateTotal: function(component) {
<aura:registerEvent
name= />
Event handler
<aura:handler
action= />
Explicit dependency
<aura:dependency resource="markup://yournamespace:myComponent"
/>
type="yournamespace:updateExpenseItem"
event="yournamespace:updateExpenseItem"
45
Creating Components
Component Bundles
Referenced Item
Example
Static resources
<ltng:require scripts="/resource/yournamespace__resourceName"
styles="/resource/yournamespace__resourceName" />
Component Bundles
A component bundle contains a component or an app and all its related resources.
Resource
Resource Name
Usage
See Also
Component or Application
sample.cmp or
sample.app
CSS Styles
sample.css
Controller
sampleController.js
Design
sample.design
Documentation
sample.auradoc
Renderer
sampleRenderer.js
Helper
sampleHelper.js
SVG File
sample.svg
All resources in the component bundle follow the naming convention and are auto-wired. For example, a controller
<componentName>Controller.js is auto-wired to its component, which means that you can use the controller within the
scope of that component.
46
Creating Components
Component IDs
Component IDs
A component has two types of IDs: a local ID and a global ID.
Local IDs
A local ID is an ID that is only scoped to the component. A local ID enables you to retrieve a component by its ID in JavaScript code. A
local ID is often unique but its not required to be unique.
Create a local ID by using the aura:id attribute. For example:
<ui:button aura:id="button1" label="button1"/>
Note: aura:id doesn't support expressions. You can only assign literal string values to aura:id.
Find the button component by calling cmp.find("button1") in your client-side controller, where cmp is a reference to the
component containing the button.
find() returns different types depending on the result.
Global IDs
Every component has a unique globalId, which is the generated runtime-unique ID of the component instance. A global ID is not
guaranteed to be the same beyond the lifetime of a component, so it should never be relied on.
To create a unique ID for an HTML element, you can use the globalId as a prefix or suffix for your element. For example:
<div id="{!globalId + '_footer'}"></div>
You can use the getGlobalId() function in JavaScript to get a component's global ID.
var globalId = cmp.getGlobalId();
You can also do the reverse operation and get a component if you have its global ID.
var cmp = $A.getComponent(globalId);
47
Creating Components
HTML in Components
HTML in Components
An HTML tag is treated as a first-class component by the framework. Each HTML tag is translated into a component, allowing it to enjoy
the same rights and privileges as any other component.
You can add HTML markup in components. Note that you must use strict XHTML. For example, use <br/> instead of <br>. You can
also use HTML attributes and DOM events, such as onclick.
Warning: Some tags, like <applet> and <font>, arent supported. For a full list of unsupported tags, see Supported HTML
Tags on page 319.
Unescaping HTML
To output pre-formatted HTML, use aura:unescapedHTML. For example, this is useful if you want to display HTML that is generated
on the server and add it to the DOM. You must escape any HTML if necessary or your app might be exposed to security vulnerabilities.
You can pass in values from an expression, such as in <aura:unescapedHtml value="{!v.note.body}"/>.
{!expression} is the framework's expression syntax. For more information, see Using Expressions on page 57.
SEE ALSO:
Supported HTML Tags
CSS in Components
CSS in Components
Style your components with CSS.
Add CSS to a component bundle by clicking the STYLE button in the Developer Console sidebar.
For external CSS resources, see Styling Apps on page 143.
All top-level elements in a component have a special THIS CSS class added to them. This, effectively, adds namespacing to CSS and
helps prevent one component's CSS from blowing away another component's styling. The framework throws an error if a CSS file doesn't
follow this convention.
Let's look at a sample helloHTML.cmp component. The CSS is in helloHTML.css.
Component source
<aura:component>
<div class="white">
Hello, HTML!
</div>
<h2>Check out the style in this list.</h2>
<ul>
<li class="red">I'm red.</li>
<li class="blue">I'm blue.</li>
<li class="green">I'm green.</li>
</ul>
</aura:component>
48
Creating Components
Component Attributes
CSS source
.THIS {
background-color: grey;
}
.THIS.white {
background-color: white;
}
.THIS .red {
background-color: red;
}
.THIS .blue {
background-color: blue;
}
.THIS .green {
background-color: green;
}
Output
The top-level elements, h2 and ul, match the THIS class and render with a grey background. Top-level elements are tags wrapped
by the HTML body tag and not by any other tags. In this example, the li tags are not top-level because they are nested in a ul tag.
The <div class="white"> element matches the .THIS.white selector and renders with a white background. Note that
there is no space in the selector as this rule is for top-level elements.
The <li class="red"> element matches the .THIS .red selector and renders with a red background. Note that this is a
descendant selector and it contains a space as the <li> element is not a top-level element.
SEE ALSO:
Adding and Removing Styles
HTML in Components
Component Attributes
Component attributes are like member variables on a class in Apex. They are typed fields that are set on a specific instance of a component,
and can be referenced from within the component's markup using an expression syntax. Attributes enable you to make components
more dynamic.
Use the <aura:attribute> tag to add an attribute to the component or app. Lets look at the following sample,
helloAttributes.app:
<aura:application>
<aura:attribute name="whom" type="String" default="world"/>
Hello {!v.whom}!
49
Creating Components
Component Composition
</aura:application>
All attributes have a name and a type. Attributes may be marked as required by specifying required="true", and may also specify
a default value.
In this case we've got an attribute named whom of type String. If no value is specified, it defaults to "world".
Though not a strict requirement, <aura:attribute> tags are usually the first things listed in a components markup, as it provides
an easy way to read the component's shape at a glance.
Attribute names must start with a letter or underscore. They can also contain numbers or hyphens after the first character.
Note: You can't use attributes with hyphens in expressions. For example, cmp.get("v.name-withHyphen") is supported,
but not <ui:button label="{!v.name-withHyphen}"/>.
Now, append ?whom=you to the URL and reload the page. The value in the query string sets the value of the whom attribute. Supplying
attribute values via the query string when requesting a component is one way to set the attributes on that component.
Warning: This only works for attributes of type String.
Expressions
helloAttributes.app contains an expression, {!v.whom}, which is responsible for the component's dynamic output.
{!expression} is the framework's expression syntax. In this case, the expression we are evaluating is v.whom. The name of the
attribute we defined is whom, while v is the value provider for a component's attribute set, which represents the view.
Note: Expressions are case sensitive. For example, if you have a custom field myNamespace__Amount__c, you must refer
to it as {!v.myObject.myNamespace__Amount__c}.
Attribute Validation
We defined the set of valid attributes in helloAttributes.app, so the framework automatically validates that only valid attributes
are passed to that component.
Try requesting helloAttributes.app with the query string ?fakeAttribute=fakeValue. You should receive an error
that helloAttributes.app doesnt have a fakeAttribute attribute.
SEE ALSO:
Supported aura:attribute Types
Using Expressions
Component Composition
Composing fine-grained components in a larger component enables you to build more interesting components and applications.
Let's see how we can fit components together. We will first create a few simple components: c:helloHTML and
c:helloAttributes. Then, well create a wrapper component, c:nestedComponents, that contains the simple components.
50
Creating Components
Component Composition
CSS source
.THIS {
background-color: grey;
}
.THIS.white {
background-color: white;
}
.THIS .red {
background-color: red;
}
.THIS .blue {
background-color: blue;
}
.THIS .green {
background-color: green;
}
Output
51
Creating Components
Observe!
Component Composition
<c:helloHTML/>
<c:helloAttributes whom="component composition"/>
</aura:component>
Output
Including an existing component is similar to including an HTML tag. Reference the component by its "descriptor", which is of the form
namespace:component. nestedComponents.cmp references the helloHTML.cmp component, which lives in the c
namespace. Hence, its descriptor is c:helloHTML.
Note how nestedComponents.cmp also references c:helloAttributes. Just like adding attributes to an HTML tag, you
can set attribute values in a component as part of the component tag. nestedComponents.cmp sets the whom attribute of
helloAttributes.cmp to "component composition".
Attribute Passing
You can also pass attributes to nested components. nestedComponents2.cmp is similar to nestedComponents.cmp,
except that it includes an extra passthrough attribute. This value is passed through as the attribute value for c:helloAttributes.
<!--c:nestedComponents2-->
<aura:component>
<aura:attribute name="passthrough" type="String" default="passed attribute"/>
Observe! Components within components!
<c:helloHTML/>
<c:helloAttributes whom="{!v.passthrough}"/>
</aura:component>
Output
52
Creating Components
Component Body
It shouldn't be surprising that we can add multiple instances of the same component with different attributes.
nestedComponents3.cmp adds another instance of c:helloAttributes with a different attribute value. The two instances
of the c:helloAttributes component have different values for their whom attribute .
<!--c:nestedComponents3-->
<aura:component>
<aura:attribute name="passthrough" type="String" default="passed attribute"/>
Observe! Components within components!
<c:helloHTML/>
<c:helloAttributes whom="{!v.passthrough}"/>
<c:helloAttributes whom="separate instance"/>
</aura:component>
Output
Component Body
The root-level tag of every component is <aura:component>. Every component inherits the body attribute from
<aura:component>.
The <aura:component> tag can contain tags, such as <aura:attribute>, <aura:registerEvent>,
<aura:handler>, <aura:set>, and so on. Any free markup that is not enclosed in one of the tags allowed in a component is
assumed to be part of the body and is set in the body attribute.
The body attribute has type Aura.Component[]. It can be an array of one component, or an empty array, but it's always an array.
In a component, use v to access the collection of attributes. For example, {!v.body} outputs the body of the component.
To set the value of an inherited attribute, use the <aura:set> tag. Setting the body content is equivalent to wrapping that free
markup inside <aura:set attribute="body">. Since the body attribute has this special behavior, you can omit <aura:set
attribute="body">.
53
Creating Components
Component Facets
The previous sample is a shortcut for this markup. We recommend the less verbose syntax in the previous sample.
<aura:component>
<aura:set attribute="body">
<!--START BODY-->
<div>Body part</div>
<ui:button label="Push Me/>
<!--END BODY-->
</aura:set>
</aura:component>
The same logic applies when you use any component that has a body attribute, not just <aura:component>. For example:
<ui:panel>
Hello world!
</ui:panel>
Component Facets
A facet is any attribute of type Aura.Component[]. The body attribute is an example of a facet.
To define your own facet, add an aura:attribute tag of type Aura.Component[] to your component. For example, let's
create a new component called facetHeader.cmp.
<!--c:facetHeader-->
<aura:component>
<aura:attribute name="header" type="Aura.Component[]"/>
<div>
<span class="header">{!v.header}</span><br/>
<span class="body">{!v.body}</span>
</div>
</aura:component>
This component has a header facet. Note how we position the output of the header using the v.header expression.
54
Creating Components
The component doesn't have any output when you access it directly as the header and body attributes aren't set. Lets create another
component, helloFacets.cmp, that sets these attributes.
<!--c:helloFacets-->
<aura:component>
See how we set the header facet.<br/>
<auradocs:facetHeader>
Nice body!
<aura:set attribute="header">
Hello Header!
</aura:set>
</auradocs:facetHeader>
</aura:component>
Note that aura:set sets the value of the header attribute of facetHeader.cmp, but you dont need to use aura:set if
youre setting the body attribute.
SEE ALSO:
Component Body
Only consider using <aura:renderIf> if you expect to show the markup for both the true and false states, and it would require
a server round trip to create the components that aren't initially rendered.
Heres a quick comparison of <aura:if> versus <aura:renderIf>.
<aura:if>
<aura:renderIf>
Displaying
Switching condition
Unrenders and destroys the current branch. Unrenders the current branch and renders
Creates and displays the other branch.
the other branch
Empty branch
55
Creating Components
Component Versioning
Component Versioning
Component versioning enables you to declare dependencies against specific revisions of an installed managed package.
By assigning a version to your component, you have granular control over how the component functions when new versions of a
managed package are released. For example, imagine that a <packageNamespace>:button is pinned to version 2.0 of a package.
Upon installing version 3.0, the button retains its version 2.0 functionality.
Note: The package developer is responsible for inserting versioning logic into the markup when updating a component. If the
component wasnt changed in the update or if the markup doesnt account for version, the component behaves in the context
of the most recent version.
Versions are assigned declaratively in the Developer Console. When youre working on a component, click Bundle Version Settings
in the right panel to define the version. You can only version a component if youve installed a package, and the valid versions for the
component are the available versions of that package. Versions are in the format <major>.<minor>. So if you assign a component
version 1.4, its behavior depends on the first major release and fourth minor release of the associated package.
56
Creating Components
Using Expressions
JavaScript helpers
JavaScript renderers
Bundle markup
Applications (.app)
Components (.cmp)
Interfaces (.intf)
Events (.evt)
You cant version any other types of resources in bundles. Unsupported types include:
Styles (.css)
Documentation (.doc)
Design (.design)
SVG (.svg)
Once youve assigned versions to components, or if youre developing components for a package, you can retrieve the version in several
contexts.
Resource
Return Type
Expression
Apex
Version
System.requestVersion()
JavaScript
String
cmp.getVersion()
String
{!Version}
You can use the retrieved version to add logic to your code or markup to assign different functionality to different versions. Heres an
example of using versioning in an <aura:if> statement.
<aura:component>
<aura:if isTrue="{!Version > 1.0}">
<c:newVersionFunctionality/>
</aura:if>
<c:oldVersionFunctionality/>
...
</aura:component>
Using Expressions
Expressions allow you to make calculations and access property values and other data within component markup. Use expressions for
dynamic output or passing values into components by assigning them to attributes.
An expression is any set of literal values, variables, sub-expressions, or operators that can be resolved to a single value. Method calls are
not allowed in expressions.
The expression syntax is: {!expression}
expression is a placeholder for the expression.
Anything inside the {! } delimiters is evaluated and dynamically replaced when the component is rendered or when the value is
used by the component. Whitespace is ignored.
57
Creating Components
The resulting value can be a primitive, such as an integer, string, or boolean. It can also be a JavaScript object, a component or collection,
a controller method such as an action method, and other useful results.
Note: If you're familiar with other languages, you may be tempted to read the ! as the "bang" operator, which negates boolean
values in many programming languages. In the Lightning Component framework, {! is simply the delimiter used to begin an
expression.
If you're familiar with Visualforce, this syntax will look familiar.
Identifiers in an expression, such as attribute names accessed through the view, controller values, or labels, must start with a letter or
underscore. They can also contain numbers or hyphens after the first character. For example, {!v.2count} is not valid, but
{!v.count} is.
Important: Only use the {! } syntax in markup in .app or .cmp files. In JavaScript, use string syntax to evaluate an expression.
For example:
var theLabel = cmp.get("v.label");
This renders {! in plain text because the aura:text component never interprets {! as the start of an expression.
IN THIS SECTION:
Dynamic Output in Expressions
The simplest way to use expressions is to output dynamic values.
Conditional Expressions
Here are examples of conditional expressions using the ternary operator and the <aura:if> tag.
Value Providers
Value providers are a way to access data. Value providers encapsulate related values together, similar to how an object encapsulates
properties and methods.
Expression Evaluation
Expressions are evaluated much the same way that expressions in JavaScript or other programming languages are evaluated.
Expression Operators Reference
The expression language supports operators to enable you to create more complex expressions.
Expression Functions Reference
The expression language contains math, string, array, comparison, boolean, and conditional functions. All functions are case-sensitive.
In this expression, v represents the view, which is the set of component attributes, and desc is an attribute of the component. The
expression is simply outputting the desc attribute value for the component that contains this markup.
If you're including literal values in expressions, enclose text values within single quotes, such as {!'Some text'}.
58
Creating Components
Conditional Expressions
Conditional Expressions
Here are examples of conditional expressions using the ternary operator and the <aura:if> tag.
Ternary Operator
This expression uses the ternary operator to conditionally output one of two values dependent on a condition.
<a class="{!v.location == '/active' ? 'selected' : ''}" href="#/active">Active</a>
The {!v.location == '/active' ? 'selected' : ''} expression conditionally sets the class attribute of an HTML
<a> tag, by checking whether the location attribute is set to /active. If true, the expression sets class to selected.
If the edit attribute is set to true, a ui:button displays. Otherwise, the text in the else attribute displays.
SEE ALSO:
Best Practices for Conditional Markup
Value Providers
Value providers are a way to access data. Value providers encapsulate related values together, similar to how an object encapsulates
properties and methods.
The value providers for a component are v (view) and c (controller).
Value Provider
Description
See Also
59
Creating Components
Value Providers
Value Provider
Description
See Also
A components controller, which enables you to wire up Handling Events with Client-Side Controllers
event handlers and actions for the component
All components have a v value provider, but aren't required to have a controller. Both value providers are created automatically when
defined for a component.
Note: Expressions are bound to the specific component that contains them. That component is also known as the attribute value
provider, and is used to resolve any expressions that are passed to attributes of its contained components.
Description
See Also
globalID
The globalId global value provider returns the global Component IDs
ID for a component. Every component has a unique
globalId, which is the generated runtime-unique ID
of the component instance.
$Browser
$Label
The $Label global value provider enables you to access Using Custom Labels
labels stored outside your code.
$Locale
$Browser
60
Creating Components
Value Providers
$Browser
The $Browser global value provider returns information about the hardware and operating system of the browser accessing the
application.
Attribute
Description
formFactor
Returns a FormFactor enum value based on the type of hardware the browser is running on.
DESKTOP for a desktop client
PHONE for a phone including a mobile phone with a browser and a smartphone
TABLET for a tablet client (for which isTablet returns true)
isAndroid
Indicates whether the browser is running on an Android device (true) or not (false).
isIOS
Not available in all implementations. Indicates whether the browser is running on an iOS device (true)
or not (false).
isIPad
Not available in all implementations. Indicates whether the browser is running on an iPad (true) or not
(false).
isIPhone
Not available in all implementations. Indicates whether the browser is running on an iPhone (true) or
not (false).
isPhone
Indicates whether the browser is running on a phone including a mobile phone with a browser and a
smartphone (true), or not (false).
isTablet
Indicates whether the browser is running on an iPad or a tablet with Android 2.2 or later (true) or not
(false).
isWindowsPhone
Indicates whether the browser is running on a Windows phone (true) or not (false). Note that this
only detects Windows phones and does not detect tablets or other touch-enabled Windows 8 devices.
Example: This example shows usage of the $Browser global value provider.
<aura:component>
{!$Browser.isTablet}
{!$Browser.isPhone}
{!$Browser.isAndroid}
{!$Browser.formFactor}
</aura:component>
Similarly, you can check browser information in a client-side controller using $A.get().
({
checkBrowser: function(component) {
var device = $A.get("$Browser.formFactor");
alert("You are using a " + device);
}
})
61
Creating Components
Value Providers
$Locale
The $Locale global value provider returns information about the current users preferred locale.
These attributes are based on Javas Calendar, Locale and TimeZone classes.
Attribute
Description
Sample Value
country
currency
"$"
currencyCode
decimal
"."
firstDayOfWeek
grouping
","
false
labelForToday
Today
language
langLocale
en_US, en_GB
nameOfMonths
nameOfWeekdays
timezone
"America/Los_Angeles"
US
userLocaleLang
en
variant
Description
Sample Value
currencyformat
"#,##0.00;(#,##0.00)"
represents the currency sign, which is replaced
by the currency symbol.
dateFormat
"MMM d, yyyy"
datetimeFormat
62
Creating Components
Expression Evaluation
Attribute
Description
Sample Value
numberformat
"#,##0.###"
# represents a digit, the comma is a placeholder for
the grouping separator, and the period is a
placeholder for the decimal separator. Zero (0)
replaces # to represent trailing zeros.
percentformat
"#,##0%"
timeFormat
"h:mm:ss a"
zero
Similarly, you can check locale information in a client-side controller using $A.get().
({
checkDevice: function(component) {
var locale = $A.get("$Locale.language");
alert("You are using " + locale);
}
})
SEE ALSO:
Localization
Expression Evaluation
Expressions are evaluated much the same way that expressions in JavaScript or other programming languages are evaluated.
Operators are a subset of those available in JavaScript, and evaluation order and precedence are generally the same as JavaScript.
Parentheses enable you to ensure a specific evaluation order. What you may find surprising about expressions is how often they are
evaluated. The framework notices when things change, and trigger re-rendering of any components that are affected. Dependencies
are handled automatically. This is one of the fundamental benefits of the framework. It knows when to re-render something on the page.
When a component is re-rendered, any expressions it uses will be re-evaluated.
63
Creating Components
Action Methods
Expressions are also used to provide action methods for user interface events: onclick, onhover, and any other component
attributes beginning with "on". Some components simplify assigning actions to user interface events using other attributes, such as the
press attribute on <ui:button>.
Action methods must be assigned to attributes using an expression, for example {!c.theAction}. This assigns an Aura.Action,
which is a reference to the controller function that handles the action.
Assigning action methods via expressions allows you to assign them conditionally, based on the state of the application or user interface.
For more information, see Conditional Expressions on page 59.
<ui:button aura:id="likeBtn"
label="{!(v.likeId == null) ? 'Like It' : 'Unlike It'}"
press="{!(v.likeId == null) ? c.likeIt : c.unlikeIt}"
/>
This button will show "Like It" for items that have not yet been liked, and clicking it will call the likeIt action method. Then the
component will re-render, and the opposite user interface display and method assignment will be in place. Clicking a second time will
unlike the item, and so on.
Arithmetic Operators
Expressions based on arithmetic operators result in numerical values.
Operator
Usage
Description
1 + 1
2 - 1
2 * 2
4 / 2
5 % 2
-v.exp
Numeric Literals
Literal
Usage
Description
Integer
64
Creating Components
Literal
Usage
Description
Float
3.14
-1.1e10
Null
A literal null number. Matches the explicit null value and numbers
with an undefined value.
null
String Operators
Expressions based on string operators result in string values.
Operator
Usage
Description
String Literals
String literals must be enclosed in single quotation marks 'like this'.
Literal
Usage
Description
string
'hello world'
Literal strings must be enclosed in single quotation marks. Double quotation marks
are reserved for enclosing attribute values, and must be escaped in strings.
\<escape>
'\n'
Whitespace characters:
\t (tab)
\n (newline)
\r (carriage return)
Escaped characters:
\" (literal ")
\' (literal ')
\\ (literal \)
Unicode
'\u####'
A Unicode code point. The # symbols are hexadecimal digits. A Unicode literal
requires four digits.
null
null
A literal null string. Matches the explicit null value and strings with an undefined
value.
Comparison Operators
Expressions based on comparison operators result in a true or false value. For comparison purposes, numbers are treated as the
same type. In all other cases, comparisons check both value and type.
65
Creating Components
Operator
Alternative
Usage
Description
==
eq
1 == 1
1 == 1.0
1 eq 1
Note:
undefined==null
evaluates to true.
!=
ne
1 != 2
1 != true
1 != '1'
null != false
1 ne 2
<
lt
1 < 2
1 lt 2
>
gt
42 > 2
42 gt 2
<=
le
2 <= 42
2 le 42
>=
ge
42 >= 42
42 ge 42
Logical Operators
Expressions based on logical operators result in a true or false value.
Operator
Usage
Description
&&
isEnabled &&
hasPermission
Returns true if both operands are individually true. You must escape the && operator to
&& to use it in component markup. Alternatively, you can use the and()
function and pass it two arguments. For example, and(isEnabled, hasPermission).
||
hasPermission
|| isRequired
!isRequired
Unary operator. Returns true if the operand is false. This operator should not be confused
with the ! delimiter used to start an expression in {!. You can combine the expression
66
Creating Components
Operator
Usage
Description
delimiter with this negation operator to return the logical negation of a value, for example,
{!!true} returns false.
Logical Literals
Logical values are never equivalent to non-logical values. That is, only true == true, and only false == false; 1 !=
true, and 0 != false, and null != false.
Literal
Usage
Description
true
true
false
false
Conditional Operator
There is only one conditional operator, the traditional ternary operator.
Operator
Usage
Description
? :
(1 != 2) ? "Obviously" : "Black
is White"
SEE ALSO:
Expression Functions Reference
Math Functions
The math functions perform math operations on numbers. They take numerical arguments. The Corresponding Operator column lists
equivalent operators, if any.
Function
Alternative
Usage
Description
Corresponding
Operator
add
concat
add(1,2)
sub
subtract
sub(10,2)
mult
multiply
mult(2,10)
67
Creating Components
Function
Alternative
Usage
Description
div
divide
div(4,2)
mod
modulus
mod(5,2)
abs(-5)
neg(100)
abs
neg
negate
Corresponding
Operator
- (unary)
neg(100) is -100.
String Functions
Function
Alternative
Usage
Description
concat
add
concat('Hello ',
'world')
68
placeholders with
comma-separated
attribute values.
Corresponding
Operator
Creating Components
Label Functions
Function
Usage
Description
format
format($Label.np.labelName,
v.attribute1 , v.attribute2)
format($Label.np.hello, v.name)
Informational Functions
Function
Usage
Description
length
myArray.length
empty
empty(v.attributeName)
Comparison Functions
Comparison functions take two number arguments and return true or false depending on the comparison result. The eq and
ne functions can also take other data types for their arguments, such as strings.
Function
Usage
Description
equals
equals(1,1)
notequals
notequals(1,2)
lessthan
lessthan(1,5)
69
Corresponding
Operator
< or lt
Creating Components
Using Labels
Function
Usage
Description
Corresponding
Operator
greaterthan
greaterthan(5,1)
> or gt
lessthanorequal
<= or le
>= or ge
Boolean Functions
Boolean functions operate on Boolean arguments. They are equivalent to logical operators.
Function
Usage
Description
Corresponding Operator
and
and(isEnabled,
hasPermission)
&&
or
or(hasPermission,
hasVIPPass)
||
not
not(isNew)
Function
Usage
Description
Corresponding Operator
if
if(isEnabled,
'Enabled', 'Not
enabled')
?: (ternary)
Conditional Function
Using Labels
The framework supports various methods to provide labels in your code using the $Label global value provider, which accesses labels
stored outside your code.
This section discusses how to use the $Label global value provider with these methods:
The label attribute in input components
The format() expression function for dynamically populating placeholder values in labels
70
Creating Components
IN THIS SECTION:
Using Custom Labels
Use custom labels in Lightning components with the $Label global value provider.
Input Component Labels
A label describes the purpose of an input component. To set a label on an input component, use the label attribute.
Dynamically Populating Label Parameters
Output and update labels using the format() expression function.
Setting Label Values via a Parent Attribute
Setting label values via a parent attribute is useful if you want control over labels in child components.
Note: Custom labels referenced in a Lightning component are not automatically added when you create a package containing
the Lightning component. To include a custom label in a package, another member of the package, such as a Visualforce page,
must reference the custom label.
SEE ALSO:
Value Providers
The label is placed on the left of the input field and can be hidden by setting labelClass="assistiveText". assistiveText
is a global style class used to support accessibility.
71
Creating Components
Using $Label
Use the $Label global value provider to access labels stored in an external source. For example:
<ui:inputNumber label="{!$Label.Number.PickOne}" />
To output a label and dynamically update it, use the format() expression function. For example, if you have np.labelName set
to Hello {0}, the following expression returns Hello World if v.name is set to World.
{!format($Label.np.labelName, v.name)}
SEE ALSO:
Supporting Accessibility
72
Creating Components
Localization
default="My Label"/>
<ui:button label="Set Label" aura:id="button1" press="{!c.setLabel}"/>
<auradocs:inner aura:id="inner" label="{!v._label}"/>
</aura:component>
This inner component contains a text area component and a label attribute thats set by the container component.
<aura:component>
<aura:attribute name="label" type="String"/>
<ui:inputTextarea aura:id="textarea"
label="{!v.label}"/>
</aura:component>
When the component is initialized, youll see a button and a text area with the label My Label. When the button in the container
component is clicked, the setLabel action updates the label value in the inner component. This action finds the label attribute
and sets its value to new label.
SEE ALSO:
Input Component Labels
Component Attributes
Localization
The framework provides client-side localization support on input and output components.
The following example shows how you can override the default langLocale and timezone attributes. The output displays the
time in the format hh:mm by default.
Note: For more information on supported attributes, see the Reference Doc App.
Component source
<aura:component>
<ui:outputDateTime value="2013-10-07T00:17:08.997Z"
langLocale="de"/>
</aura:component>
timezone="Europe/Berlin"
73
Creating Components
Localization
Running $A.get("$Locale.timezone") returns the time zone name, for example, Europe/Paris. For more information,
see "Supported Time Zones" in the Salesforce Help.
Setting the currency locale on the Company Information page to Japanese (Japan) - JPY returns 100,000 when you
run the following code.
<ui:outputCurrency value="100000" />
Similarly, running $A.get("$Locale.currency") returns "" when your orgs currency locale is set to Japanese
(Japan) - JPY. For more information, see "Supported Currencies" in the Salesforce Help.
If youre not retrieving the browsers date information, you can specify the date format on your own. This example specifies the date
format and uses the browsers language locale information.
var dateFormat = "MMMM d, yyyy h:mm a";
var userLocaleLang = $A.get("$Locale.langLocale");
return $A.localizationService.formatDate(date, dateFormat, userLocaleLang);
The AuraLocalizationService JavaScript API provides methods for working with localization. For example, you can compare
two dates to check that one is later than the other.
var startDateTime = new Date();
//return the date time at end of the day
var endDateTime = $A.localizationService.endOf(d, 'day');
if( $A.localizationService.isAfter(startDateTime,endDateTime)) {
//throw an error if startDateTime is after endDateTime
}
74
Creating Components
Note: For more information on the localization service, see the JavaScript API in the Reference Doc App.
SEE ALSO:
Value Providers
Description
<aura:documentation>
<aura:description>
Describes the component using extensive HTML markup. To include code samples in the
description, use the <pre> tag, which renders as a code block. Code entered in the <pre> tag
must be escaped. For example, escape <aura:component> by entering
<aura:component>.
<aura:example>
References an example that demonstrates how the component is used. Supports extensive HTML
markup, which displays as text preceding the visual output and example component source. The
example is displayed as interactive output. Multiple examples are supported and should be wrapped
in individual <aura:example> tags.
name: The API name of the example
75
Creating Components
Tag
Description
ref: The reference to the example component in the format
<namespace:exampleComponent>
The following is an example component that demonstrates how np:myComponent can be used.
<!--The np:myComponentExample example component-->
<aura:component>
<np:myComponent>
<aura:set attribute=myAttribute>This sets the attribute on the np:myComponent
component.</aura:set>
<!--More markup that demonstrates the usage of np:myComponent-->
</np:myComponent>
</aura:component>
Example
<aura:component>
<aura:attribute>
<aura:event>
<aura:interface>
<aura:registerEvent>
76
Creating Components
Key Components
Description
Message
ui:message
Menu
ui:menu
ui:menuList
ui:actionMenuItem
ui:checkboxMenuItem
ui:radioMenuItem
ui:menuItemSeparator
ui:menuItem
ui:menuTrigger
ui:menuTriggerLink
77
Creating Components
Key Components
Description
Button
ui:button
Checkbox
ui:inputCheckbox
ui:outputCheckbox
Radio button
ui:inputRadio
Drop-down List
ui:inputSelect
ui:inputSelectOption
Visual Components
The following components provides informative cues, for example, like error messages and loading spinners.
Type
Key Components
Description
Field-level error
ui:inputDefaultError
Spinner
ui:spinner
A loading spinner
Field Components
The following components enables you to enter or display values.
Type
Key Components
Description
Currency
ui:inputCurrency
ui:outputCurrency
ui:inputEmail
ui:outputEmail
ui:inputDate
ui:inputDateTime
ui:outputDate
ui:outputDateTime
Password
ui:inputSecret
Phone Number
ui:inputPhone
ui:outputPhone
78
Creating Components
UI Events
Type
Key Components
Description
Number
ui:inputNumber
ui:outputNumber
Displays a number
Range
ui:inputRange
Rich Text
ui:inputRichText
ui:outputRichText
ui:inputText
ui:outputText
Displays text
ui:inputTextArea
ui:outputTextArea
ui:inputURL
ui:outputURL
Text
Text Area
URL
SEE ALSO:
Using the UI Components
Creating Components
Component Bundles
UI Events
UI components provide easy handling of user interface events such as keyboard and mouse interactions. By listening to these events,
you can also bind values on UI input components using the updateon attribute, such that the values update when those events are
fired.
Capture a UI event by defining its handler on the component. For example, you want to listen to the HTML DOM event, onblur, on a
ui:inputTextArea component.
<ui:inputTextArea aura:id="textarea" value="My text area" label="Type something"
blur="{!c.handleBlur}" />
The blur="{!c.handleBlur}" listens to the onblur event and wires it to your client-side controller. When you trigger the
event, the following client-side controller handles the event.
handleBlur : function(cmp, event, helper){
var elem = cmp.find("textarea").getElement();
//do something else
}
For all available events on all components, see the Component Reference on page 218.
79
Creating Components
The next example takes in numerical inputs and returns the sum of those numbers. The ui:inputNumber component listens to
the onkeyup browser event. When the value in this component changes on the keyup event, the value in the ui:outputNumber
component is updated as well, and returns the sum of the two values.
<aura:attribute name="number1" type="integer" default="1"/>
<aura:attribute name="number2" type="integer" default="2"/>
<ui:inputNumber label="Number 1" value="{!v.number1}" updateOn="keyup" />
<ui:inputNumber label="Number 2" value="{!v.number2}" updateOn="keyup" />
<!-- Adds the numbers and returns the sum -->
<ui:outputNumber value="{!(v.number1 * 1) + (v.number2 * 1)}"/>
Note: The input fields return a string value and must be properly handled to accommodate numerical values. In this example,
both values are multiplied by 1 to obtain their numerical equivalents.
Note: All text fields must specify the label attribute to provide a textual label of the field. If you must hide the label from view,
set labelClass="assitiveText" to make the label available to assistive technologies.
80
Creating Components
The ui:outputText component acts as a placeholder for the output value of its corresponding ui:inputText component.
The value in the ui:outputText component can be set with the following client-side controller action.
getInput : function(cmp, event) {
var fullName = cmp.find("name").get("v.value");
var outName = cmp.find("nameOutput");
outName.set("v.value", fullName);
}
The following example is similar to the previous, but uses value binding without a client-side controller. The ui:outputText
component reflects the latest value on the ui:inputText component when the onkeyup browser event is fired.
<aura:attribute name="first" type="String" default="John"/>
<aura:attribute name="last" type="String" default="Doe"/>
<ui:inputText label="First Name" value="{!v.first}" updateOn="keyup"/>
<ui:inputText label="Last Name" value="{!v.last}" updateOn="keyup"/>
<!-- Returns "John Doe" -->
<ui:outputText value="{!v.first +' '+ v.last}"/>
Tip: To create and edit records in Salesforce1, use the force:createRecord and force:recordEdit events to utilize
the built-in record create and edit pages.
Description
Related Components
Date
ui:inputDate
ui:outputDate
81
Creating Components
SEE ALSO:
Input Component Labels
Handling Events with Client-Side Controllers
Localization
CSS in Components
Number Fields
Number fields can contain a numerical value. They support client-side formatting, localization, and common keyboard and mouse events.
82
Creating Components
If you want to render the output from these field components, use the respective ui:output components. For example, to render
the output for the ui:inputNumber component, use ui:outputNumber.
Number fields are represented by the following components.
Type
Related Components
Description
Number
ui:inputNumber
ui:outputNumber
Displays a number
ui:inputCurrency
ui:outputCurrency
Displays currency
Currency
83
Creating Components
SEE ALSO:
Input Component Labels
Handling Events with Client-Side Controllers
Localization
CSS in Components
Text Fields
A text field can contain alphanumerical characters and special characters. They provide common keyboard and mouse events. If you
want to render the output from these field components, use the respective ui:output components. For example, to render the
output for the ui:inputPhone component, use ui:outputPhone.
Text fields are represented by the following components.
Type
Related Components
Description
ui:inputEmail
ui:outputEmail
Password
ui:inputSecret
Phone Number
ui:inputPhone
ui:outputPhone
ui:inputRichText
Rich Text
84
Creating Components
Type
Text
Text Area
URL
Related Components
Description
ui:outputRichText
ui:inputText
ui:outputText
Displays text
ui:inputTextArea
ui:outputTextArea
ui:inputURL
ui:outputURL
Note: You can also use the force:navigateToURL event to make an element behave like a URL link. For more information, see
force:navigateToURL on page 305.
85
Creating Components
SEE ALSO:
Rich Text Fields
Input Component Labels
Handling Events with Client-Side Controllers
Localization
CSS in Components
which is rendered as a text area and button. A button click runs the client-side controller action that returns the input value in a
ui:outputRichText component. In this case, the value returns Aura in bold, and input rich text demo in red.
<!--Rich text demo-->
<ui:inputRichText isRichText="false" aura:id="inputRT" label="Rich Text Demo"
cols="50" rows="5" value="<b>Aura</b>, <span style='color:red'>input
rich text demo</span>"/>
<ui:button aura:id="outputButton"
buttonTitle="Click to see what you put into the rich text field"
label="Display" press="{!c.getInput}"/>
<ui:outputRichText aura:id="outputRT" value=" "/>
/*Client-side controller*/
getInput : function(cmp) {
var userInput = cmp.find("inputRT").get("v.value");
var output = cmp.find("outputRT");
output.set("v.value", userInput);
}
In this demo, the isRichText="false" attribute replaces the component with the ui:inputTextArea component. The
WYSIWYG rich text editor is provided when this attribute is not set, as shown below.
The width and height of the rich text editor are independent of those on the ui:inputTextArea component. To set the width
and height of the component when you set isRichText="false", use the cols and rows attributes. Otherwise, use the
width and height attributes.
SEE ALSO:
Text Fields
86
Creating Components
Checkboxes
Checkboxes are clickable and actionable, and they can be presented in a group for multiple selection. You can create a checkbox with
ui:inputCheckbox, which inherits the behavior and events from ui:input. The value and disabled attributes control
the state of a checkbox, and events such as click and change determine its behavior. Events must be used separately on each
checkbox.
Here are several basic ways to set up a checkbox.
Checked
To select the checkbox, set value="true". This example sets the inital value of the checkbox.
<aura:attribute name="check" type="Boolean" default="true"/>
<ui:inputcheckbox value="{!v.check}"/>
Disabled State
<ui:inputCheckbox disabled="true" label="Select" />
<ui:inputCheckbox labelClass="check"
label="Select?" value="true" />
87
Creating Components
The following CSS style replaces the default checkbox with the given image.
.THIS input[type="checkbox"] {
display: none;
}
.THIS .check span {
margin: 20px;
}
.THIS input[type="checkbox"]+label {
display: inline-block;
width: 20px;
height: 20px;
vertical-align: middle;
background: url('images/checkbox.png') top left;
cursor: pointer;
}
.THIS input[type="checkbox"]:checked+label {
background:url('images/checkbox.png') bottom left;
}
SEE ALSO:
Handling Events with Client-Side Controllers
CSS in Components
Radio Buttons
Radio buttons are clickable and actionable, and they can only be individually selected when presented in a group. You can create a radio
button with ui:inputRadio, which inherits the behavior and events from ui:input. The value and disabled attributes
control the state of a radio button, and events such as click and change determine its behavior. Events must be used separately
on each radio button.
If you want to use radio buttons in a menu, use ui:radioMenuItem instead.
Here are several basic ways to set up a radio button.
Selected
To select the radio button, set value="true".
<ui:inputRadio value="true" label="Select?"/>
Disabled State
<ui:inputRadio label="Select" disabled="true"/>
88
Creating Components
SEE ALSO:
Handling Events with Client-Side Controllers
CSS in Components
Buttons
A button is clickable and actionable, providing a textual label, an image, or both. You can create a button in three different ways:
Text-only Button
<ui:button label="Find" />
Image-only Button
<!-- Component markup -->
<ui:button label="Find" labelClass="assistiveText" class="img" />
/** CSS **/
THIS.uiButton.img {
background: url(/https/www.scribd.com/path/to/img) no-repeat;
width:50px;
height:25px;
}
89
Creating Components
The assistiveText class hides the label from view but makes it available to assistive technologies.
Button with Text and Image
<!-- Component markup -->
<ui:button label="Find" />
/** CSS **/
THIS.uiButton {
background: url(/https/www.scribd.com/path/to/img) no-repeat;
}
HTML Rendering
The markup for a button with text and image results in the following HTML.
<button class="default uiBlock uiButton" accesskey type="button">
<span class="label bBody truncate" dir="ltr">Find</span>
</button>
Note that no space is added in the .THIS.uiButton selector if your button component is a top-level element.
90
Creating Components
To override the styling for all ui:button components in your app, in the CSS resource of your app, add the following class selector.
.THIS .uiButton {
margin-left: 20px;
}
SEE ALSO:
Handling Events with Client-Side Controllers
CSS in Components
Which Button Was Pressed?
Drop-down Lists
Drop-down lists display a dropdown menu with options you can select.
Both single and multiple selections are supported. You can create a drop-down list using ui:inputSelect, which inherits the
behavior and events from ui:input.
Here are a few basic ways to set up a drop-down list.
For multiple selections, set the multiple attribute to true.
Single Selection
<ui:inputSelect>
<ui:inputSelectOption text="Red"/>
<ui:inputSelectOption text="Green" value="true"/>
<ui:inputSelectOption text="Blue"/>
</ui:inputSelect>
Multiple Selection
<ui:inputSelect multiple="true">
<ui:inputSelectOption text="All Primary" label="All Contacts"/>
<ui:inputSelectOption text="All Primary" label="All Primary"/>
<ui:inputSelectOption text="All Secondary" label="All Secondary"/>
</ui:inputSelect>
Each option is represented by ui:inputSelectOption. The default selected value is specified by value="true" on the
option.
Note: v.value represents the options HTML selected attribute, and v.text represents the options HTML value
attribute.
91
Creating Components
The following client-side controller generates options using v.options on the ui:inputSelect component by creating the
opts object with several parameters. v.options takes in the list of objects and converts them into list options. Although the sample
code generates the options during initialization, the list of options can be modified anytime when you manipulate the list in v.options.
The component automatically updates itself and rerenders with the new options.
({
doInit : function(cmp) {
var opts = [
{ class: "optionClass", label: "Option1", value: "opt1"},
{ class: "optionClass", label: "Option2", value: "opt2" },
{ class: "optionClass", label: "Option3", value: "opt3" }
];
cmp.find("InputSelectDynamic").set("v.options", opts);
}
})
Note: class is a reserved word that might not work with older versions of Internet Explorer. We recommend using "class"
with double quotes.
The list options support these parameters.
Parameter
Type
Description
class
String
disabled
Boolean
label
String
selected
Boolean
value
String
92
Creating Components
Alternatively, use the class attribute to specify your own CSS class.
SEE ALSO:
Handling Events with Client-Side Controllers
CSS in Components
93
Creating Components
This client-side controller initializes the option values by calling a helper and prints out the selected value when a select change event
occurs.
({
doInit : function(component, event, helper) {
// Retrieve contacts during component initialization
helper.getMyContacts(component);
},
onSelectChange : function(component, event, helper) {
// Print out the selected value
var selected = component.find("opt").get("v.value");
console.log(selected);
}
})
The helper function calls the Apex controller getContacts()method to load the contact names.
({
getMyContacts : function(cmp) {
// Load all contact data
var action = cmp.get("c.getContacts");
action.setCallback(this, function(response){
var state = response.getState();
if (state === "SUCCESS") {
cmp.set("v.contacts", response.getReturnValue());
}
});
$A.enqueueAction(action);
}
})
Finally, the Apex controller queries and returns a list of contacts. Your controller name must correspond with your components
controller attribute.
public with sharing class ContactController {
@AuraEnabled
public static List<Contact> getContacts() {
List<Contact> contacts = [SELECT Id, Name FROM Contact];
//Add isAccessible() check
return contacts;
}
}
Field-level Errors
Field-level errors are displayed when a validation error occurs on the field after a user input. The framework creates a default error
component, ui:inputDefaultError, which provides basic events such as click and mouseover. See Validating Fields for
more information.
Alternatively, you can use ui:message for field-level errors by toggling visibility of the message when an error condition is met. See
Dynamically Showing or Hiding Markup for more information.
94
Creating Components
Menus
A menu is a drop-down list with a trigger that controls its visibility. You must provide the trigger and list of menu items. The dropdown
menu and its menu items are hidden by default. You can change this by setting the visible attribute on the ui:menuList
component to true. The menu items are shown only when you click the ui:menuTriggerLink component.
This example creates a menu with several items.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Opportunity Status"/>
<ui:menuList class="actionMenu" aura:id="actionMenu">
<ui:actionMenuItem aura:id="item2" label="Open"
click="{!c.updateTriggerLabel}"/>
<ui:actionMenuItem aura:id="item3" label="Closed"
click="{!c.updateTriggerLabel}"/>
<ui:actionMenuItem aura:id="item4" label="Closed Won"
click="{!c.updateTriggerLabel}"/>
</ui:menuList>
</ui:menu>
You can display a list of items from an object. This example displays a list of contact names in a menu using aura:iteration.
<aura:component>
<aura:attribute name="contacts" type="String[]" default="All,Primary,Secondary"/>
<ui:menu>
<ui:menuTriggerLink label="Select Contact"/>
<ui:menuList>
<aura:iteration var="contact" items="{!v.contacts}">
<ui:actionMenuItem label="{!contact}"/>
</aura:iteration>
</ui:menuList>
</ui:menu>
</aura:component>
Description
ui:menu
95
Creating Components
Supporting Accessibility
Component
Description
ui:menuList
ui:actionMenuItem
ui:checkboxMenuItem
ui:radioMenuItem
ui:menuItemSeparator
ui:menuItem
ui:menuTrigger
ui:menuTriggerLink
Supporting Accessibility
When customizing components, be careful in preserving code that ensures accessibility, such as the aria attributes. See Working with
UI Components for components you can use in your apps.
Accessible software and assistive technology enable users with disabilities to use and interact with the products you build. Aura
components are created according to W3C specifications so that they work with common assistive technologies. While we always
recommend that you follow the WCAG Guidelines for accessibility when developing with the Lightning Component framework, this
guide explains the accessibility features that you can leverage when using components in the ui namespace.
IN THIS SECTION:
Button Labels
Help and Error Messages
Audio Messages
Forms, Fields, and Labels
Events
Menus
Button Labels
Buttons may be designed to appear with just text, an image and text, or an image without text. To create an accessible button, use
ui:button and set a textual label using the label attribute. The text is available to assistive technologies, but not visible on screen.
<ui:button label="Search"
iconImgSrc="/auraFW/resources/aura/images/search.png"/>
96
Creating Components
When using ui:button, assign a non-empty string to label attribute. These examples show how a ui:button should render:
<!-- Good: using alt attribute to provide a invisible label -->
<button>
<img src="search.png" alt="Search"/>
</button>
<!-- Good: using span/assistiveText to hide the label visually, but show it to screen
readers -->
<button>
::before
<span class="assistiveText">Search</span>
</button>
SEE ALSO:
Buttons
SEE ALSO:
Validating Fields
Audio Messages
To convey audio notifications, use the ui:message component, which has role="alert" set on the component by default.
The "alert" aria role will take any text inside the div and read it out loud to screen readers without any additional action by the
user.
<ui:message title="Error" severity="error" closable="true">
This is an error message.
</ui:message>
97
Creating Components
Events
Use the input components that extend ui:input, except when type="file". For example, use ui:inputTextarea in
preference to the <textarea> tag for multi-line text input or the ui:inputSelect component in preference to the <select>
tag.
If your code failed, check the label element during component rendering. A label element should have the for attribute and match
the value of input control id attribute, OR the label should be wrapped around an input. Input controls include <input>, <textarea>,
and <select>.
<!-- Good: using label/for= -->
<label for="fullname">Enter your full name:</label>
<input type="text" id="fullname" />
<!-- Good: --using implicit label>
<label>Enter your full name:
<input type="text" id="fullname"/>
</label>
SEE ALSO:
Using Labels
Events
Although you can attach an onclick event to any type of element, for accessibility, consider only applying this event to elements
that are actionable in HTML by default, such as <a>, <button>, or <input> tags in component markup. You can use an onclick
event on a <div> tag to prevent event bubbling of a click.
Menus
A menu is a drop-down list with a trigger that controls its visibility. You must provide the trigger and list of menu items. The drop-down
menu and its menu items are hidden by default. You can change this by setting the visible attribute on the ui:menuList
component to true. The menu items are shown only when you click the ui:menuTriggerLink component.
This example code creates a menu with several items:
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Opportunity Status"/>
<ui:menuList class="actionMenu" aura:id="actionMenu">
<ui:actionMenuItem aura:id="item2" label="Open"
click="{!c.updateTriggerLabel}"/>
<ui:actionMenuItem aura:id="item3" label="Closed"
click="{!c.updateTriggerLabel}"/>
<ui:actionMenuItem aura:id="item4" label="Closed Won"
click="{!c.updateTriggerLabel}"/>
</ui:menuList>
</ui:menu>
Different menus achieve different goals. Make sure you use the right menu for the desired behavior. The three types of menus are:
Actions
Use the ui:actionMenuItem for items that create an action, like print, new, or save.
Radio button
If you want users to pick only one from a list several items, use ui:radioMenuItem.
98
Creating Components
Menus
Checkbox style
If users can pick multiple items from a list of several items, use ui:checkboxMenuItem. Checkboxes can also be used to turn
one item on or off.
99
CHAPTER 4
In this chapter ...
Adding Components
to Apps
Add Lightning
Components to
Salesforce1
Add Lightning
Components to
Lightning Experience
Add Lightning
Components to
Visualforce Pages
Configure
Components for
Communities
Configure
Components for
Lightning Pages and
the Lightning App
Builder
Using Components
You can use components in many different contexts. This section shows you how.
100
Using Components
Components are encapsulated and their internals stay private, while their public shape is visible to consumers of the component. This
strong separation gives component authors freedom to change the internal implementation details and insulates component consumers
from those changes.
The public shape of a component is defined by the attributes that can be set and the events that interact with the component. The
shape is essentially the API for developers to interact with the component. To design a new component, think about the attributes that
you want to expose and the events that the component should initiate or respond to.
Once you have defined the shape of any new components, developers can work on the components in parallel. This is a useful approach
if you have a team working on an app.
To add a new custom component to your app, see Using the Developer Console on page 4.
SEE ALSO:
Component Composition
Using Object-Oriented Development
Component Attributes
Communicating with Events
101
Using Components
EDITIONS
USER PERMISSIONS
To create Lightning
Component Tabs:
Customize Application
<aura:component implements="force:appHostable">
102
Using Components
EDITIONS
Available in: Salesforce
Classic and Lightning
Experience
Available for use in: Contact
Manager, Group,
Professional, Enterprise,
Performance, Unlimited,
and Developer Editions
Create Lightning
components using the UI in
Enterprise, Performance,
Unlimited, Developer
Editions or a sandbox.
USER PERMISSIONS
To create Lightning
Component Tabs:
Customize Application
<aura:component implements="force:appHostable">
103
Using Components
3. Check your output by navigating to the App Launcher in Lightning Experience. Your custom app should appear in theApp Launcher.
Click the custom app to see the components you added.
Adding <apex:includeLightning>
Add <apex:includeLightning /> at the beginning of your page. This loads the JavaScript file needed to use Lightning
Components for Visualforce.
To reference this app, use the following markup where theNamespace is the namespace prefix for the appeither your orgs
namespace, or the namespace of the managed package that provides the app.
$Lightning.use("theNamespace:lcvfTest", function() {});
If the app is defined in your org (that is, not in a managed package), you can use the default c namespace instead, as shown in the
next example. If your org doesnt have a namespace defined, you must use the default namespace.
104
Using Components
$Lightning.createComponent("ui:button",
{ label : "Press Me!" },
"lightning",
function(cmp) {
// do some stuff
});
});
</script>
</apex:page>
This code creates a DOM node with an ID lightning thats referenced in the $Lightning.createComponent() method. This
method creates a ui:button that says Press Me! and executes the callback function.
Note: Mark your resources with access="global" to make the resource usable outside of your own org; for example, if
you want the resource to be usable in an installed package or by a Lightning App Builder user or a Community Builder user in
another org.
Next, add a design resource to your component bundle. A design resource describes the design-time behavior of a Lightning
componentinformation that visual tools need to allow adding the component to a page or app. It contains attributes that are available
for administrators to edit in the Community Builder.
Adding this resource is similar to adding it for the Lightning App Builder. For more information, see Configure Components for Lightning
Pages and the Lightning App Builder.
105
Using Components
IN THIS SECTION:
Create Custom Page Layout Components for Communities
Community Builder includes several ready-to-use layouts that let you quickly change the look of your communitys pages. However,
if you need a layout thats customized for your community, create a custom layout component to use when building new pages in
Community Builder. You can also update the layout of the default pages that come with your community template.
SEE ALSO:
Component Bundles
<div class="container">
<div class='contentPanel'>
<div class='left'>
{!v.column1}
</div>
<div class='right'>
{!v.column2}
</div>
</div>
</div>
</aura:component>
Note: Mark your resources with access="global" to make the resource usable outside of your own org; for example, if
you want the resource to be usable in an installed package or by a Lightning App Builder user or a Community Builder user in
another org.
106
Using Components
CSS resources must be named componentName.css. For example, the CSS resource for the component communityLayout.cmp
is communityLayout.css.
107
Using Components
Note: Mark your resources with access="global" to make the resource usable outside of your own org; for example, if
you want the resource to be usable in an installed package or by a Lightning App Builder user or a Community Builder user in
another org.
To render a field as a picklist, add a datasource onto the attribute in the design resource, like this:
<design:attribute name="Name" datasource="value1,value2,value3" />
108
Using Components
109
Using Components
force:hasRecordId
Useful for record home components. Implement this interface if you want your component to receive the ID of the currently displaying
record.
This interface adds an attribute named recordId to your component. This attribute is of type String, and its value is an 18 character
Salesforce record ID, like this: 001xx000003DGSWAA4. Dont expose the recordId attribute to the Lightning App Builderdont put
it in the components design file. You dont want admins supplying a record ID.
<aura:attribute name="recordId" type="String" />
The record ID is populated only when you place the component on a record home Lightning Page. In all other cases, the record ID isnt
populated, such as when you create this component programmatically inside another component.
force:hasSObjectName
Useful for record home components. Implement this interface if your component needs to know the API name of the object of the
currently displaying record.
This interface adds an attribute named sObjectName to your component. This attribute is of type String, and its value is the API
name of an object, such as Account or myNamespace__myObject__c.
<aura:attribute name="sObjectName" type="String" />
The sObjectName attribute is populated only when you place the component on a record home Lightning Page. In all other cases,
sObjectName isnt populated, such as when you create this component programmatically inside another component.
Tip: Some components only work with a specific object. The mechanism for restricting components to specific objects isnt yet
available. In the meantime, we recommend using the Entity Context to check the object. Then, display a message in the component
to gracefully handle the case where the component has been added to an incompatible object page.
SEE ALSO:
Configure Components for Lightning Pages and the Lightning App Builder
Tips and Considerations for Configuring Components for Lightning App Builder
Working with Salesforce Records
Components
Set a friendly name for the component using the label attribute in the element in the design file, such as <design:component
label="foo">.
Design your components to fill 100% of the width (including margins) of the region that they display in.
Components should provide an appropriate placeholder behavior in declarative tools if they require interaction.
110
Using Components
A component should never display a blank box. Think of how other sites work. For example, Facebook displays an outline of the
feed before the actual feed items come back from the server. This improves the users perception of UI responsiveness.
If the component depends on a fired event, then give it a default state that displays before the event fires.
Style components in a manner consistent with the styling of Lightning Experience and consistent with the Salesforce Design System.
Attributes
Use the design file to control which attributes are exposed to the App Builder.
Make your attributes easy to use and understandable to an administrator. Dont expose SOQL queries, JSON objects, or APEX class
names.
Give your required attributes default values. When a component that has required attributes with no default values is added to the
App Builder, it appears invalid, which is a poor user experience.
Use basic supported types (string, integer, boolean) for any exposed attributes.
Specify a min and max attribute for integer attributes in the <design:attribute> element to control the range of accepted
values.
String attributes can provide a datasource with a set of predefined values allowing the attribute to expose its configuration as a
picklist.
Give all attributes a label with a friendly display name.
Provide descriptions to explain the expected data and any guidelines, such as data format or expected range of values. Description
text appears as a tooltip in the Property Editor.
To delete a design attribute for a component that implements the flexipage:availableForAllPageTypes or
forceCommunity:availableForAllPageTypes interface, first remove the interface from the component before
deleting the design attribute. Then reimplement the interface. If the component is referenced in a Lightning Page, you must remove
the component from the page before you can change it.
SEE ALSO:
Configure Components for Lightning Pages and the Lightning App Builder
Configure Components for Lightning Experience Record Home Pages (PILOT)
111
CHAPTER 5
In this chapter ...
In the Lightning Component framework, events are fired from JavaScript controller actions. Events can
contain attributes that can be set before the event is fired and read when the event is handled.
Component Events
Events are declared by the aura:event tag in a .evt resource, and they can have one of two types:
component or application.
Application Events
Event Handling
Lifecycle
Advanced Events
Example
Firing Lightning
Events from
Non-Lightning Code
Salesforce1 Events
System Events
Component Events
A component event is fired from an instance of a component. A component event can be handled
by the component that fired the event or by a component in the containment hierarchy that receives
the bubbled event.
Application Events
Application events follow a traditional publish-subscribe model. An application event is fired from
an instance of a component. All components that provide a handler for the event are notified.
Note: Always try to use a component event instead of an application event, if possible. Component
events can only be handled by components above them in the containment hierarchy so their
usage is more localized to the components that need to know about them. Application events
are best used for something that should be handled at the application level, such as navigating
to a specific record.
112
113
}
}
Any browser DOM element event starting with on, such as onclick or onkeypress, can be wired to a controller action. You can
only wire browser events to controller actions. Arbitrary JavaScript in the component is ignored.
If you know some JavaScript, you might be tempted to write something like the first "Flawed" button because you know that HTML tags
are first-class citizens in the framework. However, the "Flawed" button won't work as the framework has its own event system. DOM
events are mapped to Lightning events, since HTML tags are mapped to Lightning components.
114
Actions
User interaction with an element on a component or app. User actions trigger events, but events are not always explicitly triggered
by user actions. Note that this type of action is not the same as a client-side JavaScript controller, which is sometimes known as a
controller action. The following button is wired up to a browser onclick event in response to a button click.
<ui:button label = "Click Me" press = "{!c.handleClick}" />
Clicking the button invokes the handeClick method in the components client-side controller.
Events
A notification by the browser regarding an action. Browser events are handled by client-side JavaScript controllers, as shown in the
previous example. Note that a browser event is not the same as a component event or application event, which you can create and
fire on your own in a JavaScript controller to communicate data between components. For example, you can wire up the click event
of a checkbox to a client-side controller, which then fires a component event to communicate relevant data to a parent component.
Another type of event, known as a system event, is fired automatically by the framework during its lifecycle, such as during component
initialization, change of an attribute value, and rendering. Components can handle a system event by registering the event in the
component markup.
The following diagram describes what happens when a user clicks a button that requires the component to retrieve data from the server.
1. User clicks a button or interacts with a component, triggering a browser event. For example, you want to save data from the server
when the button is clicked.
2. The button click invokes a client-side JavaScript controller, which provides some custom logic before invoking a helper function.
3. The JavaScript controller invokes a helper function. Note that a helper function improves code reuse but its optional for this example.
4. The helper function calls an Apex controller method and queues the action.
5. The Apex method is invoked and data is returned.
6. A JavaScript callback function is invoked when the Apex method completes.
7. The JavaScript callback function evaluates logic and updates the components UI.
8. User sees the updated component.
115
Component Events
Alternatively, consider an attribute value on a component that changes without a user action directly causing it, which then automatically
fires a change event. When the attribute value changes, the component that registers a change event handles this event by invoking
a JavaScript controller that contains custom logic, which could then proceed from step (3) onwards to retrieve data from the server.
SEE ALSO:
Handling Events with Client-Side Controllers
Detecting Data Changes
Calling a Server-Side Action
Events Fired During the Rendering Lifecycle
Component Events
A component event is fired from an instance of a component. A component event can be handled by the component that fired the
event or by a component in the containment hierarchy that receives the bubbled event.
The component that handles an event can retrieve the event data. To retrieve the attribute in this event, call
event.getParam("message") in the handlers client-side controller.
Well see how the value of the name attribute is used for firing and handling events.
116
117
Note: The name attributes in <aura:registerEvent> and <aura:handler> must match, since each event is
defined by its name.
If c:eventBubblingGrandchild fires a component event, it can handle the event itself. The event then bubbles up the
containment hierarchy. c:eventBubblingChild contains c:eventBubblingGrandchild but it's not the facet value
provider as it's not the outermost component in the markup so it can't handle the bubbled event. c:eventBubblingParent is
the facet value provider as c:eventBubblingChild is in its markup. c:eventBubblingParent can handle the event.
A component handling the bubbled component event uses the <aura:handler> tag to assign a handling action in its client-side
controller.
<aura:component>
<aura:handler name="bubblingEvent" event="c:compEvent" action="{!c.handleBubbling}"/>
</aura:component>
Note: The name attribute in <aura:handler> must match the name attribute in the <aura:registerEvent> tag
in the component that fires the event.
118
Here is the controller for c:eventBubblingEmitter. When you press the button, it fires the bubblingEvent event registered
in the markup.
/*eventBubblingEmitterController.js*/
{
fireEvent : function(cmp) {
var cmpEvent = cmp.getEvent("bubblingEvent");
cmpEvent.fire();
}
}
<div class="grandchild">
<c:eventBubblingEmitter />
</div>
</aura:component>
The controller logs the event name when the handler is called.
Here is the markup for c:eventBubblingChild. We will pass c:eventBubblingGrandchild in as the body of
c:eventBubblingChild when we create c:eventBubblingParent later in this example.
<!--c:eventBubblingChild-->
<aura:component>
<aura:handler name="bubblingEvent" event="c:compEvent" action="{!c.handleBubbling}"/>
119
<div class="child">
{!v.body}
</div>
</aura:component>
<div class="parent">
<c:eventBubblingChild>
<c:eventBubblingGrandchild />
</c:eventBubblingChild>
</div>
</aura:component>
Now, lets see what happens when you run the code.
1. In your browser, navigate to c:eventBubblingParent. Create a .app resource that contains
<c:eventBubblingParent />.
2. Click the Start Bubbling button that is part of the markup in c:eventBubblingEmitter.
3. Note the output in your browser's console:
Grandchild handler for bubblingEvent
Parent handler for bubblingEvent
120
Component Event
The ceEvent.evt component event has one attribute. Well use this attribute to pass some data in the event when its fired.
<!--c:ceEvent-->
<aura:event type="COMPONENT">
<aura:attribute name="message" type="String"/>
</aura:event>
Notifier Component
The c:ceNotifier component uses aura:registerEvent to declare that it may fire the component event.
The button in the component contains a press browser event that is wired to the fireComponentEvent action in the client-side
controller. The action is invoked when you click the button.
<!--c:ceNotifier-->
<aura:component>
121
The client-side controller gets an instance of the event by calling cmp.getEvent("cmpEvent"), where cmpEvent matches
the value of the name attribute in the <aura:registerEvent> tag in the component markup. The controller sets the message
attribute of the event and fires the event.
/* ceNotifierController.js */
{
fireComponentEvent : function(cmp, event) {
// Get the component event by using the
// name value from aura:registerEvent
var cmpEvent = cmp.getEvent("cmpEvent");
cmpEvent.setParams({
"message" : "A component event fired me. " +
"It all happened so fast. Now, I'm here!" });
cmpEvent.fire();
}
}
Handler Component
The c:ceHandler handler component contains the c:ceNotifier component. The <aura:handler> tag uses the same
value of the name attribute, cmpEvent, from the <aura:registerEvent> tag in c:ceNotifier. This wires up
c:ceHandler to handle the event bubbled up from c:ceNotifier.
When the event is fired, the handleComponentEvent action in the client-side controller of the handler component is invoked.
<!--c:ceHandler-->
<aura:component>
<aura:attribute name="messageFromEvent" type="String"/>
<aura:attribute name="numEvents" type="Integer" default="0"/>
<!-- Note that name="cmpEvent" in aura:registerEvent
in ceNotifier.cmp -->
<aura:handler name="cmpEvent" event="c:ceEvent" action="{!c.handleComponentEvent}"/>
<!-- handler contains the notifier component -->
<c:ceNotifier />
<p>{!v.messageFromEvent}</p>
<p>Number of events: {!v.numEvents}</p>
</aura:component>
The controller retrieves the data sent in the event and uses it to update the messageFromEvent attribute in the handler component.
/* ceHandlerController.js */
{
122
Application Events
Application Events
Application events follow a traditional publish-subscribe model. An application event is fired from an instance of a component. All
components that provide a handler for the event are notified.
123
Application Events
Use type="APPLICATION" in the <aura:event> tag for an application event. For example, this is a c:appEvent application
event with one message attribute.
<!--c:appEvent-->
<aura:event type="APPLICATION">
<!-- add aura:attribute tags to define event shape.
One sample attribute here -->
<aura:attribute name="message" type="String"/>
</aura:event>
The component that handles an event can retrieve the event data. To retrieve the attribute in this event, call
event.getParam("message") in the handlers client-side controller.
If you need to find the source of an application event, you could use evt.setParams() to set the source component in the event
data before firing it. For example, evt.setParams("source" : sourceCmp), where sourceCmp is a reference to the
source component.
124
IN THIS SECTION:
Handling Application Events
Use <aura:handler> in the markup of the handler component.
SEE ALSO:
Component Events
Handling Events with Client-Side Controllers
Advanced Events Example
What is Inherited?
When the event is fired, the handleApplicationEvent client-side controller action is called.
Application Event
The aeEvent.evt application event has one attribute. Well use this attribute to pass some data in the event when its fired.
<!--c:aeEvent-->
<aura:event type="APPLICATION">
<aura:attribute name="message" type="String"/>
</aura:event>
Notifier Component
The aeNotifier.cmp notifier component uses aura:registerEvent to declare that it may fire the application event. Note
that the name attribute is required but not used for application events. The name attribute is only relevant for component events.
125
The button in the component contains a press browser event that is wired to the fireApplicationEvent action in the
client-side controller. Clicking this button invokes the action.
<!--c:aeNotifier-->
<aura:component>
<aura:registerEvent name="appEvent" type="c:aeEvent"/>
<h1>Simple Application Event Sample</h1>
<p><ui:button
label="Click here to fire an application event"
press="{!c.fireApplicationEvent}" />
</p>
</aura:component>
The client-side controller gets an instance of the event by calling $A.get("e.c:aeEvent"). The controller sets the message
attribute of the event and fires the event.
/* aeNotifierController.js */
{
fireApplicationEvent : function(cmp, event) {
// Get the application event by using the
// e.<namespace>.<event> syntax
var appEvent = $A.get("e.c:aeEvent");
appEvent.setParams({
"message" : "An application event fired me. " +
"It all happened so fast. Now, I'm everywhere!" });
appEvent.fire();
}
}
Handler Component
The aeHandler.cmp handler component uses the <aura:handler> tag to register that it handles the application event.
When the event is fired, the handleApplicationEvent action in the client-side controller of the handler component is invoked.
<!--c:aeHandler-->
<aura:component>
<aura:attribute name="messageFromEvent" type="String"/>
<aura:attribute name="numEvents" type="Integer" default="0"/>
<aura:handler event="c:aeEvent" action="{!c.handleApplicationEvent}"/>
<p>{!v.messageFromEvent}</p>
<p>Number of events: {!v.numEvents}</p>
</aura:component>
The controller retrieves the data sent in the event and uses it to update the messageFromEvent attribute in the handler component.
/* aeHandlerController.js */
{
handleApplicationEvent : function(cmp, event) {
var message = event.getParam("message");
// set the handler attributes based on event data
cmp.set("v.messageFromEvent", message);
126
Container Component
The aeContainer.cmp container component contains the notifier and handler components. This is different from the component
event example where the handler contains the notifier component.
<!--c:aeContainer-->
<aura:component>
<c:aeNotifier/>
<c:aeHandler/>
</aura:component>
Salesforce domain.
If you want to access data on the server, you could extend this example to call a server-side controller from the handlers client-side
controller.
SEE ALSO:
Application Events
Creating Server-Side Logic with Controllers
Component Event Example
127
128
Set attributes or modify data on the component (causing a re-rendering of the component).
Fire another event or invoke a client-side or server-side action.
3.2 Executing an Application Event Handler
All event handlers are executed. When the event handler is executed, the event instance is passed into the event handler.
4 Re-render Component (optional)
After the event handlers and any callback actions are executed, a component might be automatically re-rendered if it was modified
during the event handling process.
SEE ALSO:
Client-Side Rendering to the DOM
Resource Name
Usage
Event files
Notifier
Handler
Container Component
eventsContainer.cmp
The definitions of component and application events are stored in separate .evt resources, but individual notifier and handler
component bundles can contain code to work with both types of events.
The component and application events both contain a context attribute that defines the shape of the event. This is the data that is
passed to handlers of the event.
129
Component Event
Here is the markup for compEvent.evt.
<!--c:compEvent-->
<aura:event type="COMPONENT">
<!-- pass context of where the event was fired to the handler. -->
<aura:attribute name="context" type="String"/>
</aura:event>
Application Event
Here is the markup for appEvent.evt.
<!--c:appEvent-->
<aura:event type="APPLICATION">
<!-- pass context of where the event was fired to the handler. -->
<aura:attribute name="context" type="String"/>
</aura:event>
Notifier Component
The eventsNotifier.cmp notifier component contains buttons to initiate a component or application event.
The notifier uses aura:registerEvent tags to declare that it may fire the component and application events. Note that the
name attribute is required but the value is only relevant for the component event; the value is not used anywhere else for the application
event.
The parentName attribute is not set yet. We will see how this attribute is set and surfaced in eventsContainer.cmp.
<!--c:eventsNotifier-->
<aura:component>
<aura:attribute name="parentName" type="String"/>
<aura:registerEvent name="componentEventFired" type="c:compEvent"/>
<aura:registerEvent name="appEvent" type="c:appEvent"/>
<div>
<h3>This is {!v.parentName}'s eventsNotifier.cmp instance</h3>
<p><ui:button
label="Click here to fire a component event"
press="{!c.fireComponentEvent}" />
</p>
<p><ui:button
label="Click here to fire an application event"
press="{!c.fireApplicationEvent}" />
</p>
</div>
</aura:component>
CSS source
The CSS is in eventsNotifier.css.
/* eventsNotifier.css */
.cEventsNotifier {
130
display: block;
margin: 10px;
padding: 10px;
border: 1px solid black;
}
You can click the buttons to fire component and application events but there is no change to the output because we haven't wired up
the handler component to react to the events yet.
The controller sets the context attribute of the component or application event to the parentName of the notifier component
before firing the event. We will see how this affects the output when we look at the handler component.
Handler Component
The eventsHandler.cmp handler component contains the c:eventsNotifier notifier component and <aura:handler>
tags for the application and component events.
<!--c:eventsHandler-->
<aura:component>
<aura:attribute name="name" type="String"/>
<aura:attribute name="mostRecentEvent" type="String" default="Most recent event handled:"/>
<aura:attribute name="numComponentEventsHandled" type="Integer" default="0"/>
<aura:attribute name="numApplicationEventsHandled" type="Integer" default="0"/>
<aura:handler event="c:appEvent" action="{!c.handleApplicationEventFired}"/>
<aura:handler name="componentEventFired" event="c:compEvent"
action="{!c.handleComponentEventFired}"/>
131
<div>
<h3>This is {!v.name}</h3>
<p>{!v.mostRecentEvent}</p>
<p># component events handled: {!v.numComponentEventsHandled}</p>
<p># application events handled: {!v.numApplicationEventsHandled}</p>
<c:eventsNotifier parentName="{!v.name}" />
</div>
</aura:component>
CSS source
The CSS is in eventsHandler.css.
/* eventsHandler.css */
.cEventsHandler {
display: block;
margin: 10px;
padding: 10px;
border: 1px solid black;
}
The name attribute is not set yet. We will see how this attribute is set and surfaced in eventsContainer.cmp.
You can click buttons and the UI now changes to indicate the type of event. The click count increments to indicate whether it's a
component or application event. We aren't finished yet though. Notice that the source of the event is undefined as the event context
attribute hasn't been set .
132
Container Component
Here is the markup for eventsContainer.cmp.
<!--c:eventsContainer-->
<aura:component>
<c:eventsHandler name="eventsHandler1"/>
<c:eventsHandler name="eventsHandler2"/>
</aura:component>
The container component contains two handler components. It sets the name attribute of both handler components, which is passed
through to set the parentName attribute of the notifier components. This fills in the gaps in the UI text that we saw when we looked
at the notifier or handler components directly.
Add the c:eventsContainer component to a c:eventsContainerApp application. Navigate to the application.
https://<myDomain>.lightning.force.com/c/eventsContainerApp.app, where <myDomain> is the name
window.opener.$A.get() references the master window where your Lightning app is loaded.
SEE ALSO:
Application Events
Modifying Components Outside the Framework Lifecycle
133
Events Anti-Patterns
These are some anti-patterns that you should avoid when using events.
134
Dont do this!
afterRender: function(cmp, helper) {
this.superAfterRender();
$A.get("e.myns:mycmp").fire();
}
Instead, use the init hook to run a controller action after component construction but before rendering. Add this code to your
component:
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
For more details, see .Invoking Actions on Component Initialization on page 167.
Component Creation
The component lifecycle starts when the client sends an HTTP request to the server and the component configuration data is returned
to the client. No server trip is made if the component definition is already on the client from a previous request and the component has
no server dependencies.
Lets look at an app with several nested components. The framework instantiates the app and goes through the children of the v.body
facet to create each component, First, it creates the component definition, its entire parent hierarchy, and then creates the facets within
those components. The framework also creates any component dependencies on the server, including definitions for attributes, interfaces,
controllers, and actions..
The following image lists the order of component creation.
135
After creating a component instance, the serialized component definitions and instances are sent down to the client. Definitions are
cached but not the instance data. The client deserializes the response to create the JavaScript objects or maps, resulting in an instance
tree thats used to render the component instance. When the component tree is ready, the init event is fired for all the components,
starting from the children component and finishing in the parent component.
Component Rendering
The following image depicts a typical rendering lifecycle of a component on the client, after the component definitions and instances
are deserialized.
136
1. The init event is fired by the component service that constructs the components to signal that initialization has completed.
<aura:handler name="init" value="{!this}" action="{!.c.doInit}"/>
You can customize the init handler and add your own controller logic before the component starts rendering. For more information,
see Invoking Actions on Component Initialization on page 167.
2. For each component in the tree, the base implementation of render() or your custom renderer is called to start component
rendering. For more information, see Client-Side Rendering to the DOM on page 164. Similar to the component creation process,
rendering starts at the root component, its children components and their super components, if any, and finally the subchildren
components.
3. Once your components are rendered to the DOM, afterRender() is called to signal that rendering is completed for each of
these component definitions. It enables you to interact with the DOM tree after the framework rendering service has created the
DOM elements.
4. To indicate that the client is done waiting for a response to the server request XHR, the doneWaiting event is fired. You can
handle this event by adding a handler wired to a client-side controller action.
5. The framework checks whether any components need to be rerendered and rerenders any dirtied components to reflect any
updates to attribute values. This rerender check is done even if theres no dirtied components or values.
6. Finally, the doneRendering event is fired at the end of the rendering lifecycle.
Lets see what happens when a ui:button component is returned from the server and any rerendering that occurs when the button
is clicked to update its label.
<!-- The uiExamples:buttonExample container component -->
<aura:component>
<aura:attribute name="num" type="Integer" default="0"/>
<ui:button aura:id="button" label="{!v.num}" press="{!c.update}"/>
</aura:component>
/** Client-side Controller **/
({
update : function(cmp, evt) {
cmp.set("v.num", cmp.get("v.num")+1);
}
})
Note: Its helpful to refer to the ui:button source to understand the component definitions to be rendered. For more
information, see
https://github.com/forcedotcom/aura/blob/master/aura-components/src/main/components/ui/button/button.cmp.
After initialization, render() is called to render ui:button. ui:button doesnt have a custom renderer, and uses the base
implementation of render(). In this example, render() is called eight times in the following order.
Component
Description
uiExamples:buttonExample
ui:button
aura:html
aura:if
137
Salesforce1 Events
Component
Description
aura:if
aura:html
The <span> tag for the button label, nested in the <button>
tag
aura:expression
aura:expression
HTML tags in the markup are converted to aura:html, which has a tag attribute that defines the HTML tag to be generated. When
rendering is done, this example calls afterRender() eight times for these component definitions. The doneWaiting event is
fired, followed by the doneRendering event.
Clicking the button updates its label, which checks for any dirtied components and fires rerender() to rerender these components,
followed by the doneRendering event. In this example, rerender() is called eight times. All changed values are stored in a
list on the rendering service, resulting in the rerendering of any dirtied components.
Note: Firing an event in a custom renderer is not recommended. For more information, see Events Anti-Patterns.
During initialization, the init() event is fired in this order: ui:button, ui:myCmp, and myApp.app. The doneWaiting
event is fired in the same order. Finally, the doneRendering event is also called in the same order.
SEE ALSO:
Client-Side Rendering to the DOM
System Event Reference
Salesforce1 Events
Lightning components interact with Salesforce1 via events.
138
Salesforce1 Events
You can fire the following events, which are automatically handled by Salesforce1. If you fire these events in your Lightning apps or
components outside of Salesforce1, you must handle them as necessary.
Event Name
Description
force:createRecord
Opens the page to create a new record for the specified entityApiName, for
example, Account or myNamespace__MyObject__c.
force:editRecord
force:navigateToList
force:navigateToObjectHome
force:navigateToRelatedList
force:navigateToSObject
force:navigateToURL
force:recordSave
Saves a record.
force:recordSaveSuccess
force:refreshView
force:showToast
SEE ALSO:
Event Reference
139
System Events
System Events
The framework fires several system events during its lifecycle.
You can handle these events in your Lightning apps or components, and within Salesforce1.
Event Name
Description
aura:doneRendering
Indicates that the initial rendering of the root application or root component has
completed.
aura:doneWaiting
Indicates that the app or component is done waiting for a response to a server
request. This event is preceded by an aura:waiting event.
aura:locationChange
aura:noAccess
aura:systemError
aura:valueChange
aura:valueDestroy
aura:valueInit
aura:waiting
Indicates that the app or component is waiting for a response to a server request.
SEE ALSO:
System Event Reference
140
CHAPTER 6
In this chapter ...
App Overview
Designing App UI
Creating App
Templates
Content Security
Policy Overview
Styling Apps
Using JavaScript
JavaScript Cookbook
Using Apex
Controlling Access
Using
Object-Oriented
Development
Distributing
Applications and
Components
Creating Apps
Components are the building blocks of an app. This section shows you a typical workflow to put the
pieces together to create a new app.
First, you should decide whether youre creating a component for a standalone app or for Salesforce1.
Both components can access your Salesforce data, but only a component created for Salesforce1 can
utilize built-in Salesforce1 events to take advantage of record create and edit pages, among other benefits.
The Quick Start on page 6 walks you through creating components for a standalone app and
components for Salesforce1 to help you determine which one you need.
141
Creating Apps
App Overview
App Overview
An app is a special top-level component whose markup is in a .app resource.
On a production server, the .app resource is the only addressable unit in a browser URL. Access an app using the URL:
https://<myDomain>.lightning.force.com/<namespace>/<appName>.app, where <myDomain> is the
Designing App UI
Design your app's UI by including markup in the .app resource, which starts with the <aura:application> tag.
Lets take a look at the accounts.app resource created in Create a Standalone Lightning App.
<aura:application>
<h1>Accounts</h1>
<div class="container">
<!-- Other components or markup here -->
</div>
</aura:application>
accounts.app contains HTML tags and component markup. You can use HTML tags like <div class="container"> to
Note how the component extends aura:template and sets the title attribute using aura:set.
142
Creating Apps
The app points at the custom template by setting the template system attribute in <aura:application>.
<aura:application template="np:template">
...
</aura:application>
A template can only extend a component or another template. A component or an application can't extend a template.
Browser Support
CSP is not enforced for all browsers. For a list of browsers that enforce CSP, see caniuse.com.
If your app's functionality is not affected, you can ignore the CSP violation.
Styling Apps
An app is a special top-level component whose markup is in a .app resource. Just like any other component, you can put CSS in its
bundle in a resource called <appName>.css.
For example, if the app markup is in notes.app, its CSS is in notes.css.
When viewed in Salesforce1 and Lightning Experience, the UI components include styling that matches those visual themes. For example,
the ui:button includes the button--neutral class to display a neutral style. The input components that extend ui:input
include the uiInput--input class to display the input fields using a custom font in addition to other styling.
Note: Styles added to UI components in Salesforce1 and Lightning Experience dont apply to components in standalone apps.
143
Creating Apps
IN THIS SECTION:
Using External CSS
To reference an external CSS resource that youve uploaded as a static resource, use a <ltng:require> tag in your .cmp or
.app markup.
Tips for CSS in Components
Here are some tips for configuring the CSS for components that you plan to use in Lightning Pages, the Lightning App Builder, or
the Community Builder.
Styling with Design Tokens
Capture the essential values of your visual design into named tokens. Define the token values once and reuse them throughout your
Lightning components CSS resources. Tokens make it easy to ensure that your design is consistent, and even easier to update it as
your design evolves.
SEE ALSO:
CSS in Components
Add Lightning Components to Salesforce1
resourceName is the Name of the static resource. Note that the framework doesnt currently support the $Resource global
variable available in Visualforce. In a managed packaged, the resource name must include the package namespace prefix, such as
/resource/np_resourceName.
Here are some considerations for loading styles:
Loading Sets of CSS
Specify a comma-separated list of resources in the styles attribute to load a set of CSS.
Loading Order
The styles are loaded in the order that they are listed.
One-Time Loading
The styles only load once if they are specified in multiple <ltng:require> tags in the same component or across different
components.
Encapsulation
To ensure encapsulation and reusability, add the <ltng:require> tag to every .cmp or .app resource that uses the CSS
resource.
<ltng:require> also has a scripts attribute to load a list of JavaScript libraries. The afterScriptsLoaded event enables
you to call a controller action after the scripts are loaded. It's only triggered by loading of the scripts and is never triggered
when the CSS in styles is loaded.
For more information on static resources, see What is a Static Resource? in the Salesforce online help.
144
Creating Apps
Note: Prefixing your CSS with a unique namespace only applies to external CSS. If youre using CSS within a component bundle,
the .THIS keyword becomes .namespaceComponentName during runtime.
SEE ALSO:
Using External JavaScript Libraries
CSS in Components
Because they can be moved to different locations on the page as well as used on different pages entirely, components must rely on
the normal document flow. Using floats and absolute or fixed positions breaks the layout of the page the component is on. Even if
they dont break the layout of the page youre looking at, they will break the layout of some page the component can be put on.
Child elements shouldnt be styled to be larger than the root element
The Lightning Page maintains consistent spacing between components, and cant do that if child elements are larger than the root
element.
For example, avoid these patterns:
<div style="height: 100px">
<div style="height: 200px">
<!--Other markup here-->
145
Creating Apps
Vendor Prefixes
</div>
</div>
<!--Margin increases the elements effective size-->
<div style="height: 100px">
<div style="height: 100px margin: 10px">
<!--Other markup here-->
</div>
</div>
Vendor Prefixes
Vendor prefixes, such as moz- and webkit- among many others, are automatically added in Lightning.
You only need to write the unprefixed version, and the framework automatically adds any prefixes that are necessary when generating
the CSS output. If you choose to add them, they are used as-is. This enables you to specify alternative values for certain prefixes.
Example: For example, this is an unprefixed version of border-radius.
.class {
border-radius: 2px;
}
146
Creating Apps
Tokens Bundles
Tokens are a type of bundle, just like components, events, and interfaces.
A tokens bundle contains only one resource, a tokens collection definition.
Resource
Resource Name
Usage
Tokens Collection
for one or more tokens. Each tokens bundle contains only one
tokens resource.
Note: In this developer preview of Lightning tokens, you cant edit the tokens bundle name or description in the Developer
Console after you create it. The bundles AuraBundleDefinition can be modified using the Metadata API.
A tokens collection starts with the <aura:tokens> tag. It can only contain <aura:token> tags to define tokens.
Tokens collections have restricted support for expressions; see Using Expressions in Tokens. You cant use other markup, renderers,
controllers, or anything else in a tokens collection.
SEE ALSO:
Using Expressions in Tokens
147
Creating Apps
Note: In this developer preview of Lightning tokens, you cant edit the tokens bundle name or description in the Developer
Console after you create it. The bundles AuraBundleDefinition can be modified using the Metadata API. Although you
can set a version on a tokens bundle, doing so has no effect.
Defining Tokens
Add new tokens as child components of the bundles <aura:tokens> component. For example:
<aura:tokens>
<aura:token name="myBodyTextFontFace"
value="'Salesforce Sans', Helvetica, Arial, sans-serif"/>
<aura:token name="myBodyTextFontWeight" value="normal"/>
<aura:token name="myBackgroundColor" value="#f4f6f9"/>
<aura:token name="myDefaultMargin" value="6px"/>
</aura:tokens>
The only allowed attributes for the <aura:token> tag are name and value.
Using Tokens
Tokens created in your defaultTokens bundle are automatically available in components in your namespace. To use a design
token, reference it using the token() function and the token name in the CSS resource of a component bundle. For example:
.THIS p {
font-family: token(myBodyTextFontFace);
font-weight: token(myBodyTextFontWeight);
}
If you prefer a more concise function name for referencing tokens, you can use the t() function instead of token(). The two are
equivalent. If your token names follow a naming convention or are sufficiently descriptive, the use of the more terse function name
wont affect the clarity of your CSS styles.
Cross-Referencing Tokens
To reference one tokens value in another tokens definition, wrap the token to be referenced in standard expression syntax.
In the following example, well reference tokens provided by Salesforce in our custom tokens. Although you cant see the standard tokens
directly, well imagine they look something like the following.
<!-- force:base tokens (SLDS standard tokens) -->
<aura:tokens>
...
<aura:token name="colorBackground" value="rgb(244, 246, 249)" />
148
Creating Apps
With the preceding in mind, you can reference the standard tokens in your custom tokens, as in the following.
<!-- defaultTokens.tokens (your tokens) -->
<aura:tokens extends="force:base">
<aura:token name="mainColor" value="{! colorBackground }" />
<aura:token name="btnColor" value="{! mainColor }" />
<aura:token name="myFont" value="{! fontFamily }" />
</aura:tokens>
You can only cross-reference tokens defined in the same file or a parent.
Expression syntax in tokens resources is restricted to references to other tokens.
Combining Tokens
To support combining individual token values into more complex CSS style properties, the token() function supports string
concatenation. For example, if you have the following tokens defined:
<!-- defaultTokens.tokens (your tokens) -->
<aura:tokens>
<aura:token name="defaultHorizonalSpacing" value="12px" />
<aura:token name="defaultVerticalSpacing" value="6px" />
</aura:tokens>
You can combine these two tokens in a CSS style definition. For example:
/* myComponent.css */
.THIS div.notification {
margin: token(defaultVerticalSpacing + ' ' + defaultHorizonalSpacing);
/* more styles here */
}
You can mix tokens with strings as much as necessary to create the right style definition. For example, use margin:
token(defaultVerticalSpacing + ' ' + defaultHorizonalSpacing + ' 3px'); to hard code the bottom
spacing in the preceding definition.
The only operator supported within the token() function is + for string concatenation.
SEE ALSO:
Defining and Using Tokens
Standard Design Tokens
149
Creating Apps
To add the standard tokens to your org, you extend your orgs tokens bundle from the base tokens, like so.
<aura:tokens extends="force:base">
<!-- your own tokens here -->
</aura:tokens>
Once added to defaultTokens, you can reference tokens from force:base just like your own tokens, using the token()
function and token name. For example:
.THIS p {
font-family: token(fontFamily);
font-weight: token(fontWeightRegular);
}
You can mix-and-match your tokens with the standard tokens. Its a best practice to develop a naming system for your own tokens to
make them easily distinguishable from standard tokens. Consider prefixing your token names with my, or something else easily
identifiable.
Overriding standard token values is undefined behavior and unsupported. If you create a token with the same name as a standard token,
it overrides the standard tokens value in some contexts, and has no effect in others. This behavior will change in a future release. Dont
use it.
Available Tokens
This developer preview of Lightning tokens makes available a subset of the design tokens offered in the Salesforce Lightning Design
System. The tokens available when extending from force:base are the following.
Important: In this developer preview, the standard token values are still evolving. Available tokens and their values can change
without notice. Token values presented here are for example only.
Token Name
Example Value
mqSmall
mqSmall
mqMedium
mqMediumLandscape
mqLarge
colorBackground
colorBackgroundAlt
colorBackgroundAltInverse
colorBackgroundRowHover
colorBackgroundRowActive
colorBackgroundRowSelected
colorBackgroundRowNew
colorBackgroundInverse
150
Creating Apps
Token Name
Example Value
colorBackgroundAnchor
colorBackgroundBrowser
colorBackgroundChromeMobile
colorBackgroundChromeDesktop
colorBackgroundHighlight
colorBackgroundModal
colorBackgroundModalBrand
colorBackgroundNotificationBadge
colorBackgroundPayload
colorBackgroundShade
colorBackgroundStencil
colorBackgroundStencilAlt
colorBackgroundScrollbar
colorBackgroundScrollbarTrack
colorBrand
colorBrandDark
borderWidthThin
1px
borderWidthThick
2px
borderRadiusSmall
.125rem
borderRadiusMedium
.25rem
borderRadiusLarge
.5rem
borderRadiusPill
15rem
borderRadiusCircle
50%
colorBorder
colorBorderBrand
colorBorderError
151
Creating Apps
Token Name
Example Value
colorBorderSuccess
colorBorderWarning
colorBorderTabSelected
colorBorderSeparator
colorBorderSeparatorAlt
colorBorderSeparatorInverse
colorBorderRowSelected
colorBorderRowSelectedHover
colorTextButtonBrand
colorTextButtonBrandHover
colorTextButtonBrandActive
colorTextButtonBrandDisabled
colorTextButtonDefault
colorTextButtonDefaultHover
colorTextButtonDefaultActive
colorTextButtonDefaultDisabled
colorTextButtonDefaultHint
colorTextButtonInverse
colorTextButtonInverseDisabled
colorTextIconDefault
colorTextIconDefaultHint
colorTextIconDefaultHover
colorTextIconDefaultActive
colorTextIconDefaultDisabled
colorTextIconInverse
colorTextIconInverseHover
colorTextIconInverseActive
colorTextIconInverseDisabled
colorBackgroundButtonBrand
colorBackgroundButtonBrandActive
152
Creating Apps
Token Name
Example Value
colorBackgroundButtonBrandHover
colorBackgroundButtonBrandDisabled
colorBackgroundButtonDefault
colorBackgroundButtonDefaultHover
colorBackgroundButtonDefaultFocus
colorBackgroundButtonDefaultActive
rgba(0, 0, 0, 0)
colorBackgroundButtonIconHover
colorBackgroundButtonIconFocus
colorBackgroundButtonIconActive
colorBackgroundButtonIconDisabled
colorBackgroundButtonInverse
rgba(0, 0, 0, 0)
colorBackgroundButtonInverseActive
rgba(0, 0, 0, 0.24)
colorBackgroundButtonInverseDisabled rgba(0, 0, 0, 0)
colorBackgroundModalButton
rgba(0, 0, 0, 0.07)
colorBackgroundModalButtonActive
rgba(0, 0, 0, 0.16)
colorBorderButtonBrand
colorBorderButtonBrandDisabled
rgba(0, 0, 0, 0)
colorBorderButtonDefault
colorBorderButtonInverseDisabled
fontFamily
fontWeightLight
300
fontWeightRegular
400
fontWeightBold
700
lineHeightHeading
1.25
lineHeightText
1.375
lineHeightReset
lineHeightTab
3rem
lineHeightButton
2.125rem
153
Creating Apps
Token Name
Example Value
lineHeightButtonSmall
1.75rem
colorBackgroundInput
colorBackgroundInputActive
colorBackgroundInputCheckbox
colorBackgroundInputError
colorBackgroundPill
colorTextLabel
colorTextPlaceholder
colorTextPlaceholderInverse
colorTextRequired
colorTextPill
colorBorderInput
colorBorderInputActive
colorBorderInputDisabled
colorBackgroundToastSuccess
colorBackgroundToastError
shadowDrag
shadowDropDown
shadowHeader
shadowButtonFocus
0 0 3px #0070D2
shadowButtonFocusIE11
0 0 4px #0070D2
shadowButtonFocusInverse
0 0 3px #E0E5EE
sizeXxSmall
6rem
sizeXSmall
12rem
sizeSmall
15rem
154
Creating Apps
Token Name
Example Value
sizeMedium
20rem
sizeLarge
25rem
sizeXLarge
40rem
sizeXxLarge
60rem
squareIconUtilitySmall
1rem
squareIconUtilityMedium
1.25rem
squareIconUtilityLarge
1.5rem
squareIconLargeBoundary
3rem
squareIconLargeBoundaryAlt
5rem
squareIconLargeContent
2rem
squareIconMediumBoundary
2rem
squareIconMediumBoundaryAlt
2.25rem
squareIconMediumContent
1rem
squareIconSmallBoundary
1.5rem
squareIconSmallContent
.75rem
squareIconXSmallBoundary
1.25rem
squareIconXSmallContent
.5rem
spacingXxxSmall
0.125rem
spacingXxSmall
0.25rem
spacingXSmall
0.5rem
spacingSmall
0.75rem
spacingMedium
1rem
spacingLarge
1.5rem
spacingXLarge
2rem
colorTextActionLabel
colorTextActionLabelActive
colorTextBrand
colorTextBrowser
colorTextBrowserActive
rgba(0, 0, 0, 0.4)
colorTextDefault
155
Creating Apps
Token Name
Example Value
colorTextError
colorTextInputDisabled
colorTextInputFocusInverse
colorTextInputIcon
colorTextInverse
colorTextInverseWeak
colorTextInverseActive
colorTextInverseHover
colorTextLink
colorTextLinkActive
colorTextLinkDisabled
colorTextLinkFocus
colorTextLinkHover
colorTextLinkInverse
colorTextLinkInverseHover
colorTextLinkInverseActive
colorTextLinkInverseDisabled
colorTextModal
colorTextModalButton
colorTextStageLeft
colorTextTabLabel
colorTextTabLabelSelected
colorTextTabLabelHover
colorTextTabLabelFocus
colorTextTabLabelActive
colorTextTabLabelDisabled
colorTextToast
colorTextWeak
colorTextIconBrand
durationInstantly
0s
156
Creating Apps
Using JavaScript
Token Name
Example Value
durationImmediately
0.05s
durationQuickly
0.1s
durationPromptly
0.2s
durationSlowly
0.4s
durationPaused
3.2s
For a complete list of the design tokens available in the SLDS, see Design Tokens on the Lightning Design System site.
Using JavaScript
Use JavaScript for client-side code. The $A namespace is the entry point for using the framework in JavaScript code.
For all the methods available in $A, see the JavaScript API at
https://<myDomain>.lightning.force.com/auradocs/reference.app, where <myDomain> is the name of
Note: Only use the {! } expression syntax in markup in .app or .cmp resources.
IN THIS SECTION:
Accessing the DOM
The Document Object Model (DOM) is the language-independent model for representing and interacting with objects in HTML and
XML documents. The frameworks rendering service takes in-memory component state and updates the component in the DOM.
Using External JavaScript Libraries
To reference a JavaScript library that youve uploaded as a static resource, use a <ltng:require> tag in your .cmp or .app
markup.
Working with Attribute Values in JavaScript
These are useful and common patterns for working with attribute values in JavaScript.
Working with a Component Body in JavaScript
These are useful and common patterns for working with a components body in JavaScript.
Sharing JavaScript Code in a Component Bundle
Put functions that you want to reuse in the component's helper. Helper functions also enable specialization of tasks, such as processing
data and firing server-side actions.
157
Creating Apps
Using Renderers
The rendering service is the bridge from the framework to update the DOM. If you modify the DOM from a client-side controller, the
changes may be overwritten when the components are rendered, depending on how the component renderers behave. Modify the
DOM only in afterRender() and rerender(). If you need to modify the DOM outside of the renderers, use utilities like
$A.util.addClass(), $A.util.removeClass(), and $A.util.toggleClass(). Modify the DOM that belongs
to the context component only.
158
Creating Apps
Using Expressions
You can often avoid writing a custom renderer by using expressions in the markup instead. See Dynamically Showing or Hiding Markup
on page 178 for more information.
resourceName is the Name of the static resource. Note that the framework doesnt currently support the $Resource global
variable available in Visualforce. In a managed packaged, the resource name must include the package namespace prefix, such as
/resource/np_resourceName.
The afterScriptsLoaded action in the client-side controller is called after the scripts are loaded.
Here are some considerations for loading scripts:
Loading Sets of Scripts
Specify a comma-separated list of resources in the scripts attribute to load a set of resources.
Loading Order
The scripts are loaded in the order that they are listed.
One-Time Loading
Scripts only load once if they are specified in multiple <ltng:require> tags in the same component or across different
components.
Parallel Loading
Use separate <ltng:require> tags for parallel loading if you have multiple sets of scripts that are not dependent on each
other.
Encapsulation
To ensure encapsulation and reusability, add the <ltng:require> tag to every .cmp or .app resource that uses the JavaScript
library.
<ltng:require> also has a styles attribute to load a list of CSS resources. You can set the scripts and styles attributes
in one <ltng:require> tag.
If youre using an external library to work with your HTML elements after rendering, use afterScriptsLoaded to wire up a
client-side controller. The following example sets up a chart using the Chart.js library, which is uploaded as a static resource.
<ltng:require scripts="/resource/chart"
afterScriptsLoaded="{!c.setup}"/>
<canvas aura:id="chart" id="myChart" width="400" height="400"/>
The components client-side controller sets up the chart after component initialization and rendering.
setup : function(component, event, helper) {
var data = {
labels: ["January", "February", "March"],
159
Creating Apps
datasets: [{
data: [65, 59, 80, 81, 56, 55, 40]
}]
};
var el = component.find("chart").getElement();
var ctx = el.getContext("2d");
var myNewChart = new Chart(ctx).Line(data);}
SEE ALSO:
Reference Doc App
Content Security Policy Overview
Using External CSS
associated with the specified key on the component. Keys are passed in as an expression, which represents attribute values. To retrieve
an attribute value of a component reference, use component.find("cmpId").get("v.value"). Similarly, use
component.find("cmpId").set("v.value", myValue) to set the attribute value of a component reference. This
example shows how you can retrieve and set attribute values on a component reference, represented by the button with an ID of
button1.
<aura:component>
<aura:attribute name="buttonLabel" type="String"/>
<ui:button aura:id="button1" label="Button 1"/>
{!v.buttonLabel}
<ui:button label="Get Label" press="{!c.getLabel}"/>
</aura:component>
This controller action retrieves the label attribute value of a button in a component and sets its value on the buttonLabel
attribute.
({
getLabel : function(component, event, helper) {
var myLabel = component.find("button1").get("v.label");
component.set("v.buttonLabel", myLabel);
}
})
160
Creating Apps
SEE ALSO:
Working with a Component Body in JavaScript
161
Creating Apps
body.push(newCmp);
cmp.set("v.body", body);
SEE ALSO:
Component Body
Working with Attribute Values in JavaScript
Creating a Helper
A helper resource is part of the component bundle and is auto-wired via the naming convention, <componentName>Helper.js.
To create a helper using the Developer Console, click HELPER in the sidebar of the component. This helper file is valid for the scope of
the component to which its auto-wired.
162
Creating Apps
detailsRenderer.js
({
afterRender : function(component, helper){
helper.open(component, null, "new");
}
})
detailsHelper.js
({
open : function(component, note, mode, sort){
if(mode === "new") {
//do something
}
// do something else, such as firing an event
}
})
For an example on using helper methods to customize renderers, see Client-Side Rendering to the DOM.
Helper functions are local to a component, improve code reuse, and move the heavy lifting of JavaScript logic away from the client-side
controller where possible. The following code shows the helper function, which takes in the value parameter set in the controller via
the item argument. The code walks through calling a server-side action and returning a callback but you can do something else in
the helper function.
({
updateItem : function(component, item, callback) {
//Update the items via a server-side action
var action = component.get("c.saveItem");
action.setParams({"item" : item});
//Set any optional callback and enqueue the action
if (callback) {
action.setCallback(this, callback);
}
$A.enqueueAction(action);
163
Creating Apps
}
})
SEE ALSO:
Client-Side Rendering to the DOM
Component Bundles
Handling Events with Client-Side Controllers
Rendering Lifecycle
The rendering lifecycle automatically handles rendering and rerendering of components whenever the underlying data changes. Here
is an outline of the rendering lifecycle.
1. A browser event triggers one or more Lightning events.
2. Each Lightning event triggers one or more actions that can update data. The updated data can fire more events.
3. The rendering service tracks the stack of events that are fired.
4. When all the data updates from the events are processed, the framework rerenders all the components that own modified data.
For more information, see Events Fired During the Rendering Lifecycle .
Creating a Renderer
You don't normally have to write a custom renderer, but if you want to customize rendering behavior, you can create a client-side
renderer in a component bundle. A renderer file is part of the component bundle and is auto-wired if you follow the naming convention,
<componentName>Renderer.js. For example, the renderer for sample.cmp would be in sampleRenderer.js.
164
Creating Apps
Rerendering Components
When an event is fired, it may trigger actions to change data and call rerender() on affected components. The rerender()
function enables components to update themselves based on updates to other components since they were last rendered. This function
doesn't return a value.
The framework automatically calls rerender() if you update data in a component.
You generally want to extend default rerendering by calling superRerender() from your renderer() function before you
add your custom rerendering code. Calling superRerender() chains the rerendering to the components in the body attribute.
Unrendering Components
The base unrender() function deletes all the DOM nodes rendered by a component's render() function. It is called by the
framework when a component is being destroyed. Customize this behavior by overriding unrender() in your component's renderer.
This can be useful when you are working with third-party libraries that are not native to the framework.
You generally want to extend default unrendering by calling superUnrender() from your unrender() function before you
add your custom code.
Rendering Example
Let's look at the button component to see how it customizes the base rendering behavior. It is important to know that every tag in
markup, including standard HTML tags, has an underlying component representation. Therefore, the frameworks rendering service uses
the same process to render standard HTML tags or custom components that you create.
View the source for ui:button. Note that the button component includes a disabled attribute to track the disabled status for
the component in a Boolean.
<aura:attribute name="disabled" type="Boolean" default="false"/>
165
Creating Apps
The first line calls the superRender() function to invoke the default rendering behavior. The helper.updateDisabled(cmp)
call invokes a helper function to customize the rendering.
Let's look at the updateDisabled(cmp) function in buttonHelper.js.
updateDisabled: function(cmp) {
if (cmp.get("v.disabled")) {
var disabled = $A.util.getBooleanValue(cmp.get("v.disabled"));
var button = cmp.find("button");
if (button) {
var element = button.getElement();
if (element) {
if (disabled) {
element.setAttribute('disabled', 'disabled');
} else {
element.removeAttribute('disabled');
}
}
}
}
}
The updateDisabled(cmp) function translates the Boolean disabled value to the value expected in HTML, where the
attribute doesn't exist or is set to disabled.
It uses cmp.find("button") to retrieve a unique component. Note that button.cmp uses aura:id="button" to
uniquely identify the component. button.getElement() returns the DOM element.
The rerender() function in buttonRenderer.js is very similar to the render() function. Note that it also calls
updateDisabled(cmp).
rerender : function(cmp, helper){
this.superRerender();
helper.updateDisabled(cmp);
}
166
Creating Apps
Rendering components is part of the lifecycle of the framework and it's a bit trickier to demonstrate than some other concepts. The
takeaway is that you don't need to think about it unless you need to customize the default rendering behavior for a component.
SEE ALSO:
Accessing the DOM
Invoking Actions on Component Initialization
Component Bundles
Modifying Components Outside the Framework Lifecycle
Sharing JavaScript Code in a Component Bundle
Let's look at the Component source to see how this works. The magic happens in this line.
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
This registers an init event handler for the component. init is a predefined event sent to every component. After the component
is initialized, the doInit action is called in the component's controller. In this sample, the controller action sets an attribute value, but
it could do something more interesting, such as firing an event.
Setting value="{!this}" marks this as a value event. You should always use this setting for an init event.
SEE ALSO:
Handling Events with Client-Side Controllers
Client-Side Rendering to the DOM
Component Attributes
Detecting Data Changes
167
Creating Apps
Note how the code updating a component attribute is wrapped in $A.getCallback(), which ensures that the framework rerenders
the modified component.
Note: Always add an isValid() check if you reference a component in asynchronous code, such as a callback or a timeout.
If you navigate elsewhere in the UI while asynchronous code is executing, the framework unrenders and destroys the component
that made the asynchronous request. You'll still have a reference to that component, but it is no longer valid. Add an isValid()
call to check that the component is still valid before processing the results of the asynchronous request.
Warning: Don't save a reference to a function wrapped in $A.getCallback(). If you use the reference later to send actions,
the saved transaction state will cause the actions to be aborted.
SEE ALSO:
Handling Events with Client-Side Controllers
Firing Lightning Events from Non-Lightning Code
Communicating with Events
Validating Fields
You can validate fields using JavaScript. Typically, you validate the user input, identify any errors, and display the error messages.
168
Creating Apps
Validating Fields
When you enter a value and click Submit, doAction in the controller validates the input and displays an error message if the input
is not a number. Entering a valid input clears the error. Add error messages to the input component using the errors attribute.
The following example shows how you can handle a validation error using custom error handlers and display the error message using
the default error component. Here is the markup.
<!--c:errorHandlingCustom-->
<aura:component>
Enter a number: <ui:inputNumber aura:id="inputCmp" onError="{!c.handleError}"
onClearErrors="{!c.handleClearError}"/> <br/>
<ui:button label="Submit" press="{!c.doAction}"/>
</aura:component>
169
Creating Apps
}
},
handleError: function(component, event){
/* do any custom error handling
* logic desired here */
// get v.errors, which is an Object[]
var errorsArr = event.getParam("errors");
for (var i = 0; i < errorsArr.length; i++) {
console.log("error " + i + ": " + JSON.stringify(errorsArr[i]));
}
},
handleClearError: function(component, event) {
/* do any custom error handling
* logic desired here */
}
}
When you enter a value and click Submit, doAction in the controller executes. However, instead of letting the framework handle
the errors, we define a custom error handler using the onError event in <ui:inputNumber>. If the validation fails, doAction
adds an error message using the errors attribute. This automatically fires the handleError custom error handler.
Similarly, you can customize clearing the errors by using the onClearErrors event. See the handleClearError handler in
the controller for an example.
SEE ALSO:
Handling Events with Client-Side Controllers
Component Events
Unrecoverable Errors
Use throw new Error("error message here") for unrecoverable errors, such as an error that prevents your app from
starting successfully. The error message is displayed.
Note: $A.error() is deprecated. Throw the native JavaScript Error object instead by using throw new Error().
This example shows you the basics of throwing an unrecoverable error in a JavaScript controller.
<!--c:unrecoverableError-->
<aura:component>
<ui:button label="throw error" press="{!c.throwError}"/>
</aura:component>
170
Creating Apps
Recoverable Errors
To handle recoverable errors, use a component, such as ui:message to tell the user about the problem.
This sample shows you the basics of throwing and catching a recoverable error in a JavaScript controller.
<!--c:recoverableError-->
<aura:component>
<p>Click the button to trigger the controller to throw an error.</p>
<div aura:id="div1"></div>
<ui:button label="Throw an Error" press="{!c.throwErrorForKicks}"/>
</aura:component>
171
Creating Apps
}
})
The controller code always throws an error and catches it in this example. The message in the error is displayed to the user in a dynamically
created ui:message component. The body of the ui:message is a ui:outputText component containing the error text.
SEE ALSO:
Validating Fields
Dynamically Creating Components
cmp is a reference to the component. arg1, argN is an optional comma-separated list of arguments passed to the method.
Lets look at an example of a component containing a button. The handler for the button calls a component method instead of firing
and handling its own component event.
Here is the component source.
<!--c:auraMethod-->
<aura:component>
<aura:method name="sampleMethod" action="{!c.doAction}" access="PUBLIC"
description="Sample method with parameters">
<aura:attribute name="param1" type="String" default="parameter 1" />
</aura:method>
<ui:button label="Press Me" press="{!c.handleClick}"/>
</aura:component>
172
Creating Apps
},
})
This simple example just logs the parameter passed to the method.
The <aura:method> tag set name="sampleMethod" and action="{!c.doAction}" so the method is called by
cmp.sampleMethod() and handled by doAction() in the controller.
Note: If you dont specify an action value, the controller action defaults to the value of the method name. If we omitted
action="{!c.doAction}" from the earlier example, the method would be called by cmp.sampleMethod() and
handled by sampleMethod() instead of doAction() in the controller.
JavaScript Cookbook
This section includes code snippets and samples that can be used in various JavaScript files.
IN THIS SECTION:
Detecting Data Changes
Finding Components by ID
Dynamically Creating Components
Dynamically Adding Event Handlers
Dynamically Showing or Hiding Markup
Adding and Removing Styles
You can add or remove a CSS style on a component or element during runtime.
173
Creating Apps
A component can have multiple <aura:handler name="change"> tags to detect changes to different attributes.
In the controller, define the action for the handler.
({
itemsChange: function(cmp, evt) {
var v = evt.getParam("value");
if (v === cmp.get("v.items")) {
//do something
}
}
})
When a change occurs to a value that is represented by the change handler, the framework handles the firing of the event and
rerendering of the component. For more information, see aura:valueChange on page 316.
SEE ALSO:
Invoking Actions on Component Initialization
Finding Components by ID
Retrieve a component by its ID in JavaScript code. For example, you can use aura:id to add a local ID of button1 to the
ui:button component.
<ui:button aura:id="button1" label="button1"/>
You can find the component by calling cmp.find("button1"), where cmp is a reference to the component containing the
button. The find() function has one parameter, which is the local ID of a component within the markup.
find() returns different types depending on the result.
174
Creating Apps
For example, the ui:button component renders as an HTML button element with this markup.
<button class="default uiButton" data-aura-rendered-by="30:463;a">...</button>
The client-side controller calls $A.createComponent() to create the button with a local ID and a handler for the press event.
The button is appended to the body of c:createComponent.
/*createComponentController.js*/
({
doInit : function(cmp) {
$A.createComponent(
"ui:button",
{
"aura:id": "findableAuraId",
"label": "Press Me",
"press": cmp.getReference("c.handlePress")
},
175
Creating Apps
function(newButton){
//Add the new button to the body array
if (cmp.isValid()) {
var body = cmp.get("v.body");
body.push(newButton);
cmp.set("v.body", body);
}
}
);
},
handlePress : function(cmp) {
console.log("button pressed");
}
})
Note: c:createComponent contains a {!v.body} expression. When you use cmp.set("v.body", ...) to set
the component body, you must explicitly include {!v.body} in your component markup.
To retrieve the new button you created, use body[0].
var newbody = cmp.get("v.body");
var newCmp = newbody[0].find("findableAuraId");
176
Creating Apps
If you create a component dynamically in JavaScript and that component isn't added to a facet (v.body or another attribute of type
Aura.Component[]), you have to destroy it manually using Component.destroy() to avoid memory leaks.
Declaring Dependencies
The framework automatically tracks dependencies between definitions, such as components. However, some dependencies aren't easily
discoverable by the framework; for example, if you dynamically create a component that is not directly referenced in the component's
markup. To tell the framework about such a dynamic dependency, use the <aura:dependency> tag. This ensures that the
component and its dependencies are sent to the client, when needed.
Server-Side Dependencies
The createComponent() method supports both client-side and server-side component creation. If no server-side dependencies
are found, this method is run synchronously. The top-level component determines whether a server request is necessary for component
creation.
Note: Creating components where the top-level components don't have server dependencies but nested inner components do
is not currently supported.
A server-side controller is not a server-side dependency for component creation as controller actions are only called after the component
has been created.
A component with server-side dependencies is created on the server, even if it's preloaded. If there are no server dependencies and the
definition already exists on the client via preloading or declared dependencies, no server call is made. To force a server request, set the
forceServer parameter to true.
SEE ALSO:
Reference Doc App
aura:dependency
Invoking Actions on Component Initialization
Dynamically Adding Event Handlers
You can also add an event handler to a component that is created dynamically in the callback function of $A.createComponent().
For more information, see Dynamically Creating Components.
addHandler() adds an event handler to a component.
177
Creating Apps
Note that you cant force a component to start firing events that it doesn't fire. c.someAction can be an action in a controller in
the component's hierarchy. someAction and cmp refers to the event name and value provider respectively. someAction must
match the name attribute value in the aura:registerEvent or aura:handler tag. Refer to the JavaScript API reference for
a full list of methods and arguments.
SEE ALSO:
Handling Events with Client-Side Controllers
Creating Server-Side Logic with Controllers
Client-Side Rendering to the DOM
Click the Toggle button to hide or show the text by toggling the CSS class.
SEE ALSO:
Handling Events with Client-Side Controllers
Component Attributes
Adding and Removing Styles
178
Creating Apps
To append and remove CSS classes from a component or element, use the $A.util.addClass(cmpTarget, 'class')
and $A.util.removeClass(cmpTarget, 'class') methods.
Component source
<aura:component>
<div aura:id="changeIt">Change Me!</div><br />
<ui:button press="{!c.applyCSS}" label="Add Style" />
<ui:button press="{!c.removeCSS}" label="Remove Style" />
</aura:component>
CSS source
.THIS.changeMe {
background-color:yellow;
width:200px;
}
The buttons in this demo are wired to controller actions that append or remove the CSS styles. To append a CSS style to a component,
use $A.util.addClass(cmpTarget, 'class'). Similarly, remove the class by using
$A.util.removeClass(cmpTarget, 'class') in your controller. cmp.find() locates the component using the local
ID, denoted by aura:id="changeIt" in this demo.
Toggling a Class
To toggle a class, use $A.util.toggleClass(cmp, 'class'), which adds or removes the class.
The cmp parameter can be component or a DOM element.
Note: We recommend using a component instead of a DOM element. If the utility function is not used inside afterRender()
or rerender(), passing in cmp.getElement() might result in your class not being applied when the components are
rerendered. For more information, see Events Fired During the Rendering Lifecycle on page 135.
To hide or show markup dynamically, see Dynamically Showing or Hiding Markup on page 178.
To conditionally set a class for an array of components, pass in the array to $A.util.toggleClass().
mapClasses: function(arr, cssClass) {
for(var cmp in arr) {
$A.util.toggleClass(arr[cmp], cssClass);
179
Creating Apps
}
}
SEE ALSO:
Handling Events with Client-Side Controllers
CSS in Components
Component Bundles
Use event.getSource() in the client-side controller to get the button component that was clicked. Call getLocalId() to
get the aura:id of the clicked button.
/* buttonPressedController.js */
({
nameThatButton : function(cmp, event, helper) {
var whichOne = event.getSource().getLocalId();
console.log(whichOne);
cmp.set("v.whichButton", whichOne);
}
})
SEE ALSO:
Component IDs
Finding Components by ID
Using Apex
Use Apex to write server-side code, such as controllers and test classes.
Server-side controllers handle requests from client-side controllers. For example, a client-side controller might handle an event and call
a server-side controller action to persist a record. A server-side controller can also load your record data.
180
Creating Apps
IN THIS SECTION:
Creating Server-Side Logic with Controllers
The framework supports client-side and server-side controllers. An event is always wired to a client-side controller action, which can
in turn call a server-side controller action. For example, a client-side controller might handle an event and call a server-side controller
action to persist a record.
Creating Components
The Cmp.<myNamespace>.<myComponent> syntax to reference a component in Apex is deprecated. Use
$A.createComponent() in client-side JavaScript code instead.
Working with Salesforce Records
Its easy to work with your Salesforce records in Apex.
Testing Your Apex Code
Before you can upload a managed package, you must write and execute tests for your Apex code to meet minimum code coverage
requirements. Also, all tests must run without errors when you upload your package to AppExchange.
Making API Calls from Apex
Make API calls from an Apex controller. You cant make API calls from JavaScript code.
181
Creating Apps
In addition to using the @AuraEnabled annotation, your Apex controller must follow these requirements.
Methods must be static and marked public or global. Non-static methods are not supported.
If a method returns an object, instance methods that retrieve the value of the objects instance field must be public.
For more information, see Understanding Classes in the Apex Code Developer's Guide.
SEE ALSO:
Calling a Server-Side Action
Creating an Apex Server-Side Controller
182
Creating Apps
8. Add a controller system attribute to the <aura:component> tag to wire the component to the controller. For example:
<aura:component controller="SimpleServerSideController" >
SEE ALSO:
Salesforce Help: Open the Developer Console
The following client-side controller includes an echo action that executes a serverEcho method on a server-side controller. The
client-side controller sets a callback action that is invoked after the server-side action returns. In this case, the callback function alerts
the user with the value returned from the server. action.setParams({ firstName : cmp.get("v.firstName")
}); retrieves the firstName attribute from the component and sets the value of the firstName argument on the server-side
controllers serverEcho method.
({
"echo" : function(cmp) {
// create a one-time use instance of the serverEcho action
// in the server-side controller
var action = cmp.get("c.serverEcho");
action.setParams({ firstName : cmp.get("v.firstName") });
// Create a callback that is executed after
// the server-side action returns
action.setCallback(this, function(response) {
var state = response.getState();
// This callback doesnt reference cmp. If it did,
// you should run an isValid() check
//if (cmp.isValid() && state === "SUCCESS") {
if (state === "SUCCESS") {
// Alert the user with the value returned
// from the server
alert("From server: " + response.getReturnValue());
// You would typically fire a event here to trigger
// client-side notification that the server-side
// action is complete
}
183
Creating Apps
In the client-side controller, we use the value provider of c to invoke a server-side controller action. This is the same syntax as we use
in markup to invoke a client-side controller action. The cmp.get("c.serverEcho") call indicates that we are calling the
serverEcho method in the server-side controller. The method name in the server-side controller must match everything after the
c. in the client-side call.
Tip: Use unique names for client-side and server-side actions in a component. A JavaScript function (client-side action) with the
same name as a server-side action (Apex method) can lead to hard-to-debug issues.
Use $A.enqueueAction(action) to add the server-side controller action to the queue of actions to be executed. All actions
that are enqueued this way will be run at the end of the event loop. Rather than sending a separate request for each individual action,
the framework processes the event chain and executes the action in the queue after batching up related requests. The actions are
asynchronous and have callbacks.
Note: Always add an isValid() check if you reference a component in asynchronous code, such as a callback or a timeout.
If you navigate elsewhere in the UI while asynchronous code is executing, the framework unrenders and destroys the component
that made the asynchronous request. You'll still have a reference to that component, but it is no longer valid. Add an isValid()
call to check that the component is still valid before processing the results of the asynchronous request.
Tip: If your action is not executing, make sure that you're not executing code outside the framework's normal rerendering lifecycle.
For example, if you use window.setTimeout() in an event handler to execute some logic after a time delay, you must wrap
your code in $A.getCallback(). You don't need to use $A.getCallback() if your code is executed as part of the
framework's call stack; for example, your code is handling an event or in the callback for a server-side controller action.
Action States
The possible action states are:
NEW
The action was created but is not in progress yet
184
Creating Apps
RUNNING
The action is in progress
SUCCESS
The action executed successfully
ERROR
The server returned an error
ABORTED
The action was aborted
Note: setCallback() has a third parameter that registers the action state that will invoke the callback. If you don't specify
the third argument for setCallback(), it defaults to registering the SUCCESS and ERROR states. To set a callback for
another state, such as ABORTED, you can call setCallback() multiple times with the action state set explicitly in the third
argument. For example:
action.setCallback(this, function(response) { ...}, "ABORTED");
SEE ALSO:
Handling Events with Client-Side Controllers
Queueing of Server-Side Actions
Abortable Actions
You can mark an action as abortable to make it potentially abortable while it's queued to be sent to the server or not yet returned from
the server. This is useful for actions that you'd like to abort when there is a newer abortable action in the queue. We recommend that
you only use abortable actions for read-only operations as they are not guaranteed to be sent to the server.
A set of actions for a single transaction, such as a click callback, are queued together to be sent to the server. If a user starts another
transaction, for example by clicking another navigation item, all abortable actions are removed from the queue. The aborted actions are
not sent to the server and their state is set to ABORTED.
185
Creating Apps
An abortable action is sent to the server and executed normally unless it hasnt returned from the server when a subsequent abortable
action is added to the queue.
If some actions have been sent but not yet returned from the server, they will complete, but only the callback logic associated with the
ABORTED state (action.getState() === "ABORTED") will be executed. This enables components to optionally log a
message or clean up if they had an aborted action.
Note: There is no requirement that the most recent abortable action has to be identical to the previous abortable actions. The
most recent action just has to be marked as abortable.
setCallback() has a third parameter that registers the action state that will invoke the callback. If you don't specify the third
argument for setCallback(), it defaults to registering the SUCCESS and ERROR states.To check for aborted actions in your
callback and take appropriate action, such as logging the aborted action, call setCallback() with the ABORTED state set explicitly
Rapid Clicking
Imagine a navigation menu where each action is a potentially slow request to the server. A user may click on several navigation items
quickly so that none of the server responses return before the subsequent click. If all the actions are marked as abortable, none of the
callbacks will be called except for the last click. This improves user experience by avoiding flickering due to sequential rendering of
multiple server responses.
SEE ALSO:
Creating Server-Side Logic with Controllers
Queueing of Server-Side Actions
Calling a Server-Side Action
186
Creating Apps
Creating Components
Creating Components
The Cmp.<myNamespace>.<myComponent> syntax to reference a component in Apex is deprecated. Use
$A.createComponent() in client-side JavaScript code instead.
SEE ALSO:
Dynamically Creating Components
For more information on working on records with Apex, see Working with Data in Apex.
This example controller persists an updated Account record. Note that the update method has the @AuraEnabled annotation,
which enables it to be called as a server-side controller action.
public with sharing class AccountController {
@AuraEnabled
public static void updateAnnualRevenue(String accountId, Decimal annualRevenue) {
Account acct = [SELECT Id, Name, BillingCity FROM Account WHERE Id = :accountId];
acct.AnnualRevenue = annualRevenue;
// Perform isAccessible() and isUpdateable() checks here
update acct;
}
}
For an example of calling Apex code from JavaScript code, see the Quick Start on page 6.
187
Creating Apps
@AuraEnabled
public static Opportunity getOpportunity(Id id) {
Opportunity opportunity = [
SELECT Id, Account.Name, Name, CloseDate,
Owner.Name, Amount, Description, StageName
FROM Opportunity
WHERE Id = :id
];
// Perform isAccessible() check here
return opportunity;
}
}
This example component uses the previous server-side controller to display a list of opportunity records when you press a button.
<aura:component controller="OpportunityController">
<aura:attribute name="opportunities" type="Opportunity[]"/>
<ui:button label="Get Opportunities" press="{!c.getOpps}"/>
<aura:iteration var="opportunity" items="{!v.opportunities}">
<p>{!opportunity.Name} : {!opportunity.CloseDate}</p>
</aura:iteration>
</aura:component>
When you press the button, the following client-side controller calls the getOpportunities() server-side controller and sets the
opportunities attribute on the component. For more information about calling server-side controller methods, see Calling a
Server-Side Action on page 183.
({
getOpps: function(cmp){
var action = cmp.get("c.getOpportunities");
action.setCallback(this, function(response){
var state = response.getState();
if (state === "SUCCESS") {
cmp.set("v.opportunities", response.getReturnValue());
}
});
$A.enqueueAction(action);
}
})
Note: To load record data during component initialization, use the init handler.
188
Creating Apps
This example component uses the previous controller to display a list of records from the myObj__c custom object.
<aura:component controller="MyObjController"/>
<aura:attribute name="myObjects" type="namespace.MyObj__c[]"/>
<aura:iteration items="{!v.myObjects}" var="obj">
{!obj.Name}, {!obj.namespace__myField__c}
</aura:iteration>
This client-side controller sets the myObjects component attribute with the record data by calling the getMyObjects() method
in the server-side controller. This step can also be done during component initialization using the init handler.
getMyObjects: function(cmp){
var action = cmp.get("c.getMyObjects");
action.setCallback(this, function(response){
var state = response.getState();
if (state === "SUCCESS") {
cmp.set("v.myObjects", response.getReturnValue());
}
});
$A.enqueueAction(action);
}
For an example on loading and updating records using controllers, see the Quick Start on page 6.
IN THIS SECTION:
CRUD and Field-Level Security (FLS)
In addition to the Content Security Policy, Lightning Components imposes CRUD and field-level security to ensure component
security.
Saving Records
You can take advantage of the built-in create and edit record pages in Salesforce1 to create or edit records via a Lightning component.
Deleting Records
You can delete records via a Lightning component to remove them from both the view and database.
SEE ALSO:
CRUD and Field-Level Security (FLS)
189
Creating Apps
explicitly check for isAccessible(), isCreateable(), isDeletable(), and isUpdateable() prior to performing
operations on records or objects.
This example shows the recommended way to perform an operation on a custom expense object.
public with sharing class ExpenseController {
// ns refers to namespace; leave out ns__ if not needed
// This method is vulnerable.
@AuraEnabled
public static List<ns__Expense__c> get_UNSAFE_Expenses() {
return [SELECT Id, Name, ns__Amount__c, ns__Client__c, ns__Date__c,
ns__Reimbursed__c, CreatedDate FROM ns__Expense__c];
}
// This method is recommended.
@AuraEnabled
public static List<ns__Expense__c> getExpenses() {
String [] expenseAccessFields = new String [] {'Id',
'Name',
'ns__Amount__c',
'ns__Client__c',
'ns__Date__c',
'ns__Reimbursed__c',
'CreatedDate'
};
Note: For more information, see the articles on Enforcing CRUD and FLS and Lightning Security.
190
Creating Apps
Saving Records
You can take advantage of the built-in create and edit record pages in Salesforce1 to create or edit records via a Lightning component.
The following component contains a button that calls a client-side controller to display the edit record page.
<aura:component>
<ui:button label="Edit Record" press="{!c.edit}"/>
</aura:component>
The client-side controller fires the force:recordEdit event, which displays the edit record page for a given contact ID. For this
event to be handled correctly, the component must be included in Salesforce1.
edit : function(component, event, helper) {
var editRecordEvent = $A.get("e.force:editRecord");
editRecordEvent.setParams({
"recordId": component.get("v.contact.Id")
});
editRecordEvent.fire();
}
Call a client-side controller from your component. For example, <ui:button label="Submit"
press="{!c.createExpense}"/>.
In your client-side controller, provide any field validation and pass the record data to a helper function.
createExpense : function(component, event, helper) {
// Validate form fields
// Pass form data to a helper function
var newExpense = component.get("v.newExpense");
helper.createExpense(component, newExpense);
}
191
Creating Apps
In your component helper, get an instance of the server-side controller and set a callback. The following example upserts a record on a
custom object. Recall that setParams() sets the value of the expense argument on the server-side controllers saveExpense()
method.
createExpense: function(component, expense) {
//Save the expense and update the view
this.upsertExpense(component, expense, function(a) {
var expenses = component.get("v.expenses");
expenses.push(a.getReturnValue());
component.set("v.expenses", expenses);
});
},
upsertExpense : function(component, expense, callback) {
var action = component.get("c.saveExpense");
action.setParams({
"expense": expense
});
if (callback) {
action.setCallback(this, callback);
}
$A.enqueueAction(action);
}
SEE ALSO:
CRUD and Field-Level Security (FLS)
Deleting Records
You can delete records via a Lightning component to remove them from both the view and database.
Create an Apex controller to delete a specified record with the delete operation. The following Apex controller deletes an expense
object record.
@AuraEnabled
public static Expense__c deleteExpense(Expense__c expense) {
// Perform isDeletable() check here
delete expense;
return expense;
}
Depending on how your components are set up, you might need to create an event to tell another component that a record has been
deleted. For example, you have a component that contains a sub-component that is iterated over to display the records. Your
sub-component contains a button (1), which when pressed fires an event thats handled by the container component (2), which deletes
the record thats clicked on.
<aura:registerEvent name="deleteExpenseItem" type="c:deleteExpenseItem"/>
<ui:button label="Delete" press="{!c.delete}"/>
192
Creating Apps
Create a component event to capture and pass the record thats to be deleted. Name the event deleteExpenseItem.
<aura:event type="COMPONENT">
<aura:attribute name="expense" type="Expense__c"/>
</aura:event>
Then, pass in the record to be deleted and fire the event in your client-side controller.
delete : function(component, evt, helper) {
var expense = component.get("v.expense");
var deleteEvent = component.getEvent("deleteExpenseItem");
deleteEvent.setParams({ "expense": expense }).fire();
}
In the container component, include a handler for the event. In this example, c:expenseList is the sub-component that displays
records.
<aura:handler name="deleteExpenseItem" event="c:deleteExpenseItem" action="c:deleteEvent"/>
<aura:iteration items="{!v.expenses}" var="expense">
<c:expenseList expense="{!expense}"/>
</aura:iteration>
And handle the event in the client-side controller of the container component.
deleteEvent : function(component, event, helper) {
// Call the helper function to delete record and update view
193
Creating Apps
helper.deleteExpense(component, event.getParam("expense"));
}
Finally, in the helper function of the container component, call your Apex controller to delete the record and update the view.
deleteExpense : function(component, expense, callback) {
// Call the Apex controller and update the view in the callback
var action = component.get("c.deleteExpense");
action.setParams({
"expense": expense
});
action.setCallback(this, function(response) {
var state = response.getState();
if (state === "SUCCESS") {
// Remove only the deleted expense from view
var expenses = component.get("v.expenses");
var items = [];
for (i = 0; i < expenses.length; i++) {
if(expenses[i]!==expense) {
items.push(expenses[i]);
}
}
component.set("v.expenses", items);
// Other client-side logic
}
});
$A.enqueueAction(action);
}
The helper function calls the Apex controller to delete the record in the database. In the callback function,
component.set("v.expenses", items) updates the view with the updated array of records.
SEE ALSO:
CRUD and Field-Level Security (FLS)
Create a Standalone Lightning App
Component Events
Calling a Server-Side Action
194
Creating Apps
While only 75% of your Apex code must be covered by tests, your focus shouldn't be on the percentage of code that is covered.
Instead, you should make sure that every use case of your application is covered, including positive and negative cases, as well
as bulk and single records. This should lead to 75% or more of your code being covered by unit tests.
Every trigger must have some test coverage.
All classes and triggers must compile successfully.
This sample shows an Apex test class that is used with the controller class in the expense tracker app available at Create a Standalone
Lightning App on page 8.
@isTest
class TestExpenseController {
static testMethod void test() {
//Create new expense and insert it into the database
Expense__c exp = new Expense__c(name='My New Expense',
amount__c=20, client__c='ABC',
reimbursed__c=false, date__c=null);
ExpenseController.saveExpense(exp);
//Assert the name field and saved expense
System.assertEquals('My New Expense',
ExpenseController.getExpenses()[0].Name,
'Name does not match');
System.assertEquals(exp, ExpenseController.saveExpense(exp));
}
}
Controlling Access
The framework enables you to control access to your applications, interfaces, components, attributes, and events via the access
system attribute. The access system attribute indicates whether the resource can be used outside of its own namespace.
Use the access system attribute on these tags:
aura:application
aura:interface
aura:component
aura:attribute
aura:event
195
Creating Apps
Controlling Access
Access Values
You can specify these values for the access system attribute.
private
Available within the component, app, interface, or event and cant be referenced externally. This value can only be used for
aura:attribute.
public
Available within the same namespace. This is the default access value.
global
Example
This sample component has global access.
<aura:component access="global">
...
</aura:component>
Access Violations
If your code accesses a resource, such as a component or attribute, that doesnt have an access system attribute allowing you to
access it, you see a warning in your browser console if you enabled debug mode.
196
Creating Apps
Otherwise, the framework loses context and allows access only to global resources.
IN THIS SECTION:
Application Access Control
The access attribute on the aura:application tag indicates whether the app can be used outside of the apps namespace.
Interface Access Control
The access attribute on the aura:interface tag indicates whether the interface can be extended or used outside of the
interfaces namespace.
Component Access Control
The access attribute on the aura:component tag indicates whether the component can be extended or used outside of
the components namespace.
Attribute Access Control
The access attribute on the aura:attribute tag indicates whether the attribute can be used outside of the attributes
namespace.
Event Access Control
The access attribute on the aura:event tag indicates whether the event can be used or extended outside of the events
namespace.
SEE ALSO:
Debug JavaScript Code
Description
public
Available within the same namespace. This is the default access value.
global
197
Creating Apps
Description
public
Available within the same namespace. This is the default access value.
global
A component can implement an interface using the implements attribute on the aura:component tag.
Description
public
Available within the same namespace. This is the default access value.
global
Note: Components arent directly addressable via a URL. To check your component output, embed your component in a .app
resource.
Description
private
Available within the component, app, interface, or event and cant be referenced externally.
public
Available within the same namespace. This is the default access value.
global
Description
public
Available within the same namespace. This is the default access value.
198
Creating Apps
Modifier
Description
global
What is Inherited?
This topic lists what is inherited when you extend a definition, such as a component.
When a component contains another component, we refer in the documentation to parent and child components in the containment
hierarchy. When a component extends another component, we refer to sub and super components in the inheritance hierarchy.
Component Attributes
A sub component that extends a super component inherits the attributes of the super component. Use <aura:set> in the markup
of a sub component to set the value of an attribute inherited from a super component.
Events
A sub component that extends a super component can handle events fired by the super component. The sub component automatically
inherits the event handlers from the super component.
The super and sub component can handle the same event in different ways by adding an <aura:handler> tag to the sub component.
The framework doesn't guarantee the order of event handling.
Helpers
A sub component's helper inherits the methods from the helper of its super component. A sub component can override a super
component's helper method by defining a method with the same name as an inherited method.
Controllers
A sub component that extends a super component can call actions in the super component's client-side controller. For example, if the
super component has an action called doSomething, the sub component can directly call the action using the {!c.doSomething}
syntax.
199
Creating Apps
Note: We don't recommend using inheritance of client-side controllers as this feature may be deprecated in the future to preserve
better component encapsulation. We recommend that you put common code in a helper instead.
SEE ALSO:
Component Attributes
Communicating with Events
Sharing JavaScript Code in a Component Bundle
Handling Events with Client-Side Controllers
aura:set
Dont worry about the {!v.body} expression for now. Well explain that when we talk about the body attribute.
c:sub extends c:super by setting extends="c:super" in its <aura:component> tag.
<!--c:sub-->
<aura:component extends="c:super">
<p>sub.cmp description: {!v.description}</p>
</aura:component
Note that sub.cmp has access to the inherited description attribute and it has the same value in sub.cmp and super.cmp.
Use <aura:set> in the markup of a sub component to set the value of an inherited attribute.
200
Creating Apps
Abstract Components
Let's look at a simple example to understand how the body attribute behaves at different levels of component extension. We have
three components.
c:superBody is the super component. It inherently extends <aura:component>.
<!--c:superBody-->
<aura:component extensible="true">
Parent body: {!v.body}
</aura:component>
At this point, c:superBody doesnt output anything for {!v.body} as its just a placeholder for data that will be passed in by a
component that extends c:superBody.
c:subBody extends c:superBody by setting extends="c:superBody" in its <aura:component> tag.
<!--c:subBody-->
<aura:component extends="c:superBody">
Child body: {!v.body}
</aura:component>
c:subBody outputs:
Parent body: Child body:
In other words, c:subBody sets the value for {!v.body} in its super component, c:superBody.
c:containerBody contains a reference to c:subBody.
<!--c:containerBody-->
<aura:component>
<c:subBody>
Body value
</c:subBody>
</aura:component>
In c:containerBody, we set the body attribute of c:subBody to Body value. c:containerBody outputs:
Parent body: Child body: Body value
SEE ALSO:
aura:set
Component Body
Component Markup
Abstract Components
Object-oriented languages, such as Java, support the concept of an abstract class that provides a partial implementation for an object
but leaves the remaining implementation to concrete sub-classes. An abstract class in Java can't be instantiated directly, but a non-abstract
subclass can.
Similarly, the Lightning Component framework supports the concept of abstract components that have a partial implementation but
leave the remaining implementation to concrete sub-components.
To use an abstract component, you must extend it and fill out the remaining implementation. An abstract component can't be used
directly in markup.
201
Creating Apps
Interfaces
The <aura:component> tag has a boolean abstract attribute. Set abstract="true" to make the component abstract.
SEE ALSO:
Interfaces
Interfaces
Object-oriented languages, such as Java, support the concept of an interface that defines a set of method signatures. A class that
implements the interface must provide the method implementations. An interface in Java can't be instantiated directly, but a class that
implements the interface can.
Similarly, the Lightning Component framework supports the concept of interfaces that define a component's shape by defining its
attributes.
An interface starts with the <aura:interface> tag. It can only contain these tags:
<aura:attribute> tags to define the interface's attributes.
<aura:registerEvent> tags to define the events that it may fire.
You can't use markup, renderers, controllers, or anything else in an interface.
To use an interface, you must implement it. An interface can't be used directly in markup otherwise. Set the implements system
attribute in the <aura:component> tag to the name of the interface that you are implementing. For example:
<aura:component implements="mynamespace:myinterface" >
Note: Use <aura:set> in a sub component to set the value of any attribute that is inherited from the super component. This
usage works for components and abstract components, but it doesn't work for interfaces. To set the value of an attribute inherited
from an interface, redefine the attribute in the sub component using <aura:attribute> and set the value in its default
attribute.
Since there are fewer restrictions on the content of abstract components, they are more common than interfaces. A component can
implement multiple interfaces but can only extend one abstract component, so interfaces can be more useful for some design patterns.
SEE ALSO:
Setting Attributes Inherited from an Interface
Abstract Components
Marker Interfaces
You can use an interface as a marker interface that is implemented by a set of components that you want to easily identify for specific
usage in your app.
In JavaScript, you can determine if a component implements an interface by using
myCmp.isInstanceOf("mynamespace:myinterface").
202
Creating Apps
Inheritance Rules
Inheritance Rules
This table describes the inheritance rules for various elements.
Element
extends
implements
component
multiple interfaces
<aura:component>
app
N/A
<aura:application>
interface
N/A
SEE ALSO:
Interfaces
Persistent
Secure
SmartStore
true
true
IndexedDB
true
false
MemoryAdapter
false
true
SmartStore
(Persistent and secure) Provides a caching service that is only available for apps built with the Salesforce Mobile SDK. The Salesforce
Mobile SDK enables developing mobile applications that integrate with Salesforce. You can use SmartStore with these mobile
applications for caching data.
IndexedDB
(Persistent but not secure) Provides access to an API for client-side storage and search of structured data. For more information, see
the Indexed Database API.
MemoryAdapter
(Not persistent but secure) Provides access to the JavaScript main memory space for caching data. The stored cache persists only
per browser page. Browsing to a new page resets the cache.
The Storage Service selects a storage adapter on your behalf that matches the persistent and secure options you specify when initializing
the service. For example, if you request a persistent and insecure storage service, the Storage Service returns the IndexedDB storage.
There are two types of storage:
203
Creating Apps
Custom named storage: Storage that you control by adding and retrieving items to and from storage.
Framework-provided actions storage: Storage for server-side actions that enables caching action response values.
When you initialize storage, you can set certain options, such as the maximum cache size and the default expiration time. The storage
name is required and must be unique.
Note: The storage name can be any name except for actions, which is reserved for the server action storage that the framework
uses.
The expiration time for an item in storage specifies the duration after which an item should be replaced with a fresh copy. The refresh
interval takes effect only if the item hasnt expired yet and applies to the actions storage only. In that case, if the refresh interval for an
item has passed, the item gets refreshed after the same action is called. If stored items have reached their expiration times or have
exceeded their refresh intervals, theyre replaced only after a call is made to access them and if the client is online.
SEE ALSO:
Creating Server-Side Logic with Controllers
Initializing Storage Service
Initialize in Markup
You can initialize storage for your component using markup by using a template or by adding the markup in the component body.
This example shows how to use a template to initialize storage. The component references the template in the template attribute.
<aura:component render="client" template="auraStorageTest:namedStorageTemplate">
</aura:component>
The template contains auraStorage:init tags that specify storage initialization properties. This example initializes three different
storages: the framework-provided actions storage, and two custom storages named savings and checking.
<aura:component isTemplate="true" extends="aura:template">
<aura:set attribute="auraPreInitBlock">
<!-- Note that the maxSize attribute in <auraStorage:init> is in KB -->
<auraStorage:init name="actions" persistent="false" secure="false"
maxSize="9999" version="1.0"/>
<auraStorage:init name="savings" persistent="false" secure="true"
maxSize="6666"/>
<auraStorage:init name="checking" maxSize="7777"/>
</aura:set>
</aura:component>
Alternatively, you can add auraStorage:init tags directly in the body of your component markup. This example shows component
markup that initializes a storage named savings.
<aura:component render="client" extensible="true"
controller="java://org.auraframework.impl.java.controller.AuraStorageTestController"
implements="auraStorage:refreshObserver">
<auraStorage:init debugLoggingEnabled="true"
name="savings"
204
Creating Apps
secure="true"
persistent="false"
clearStorageOnInit="true"
defaultExpiration="50"
defaultAutoRefreshInterval="60"
version="1.0" />
</aura:component>
IN THIS SECTION:
Enabling the AppCache
The framework disables the use of AppCache by default.
Loading Resources with AppCache
A cache manifest file is a simple text file that defines the Web resources to be cached offline in the AppCache.
SEE ALSO:
aura:application
205
Creating Apps
The cache manifest is auto-generated for you at runtime if you have enabled AppCache in your application. If there are any changes to
the resources, the framework updates the timestamp to trigger a refetch of all resources. Fetching resources only when necessary reduces
server trips for users.
When a browser initially requests an app, a link to the manifest file is included in the response.
<html manifest="/path/to/app.manifest">
The manifest path includes the mode and app name of the app thats currently running. This manifest file lists framework resources as
well as your JavaScript code and CSS, which are cached after theyre downloaded for the first time. A hash in the URL ensures that you
always have the latest resources.
Note: Youll see different resources depending on which mode youre running in. For example, aura_prod.js is available
in PROD mode and aura_proddebug.js is available in PRODDEBUG mode.
206
Creating Apps
For more information on packaging and distributing, see the ISVforce Guide.
SEE ALSO:
Testing Your Apex Code
207
CHAPTER 7
In this chapter ...
Debug JavaScript
Code
Log Messages
Warning Messages
Debugging
There are a few basic tools that can help you to debug applications.
For example, use Chrome Developer Tools to debug your client-side code.
To open Developer Tools on Windows and Linux, press Control-Shift-I in your Google Chrome
browser. On Mac, press Option-Command-I.
To quickly find which line of code is failing, enable the Pause on all exceptions option before
running your code.
To learn more about debugging JavaScript on Google Chrome, refer to the Google Chrome's Developer
Tools website.
208
Debugging
EDITIONS
Available in: Salesforce
Classic and Lightning
Experience
Available for use in: Contact
Manager, Group,
Professional, Enterprise,
Performance, Unlimited,
and Developer Editions
Create Lightning
components using the UI in
Enterprise, Performance,
Unlimited, Developer
Editions or a sandbox.
3. Click Save.
Log Messages
To help debug your client-side code, you can write output to the JavaScript console of a web
browser.
Use the $A.log(string[, error]) method to output a log message to the JavaScript console.
The first parameter is the string to log.
The optional second parameter is an error object that can include more detail.
Note: $A.log() doesn't output by default for Lightning components, which run in either PROD or PRODDEBUG modes.
To log messages in PROD or PRODDEBUG modes, see Logging in Production Modes on page 209. Alternatively, use
console.log() if your browser supports it.
For example, $A.log("This is a log message") outputs to the JavaScript console:
This is a log message
Adding $A.log("The name of the action is: " + this.getDef().getName()) in an action called openNote
in a client-side controller outputs to the JavaScript console:
The name of the action is: openNote
For instructions on using the JavaScript console, refer to the instructions for your web browser.
209
Debugging
Warning Messages
WARNING
The second parameter is the callback function that will be called when a message at the subscribed severity level is logged.
Note that $A.log() logs a message at the INFO severity level. Adding $A.logger.subscribe("INFO", logCustom)
causes $A.log() to log using the custom logCustom() function you define.
Let's look at some sample JavaScript code in a client-side controller.
({
sampleControllerAction: function(cmp) {
// subscribe to severity levels
$A.logger.subscribe("INFO", logCustom);
// Following subscriptions not exercised here but shown for completeness
//$A.logger.subscribe("WARNING", logCustom);
//$A.logger.subscribe("ASSERT", logCustom);
//$A.logger.subscribe("ERROR", logCustom);
$A.log("log one arg");
$A.log("log two args", {message: "drat and double drat"});
function logCustom(level, message, error) {
console.log(getTimestamp(), "logCustom: ", arguments);
}
function getTimestamp() {
return new Date().toJSON();
}
}
})
$A.logger.subscribe("INFO", logCustom) subscribes so that messages logged at the INFO severity level will call the
logCustom() function. In this case, logCustom() simply logs the message to the console with a timestamp.
The $A.log() calls log messages at the INFO severity level, which matches the subscription and invokes the logCustom()
callback.
Warning Messages
To help debug your client-side code, you can use the warning() method to write output to the JavaScript console of your web
browser.
Use the $A.warning(string) method to write a warning message to the JavaScript console. The parameter is the message to
display.
For example, $A.warning("This is a warning message."); outputs to the JavaScript console.
This is a warning message.
Note: $A.warning() doesn't output by default for Lightning components, which run in either PROD or PRODDEBUG
modes. To log warning messages in PROD or PRODDEBUG modes, use $A.logger.subscribe("WARNING",
logCustom), where logCustom() is a custom function that you define. For more information, see Logging in Production
Modes on page 209.
For instructions on using the JavaScript console, refer to the instructions for your web browser.
210
CHAPTER 8
In this chapter ...
aura:application
aura:dependency
aura:event
aura:interface
aura:method
aura:set
Component
Reference
Event Reference
System Event
Reference
Supported HTML
Tags
Supported
aura:attribute Types
Reference
This section contains reference documentation including details of the various tags available in the
framework.
Note that the the Lightning Component framework provides a subset of whats available in the
open-source Aura framework, in addition to components and events that are specific to Salesforce.
211
Reference
aura:application
An app is a special top-level component whose markup is in a .app resource.
The markup looks similar to HTML and can contain components as well as a set of supported HTML tags. The .app resource is a
standalone entry point for the app and enables you to define the overall application layout, style sheets, and global JavaScript includes.
It starts with the top-level <aura:application> tag, which contains optional system attributes. These system attributes tell the
framework how to configure the app.
System Attribute
Type
Description
access
String
Indicates whether the app can be extended by another app outside of a namespace.
Possible values are public (default), and global.
controller
String
description
String
extends
Component
extensible
Boolean
implements
String
template
Component
The name of the template used to bootstrap the loading of the framework and
the app. The default value is aura:template. You can customize the template
by creating your own component that extends the default template. For example:
<aura:component extends="aura:template" ... >
useAppcache
Boolean
Specifies whether to use the application cache. Valid options are true or false.
Defaults to false.
aura:application also includes a body attribute defined in a <aura:attribute> tag. Attributes usually control the output
212
Reference
aura:dependency
Attribute
Type
Description
body
Component[]
SEE ALSO:
Creating Apps
Using the AppCache
Application Access Control
aura:dependency
The <aura:dependency> tag enables you to declare dependencies that can't easily be discovered by the framework.
The framework automatically tracks dependencies between definitions, such as components. This enables the framework to automatically
reload when it detects that you've changed a definition during development. However, if a component uses a client- or server-side
provider that instantiates components that are not directly referenced in the components markup, use <aura:dependency> in
the components markup to explicitly tell the framework about the dependency. Adding the <aura:dependency> tag ensures
that a component and its dependencies are sent to the client, when needed.
For example, adding this tag to a component marks the aura:placeholder component as a dependency.
<aura:dependency resource="markup://aura:placeholder" />
Description
resource
Use an asterisk (*) in the resource name for wildcard matching. For example,
resource="markup://sampleNamespace:*" matches everything in the namespace;
resource="markup://sampleNamespace:input*" matches everything in the
namespace that starts with input.
Dont use an asterisk (*) in the namespace portion of the resource name. For example,
resource="markup://sample*:sampleComponent" is not supported.
type
The type of resource that the component depends on. The default value is COMPONENT. Use
type="*" to match all types of resources.
The most commonly used values are:
COMPONENT
APPLICATION
EVENT
213
Reference
aura:event
System Attribute
Description
Use a comma-separated list for multiple types; for example: COMPONENT,APPLICATION.
SEE ALSO:
Dynamically Creating Components
aura:event
An event is represented by the aura:event tag, which has the following attributes.
Attribute
Type
Description
access
String
description
String
extends
Component
type
String
SEE ALSO:
Communicating with Events
Event Access Control
aura:interface
The aura:interface tag has the following optional attributes.
Attribute
Type
Description
access
String
description
String
extends
Component
SEE ALSO:
Interfaces
Interface Access Control
214
Reference
aura:method
aura:method
Use <aura:method> to define a method as part of a component's API. This enables you to directly call a method in a components
client-side controller instead of firing and handling a component event. Using <aura:method> simplifies the code needed for a
parent component to call a method on a child component that it contains.
The <aura:method> tag has these system attributes.
Attribute
Type
Description
name
String
The method name. Use the method name to call the method in
JavaScript code. For example:
cmp.sampleMethod(param1);
action
Expression
String
description
String
Declaring Parameters
An <aura:method> can optionally include parameters. Use an <aura:attribute> tag within an <aura:method> to
declare a parameter for the method. For example:
<aura:method name="sampleMethod" action="{!c.doAction}" access="PUBLIC"
description="Sample method with parameters">
<aura:attribute name="param1" type="String" default="parameter 1"/>
<aura:attribute name="param2" type="Object" />
</aura:method>
Note: You dont need an access system attribute in the <aura:attribute> tag for a parameter.
215
Reference
aura:set
Retrieve the arguments using event.getParam('arguments'). It returns an object if there are arguments or an empty array
if there are no arguments.
SEE ALSO:
Calling Component Methods
Component Events
aura:set
Use <aura:set> in markup to set the value of an attribute inherited from a super component, event, or interface.
To learn more, see:
Setting Attributes Inherited from a Super Component
Setting Attributes on a Component Reference
Setting Attributes Inherited from an Interface
c:setTagSuper outputs:
setTagSuper address1:
The address1 attribute doesn't output any value yet as it hasn't been set.
Here is the c:setTagSub component that extends c:setTagSuper.
<!--c:setTagSub-->
<aura:component extends="c:setTagSuper">
<aura:set attribute="address1" value="808 State St" />
</aura:component>
c:setTagSub outputs:
setTagSuper address1: 808 State St
216
Reference
sampleSetTagExc:setTagSub sets a value for the address1 attribute inherited from the super component,
c:setTagSuper.
Warning: This usage of <aura:set> works for components and abstract components, but it doesnt work for interfaces. For
more information, see Setting Attributes Inherited from an Interface on page 218.
If youre using a component by making a reference to it in your component, you can set the attribute value directly in the markup. For
example, c:setTagSuperRef makes a reference to c:setTagSuper and sets the address1 attribute directly without using
aura:set.
<!--c:setTagSuperRef-->
<aura:component>
<c:setTagSuper address1="1 Sesame St" />
</aura:component>
c:setTagSuperRef outputs:
setTagSuper address1: 1 Sesame St
SEE ALSO:
Component Body
Inherited Component Attributes
Setting Attributes on a Component Reference
The latter syntax without aura:set makes more sense in this simple example. You can also use this simpler syntax in component
references to set values for attributes that are inherited from parent components.
aura:set is more useful when you want to set markup as the attribute value. For example, this sample specifies the markup for the
else attribute in the aura:if tag.
<aura:component>
<aura:attribute name="display" type="Boolean" default="true"/>
<aura:if isTrue="{!v.display}">
Show this if condition is true
<aura:set attribute="else">
<ui:button label="Save" press="{!c.saveRecord}" />
</aura:set>
217
Reference
</aura:if>
</aura:component>
SEE ALSO:
Setting Attributes Inherited from a Super Component
Component Reference
Reuse or extend out-of-the-box components for Salesforce1 or for your Lightning apps.
aura:component
The root of the component hierarchy. Provides a default rendering implementation.
Components are the functional units of Aura, which encapsulate modular and reusable sections of UI. They can contain other components
or HTML markup. The public parts of a component are its attributes and events. Aura provides out-of-the-box components in the aura
and ui namespaces.
Every component is part of a namespace. For example, the button component is saved as button.cmp in the ui namespace
can be referenced in another component with the syntax <ui:button label="Submit"/>, where label="Submit" is
an attribute setting.
To create a component, follow this syntax.
<aura:component>
<!-- Optional coponent attributes here -->
<!-- Optional HTML markup -->
<div class="container">
Hello world!
<!-- Other components -->
</div>
218
Reference
aura:expression
</aura:component>
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
aura:expression
Renders the value to which an expression evaluates. Creates an instance of this component which renders the referenced "property
reference value" set to the value attribute when expressions are found in free text or markup.
An expression is any set of literal values, variables, sub-expressions, or operators that can be resolved to a single value. It is used for
dynamic output or passing a value into components by assigning them to attributes.
The syntax for an expression is {!expression}. expression is evaluated and dynamically replaced when the component is
rendered or when the value is used by the component. The resulting value can be a primitive (integer, string, and so on), a boolean, a
JavaScript or Aura object, an Aura component or collection, a controller method such as an action method, and other useful results.
An expression uses a value provider to access data and can also use operators and functions for more complex expressions. Value
providers include m (data from model), v(attribute data from component), and c (controller action). This example show an expression
{!v.num} whose value is resolved by the attribute num.
<aura:attribute name="num" type="integer" default="10"/>
<ui:inputNumber label="Enter age" aura:id="num" value="{!v.num}"/>
Attributes
Attribute Name
Attribute Type
Description
Required?
value
String
aura:html
A meta component that represents all html elements. Any html found in your markup causes the creation of one of these.
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
HTMLAttributes HashMap
Required?
219
Reference
aura:if
Attribute Name
Attribute Type
Description
Required?
tag
String
aura:if
Conditionally instantiates and renders either the body or the components in the else attribute.
aura:if evaluates the isTrue expression on the server and instantiates components in either its body or else attribute. Only
one branch is created and rendered. Switching condition unrenders and destroys the current branch and generates the other
<aura:component>
<aura:if isTrue="{!v.truthy}">
True
<aura:set attribute="else">
False
</aura:set>
</aura:if>
</aura:component>
Attributes
Attribute Name
Attribute Type
Description
Required?
body
ComponentDefRef[]
Yes
else
ComponentDefRef[]
The alternative to render when isTrue evaluates to false, and the body is
not rendered. Should always be set using the aura:set tag.
isTrue
Boolean
Yes
aura:iteration
Renders a view of a collection of items. Supports iterations containing components that can be created exclusively on the client-side.
aura:iteration iterates over a collection of items and renders the body of the tag for each item. Data changes in the collection
are rerendered automatically on the page. It also supports iterations containing components that are created exclusively on the client-side
or components that have server-side dependencies.
This example shows a basic way to use aura:iteration exclusively on the client-side.
<aura:component>
<aura:iteration items="1,2,3,4,5" var="item">
<meter value="{!item / 5}"/><br/>
</aura:iteration>
</aura:component>
220
Reference
aura:renderIf
Attributes
Attribute Name
Attribute Type
Description
Required?
body
ComponentDefRef[]
Yes
end
Integer
indexVar
String
The name of variable to use for the index of each item inside the iteration
items
List
loaded
Boolean
start
Integer
template
ComponentDefRef[]
var
String
The name of the variable to use for each item inside the iteration
Yes
Yes
aura:renderIf
This component allows you to conditionally render its contents. It renders its body only if isTrue evaluates to true. The else attribute
allows you to render an alternative when isTrue evaluates to false.
The expression in isTrue is re-evaluated every time any value used in the expression changes. When the results of the expression
change, it triggers a re-rendering of the component. Use aura:renderIf if you expect to show the components for both the true
and false states, and it would require a server round trip to instantiate the components that aren't initially rendered. Switching condition
unrenders current branch and renders the other. Otherwise, use aura:if instead if you want to instantiate the components in either
its body or the else attribute, but not both.
<aura:component>
<aura:renderIf isTrue="{!v.truthy}">
True
<aura:set attribute="else">
False
</aura:set>
</aura:renderIf>
</aura:component>
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
else
Component[]
The alternative content to render when isTrue evaluates to false, and the
body is not rendered. Set using the <aura:set> tag.
isTrue
Boolean
221
Yes
Reference
aura:template
aura:template
Default template used to bootstrap Aura framework. To use another template, extend aura:template and set attributes using aura:set.
Attributes
Attribute Name
Attribute Type
auraPreInitBlock Component[]
Description
Required?
body
Component[]
bodyClass
String
defaultBodyClass String
doctype
String
errorMessage
String
errorTitle
String
loadingText
String
Loading text
title
String
aura:text
Renders plain text. When any free text (not a tag or attribute value) is found in markup, an instance of this component is created with
the value attribute set to the text found in the markup.
Attributes
Attribute Name
Attribute Type
Description
Required?
value
String
aura:unescapedHtml
The value assigned to this component will be rendered as-is, without altering its contents. It's intended for outputting pre-formatted
HTML, for example, where the formatting is arbitrary, or expensive to calculate. The body of this component is ignored, and won't be
rendered. Warning: this component outputs value as unescaped HTML, which introduces the possibility of security vulnerabilities in
your code. You must sanitize user input before rendering it unescaped, or you will create a cross-site scripting (XSS) vulnerability. Only
use <aura:unescapedHtml> with trusted or sanitized sources of data.
222
Reference
force:canvasApp
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
value
String
force:canvasApp
Enables you to include a Force.com Canvas app in a Lightning component.
A force:canvasApp component represents a canvas app that's embedded in your Lightning component. You can create a web
app in the language of your choice and expose it in Salesforce as a canvas app. Use the Canvas App Previewer to test and debug the
canvas app before embedding it in a Lightning component.
If you have a namespace prefix, specify it using the namespacePrefix attribute. Either the developerName or
applicationName attribute is required. This example embeds a canvas app in a Lightning component.
<aura:component>
<force:canvasApp developerName="MyCanvasApp" namespacePrefix="myNamespace" />
</aura:component />
For more information on building canvas apps, see the Force.com Canvas Developer's Guide.
Attributes
Attribute Name
Attribute Type
applicationName String
Description
Required?
body
Component[]
border
String
canvasId
String
An unique label within a page for the Canvas app window. This should
be used when targeting events to this canvas app.
containerId
String
developerName
String
Developer name of the canvas app. This name is defined when the canvas
app is created and can be viewed in the Canvas App Previewer. Either
developerName or applicationName is required.
displayLocation String
The location in the application where the canvas app is currently being
called from.
String
Canvas app window height, in pixels. If not specified, defaults to 900 px.
height
223
Reference
force:inputField
Attribute Name
Attribute Type
Description
Required?
maxHeight
String
maxWidth
String
namespacePrefix String
onCanvasAppError String
onCanvasAppLoad String
Name of the JavaScript function to be called after the canvas app loads.
onCanvasSubscribed String
Name of the JavaScript function to be called after the canvas app registers
with the parent.
parameters
String
referenceId
String
scrolling
String
sublocation
String
The sublocation is the location in the application where the canvas app
is currently being called from, for ex, displayLocation can be PageLayout
and sublocation can be S1MobileCardPreview or S1MobileCardFullview,
etc
title
String
watermark
Boolean
width
String
Canvas app window width, in pixels. If not specified, defaults to 800 px.
force:inputField
An abstract component that provides a concrete type-specific input component implementation based on the data to which it is bound.
Represents an input field that corresponds to a field on a Salesforce object. This component respects the attributes of the associated
field. For example, if the component is a number field with 2 decimal places, then the default input value contains the same number of
decimal places. Bind the field using the value attribute and provide a default value to initialize the object.
<aura:attribute name="contact" type="Contact"
default="{ 'sobjectType': 'Contact' }"/>
<force:inputField aura:id="contactName"
value="{!v.contact.Name}"/>
224
Reference
force:outputField
Use a different input component such as ui:inputText if you're working with user input that does not correspond to a field on a
Salesforce object.
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
errorComponent Component[]
Required?
required
Boolean
value
Object
Events
Event Name
Event Type
Description
change
COMPONENT
force:outputField
An abstract component that provides a concrete type-specific output component implementation based on the data to which it is
bound.
Represents a read-only display of a value for a field on a Salesforce object. This component respects the attributes of the associated field
and how it should be displayed. For example, if the component contains a date and time value, then the default output value contains
the date and time in the user's locale. Bind the field using the value attribute and provide a default value to initialize the object.
<aura:attribute name="contact" type="Contact"
default="{ 'sobjectType': 'Contact'}"/>
<force:outputField aura:id="contactName"
value="{!v.contact.Name}"/>
Use a different output component such as ui:outputText if you're working with user input that does not correspond to a field on
a Salesforce object.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
225
Reference
force:recordEdit
Attribute Name
Attribute Type
Description
Required?
value
Object
force:recordEdit
Generates an editable view of the specified Salesforce record.
A force:recordEdit component represents the record edit UI for the specified recordId. This example displays the record
edit UI and a button, which when pressed saves the record.
<force:recordEdit aura:id="edit" recordId="a02D0000006V8Ni"/>
<ui:button label="Save" press="{!c.save}"/>
This client-side controller fires the recordSave event, which saves the record.
save : function(component, event, helper) {
component.find("edit").get("e.recordSave").fire();
}
You can provide a dynamic ID for the recordId attribute using the format {!v.myObject.recordId}. Make sure you have
wired up the container component to an Apex controller that returns the object data using the @AuraEnabled syntax.
To indicate that the record has been successfully saved, handle the force:recordSaveSuccess event.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
recordId
String
Events
Event Name
Event Type
Description
recordSave
COMPONENT
recordSaveSuccess COMPONENT
force:recordView
Generates a view of the specified Salesforce record.
A force:recordView component represents a read-only view of a record. You can display the record view using different layout
types. By default, the record view uses the full layout to display all fields of the record. The mini layout displays the name field and any
associated parent record field. This example shows a record view with a mini layout.
<force:recordView recordId="a02D0000006V8Ov" type="MINI"/>
226
Reference
forceChatter:feed
You can provide a dynamic ID for the recordId attribute using the format {!v.myObject.recordId}. Make sure you have
wired up the container component to an Apex controller that returns the object data using the @AuraEnabled syntax.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
record
SObjectRow
recordId
String
type
String
The type of layout to use to display the record. Possible values: FULL,
MINI. The default is FULL.
forceChatter:feed
Represents a Chatter Feed
A forceChatter:feed component represents a feed that's specified by its type. Use the type attribute to display a specific feed
type. For example, set type="groups" to display the feed from all groups the context user either owns or is a member of.
<aura:component implements="force:appHostable">
<forceChatter:feed type="groups"/>
</aura:component>
You can also display a feed depending on the type selected. This example provides a drop-down menu that controls the type of feed
to display.
<aura:component implements="force:appHostable">
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<aura:attribute name="type" type="String" default="News" description="The type of feed"
access="GLOBAL"/>
<aura:attribute name="types" type="String[]"
default="Bookmarks,Company,Files,Groups,Home,News,People"
description="A list of feed types"/>
<h1>My Feeds</h1>
<ui:inputSelect aura:id="typeSelect" change="{!c.onChangeType}" label="Type"/>
<div aura:id="feedContainer" class="feed-container">
<forceChatter:feed />
</div>
</aura:component>
The types attribute specifies the feed types, which are set on the ui:inputSelect component during component initialization.
When a user selects a feed type, the feed is dynamically created and displayed.
({
// Handle component initialization
doInit : function(component, event, helper) {
var type = component.get("v.type");
var types = component.get("v.types");
var typeOpts = new Array();
227
Reference
ltng:require
The feed is supported for Salesforce1 only. You can include the feed in a component and access it in the Salesforce1 app. For a list of
feed types, see the Chatter REST API Developer's Guide.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
subjectId
String
For most feeds tied to an entity, this is used specified the desired entity.
Defaults to the current user if not specified
type
String
The strategy used to find items associated with the subject. Valid values
include: News, Home, Record, To.
ltng:require
Loads scripts and stylesheets while maintaining dependency order. The styles are loaded in the order that they are listed. The styles only
load once if they are specified in multiple <ltng:require> tags in the same component or across different components.
ltng:require enables you to load external CSS and JavaScript libraries after you upload them as static resources.
<ltng:require scripts="/resource/jsLibOne,/resource/jsLibTwo"
styles="/resource/cssOne,/resource/cssTwo"
afterScriptsLoaded="{!c.afterScriptsLoaded}"/>
The comma-separated lists of resources are loaded in the order that they are entered in the scripts and styles attributes. The
afterScriptsLoaded action in the client-side controller is called after the scripts are loaded. To ensure encapsulation and
reusability, add the <ltng:require> tag to every .cmp or .app resource that uses the CSS or JavaScript library.
228
Reference
ui:actionMenuItem
The resources only load once if they are specified in multiple <ltng:require> tags in the same component or across different
components.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
scripts
String[]
styles
String[]
Events
Event Name
Event Type
Description
afterScriptsLoaded COMPONENT
beforeLoadingResources COMPONENT
ui:actionMenuItem
A menu item that triggers an action. This component is nested in a ui:menu component.
A ui:actionMenuItem component represents a menu list item that triggers an action when clicked. Use aura:iteration
to iterate over a list of values and display the menu items. A ui:menuTriggerLink component displays and hides your menu
items.
<aura:attribute name="status" type="String[]" default="Open, Closed, Closed Won, Any"/>
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Opportunity Status"/>
<ui:menuList class="actionMenu" aura:id="actionMenu">
<aura:iteration items="{!v.status}" var="s">
<ui:actionMenuItem label="{!s}" click="{!c.doSomething}"/>
</aura:iteration>
</ui:menuList>
</ui:menu>
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
229
Reference
ui:button
Attribute Name
Attribute Type
Description
disabled
Boolean
hideMenuAfterSelected Boolean
Required?
label
String
selected
Boolean
The status of the menu item. True means this menu item is selected;
False is not selected.
type
String
The concrete type of the menu item. Accepted values are 'action',
'checkbox', 'radio', 'separator' or any namespaced component descriptor,
e.g. ns:xxxxmenuItem.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
ui:button
Represents a button element.
A ui:button component represents a button element that executes an action defined by a controller. Clicking the button triggers
the client-side controller method set for the press event. The button can be created in several ways.
A text-only button has only the required label attribute set on it.
<ui:button label="Find"/>
230
Reference
ui:button
An image-only button uses both the label and labelClass attributes with CSS.
<!-- Component markup -->
<ui:button label="Find" labelClass="assistiveText" class="img" />
/** CSS **/
THIS.uiButton.img {
background: url(/https/www.scribd.com/path/to/img) no-repeat;
width:50px;
height:25px;
}
The assistiveText class hides the label from view but makes it available to assistive technologies. To create a button with both
image and text, use the label attribute and add styles for the button.
<!-- Component markup -->
<ui:button label="Find" />
/** CSS **/
THIS.uiButton {
background: url(/https/www.scribd.com/path/to/img) no-repeat;
}
The previous markup for a button with text and image results in the following HTML.
<button class="button uiButton--default uiButton" accesskey type="button">
<span class="label bBody truncate" dir="ltr">Find</span>
</button>
This example shows a button that displays the input value you enter.
<aura:component access="global">
<ui:inputText aura:id="name" label="Enter Name:" placeholder="Your Name" />
<ui:button aura:id="button" buttonTitle="Click to see what you put into the field"
class="button" label="Click me" press="{!c.getInput}"/>
<ui:outputText aura:id="outName" value="" class="text"/>
</aura:component>
({
getInput : function(cmp, evt) {
var myName = cmp.find("name").get("v.value");
var myText = cmp.find("outName");
var greet = "Hi, " + myName;
myText.set("v.value", greet);
}
})
231
Reference
ui:checkboxMenuItem
Attributes
Attribute Name
Attribute Type
Description
Required?
accesskey
String
The keyboard access key that puts the button in focus. When the button
is in focus, pressing Enter clicks the button.
body
Component[]
buttonTitle
String
The text displayed in a tooltip when the mouse pointer hovers over the
button.
buttonType
String
Specifies the type attribute in the HTML input element. Default value is
"button".
class
String
disabled
Boolean
label
String
The text displayed on the button. Corresponds to the value attribute of Yes
the rendered HTML input element.
labelClass
String
Events
Event Name
Event Type
Description
press
COMPONENT
ui:checkboxMenuItem
A menu item with a checkbox that supports multiple selection and can be used to invoke an action. This component is nested in a
ui:menu component.
A ui:checkboxMenuItem component represents a menu list item that enables multiple selection. Use aura:iteration to
iterate over a list of values and display the menu items. A ui:menuTriggerLink component displays and hides your menu items.
<aura:attribute name="status" type="String[]" default="Open, Closed, Closed Won, Any"/>
<ui:menu>
<ui:menuTriggerLink aura:id="checkboxMenuLabel" label="Multiple selection"/>
<ui:menuList aura:id="checkboxMenu" class="checkboxMenu">
<aura:iteration items="{!v.status}" var="s">
<ui:checkboxMenuItem label="{!s}"/>
</aura:iteration>
</ui:menuList>
</ui:menu>
232
Reference
ui:checkboxMenuItem
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
hideMenuAfterSelected Boolean
Required?
label
String
selected
Boolean
The status of the menu item. True means this menu item is selected;
False is not selected.
type
String
The concrete type of the menu item. Accepted values are 'action',
'checkbox', 'radio', 'separator' or any namespaced component descriptor,
e.g. ns:xxxxmenuItem.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
233
Reference
ui:inputCheckbox
ui:inputCheckbox
Represents a checkbox. Its behavior can be configured using events such as click and change.
A ui:inputCheckbox component represents a checkbox whose state is controlled by the value and disabled attributes.
It's rendered as an HTML input tag of type checkbox. To render the output from a ui:inputCheckbox component, use the
ui:outputCheckbox component.
This is a basic set up of a checkbox.
<ui:inputCheckbox label="Reimbursed?"/>
The value attribute controls the state of a checkbox, and events such as click and change determine its behavior. This example
updates the checkbox CSS class on a click event.
<!-- Component Markup -->
<ui:inputCheckbox label="Color me" click="{!c.update}"/>
/** Client-Side Controller **/
update : function (cmp, event) {
$A.util.toggleClass(event.getSource(), "red");
}
({
onCheck: function(cmp, evt) {
var checkCmp = cmp.find("checkbox");
resultCmp = cmp.find("checkResult");
resultCmp.set("v.value", ""+checkCmp.get("v.value"));
}
})
234
Reference
ui:inputCheckbox
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
name
String
required
Boolean
requiredIndicatorClass String
Required?
text
String
updateOn
String
value
Boolean
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
235
Reference
ui:inputCurrency
Event Name
Event Type
Description
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputCurrency
An input field for entering a currency.
A ui:inputCurrency component represents an input field for a number as a currency, which is rendered as an HTML input
tag of type text. The browser's locale is used by default. To render the output from a ui:inputCurrency component, use the
ui:outputCurrency component.
This is a basic set up of a ui:inputCurrency component, which renders an input field with the value $50.00 when the browser's
currency locale is $.
<ui:inputCurrency aura:id="amount" label="Amount" class="field" value="50"/>
To override the browser's locale, set the new format on the v.format attribute of the ui:inputCurrency component. This
example renders an input field with the value 50.00.
var curr = component.find("amount");
curr.set("v.format", '#,###.00');
This example retrieves the value of a ui:inputCurrency component and displays it using ui:outputCurrency.
<aura:component>
<ui:inputCurrency aura:id="amount" label="Amount" class="field" value="50"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputCurrency aura:id="oCurrency" value=""/>
236
Reference
ui:inputCurrency
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var amount = component.find("amount").get("v.value");
var oCurrency = component.find("oCurrency");
oCurrency.set("v.value", amount);
}
})
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
format
String
The format of the number. For example, format=.00 displays the number
followed by two decimal places. If not specified, the Locale default format
will be used.
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
Required?
size
Integer
updateOn
String
value
BigDecimal
237
Reference
ui:inputDate
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputDate
An input field for entering a date.
A ui:inputDate component represents a date input field, which is rendered as an HTML input tag of type text. The value is
displayed in the default format specified language locale of the browser.
This is a basic set up of a date field with a date picker, which displays the field value 1/30/2014. Specifying format="MMMM d,
yyyy" renders the field value as January 30, 2014.
<ui:inputDate aura:id="dateField" label="Birthday" value="2014-01-30"
displayDatePicker="true"/>
238
Reference
ui:inputDate
<span>Birthday</span>
</label>
<form class="form--stacked form-element">
<input placeholder="MMM d, yyyy" type="text">
<a class="datePicker-openIcon display" aria-haspopup="true">
<span class="assistiveText">Date Picker</span>
</a>
<a class="clearIcon hide">
<span class="assistiveText">Clear Button</span>
</a>
</form>
</div>
<div class="DESKTOP uiDatePicker--default uiDatePicker">
<!--Date picker set to visible when icon is clicked-->
</div>
On desktop, the input tag is wrapped in a form tag. The form factor (DESKTOP, MOBILE, or PHONE) determines the dimensions of
the date picker.
This example sets today's date on a ui:inputDate component, retrieves its value, and displays it using ui:outputDate. The
init handler initializes and sets the date on the component.
<aura:component>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<aura:attribute name="today" type="Date" default=""/>
<ui:inputDate aura:id="expdate" label="Today's Date" class="field" value="{!v.today}"
displayDatePicker="true" />
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputDate aura:id="oDate" value="" />
</div>
</aura:component>
({
doInit : function(component, event, helper) {
var today = new Date();
component.set('v.today', today.getFullYear() + "-" + (today.getMonth() + 1) + "-"
+ today.getDate());
component.set('v.deadline', today);
},
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var expdate = component.find("expdate").get("v.value");
var oDate = component.find("oDate");
oDate.set("v.value", expdate);
}
})
239
Reference
ui:inputDate
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
displayDatePicker Boolean
Required?
format
String
label
String
labelClass
String
langLocale
String
required
Boolean
requiredIndicatorClass String
updateOn
String
value
Date
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
240
Reference
ui:inputDateTime
Event Name
Event Type
Description
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputDateTime
An input field for entering a date and time.
A ui:inputDateTime component represents a date and time input field, which is rendered as an HTML input tag of type text.
The value is displayed in the default format specified by the language locale of the browser.
This is a basic set up of a date and time field with a date picker, which displays the current date and time in the format 7/29/2014
1:11 PM.
<!-- Component markup -->
<aura:attribute name="today" type="DateTime" />
<ui:inputDateTime aura:id="expdate" label="Expense Date" class="form-control"
value="{!v.today}" displayDatePicker="true" />
/** Client-Side Controller **/
var today = new Date();
component.set("v.today", today);
241
Reference
ui:inputDateTime
On desktop, the input tag is wrapped in a form tag; the date and time fields display as two separate fields. The form factor (DESKTOP,
MOBILE, or PHONE) determines the dimensions of the date picker. The time picker displays a list of time in 30-minute increments.
This example retrieves the value of a ui:inputDateTime component and displays it using ui:outputDateTime.
<aura:component>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<aura:attribute name="today" type="Date" default=""/>
<ui:inputDateTime aura:id="today" label="Time" class="field" value=""
displayDatePicker="true" />
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputDateTime aura:id="oDateTime" value=""
</div>
</aura:component>
/>
({
doInit : function(component, event, helper) {
var today = new Date();
component.set('v.today', today.getFullYear() + "-" + (today.getMonth() + 1) + "-"
+ today.getDate());
},
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var todayVal = component.find("today").get("v.value");
var oDateTime = component.find("oDateTime");
oDateTime.set("v.value", todayVal);
}
})
242
Reference
ui:inputDateTime
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
displayDatePicker Boolean
Required?
format
String
label
String
labelClass
String
langLocale
String
required
Boolean
requiredIndicatorClass String
updateOn
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
243
Reference
ui:inputDefaultError
Event Name
Event Type
Description
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputDefaultError
The default implementation of field-level errors, which iterates over the value and displays the message.
ui:inputDefaultError is the default error handling for your input components. This component displays as a list of errors below
the field. Field-level error messages can be added using set("v.errors"). You can use the error atribute to show the error message.
Alternatively, you can provide your own ui:inputDefaultError component. This example returns an error message if the
warnings attribute contains any messages.
<aura:component>
<aura:attribute name="warnings" type="String[]" description="Warnings for input
text"/>
Enter a number: <ui:inputNumber aura:id="inputCmp" label="number"/>
<ui:button label="Submit" press="{!c.doAction}"/>
<ui:inputDefaultError aura:id="number" value="{!v.warnings}" />
</aura:component>
244
Reference
ui:inputDefaultError
This client-side controller diplays an error by adding a string to the warnings attribute.
doAction : function(component, event) {
var inputCmp = component.find("inputCmp");
var value = inputCmp.get("v.value");
// is input numeric?
if (isNaN(value)) {
component.set("v.warnings", "Input is not a number");
} else {
// clear error
component.set("v.warnings", null);
}
}
This example shows a ui:inputText component with the default error handling, and a corresponding ui:outputText
component for text rendering.
<aura:component>
<ui:inputText aura:id="color" label="Enter some text: " placeholder="Blue" />
<ui:button label="Validate" press="{!c.checkInput}" />
<ui:outputText aura:id="outColor" value="" class="text"/>
</aura:component>
({
checkInput : function(cmp) {
var colorCmp = cmp.find("color");
var myColor = colorCmp.get("v.value");
var myOutput = cmp.find("outColor");
var greet = "You entered: " + myColor;
myOutput.set("v.value", greet);
if (!myColor) {
colorCmp.set("v.errors", [{message:"Enter some text"}]);
}
else {
colorCmp.set("v.errors", null);
}
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
245
Reference
ui:inputEmail
Attribute Name
Attribute Type
Description
Required?
value
String[]
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:inputEmail
Represents an input field for entering an email address.
A ui:inputEmail component represents an email input field, which is rendered as an HTML input tag of type email. To
render the output from a ui:inputEmail component, use the ui:outputEmail component.
This is a basic set up of an email field.
<ui:inputEmail aura:id="email" label="Email" placeholder="[email protected]"/>
This example retrieves the value of a ui:inputEmail component and displays it using ui:outputEmail.
<aura:component>
<ui:inputEmail aura:id="email" label="Email" class="field" value="[email protected]"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
246
Reference
ui:inputEmail
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var email = component.find("email").get("v.value");
var oEmail = component.find("oEmail");
oEmail.set("v.value", email);
}
})
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
Required?
size
Integer
updateOn
String
value
String
247
Reference
ui:inputNumber
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputNumber
An input field for entering a number, taking advantage of client input assistance and validation when available.
A ui:inputNumber component represents a number input field, which is rendered as an HTML input tag of type text. This
example shows a number field, which displays a value of 10.
<aura:attribute name="num" type="integer" default="10"/>
<ui:inputNumber aura:id="num" label="Age" value="{!v.num}"/>
248
Reference
ui:inputNumber
To render the output from a ui:inputNumber component, use the ui:inputNumber component. When providing a number
value with commas, use type="integer". This example returns 100,000.
<aura:attribute name="number" type="integer" default="100,000"/>
<ui:inputNumber label="Number" value="{!v.number}"/>
For type="string", provide the number without commas for the output to be formatted accordingly. This example also returns
100,000.
<aura:attribute name="number" type="string" default="100000"/>
<ui:inputNumber label="Number" value="{!v.number}"/>
This example retrieves the value of a ui:inputNumber component, validates the input, and displays it using ui:outputNumber.
<aura:component>
<ui:inputNumber aura:id="inputCmp" label="Enter a number: "/> <br/>
<ui:button label="Submit" press="{!c.validate}"/>
<ui:outputNumber aura:id="outNum" value=""/>
</aura:component>
({
validate : function(component, evt) {
var inputCmp = component.find("inputCmp");
var value = inputCmp.get("v.value");
var myOutput = component.find("outNum");
myOutput.set("v.value", value);
// Check if input is numeric
if (isNaN(value)) {
inputCmp.set("v.errors", [{message:"Input not a number: " + value}]);
} else {
inputCmp.set("v.errors", null);
}
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
249
Reference
ui:inputNumber
Attribute Name
Attribute Type
Description
class
String
disabled
Boolean
format
String
The format of the number. For example, format=.00 displays the number
followed by two decimal places. If not specified, the Locale default format
will be used.
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
Required?
size
Integer
updateOn
String
value
BigDecimal
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
250
Reference
ui:inputPhone
Event Name
Event Type
Description
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputPhone
Represents an input field for entering a telephone number.
A ui:inputPhone component represents an input field for entering a phone number, which is rendered as an HTML input tag
of type tel. To render the output from a ui:inputPhone component, use the ui:outputPhone component.
This example shows a phone field, which displays the specified phone number.
<ui:inputPhone label="Phone" value="415-123-4567" />
This example retrieves the value of a ui:inputPhone component and displays it using ui:outputPhone.
<aura:component>
<ui:inputPhone aura:id="phone" label="Phone Number" class="field" value="415-123-4567"
/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputPhone aura:id="oPhone" value="" />
251
Reference
ui:inputPhone
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var phone = component.find("phone").get("v.value");
var oPhone = component.find("oPhone");
oPhone.set("v.value", phone);
}
})
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
Required?
size
Integer
updateOn
String
value
String
252
Reference
ui:inputRadio
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputRadio
The radio button used in the input.
A ui:inputRadio component represents a radio button whose state is controlled by the value and disabled attributes. It's
rendered as an HTML input tag of type radio. To group your radio buttons together, specify the name attribute with a unique
name.
This is a basic set up of a radio button.
<ui:inputRadio label="Yes"/>
253
Reference
ui:inputRadio
</label>
<input type="radio">
</div>
({
onRadio: function(cmp, evt) {
var elem = evt.getSource().getElement();
var selected = elem.textContent;
resultCmp = cmp.find("radioResult");
resultCmp.set("v.value", selected);
},
onGroup: function(cmp, evt) {
var elem = evt.getSource().getElement();
var selected = elem.textContent;
resultCmp = cmp.find("radioGroupResult");
resultCmp.set("v.value", selected);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
254
Reference
ui:inputRadio
Attribute Name
Attribute Type
Description
disabled
Boolean
label
String
labelClass
String
name
String
required
Boolean
requiredIndicatorClass String
Required?
text
String
updateOn
String
value
Boolean
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
255
Reference
ui:inputRichText
Event Name
Event Type
Description
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputRichText
An input field for entering rich text.
By default, ui:inputRichText renders a WYSIWYG editor for entering rich text. Setting isRichText="false" uses the
ui:inputTextArea component instead of a WYSIWYG editor. The placeholder attribute is supported only when you set
isRichText="false".
<ui:inputRichText aura:id="inputRT" label="Rich text demo with basic toolbar" />
Tags such as <script> are removed from the component. A list of supported HTML tags is available in the JavaScript helper of the
ui:outputRichText component.
This example retrieves the value of a ui:inputRichText component and displays it using ui:outputRichText.
<aura:component>
<ui:inputRichText aura:id="inputRT" label="Rich Text Demo"
value="<script>test</script> <b>rich text</b>" />
<ui:button aura:id="outputButton" buttonTitle="Click to see what you put into the rich
text field" label="Display" press="{!c.getInput}"/>
<ui:outputRichText aura:id="outputRT"/>
</aura:component>
({
getInput : function(cmp) {
var userInput = cmp.find("inputRT").get("v.value");
var output = cmp.find("outputRT");
output.set("v.value", userInput);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
cols
Integer
The width of the text area, which is defined by the number of characters
to display in a single row at a time. Default value is 20.
256
Reference
ui:inputRichText
Attribute Name
Attribute Type
Description
disabled
Boolean
height
String
The height of the editing area (that includes the editor content). This can
be an integer, for pixel sizes, or any CSS-defined length unit.
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML
textarea element.
placeholder
String
readonly
Boolean
required
Boolean
requiredIndicatorClass String
Required?
resizable
Boolean
rows
Integer
The height of the text area, which is defined by the number of rows to
display at a time. Default value is 2.
updateOn
String
value
String
width
String
The editor UI outer width. This can be an integer, for pixel sizes, or any
CSS-defined unit. If isRichText is set to false, use the cols attribute instead.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
257
Reference
ui:inputSecret
Event Name
Event Type
Description
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputSecret
An input field for entering secret text with type password.
A ui:inputSecret component represents a password field, which is rendered as an HTML input tag of type password.
This is a basic set up of a password field.
<ui:inputSecret aura:id="secret" label="Pin" class="field" value="123456"/>
258
Reference
ui:inputSecret
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
Required?
size
Integer
updateOn
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
259
Reference
ui:inputSelect
Event Name
Event Type
Description
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputSelect
Represents a drop-down list with options.
A ui:inputSelect component is rendered as an HTML select element. It contains options, represented by the
ui:inputSelectOption components. To enable multiple selections, set multiple="true". To wire up any client-side logic
when an input value is selected, use the change event.
<ui:inputSelect multiple="true">
<ui:inputSelectOption text="All Primary" label="All Contacts" value="true"/>
<ui:inputSelectOption text="All Primary" label="All Primary"/>
<ui:inputSelectOption text="All Secondary" label="All Secondary"/>
</ui:inputSelect>
When the selected option changes, this client-side controller retrieves the new text value.
onSelectChange : function(component, event, helper) {
var selected = component.find("levels").get("v.value");
260
Reference
ui:inputSelect
The following client-side controller generates options using the options attribute on the ui:inputSelect component. v.options
takes in the list of objects and converts them into list options. The opts object constructs InputOption objects to create the
ui:inputSelectOptions components within ui:inputSelect. Although the sample code generates the options during
initialization, the list of options can be modified anytime when you manipulate the list in v.options. The component automatically
updates itself and rerenders with the new options.
({
doInit : function(cmp) {
var opts = [
{ class: "optionClass", label: "Option1", value: "opt1", selected: "true" },
{ class: "optionClass", label: "Option2", value: "opt2" },
{ class: "optionClass", label: "Option3", value: "opt3" }
];
cmp.find("InputSelectDynamic").set("v.options", opts);
}
})
class is a reserved keyword that might not work with older versions of Internet Explorer. We recommend using "class" with
double quotes.
This example displays a drop-down list with single and multiple selection enabled, and another with dynamically generated list options.
It retrieves the selected value of a ui:inputSelect component.
<aura:component>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<div class="row">
<p class="title">Single Selection</p>
<ui:inputSelect class="single" aura:id="InputSelectSingle"
change="{!c.onSingleSelectChange}">
<ui:inputSelectOption text="Any"/>
<ui:inputSelectOption text="Open" value="true"/>
<ui:inputSelectOption text="Closed"/>
<ui:inputSelectOption text="Closed Won"/>
<ui:inputSelectOption text="Prospecting"/>
<ui:inputSelectOption text="Qualification"/>
<ui:inputSelectOption text="Needs Analysis"/>
<ui:inputSelectOption text="Closed Lost"/>
261
Reference
ui:inputSelect
</ui:inputSelect>
<p>Selected Item:</p>
<p><ui:outputText class="result" aura:id="singleResult" value="" /></p>
</div>
<div class="row">
<p class="title">Multiple Selection</p>
<ui:inputSelect multiple="true" class="multiple" aura:id="InputSelectMultiple"
change="{!c.onMultiSelectChange}">
<ui:inputSelectOption
<ui:inputSelectOption
<ui:inputSelectOption
<ui:inputSelectOption
<ui:inputSelectOption
<ui:inputSelectOption
<ui:inputSelectOption
<ui:inputSelectOption
text="Any"/>
text="Open"/>
text="Closed"/>
text="Closed Won"/>
text="Prospecting"/>
text="Qualification"/>
text="Needs Analysis"/>
text="Closed Lost"/>
</ui:inputSelect>
<p>Selected Items:</p>
<p><ui:outputText class="result" aura:id="multiResult" value="" /></p>
</div>
<div class="row">
<p class="title">Dynamic Option Generation</p>
<ui:inputSelect label="Select me: " class="dynamic" aura:id="InputSelectDynamic"
change="{!c.onChange}" />
<p>Selected Items:</p>
<p><ui:outputText class="result" aura:id="dynamicResult" value="" /></p>
</div>
</aura:component>
({
doInit : function(cmp) {
// Initialize input select options
var opts = [
{ "class": "optionClass", label: "Option1", value: "opt1", selected: "true"
},
{ "class": "optionClass", label: "Option2", value: "opt2" },
{ "class": "optionClass", label: "Option3", value: "opt3" }
];
cmp.find("InputSelectDynamic").set("v.options", opts);
},
onSingleSelectChange: function(cmp) {
var selectCmp = cmp.find("InputSelectSingle");
var resultCmp = cmp.find("singleResult");
resultCmp.set("v.value", selectCmp.get("v.value"));
},
262
Reference
ui:inputSelect
onMultiSelectChange: function(cmp) {
var selectCmp = cmp.find("InputSelectMultiple");
var resultCmp = cmp.find("multiResult");
resultCmp.set("v.value", selectCmp.get("v.value"));
},
onChange: function(cmp) {
var dynamicCmp = cmp.find("InputSelectDynamic");
var resultCmp = cmp.find("dynamicResult");
resultCmp.set("v.value", dynamicCmp.get("v.value"));
}
})
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
multiple
Boolean
options
List
A list of aura.components.ui.InputOption.
required
Boolean
requiredIndicatorClass String
Required?
updateOn
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
263
Reference
ui:inputSelectOption
Event Name
Event Type
Description
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputSelectOption
An HTML option element that is nested in a ui:inputSelect component. Denotes the available options in the list.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
disabled
Boolean
label
String
name
String
text
String
264
Reference
ui:inputText
Attribute Name
Attribute Type
Description
Required?
value
Boolean
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
ui:inputText
Represents an input field suitable for entering a single line of free-form text.
A ui:inputText component represents a text input field, which is rendered as an HTML input tag of type text. To render the
output from a ui:inputText component, use the ui:outputText component.
This is a basic set up of a text field.
<ui:inputText label="Expense Name" value="My Expense" required="true"/>
265
Reference
ui:inputText
This example retrieves the value of a ui:inputText component and displays it using ui:outputText.
<aura:component>
<ui:inputText aura:id="name" label="Enter some text" class="field" value="My Text"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputText aura:id="oName" value=""/>
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var name = component.find("name").get("v.value");
var oName = component.find("oName");
oName.set("v.value", name);
}
})
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
size
Integer
Required?
266
Reference
ui:inputTextArea
Attribute Name
Attribute Type
Description
Required?
updateOn
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputTextArea
An HTML textarea element that can be editable or read-only. Scroll bars may not appear on Chrome browsers in Android devices, but
you can select focus in the textarea to activate scrolling.
A ui:inputTextArea component represents a multi-line text input control, which is rendered as an HTML textarea tag. To
render the output from a ui:inputTextArea component, use the ui:outputTextArea component.
267
Reference
ui:inputTextArea
This example retrieves the value of a ui:inputTextArea component and displays it using ui:outputTextArea.
<aura:component>
<ui:inputTextArea aura:id="comments" label="Comments"
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var comments = component.find("comments").get("v.value");
var oTextarea = component.find("oTextarea");
oTextarea.set("v.value", comments);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
cols
Integer
The width of the text area, which is defined by the number of characters
to display in a single row at a time. Default value is 20.
disabled
Boolean
268
Reference
ui:inputTextArea
Attribute Name
Attribute Type
Description
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML
textarea element.
placeholder
String
readonly
Boolean
required
Boolean
requiredIndicatorClass String
Required?
resizable
Boolean
rows
Integer
The height of the text area, which is defined by the number of rows to
display at a time. Default value is 2.
updateOn
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
269
Reference
ui:inputURL
Event Name
Event Type
Description
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:inputURL
An input field for entering a URL.
A ui:inputURL component represents an input field for a URL, which is rendered as an HTML input tag of type url. To render
the output from a ui:inputURL component, use the ui:outputURL component.
This is a basic set up of a ui:inputURL component.
<ui:inputURL aura:id="url" label="Venue URL" class="field" value="http://www.myURL.com"/>
This example retrieves the value of a ui:inputURL component and displays it using ui:outputURL.
<aura:component>
<ui:inputURL aura:id="url" label="Venue URL" class="field" value="http://www.myURL.com"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputURL aura:id="oURL" value=""/>
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var url = component.find("url").get("v.value");
var oURL = component.find("oURL");
oURL.set("v.value", url);
270
Reference
ui:inputURL
oURL.set("v.label", url);
}
})
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
label
String
labelClass
String
maxlength
Integer
The maximum number of characters that can be typed into the input
field. Corresponds to the maxlength attribute of the rendered HTML input
element.
placeholder
String
Text that is displayed when the field is empty, to prompt the user for a
valid entry.
required
Boolean
requiredIndicatorClass String
Required?
size
Integer
updateOn
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
271
Reference
ui:menu
Event Name
Event Type
Description
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
cut
COMPONENT
validationError
COMPONENT
clearErrors
COMPONENT
change
COMPONENT
copy
COMPONENT
paste
COMPONENT
Indicates that the user has pasted content from the clipboard.
ui:menu
A dropdown menu list with a trigger that controls its visibility. Need to provide a menuTriggerLink and menuList component.
A ui:menu component contains a trigger and list items. You can wire up list items to actions in a client-side controller so that selection
of the item triggers an action. This example shows a menu with list items, which when pressed updates the label on the trigger.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Opportunity Status"/>
<ui:menuList class="actionMenu" aura:id="actionMenu">
<ui:actionMenuItem aura:id="item1" label="Any"
click="{!c.updateTriggerLabel}"/>
<ui:actionMenuItem aura:id="item2" label="Open" click="{!c.updateTriggerLabel}"
disabled="true"/>
<ui:actionMenuItem aura:id="item3" label="Closed"
click="{!c.updateTriggerLabel}"/>
<ui:actionMenuItem aura:id="item4" label="Closed Won"
click="{!c.updateTriggerLabel}"/>
</ui:menuList>
</ui:menu>
This client-side controller updates the trigger label when a menu item is clicked.
({
updateTriggerLabel: function(cmp, event) {
var triggerCmp = cmp.find("trigger");
if (triggerCmp) {
272
Reference
ui:menu
The dropdown menu and its menu items are hidden by default. You can change this by setting the visible attribute on the
ui:menuList component to true. The menu items are shown only when you click the ui:menuTriggerLink component.
To use a trigger, which opens the menu, nest the ui:menuTriggerLink component in ui:menu. For list items, use the
ui:menuList component, and include any of these list item components that can trigger a client-side controller action:
ui:actionMenuItem - A menu item
ui:checkboxMenuItem - A checkbox that supports multiple selections
ui:radioMenuItem - A radio item that supports single selection
To include a separator for these menu items, use ui:menuItemSeparator.
This example shows several ways to create a menu.
<aura:component access="global">
<aura:attribute name="status" type="String[]" default="Open, Closed, Closed Won, Any"/>
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Single selection with actionable
menu item"/>
<ui:menuList class="actionMenu" aura:id="actionMenu">
<aura:iteration items="{!v.status}" var="s">
<ui:actionMenuItem label="{!s}" click="{!c.updateTriggerLabel}"/>
</aura:iteration>
</ui:menuList>
</ui:menu>
<hr/>
<ui:menu>
<ui:menuTriggerLink class="checkboxMenuLabel" aura:id="checkboxMenuLabel"
label="Multiple selection"/>
<ui:menuList aura:id="checkboxMenu" class="checkboxMenu">
<aura:iteration items="{!v.status}" var="s">
<ui:checkboxMenuItem label="{!s}"/>
</aura:iteration>
</ui:menuList>
</ui:menu>
<p><ui:button class="checkboxButton" aura:id="checkboxButton"
press="{!c.getMenuSelected}" label="Check the selected menu items"/></p>
<p><ui:outputText class="result" aura:id="result" value="Which items get
selected"/></p>
<hr/>
<ui:menu>
<ui:menuTriggerLink class="radioMenuLabel" aura:id="radioMenuLabel"
label="Select a status"/>
<ui:menuList class="radioMenu" aura:id="radioMenu">
<aura:iteration items="{!v.status}" var="s">
<ui:radioMenuItem label="{!s}"/>
</aura:iteration>
273
Reference
ui:menu
</ui:menuList>
</ui:menu>
<p><ui:button class="radioButton" aura:id="radioButton"
press="{!c.getRadioMenuSelected}" label="Check the selected menu items"/></p>
<p><ui:outputText class="radioResult" aura:id="radioResult" value="Which items
get selected"/> </p>
<hr/>
<div style="margin:20px;">
<div style="display:inline-block;width:50%;vertical-align:top;">
Combination menu items
<ui:menu>
<ui:menuTriggerLink aura:id="mytrigger" label="Select Menu Items"/>
<ui:menuList>
<ui:actionMenuItem label="Red" click="{!c.updateLabel}" disabled="true"/>
<ui:actionMenuItem label="Green" click="{!c.updateLabel}"/>
<ui:actionMenuItem label="Blue" click="{!c.updateLabel}"/>
<ui:actionMenuItem label="Yellow United" click="{!c.updateLabel}"/>
<ui:menuItemSeparator/>
<ui:checkboxMenuItem label="A"/>
<ui:checkboxMenuItem label="B"/>
<ui:checkboxMenuItem label="C"/>
<ui:checkboxMenuItem label="All"/>
<ui:menuItemSeparator/>
<ui:radioMenuItem label="A only"/>
<ui:radioMenuItem label="B only"/>
<ui:radioMenuItem label="C only"/>
<ui:radioMenuItem label="None"/>
</ui:menuList>
</ui:menu>
</div>
</div>
</aura:component>
({
updateTriggerLabel: function(cmp, event) {
var triggerCmp = cmp.find("trigger");
if (triggerCmp) {
var source = event.getSource();
var label = source.get("v.label");
triggerCmp.set("v.label", label);
}
},
updateLabel: function(cmp, event) {
var triggerCmp = cmp.find("mytrigger");
if (triggerCmp) {
var source = event.getSource();
var label = source.get("v.label");
triggerCmp.set("v.label", label);
}
},
getMenuSelected: function(cmp) {
var menuCmp = cmp.find("checkboxMenu");
274
Reference
ui:menu
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
275
Reference
ui:menuItem
ui:menuItem
An abstract component for menu items like ui:actionMenuItem, ui:checkboxMenuItem, and ui:radioMenuItem. Nest a menu item in a
ui:menuList component.
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
hideMenuAfterSelected Boolean
Required?
label
String
selected
Boolean
The status of the menu item. True means this menu item is selected;
False is not selected.
type
String
The concrete type of the menu item. Accepted values are 'action',
'checkbox', 'radio', 'separator' or any namespaced component descriptor,
e.g. ns:xxxxmenuItem.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
276
Reference
ui:menuItemSeparator
Event Name
Event Type
Description
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
ui:menuItemSeparator
A menu separator to divide menu items, such as ui:radioMenuItem, and used in a ui:menuList component.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:menuList
A menu component that contains menu items.
This component is nested in a ui:menu component and can be used together with a ui:menuTriggerLink component.
Clicking the menu trigger displays the container with menu items.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Click me
<ui:menuList class="actionMenu" aura:id="actionMenu">
<ui:actionMenuItem aura:id="item1" label="Item 1"
<ui:actionMenuItem aura:id="item2" label="Item 2"
<ui:actionMenuItem aura:id="item3" label="Item 3"
277
Reference
ui:menuList
ui:menuList can contain these components, which runs a client-side controller when clicked:
ui:actionMenuItem
ui:checkboxMenuItem
ui:radioMenuItem
ui:menuItemSeparator
See ui:menu for more information.
Attributes
Attribute Name
Attribute Type
Description
autoPosition
Boolean
Move the popup target up when there is not enough space at the bottom
to display. Note: even if autoPosition is set to false, popup will still position
the menu relative to the trigger. To override default positioning, use
manualPosition attribute.
body
Component[]
class
String
closeOnClickOutside Boolean
Required?
closeOnTabKey
Boolean
curtain
Boolean
menuItems
List
A list of menu items set explicitly using instances of the Java class: aura.
components.ui.MenuItem.
visible
Boolean
Controls the visibility of the menu. The default is false, which hides the
menu.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
278
Reference
ui:menuTrigger
Event Name
Event Type
Description
click
COMPONENT
mousedown
COMPONENT
expand
COMPONENT
menuSelect
COMPONENT
Indicates that the user selects a menu item inside a menu component.
collapse
COMPONENT
menuFocusChange
COMPONENT
Indicates that the user changes menu item focus inside a menu component.
ui:menuTrigger
A clickable link that expands and collapses a menu, used in a ui:menu component.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
disabled
Boolean
title
String
The text to display as a tooltip when the mouse pointer hovers over this
component.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
select
COMPONENT
279
Reference
ui:menuTriggerLink
Event Name
Event Type
Description
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
menuTriggerPress COMPONENT
ui:menuTriggerLink
A link that triggers a dropdown menu.
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
disabled
Boolean
label
String
title
String
The text to display as a tooltip when the mouse pointer hovers over this
component.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
280
Reference
ui:message
Event Name
Event Type
Description
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
menuTriggerPress COMPONENT
ui:message
Represents a message of varying severity levels
The severity attribute indicates a message's severity level and determines the style to use when displaying the message. If the
closable attribute is set to true, the message can be dismissed by pressing the symbol.
This example shows a confirmation message that can be dismissed.
<ui:message title="Confirmation" severity="confirm" closable="true">
This is a confirmation message.
</ui:message>
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
281
Reference
ui:outputCheckbox
Attribute Name
Attribute Type
Description
Required?
class
String
closable
Boolean
Specifies whether to display an 'x' that will close the alert when clicked.
Default value is 'false'.
severity
String
title
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputCheckbox
Displays a checkbox in a checked or unchecked state.
A ui:outputCheckbox component represents a checkbox that is rendered as an HTML img tag. This component can be used
with ui:inputCheckbox, which enables users to select or deselect the checkbox. To select or deselect the checkbox, set the
value attribute to true or false. To display a checkbox, you can use an attribute value and bind it to the ui:outputCheckbox
component.
<aura:attribute name="myBool" type="Boolean" default="true"/>
<ui:outputCheckbox value="{!v.myBool}"/>
This example shows how you can use the ui:inputCheckbox component.
<aura:component>
<aura:attribute name="myBool" type="Boolean" default="true"/>
<ui:inputCheckbox aura:id="checkbox" label="Select?" change="{!c.onCheck}"/>
<p>Selected:</p>
282
Reference
ui:outputCheckbox
({
onCheck: function(cmp, evt) {
var checkCmp = cmp.find("checkbox");
resultCmp = cmp.find("checkResult");
resultCmp.set("v.value", ""+checkCmp.get("v.value"));
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
altChecked
String
altUnchecked
String
body
Component[]
class
String
value
Boolean
Yes
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
283
Reference
ui:outputCurrency
ui:outputCurrency
Displays the currency in the default or specified format, such as with specific currency code or decimal places.
A ui:outputCurrency component represents a number as a currency that is wrapped in an HTML span tag. This component
can be used with ui:inputCurrency, which takes in a number as a currency. To display a currency, you can use an attribute value
and bind it to the ui:outputCurrency component.
<aura:attribute name="myCurr" type="Decimal" default="50000"/>
<ui:outputCurrency aura:id="curr" value="{!v.myCurr}"/>
This example shows how you can bind data from a ui:inputCurrency component.
<aura:component>
<ui:inputCurrency aura:id="amount" label="Amount" class="field" value="50"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputCurrency aura:id="oCurrency" value=""/>
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var amount = component.find("amount").get("v.value");
var oCurrency = component.find("oCurrency");
oCurrency.set("v.value", amount);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
284
Reference
ui:outputDate
Attribute Name
Attribute Type
Description
class
String
currencyCode
String
currencySymbol String
Required?
format
String
The format of the number. For example, format=.00 displays the number
followed by two decimal places. If not specified, the default format based
on the browser's locale will be used.
value
BigDecimal
Yes
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputDate
Displays a date in the default or specified format based on the user's locale.
A ui:outputDate component represents a date output in the YYYY-MM-DD format and is wrapped in an HTML span tag. This
component can be used with ui:inputDate, which takes in a date input. ui:outputDate retrieves the browser's locale
information and displays the date accordingly. To display a date, you can use an attribute value and bind it to the ui:outputDate
component.
<aura:attribute name="myDate" type="Date" default="2014-09-29"/>
<ui:outputDate value="{!v.myDate}"/>
This example shows how you can bind data from the ui:inputDate component.
<aura:component>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<aura:attribute name="today" type="Date" default=""/>
285
Reference
ui:outputDate
({
doInit : function(component, event, helper) {
var today = new Date();
component.set('v.today', today.getFullYear() + "-" + (today.getMonth() + 1) + "-"
+ today.getDate());
component.set('v.deadline', today);
},
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var expdate = component.find("expdate").get("v.value");
var oDate = component.find("oDate");
oDate.set("v.value", expdate);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
format
String
langLocale
String
value
String
The output value of the date. It should be a date string in ISO-8601 format Yes
(YYYY-MM-DD).
286
Reference
ui:outputDateTime
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputDateTime
Displays a date, time in a specified or default format based on the user's locale.
A ui:outputDateTime component represents a date and time output that is wrapped in an HTML span tag. This component
can be used with ui:inputDateTime, which takes in a date input. ui:outputDateTime retrieves the browser's locale
information and displays the date accordingly. To display a date and time, you can use an attribute value and bind it to the
ui:outputDateTime component.
<aura:attribute name="myDateTime" type="Date" default="2014-09-29T00:17:08z"/>
<ui:outputDateTime value="{!v.myDateTime}"/>
This example shows how you can bind data from a ui:inputDateTime component.
<aura:component>
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
<aura:attribute name="today" type="Date" default=""/>
<ui:inputDateTime aura:id="today" label="Time" class="field" value=""
displayDatePicker="true" />
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputDateTime aura:id="oDateTime" value=""
</div>
</aura:component>
/>
({
doInit : function(component, event, helper) {
var today = new Date();
component.set('v.today', today.getFullYear() + "-" + (today.getMonth() + 1) + "-"
+ today.getDate());
287
Reference
ui:outputDateTime
},
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var todayVal = component.find("today").get("v.value");
var oDateTime = component.find("oDateTime");
oDateTime.set("v.value", todayVal);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
format
String
langLocale
String
timezone
String
value
String
Yes
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
288
Reference
ui:outputEmail
ui:outputEmail
Displays an email address in an HTML anchor (<a>) element. The leading and trailing space are trimmed.
A ui:outputEmail component represents an email output that is wrapped in an HTML span tag. This component can be used
with ui:inputEmail, which takes in an email input. The email output is wrapped in an HTML anchor element and mailto is
automatically appended to it. This is a simple set up of a ui:outputEmail component.
<ui:outputEmail value="[email protected]"/>
This example shows how you can bind data from a ui:inputEmail component.
<aura:component>
<ui:inputEmail aura:id="email" label="Email" class="field" value="[email protected]"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputEmail aura:id="oEmail" value="Email" />
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var email = component.find("email").get("v.value");
var oEmail = component.find("oEmail");
oEmail.set("v.value", email);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
value
String
289
Yes
Reference
ui:outputNumber
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputNumber
Displays the number in the default or specified format. Supports up to 18 digits before the decimal place.
A ui:outputNumber component represents a number output that is rendered as an HTML span tag. This component can be
used with ui:inputNumber, which takes in a number input. ui:outputNumber retrieves the locale information and displays
the number in the given decimal format. To display a number, you can use an attribute value and bind it to the ui:outputNumber
component.
<aura:attribute name="myNum" type="Decimal" default="10.10"/>
<ui:outputNumber value="{!v.myNum}" format=".00"/>
This example retrieves the value of a ui:intputNumber component, validates the input, and displays it using ui:outputNumber.
<aura:component>
<ui:inputNumber aura:id="inputCmp" label="Enter a number: "/> <br/>
<ui:button label="Submit" press="{!c.validate}"/>
<ui:outputNumber aura:id="outNum" value=""/>
</aura:component>
({
validate : function(component, evt) {
var inputCmp = component.find("inputCmp");
var value = inputCmp.get("v.value");
var myOutput = component.find("outNum");
myOutput.set("v.value", value);
// Check if input is numeric
if (isNaN(value)) {
inputCmp.set("v.errors", [{message:"Input not a number: " + value}]);
290
Reference
ui:outputPhone
} else {
inputCmp.set("v.errors", null);
}
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
format
String
The format of the number. For example, format=.00 displays the number
followed by two decimal places. If not specified, the Locale default format
will be used.
value
BigDecimal
Yes
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputPhone
Displays the phone number in a URL link format.
A ui:outputPhone component represents a phone number output that is wrapped in an HTML span tag. This component can
be used with ui:inputPhone, which takes in a phone number input. The following example is a simple set up of a
ui:outputPhone component.
<ui:outputPhone value="415-123-4567"/>
291
Reference
ui:outputPhone
This example shows how you can bind data from a ui:inputPhone component.
<aura:component>
<ui:inputPhone aura:id="phone" label="Phone Number" class="field" value="415-123-4567"
/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputPhone aura:id="oPhone" value="" />
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var phone = component.find("phone").get("v.value");
var oPhone = component.find("oPhone");
oPhone.set("v.value", phone);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
292
Yes
Reference
ui:outputRichText
Event Name
Event Type
Description
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputRichText
Displays richly-formatted text including tags such as paragraph, image, and hyperlink, as specified in the value attribute.
A ui:outputRichText component represents rich text and can be used to display input from a ui:inputRichText
component.
For example, you can enter bold or colored text via a ui:inputRichText component and bind its value to a
ui:outputRichText component, which results in the following HTML.
<div class="uiOutputRichText">
<b>Aura</b>, <span style="color:red">input rich text demo</span>
</div>
This example shows how you can bind data from a ui:inputRichText component.
<aura:component>
<ui:inputRichText aura:id="inputRT" label="Rich Text Demo"
value="<script>test</script> <b>rich text</b>" />
<ui:button aura:id="outputButton" buttonTitle="Click to see what you put into the rich
text field" label="Display" press="{!c.getInput}"/>
<ui:outputRichText aura:id="outputRT"/>
</aura:component>
({
getInput : function(cmp) {
var userInput = cmp.find("inputRT").get("v.value");
var output = cmp.find("outputRT");
output.set("v.value", userInput);
}
})
293
Reference
ui:outputText
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputText
Displays text as specified by the value attribute.
A ui:outputText component represents text output that is wrapped in an HTML span tag. This component can be used with
ui:inputText, which takes in a text input. To display text, you can use an attribute value and bind it to the ui:outputText
component.
<aura:attribute name="myText" type="String" default="some string"/>
<ui:outputText value="{!v.myText}" label="my output"/>
This example shows how you can bind data from an ui:inputText component.
<aura:component>
<ui:inputText aura:id="name" label="Enter some text" class="field" value="My Text"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
294
Reference
ui:outputTextArea
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var name = component.find("name").get("v.value");
var oName = component.find("oName");
oName.set("v.value", name);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
title
String
value
String
Yes
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputTextArea
Displays the text area as specified by the value attribute.
295
Reference
ui:outputTextArea
A ui:outputTextArea component represents text output that is wrapped in an HTML span tag. This component can be used
with ui:inputTextArea, which takes in a multi-line text input. To display text, you can use an attribute value and bind it to the
ui:outputTextArea component.
<aura:attribute name="myTextArea" type="String" default="some string"/>
<ui:outputTextArea value="{!v.myTextArea}"/>
This example shows how you can bind data from the ui:inputTextArea component.
<aura:component>
<ui:inputTextArea aura:id="comments" label="Comments"
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var comments = component.find("comments").get("v.value");
var oTextarea = component.find("oTextarea");
oTextarea.set("v.value", comments);
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
class
String
value
String
Events
Event Name
Event Type
Description
dblclick
COMPONENT
296
Yes
Reference
ui:outputURL
Event Name
Event Type
Description
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:outputURL
Displays a link to a URL as specified by the value attribute, rendered on a given text (label attribute) and image, if any.
A ui:outputURL component represents a URL that is wrapped in an HTML a tag. This component can be used with ui:inputURL,
which takes in a URL input. To display a URL, you can use an attribute value and bind it to the ui:outputURL component.
<aura:attribute name="myURL" type="String" default="http://www.google.com"/>
<ui:outputURL value="{!v.myURL}" label="{!v.myURL}"/>
This example shows how you can bind data from a ui:inputURL component.
<aura:component>
<ui:inputURL aura:id="url" label="Venue URL" class="field" value="http://www.myURL.com"/>
<ui:button class="btn" label="Submit" press="{!c.setOutput}"/>
<div aura:id="msg" class="hide">
You entered: <ui:outputURL aura:id="oURL" value=""/>
</div>
</aura:component>
({
setOutput : function(component, event, helper) {
var cmpMsg = component.find("msg");
$A.util.removeClass(cmpMsg, 'hide');
var url = component.find("url").get("v.value");
var oURL = component.find("oURL");
oURL.set("v.value", url);
oURL.set("v.label", url);
}
})
297
Reference
ui:radioMenuItem
Attributes
Attribute Name
Attribute Type
Description
Required?
alt
String
The alternate text description for image (used when there is no label)
body
Component[]
class
String
disabled
Boolean
iconClass
String
label
String
target
String
title
String
The text to display as a tooltip when the mouse pointer hovers over this
component.
value
String
Yes
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
mousedown
COMPONENT
ui:radioMenuItem
A menu item with a radio button that indicates a mutually exclusive selection and can be used to invoke an action. This component is
nested in a ui:menu component.
298
Reference
ui:radioMenuItem
A ui:radioMenuItem component represents a menu list item for single selection. Use aura:iteration to iterate over a list
of values and display the menu items. A ui:menuTriggerLink component displays and hides your menu items.
<aura:attribute name="status" type="String[]" default="Open, Closed, Closed Won, Any"/>
<ui:menu>
<ui:menuTriggerLink class="radioMenuLabel" aura:id="radioMenuLabel" label="Select
a status"/>
<ui:menuList class="radioMenu" aura:id="radioMenu">
<aura:iteration items="{!v.status}" var="s">
<ui:radioMenuItem label="{!s}" value="{!s}"/>
</aura:iteration>
</ui:menuList>
</ui:menu>
Attributes
Attribute Name
Attribute Type
Description
body
Component[]
class
String
disabled
Boolean
hideMenuAfterSelected Boolean
Required?
label
String
selected
Boolean
The status of the menu item. True means this menu item is selected;
False is not selected.
type
String
The concrete type of the menu item. Accepted values are 'action',
'checkbox', 'radio', 'separator' or any namespaced component descriptor,
e.g. ns:xxxxmenuItem.
Events
Event Name
Event Type
Description
dblclick
COMPONENT
mouseover
COMPONENT
Indicates that the user has moved the mouse pointer over the component.
mouseout
COMPONENT
Indicates that the user has moved the mouse pointer away from the component.
mouseup
COMPONENT
mousemove
COMPONENT
click
COMPONENT
299
Reference
ui:spinner
Event Name
Event Type
Description
mousedown
COMPONENT
select
COMPONENT
blur
COMPONENT
focus
COMPONENT
keypress
COMPONENT
Indicates that the user has pressed and held down a keyboard key.
keyup
COMPONENT
keydown
COMPONENT
Indicates that the user has pressed and released a keyboard key.
ui:spinner
A loading spinner to be used while the real component body is being loaded
To toggle the spinner, use get("e.toggle"), set the isVisible parameter to true or false, and then fire the event.
This example shows a spinner when a component is expecting a server response and removes the spinner when the component is no
longer waiting for a response.
<aura:component>
<aura:handler event="aura:waiting" action="{!c.showSpinner}"/>
<aura:handler event="aura:doneWaiting" action="{!c.hideSpinner}"/>
<center><ui:spinner aura:id="spinner"/></center>
</aura:component>
300
Reference
Event Reference
({
toggleSpinner: function(cmp) {
var spinner = cmp.find('spinner');
var evt = spinner.get("e.toggle");
if(!$A.util.hasClass(spinner, 'hideEl')){
evt.setParams({ isVisible : false });
}
else {
evt.setParams({ isVisible : true });
}
evt.fire();
}
})
Attributes
Attribute Name
Attribute Type
Description
Required?
body
Component[]
isVisible
Boolean
Events
Event Name
Event Type
toggleLoadingIndicator COMPONENT
Description
Change the visibility of a ui:spinner component.
Event Reference
Use out-of-the-box events to enable component interaction within Salesforce1 or within your Lightning components. For example,
these events enable your components to open a record create or edit page, or navigate to a record.
force:createRecord
Opens the page to create a new record for the specified entityApiName, for example, Account or myNamespace__MyObject__c.
To display the record create page for an object, set the object name on the entityApiName parameter and fire the event.
recordTypeId is optional and, if provided, specifies the record type for the created object. This example displays the record create
panel for contacts.
createRecord : function (component, event, helper) {
var createRecordEvent = $A.get("e.force:createRecord");
301
Reference
force:editRecord
createRecordEvent.setParams({
"entityApiName": "Contact"
});
createRecordEvent.fire();
}
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
Attribute Name
Type
Description
entityApiName
String
Required. The API name of the custom or standard object, such as Account, Case,
Contact, Lead, Opportunity, or namespace__objectName__c.
recordTypeId
String
The ID of the record type, if record types are available for the object.
force:editRecord
Opens the page to edit the record specified by recordId.
To display the record edit page for an object, set the object name on the recordId attribute and fire the event. This example displays
the record edit page for a contact thats specified by recordId.
editRecord : function(component, event, helper) {
var editRecordEvent = $A.get("e.force:editRecord");
editRecordEvent.setParams({
"recordId": component.get("v.contact.Id")
});
editRecordEvent.fire();
}
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
Attribute Name
Type
Description
recordId
String
force:navigateToList
Navigates to the list view specified by listViewId.
To navigate to a list view, set the list view ID on the listViewId attribute and fire the event. This example displays the list views for
contacts.
gotoList : function (component, event, helper) {
var action = component.get("c.getListViews");
action.setCallback(this, function(response){
var state = response.getState();
if (state === "SUCCESS") {
var listviews = response.getReturnValue();
var navEvent = $A.get("e.force:navigateToList");
navEvent.setParams({
"listViewId": listviews.Id,
302
Reference
force:navigateToObjectHome
"listViewName": null,
"scope": "Contact"
});
navEvent.fire();
}
});
$A.enqueueAction(action);
}
This Apex controller returns all list views for the contact object.
@AuraEnabled
public static List<ListView> getListViews() {
List<ListView> listviews =
[SELECT Id, Name FROM ListView WHERE SobjectType = 'Contact'];
// Perform isAccessible() check here
return listviews;
}
You can also provide a single list view ID by providing the list view name you want to navigate to in the SOQL query.
SELECT Id, Name FROM ListView WHERE SobjectType = 'Contact' and Name='All Contacts'
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
Attribute Name
Type
Description
listViewId
String
listViewName
String
Specifies the name for the list view and doesnt need to match the actual name. To use
the actual name thats saved for the list view, set listViewName to null.
scope
String
SEE ALSO:
CRUD and Field-Level Security (FLS)
force:navigateToObjectHome
Navigates to the object home specified by the scope attribute.
To navigate to an object home, set the object name on the scope attribute and fire the event. This example displays the home page
for a custom object.
navHome : function (component, event, helper) {
var homeEvent = $A.get("e.force:navigateToObjectHome");
homeEvent.setParams({
"scope": "myNamespace__myObject__c"
});
homeEvent.fire();
}
303
Reference
force:navigateToRelatedList
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
Attribute Name
Type
Description
scope
String
Required. The API name of the custom or standard object, such as Contact, or
namespace__objectName__c.
resetHistory
Boolean
Resets history if set to true. Defaults to false, which provides a Back button in Salesforce1.
force:navigateToRelatedList
Navigates to the related list specified by parentRecordId.
To navigate to a related list, set the parent record ID on the parentRecordId attribute and fire the event. For example, to display
a related list for a Contact object, the parentRecordId is Contact.Id. This example displays the related cases for a contact
record.
gotoRelatedList : function (component, event, helper) {
var relatedListEvent = $A.get("e.force:navigateToRelatedList");
relatedListEvent.setParams({
"relatedListId": "Cases",
"parentRecordId": component.get("v.contact.Id")
});
relatedListEvent.fire();
}
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
Attribute Name
Type
Description
parentRecordId
String
relatedListId
String
Required. The API name of the related list to display, such as Contacts or Opportunities.
force:navigateToSObject
Navigates to an sObject record specified by recordId.
To display the record view, set the record ID on the recordId attribute and fire the event. The record view contains slides that displays
the Chatter feed, the record details, and related information. This example displays the related information slide of a record view for the
specified record ID.
createRecord : function (component, event, helper) {
var navEvt = $A.get("e.force:navigateToSObject");
navEvt.setParams({
"recordId": "00QB0000000ybNX",
"slideDevName": "related"
});
navEvt.fire();
}
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
304
Reference
force:navigateToURL
Attribute Name
Type
Description
recordId
String
slideDevName
String
Specifies the slide within the record view to display initially. Valid options are:
detail: The record detail slide. This is the default value.
chatter: The Chatter slide
related: The related information slide
force:navigateToURL
Navigates to the specified URL.
Relative and absolute URLs are supported. Relative URLs are relative to the Salesforce1 mobile browser app domain, and retain navigation
history. External URLs open in a separate browser window.
Use relative URLs to navigate to different screens within your app. Use external URLs to allow the user to access a different site or app,
where they can take actions that dont need to be preserved in your app. To return to your app, the separate window thats opened by
an external URL must be closed when the user is finished with the other app. The new window has a separate history from your app,
and this history is discarded when the window is closed. This also means that the user cant click a Back button to go back to your app;
the user must close the new window.
mailto:, tel:, geo:, and other URL schemes are supported for launching external apps and attempt to do the right thing.
However, support varies by mobile platform and device. mailto: and tel: are reliable, but we recommend that you test any other
305
Reference
force:recordSave
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
Attribute Name
Type
Description
isredirect
Boolean
Indicates that the new URL should replace the current one in the navigation history.
Defaults to false.
url
String
force:recordSave
Saves a record.
force:recordSave is handled by the force:recordEdit component. This examples shows a force:recordEdit
component, which takes in user input to update a record specified by the recordId attribute. The button fires the
force:recordSave event.
<force:recordEdit aura:id="edit" recordId="a02D0000006V8Ni"/>
<ui:button label="Save" press="{!c.save}"/>
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
force:recordSaveSuccess
Indicates that the record has been successfully saved.
force:recordSaveSuccess is used with the force:recordEdit component. This examples shows a
force:recordEdit component, which takes in user input to update a record specified by the recordId attribute. The button
fires the force:recordSave event.
<aura:attribute name="recordId" type="String" default="a02D0000006V8Ni"/>
<aura:attribute name="saveState" type="String" default="UNSAVED" />
<aura:handler name="onSaveSuccess" event="force:recordSaveSuccess"
action="{!c.handleSaveSuccess}"/>
<force:recordEdit aura:id="edit" recordId="{!v.recordId}" />
<ui:button label="Save" press="{!c.save}"/>
Record save status: {!v.saveState}
This client-side controller fires the event to save the record and handle it accordingly.
({
save : function(cmp, event) {
// Save the record
cmp.find("edit").get("e.recordSave").fire();
306
Reference
force:refreshView
},
handleSaveSuccess : function(cmp, event) {
// Display the save status
cmp.set("v.saveState", "SAVED");
}
})
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
force:refreshView
Reloads the view.
To refresh a view, run $A.get("e.force:refreshView").fire();, which reloads all data for the view.
This example refreshes the view after an action is successfully completed.
refresh : function(component, event, helper) {
var action = cmp.get('c.myController');
action.setCallback(cmp,
function(response) {
var state = response.getState();
if (state === 'SUCCESS'){
$A.get('e.force:refreshView').fire();
} else {
//do something
}
}
);
$A.enqueueAction(action);
}
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
force:showToast
Displays a message in a popup.
A toast displays a message below the header at the top of a view. The message is specified by the message attribute.
This example displays a toast message Success! The record has been updated successfully..
showToast : function(component, event, helper) {
var toastEvent = $A.get("e.force:showToast");
toastEvent.setParams({
"title": "Success!",
"message": "The record has been updated successfully."
});
toastEvent.fire();
}
Note: This event is supported in Salesforce1 only. If used outside of Salesforce1, this event wont be handled properly.
307
Reference
lntg:selectSObject
Attribute Name
Type
Description
title
String
message
String
key
String
duration
Integer
lntg:selectSObject
Sends the recordId of an object when its selected in the UI.
To select an object, set the record ID on the recordId attribute. Optionally, specify a channel for this event so that your components
can select if they want to listen to particular event messages.
selectedObj: function(component, event) {
var selectedObjEvent = $A.get("e.lntg:selectSObject");
selectedObjEvent.setParams({
"recordId": "0061a000004x8e1",
"channel": "AccountsChannel"
});
selectedObj.fire();
}
Attribute Name
Type
Description
recordId
String
channel
String
Specify this field if you want particular components to process some event messages
while ignoring others.
lntg:sendMessage
Passes a message between two components.
To send a message, specify a string of text that you want to pass between components. Optionally, specify a channel for this event so
that your components can select if they want to listen to particular event messages
sendMsg: function(component, event) {
var sendMsgEvent = $A.get("e.lntg:sendMessage");
sendMsgEvent.setParams({
"message": "Hello World",
"channel": "AccountsChannel"
});
sendMsg.fire();
}
Attribute Name
Type
Description
message
String
308
Reference
ui:clearErrors
Attribute Name
Type
Description
channel
String
Specify this field if you want particular components to process some event messages
while ignoring others.
ui:clearErrors
Indicates that any validation errors should be cleared.
To set a handler for the ui:clearErrors event, use the onClearErrors system attribute on a component that extends
ui:input, such as ui:inputNumber.
The following ui:inputNumber component handles an error when the ui:button component is pressed. You can fire and
handle these events in a client-side controller.
<aura:component>
Enter a number:
<!-- onError calls your client-side controller to handle a validation error -->
<!-- onClearErrors calls your client-side controller to handle clearing of errors -->
<ui:inputNumber aura:id="inputCmp" onError="{!c.handleError}"
onClearErrors="{!c.handleClearError}"/>
<!-- press calls your client-side controller to trigger validation errors -->
<ui:button label="Submit" press="{!c.doAction}"/>
</aura:component>
ui:collapse
Indicates that a menu component collapses.
For example, the ui:menuList component registers this event and handles it when its fired.
<aura:registerEvent name="menuCollapse" type="ui:collapse"
description="The event fired when the menu list collapses." />
You can handle this event in a ui:menuList component instance. This example shows a menu component with two list items. It
handles the ui:collapse and ui:expand events.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Contacts"/>
<ui:menuList class="actionMenu" aura:id="actionMenu"
menuCollapse="{!c.addMyClass}" menuExpand="{!c.removeMyClass}">
<ui:actionMenuItem aura:id="item1" label="All Contacts"
click="{!c.doSomething}"/>
<ui:actionMenuItem aura:id="item2" label="All Primary" click="{!c.doSomething}"/>
</ui:menuList>
</ui:menu>
309
Reference
ui:expand
This client-side controller adds a CSS class to the trigger when the menu is collapsed and removes it when the menu is expanded.
({
addMyClass : function(component, event, helper) {
var trigger = component.find("trigger");
$A.util.addClass(trigger, "myClass");
},
removeMyClass : function(component, event, helper) {
var trigger = component.find("trigger");
$A.util.removeClass(trigger, "myClass");
}
})
ui:expand
Indicates that a menu component expands.
For example, the ui:menuList component registers this event and handles it when its fired.
<aura:registerEvent name="menuExpand" type="ui:expand"
description="The event fired when the menu list displays." />
You can handle this event in a ui:menuList component instance. This example shows a menu component with two list items. It
handles the ui:collapse and ui:expand events.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Contacts"/>
<ui:menuList class="actionMenu" aura:id="actionMenu"
menuCollapse="{!c.addMyClass}" menuExpand="{!c.removeMyClass}">
<ui:actionMenuItem aura:id="item1" label="All Contacts"
click="{!c.doSomething}"/>
<ui:actionMenuItem aura:id="item2" label="All Primary" click="{!c.doSomething}"/>
</ui:menuList>
</ui:menu>
This client-side controller adds a CSS class to the trigger when the menu is collapsed and removes it when the menu is expanded.
({
addMyClass : function(component, event, helper) {
var trigger = component.find("trigger");
$A.util.addClass(trigger, "myClass");
},
removeMyClass : function(component, event, helper) {
var trigger = component.find("trigger");
$A.util.removeClass(trigger, "myClass");
}
})
ui:menuFocusChange
Indicates that the user changed menu item focus in a menu component.
310
Reference
ui:menuSelect
For example, this event is fired when the user scrolls up and down the menu list, which triggers a focus change in menu items. The
ui:menuList component registers this event and handles it when its fired.
<aura:registerEvent name="menuFocusChange" type="ui:menuFocusChange"
description="The event fired when the menu list focus changes from one
menu item to another." />
You can handle this event in a ui:menuList component instance. This example shows a menu component with two list items.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Contacts"/>
<ui:menuList class="actionMenu" aura:id="actionMenu"
menuFocusChange="{!c.handleChange}">
<ui:actionMenuItem aura:id="item1" label="All Contacts" />
<ui:actionMenuItem aura:id="item2" label="All Primary" />
</ui:menuList>
</ui:menu>
ui:menuSelect
Indicates that a menu item has been selected in the menu component.
For example, the ui:menuList component registers this event so it can be fired by the component.
<aura:registerEvent name="menuSelect" type="ui:menuSelect"
description="The event fired when a menu item is selected." />
You can handle this event in a ui:menuList component instance. This example shows a menu component with two list items. It
handles the ui:menuSelect event and click events.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Contacts"/>
<ui:menuList class="actionMenu" aura:id="actionMenu" menuSelect="{!c.selected}">
<ui:actionMenuItem aura:id="item1" label="All Contacts"
click="{!c.doSomething}"/>
<ui:actionMenuItem aura:id="item2" label="All Primary"
click="{!c.doSomething}"/>
</ui:menuList>
</ui:menu>
When a menu item is clicked, the click event is handled before the ui:menuSelect event, which corresponds to doSomething
and selected client-side controllers in the following example.
({
selected : function(component, event, helper) {
var selected = event.getParam("selectedItem");
// returns label of selected item
var selectedLabel = selected.get("v.label");
},
doSomething : function(component, event, helper) {
console.log("do something");
}
})
311
Reference
ui:menuTriggerPress
Attribute Name
Type
Description
selectedItem
Component[]
hideMenu
Boolean
deselectSiblings Boolean
focusTrigger
Boolean
ui:menuTriggerPress
Indicates that a menu trigger is clicked.
For example, the ui:menuTrigger component registers this event so it can be fired by the component.
<aura:registerEvent name="menuTriggerPress" type="ui:menuTriggerPress"
description="The event fired when the trigger is clicked." />
You can handle this event in a component that extends ui:menuTrigger, such as in a ui:menuTriggerLink component
instance.
<ui:menu>
<ui:menuTriggerLink aura:id="trigger" label="Contacts"
menuTriggerPress="{!c.triggered}"/>
<ui:menuList class="actionMenu" aura:id="actionMenu">
<ui:actionMenuItem aura:id="item1" label="All Contacts"
click="{!c.doSomething}"/>
<ui:actionMenuItem aura:id="item2" label="All Primary" click="{!c.doSomething}"/>
</ui:menuList>
</ui:menu>
This client-side controller retrieves the label of the trigger when its clicked.
({
triggered : function(component, event, helper) {
var trigger = component.find("trigger");
// Get the label on the trigger
var triggerLabel = trigger.get("v.label");
}
})
ui:validationError
Indicates that the component has validation errors.
To set a handler for the ui:validationError event, use the onError system attribute on a component that extends ui:input,
such as ui:inputNumber.
312
Reference
The following ui:inputNumber component handles an error when the ui:button component is pressed. You can fire and
handle these events in a client-side controller.
<aura:component>
Enter a number:
<!-- onError calls your client-side controller to handle a validation error -->
<!-- onClearErrors calls your client-side controller to handle clearing of errors -->
<ui:inputNumber aura:id="inputCmp" onError="{!c.handleError}"
onClearErrors="{!c.handleClearError}"/>
<!-- press calls your client-side controller to trigger validation errors -->
<ui:button label="Submit" press="{!c.doAction}"/>
</aura:component>
Type
Description
errors
Object[]
aura:doneRendering
Indicates that the initial rendering of the root application or root component has completed.
This event is automatically fired if no more components need to be rendered or rerendered due to any attribute value changes. The
aura:doneRendering event is handled by a client-side controller. A component can have only one <aura:handler
event="doneRendering"> tag to handle this event.
<aura:handler event="aura:doneRendering" action="{!c.doneRendering}"/>
For example, you want to customize the behavior of your app after its finished rendering the first time but not after subsequent
rerenderings. Create an attribute to determine if its the first rendering.
<aura:component>
<aura:handler event="aura:doneRendering" action="{!c.doneRendering}"/>
<aura:attribute name="isDoneRendering" type="Boolean" default="false"/>
<!-- Other component markup here -->
<p>My component</p>
</aura:component>
This client-side controller checks that the aura:doneRendering event has been fired only once.
({
doneRendering: function(cmp, event, helper) {
if(!cmp.get("v.isDoneRendering")){
cmp.set("v.isDoneRendering", true);
313
Reference
aura:doneWaiting
Note: When aura:doneRendering is fired, component.isRendered() returns true. To check if your element is
visible in the DOM, use utilities such as component.getElement(), component.hasClass(), or
element.style.display.
The aura:doneRendering handler contains these required attributes.
Attribute Name
Type
Description
event
String
action
Object
aura:doneWaiting
Indicates that the app or component is done waiting for a response to a server request. This event is preceded by an aura:waiting
event. This event is fired after aura:waiting.
This event is automatically fired if no more response from the server is expected. The aura:doneWaiting event is handled by a
client-side controller. A component can have only one <aura:handler event="aura:doneWaiting"> tag to handle this
event.
<aura:handler event="aura:doneWaiting" action="{!c.hideSpinner}"/>
Type
Description
event
String
action
Object
314
Reference
aura:locationChange
aura:locationChange
Indicates that the hash part of the URL has changed.
This event is automatically fired when the hash part of the URL has changed, such as when a new location token is appended to the
hash. The aura:locationChange event is handled by a client-side controller. A component can have only one <aura:handler
event="aura:locationChange"> tag to handle this event.
<aura:handler event="aura:locationChange" action="{!c.update}"/>
Type
Description
event
String
action
Object
Type
Description
token
String
querystring
Object
aura:systemError
Indicates that an error has occurred.
This event is automatically fired when an error is encountered during the run of a server-side action. The aura:systemError event
is handled by a client-side controller. A component can have only one <aura:handler event="aura:systemError">
tag to handle this event.
<aura:handler event="aura:systemError" action="{!c.handleError}"/>
This example shows a button that triggers an error and a handler for the aura:systemError event .
<aura:component controller="namespace.myController">
<aura:handler event="aura:systemError" action="{!c.showSystemError}"/>
<aura:attribute name="response" type="Aura.Action"/>
<!-- Other component markup here -->
<ui:button aura:id="trigger" label="Trigger error" press="{!c.trigger}"/>
</aura:component>
315
Reference
aura:valueChange
This client-side controller triggers the firing of an error and handles that error.
({
trigger: function(cmp, event) {
// Call an Apex controller that throws an error
var action = cmp.get("c.throwError");
action.setCallback(cmp, function(response){
cmp.set("v.response", response);
});
$A.enqueueAction(action);
},
showSystemError: function(cmp, event) {
// Handle system error
$A.log(cmp);
$A.log(event);
}
})
Type
Description
event
String
action
Object
The aura:systemError event contains these attributes. You can retrieve the attribute values using
event.getParam("message").
Attribute Name
Type
Description
message
String
error
String
aura:valueChange
Indicates that a value has changed.
This event is automatically fired when an attribute value changes. The aura:valueChange event is handled by a client-side
controller. A component can have multiple <aura:handler name="change"> tags to detect changes to different attributes.
<aura:handler name="change" value="{!v.items}" action="{!c.itemsChange}"/>
This example updates a Boolean value, which automatically fires the aura:valueChange event.
<aura:component>
<aura:attribute name="myBool" type="Boolean" default="true"/>
<!-- Handles the aura:valueChange event -->
<aura:handler name="change" value="{!v.myBool}" action="{!c.handleValueChange}"/>
<ui:button label="change value" press="{!c.changeValue}"/>
</aura:component>
316
Reference
aura:valueDestroy
These client-side controller actions trigger the value change and handle it.
({
changeValue : function (component, event, helper) {
component.set("v.myBool", false);
},
handleValueChange : function (component, event, helper) {
//handle value change
}
})
Type
Description
name
String
value
Object
action
Object
aura:valueDestroy
Indicates that a value is being destroyed.
This event is automatically fired when an attribute value is being destroyed. The aura:valueDestroy event is handled by a
client-side controller. A component can have only one <aura:handler name="destroy"> tag to handle this event.
<aura:handler name="destroy" value="{!this}" action="{!c.handleDestroy}"/>
For example, lets say that you are viewing your Lightning component in the Salesforce1 app. This aura:valueDestroy event is
triggered when you tap on a different menu item on the Salesforce1 navigation menu, and your component is destroyed. In this example,
the token attribute returns the component thats being destroyed.
The destroy handler contains these required attributes.
Attribute Name
Type
Description
name
String
value
Object
The value for which you want to detect the event for.
action
Object
317
Reference
aura:valueInit
Attribute Name
Type
Description
value
String
aura:valueInit
Indicates that a value has been initialized. This event is triggered on app or component initialization.
This event is automatically fired when an app or component is initialized, prior to rendering. The aura:valueInit event is handled
by a client-side controller. A component can have only one <aura:handler name="init"> tag to handle this event.
<aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
Type
Description
name
String
value
Object
action
Object
aura:waiting
Indicates that the app or component is waiting for a response to a server request. This event is fired before aura:doneWaiting.
This event is automatically fired when a server-side action is added using $A.enqueueAction() and subsequently run, or when
its expecting a response from an Apex controller. The aura:waiting event is handled by a client-side controller. A component can
have only one <aura:handler event="aura:waiting"> tag to handle this event.
<aura:handler event="aura:waiting" action="{!c.showSpinner}"/>
318
Reference
Type
Description
event
String
action
Object
319
Reference
Basic Types
Attribute Name
Type
Description
access
String
Indicates whether the attribute can be used outside of its own namespace.
Possible values are public (default), and global, and private.
name
String
type
String
Required. The type of the attribute. For a list of basic types supported, see Basic
Types.
default
String
The default value for the attribute, which can be overwritten as needed. When
setting a default value, expressions using the $Label, $Locale, and
$Browser global value providers are supported. Alternatively, to set a
dynamic default, use an init event. See Invoking Actions on Component
Initialization on page 167.
required
Boolean
description
String
All <aura:attribute> tags have name and type values. For example:
<aura:attribute name="whom" type="String" />
Note: Although type values are case insensitive, case sensitivity should be respected as your markup interacts with JavaScript,
CSS, and Apex.
SEE ALSO:
Component Attributes
Basic Types
Here are the supported basic type values. Some of these types correspond to the wrapper objects for primitives in Java. Since the
framework is written in Java, defaults, such as maximum size for a number, for these basic types are defined by the Java objects that
they map to.
type
Example
Description
Boolean
<aura:attribute
name="showDetail"
type="Boolean" />
Date
<aura:attribute
name="startDate" type="Date"
/>
320
Reference
Basic Types
type
Example
Description
DateTime
<aura:attribute
name="lastModifiedDate"
type="DateTime" />
Decimal
<aura:attribute
name="totalPrice"
type="Decimal" />
<aura:attribute
name="widthInchesFractional"
type="Double" />
Integer
<aura:attribute
name="numRecords"
type="Integer" />
<aura:attribute
name="numSwissBankAccount"
type="Long" />
Long
String
You can use arrays for each of these basic types. For example:
<aura:attribute name="favoriteColors" type="String[]" default="['red','green','blue']" />
321
Reference
Object Types
This client-side controller retrieves the string array from the Apex controller and displays it using the {!v.favoriteColors}
expression.
({
getString : function(component, event) {
var action = component.get("c.getStringArray");
action.setCallback(this, function(response) {
var state = response.getState();
if (state === "SUCCESS") {
var stringItems = response.getReturnValue();
component.set("v.favoriteColors", stringItems);
}
});
$A.enqueueAction(action);
}
})
Object Types
An attribute can have a type corresponding to an Object.
<aura:attribute name="data" type="Object" />
For example, you may want to create an attribute of type Object to pass a JavaScript array as an event parameter. In the component
event, declare the event parameter using aura:attribute.
<aura:event type="COMPONENT">
<aura:attribute name="arrayAsObject" type="Object" />
<aura:event>
322
Reference
Note: Make your Apex class methods, getter and setter methods, available to your components by annotating them with
@AuraEnabled.
SEE ALSO:
Working with Salesforce Records
Note: Make your Apex class methods, getter and setter methods, available to your components by annotating them with
@AuraEnabled.
SEE ALSO:
Working with Salesforce Records
Collection Types
Here are the supported collection type values.
type
Example
Description
type[] (Array)
<aura:attribute
An array of items of a defined type.
name="colorPalette"
type="String[]" default="['red',
'green', 'blue']" />
List
<aura:attribute
name="colorPalette" type="List"
default="['red', 'green',
'blue']" />
Map
<aura:attribute
name="sectionLabels" type="Map"
default="{ a: 'label1', b:
'label2' }" />
Set
323
Reference
Using Arrays
If an attribute can contain more than one element, use an array.
This aura:attribute tag shows the syntax for an array of Apex objects:
<aura:attribute name="colorPalette" type="docSampleNamespace.Color[]" />
324
Reference
Framework-Specific Types
Note: Make your Apex class methods, getter and setter methods, available to your components by annotating them with
@AuraEnabled.
SEE ALSO:
Working with Salesforce Records
Framework-Specific Types
Here are the supported type values that are specific to the framework.
type
Example
Description
Aura.Component
N/A
Aura.Component[]
<aura:attribute
name="detail"
type="Aura.Component[]"/>
SEE ALSO:
Component Body
Component Facets
325
INDEX
$Browser 59, 61
$Label 59, 71
$Locale 59, 62
A
Access control
application 197
attribute 198
component 198
event 198
interface 197
JavaScript 168
Accessibility
audio messages 97
buttons 96
events 98
help and error messages 97
menus 98
Actions
calling server-side 183
queueing 185
Anti-patterns
events 134
Apex
API calls 195
controllers 182
custom objects 187
deleting records 192
Lightning components 187
records 187
saving records 191
standard objects 187
API calls 173, 195
app design 30
Application
attributes 212
aura:application 212
building and running 6
creating 141
layout and UI 142
styling 143
Application cache
browser support 205
enabling 205
loading 205
overview 205
Application events
handling 125
Application templates
external CSS 142
JavaScript libraries 142
application, creating 8
application, static mockup 13
Applications
CSS 144, 146149
overview 142
styling 144, 146149
token 146149
Apps
overview 142
Attribute types
Aura.Action 325
Aura.Component 325
basic 320
collection 323
custom Apex class 324
custom object 323
Object 322
standard object 323
Attribute value, setting 216
Attributes
component reference, setting on 217
interface, setting on 218
JavaScript 160
super component, setting on 216
aura:application 212
aura:attribute 319
aura:component 218
aura:dependency 213
aura:doneRendering 313
aura:doneWaiting 314
aura:event 214
aura:expression 219
aura:html 219
aura:if 55, 59, 220
aura:interface 214
aura:iteration 220
aura:locationChange 315
aura:method 215
aura:renderIf 55, 221
aura:set 216217
aura:systemError 315
326
Index
B
Benefits 2
Best practices
events 134
Body
JavaScript 161
Bubbling 118
Buttons
local ID 180
pressed 180
C
Client-side controllers 113
Community Builder
configuring custom components 105
creating custom layouts 106
Component
abstract 201
attributes 49
aura:interface 214
body, setting and accessing 53
documentation 75
nest 50
rendering lifecycle 135
themes, vendor prefixes 146
Component attributes
inheritance 200
Component body
JavaScript 161
Component bundles
configuring for Community Builder 105
configuring for Lightning App Builder 107, 109110, 145
configuring for Lightning Experience Record Home pages
109110
configuring for Lightning Pages 107, 109110, 145
tips for configuring for Lightning App Builder 110
Component definitions
dependency 213
Component events
handling 117
handling dynamically 121
Component facets 54
Component initialization 318
component, creating 15, 24
component, nested 22
Components
access control 168
calling methods 172
conditional markup 55
creating 175
CSS 144, 146149
HTML markup, using 48
ID, local and global 47
markup 3940
methods 215
modifying 168
namespace 4143
overview 39
styling 144, 146149
styling with CSS 48
support level 39
token 146149
unescaping HTML 48
using 100
Conditional expressions 59
Content security policy 143
Controllers
calling server-side actions 183
client-side 113
creating server-side 182
Cookbook
JavaScript 173
CRUD access 189
CSP 143
CSS
external 144
tokens 146149
Custom labels 71
custom layouts
creating for Community Builder 106
custom object, create 11
D
Data changes
detecting 174
Debug
JavaScript 209
Debugging 208
Detect data changes 316
327
Index
Detecting
data changes 174
Developer Console 4
Developer Edition organization, sign up 7
DOM 158
Dynamic output 58
E
Errors
handling 170
throwing 170
Event bubbling 118
Event handlers 177
Events
anti-patterns 134
application 123, 125
aura events 301, 313
aura:doneRendering 313
aura:doneWaiting 314
aura:event 214
aura:locationChange 315
aura:systemError 315
aura:valueChange 316
aura:valueDestroy 317
aura:valueInit 318
aura:waiting 318
best practices 134
bubbling 118
component 116, 121
demo 129
example 121, 125
firing from non-Lightning code 133
force events 301
force:createRecord 301
force:editRecord 302
force:navigateToList 302
force:navigateToObjectHome 303
force:navigateToRelatedList 304
force:navigateToSObject 304305
force:recordSave 306
force:recordSaveSuccess 306
force:refreshView 307
force:sendMessage 308
handling 127
lntg:selectSObject 308
Salesforce1 138, 301
Salesforce1 and Lightning Experience demo 32
Salesforce1 demo 33, 36
system 140
Events (continued)
system events 313
ui:clearErrors 309
ui:collapse 309
ui:expand 310
ui:menuFocusChange 310
ui:menuSelect 311
ui:menuTriggerPress 312
ui:validationError 312
Events and actions 114
Expressions
conditional 59
dynamic output 58
format() 72
functions 67
operators 64
F
Field-level security 189
force:canvasApp 223
force:createRecord 301
force:editRecord 302
force:inputField 224
force:navigateToList 302
force:navigateToObjectHome 303
force:navigateToRelatedList 304
force:navigateToSObject 304305
force:outputField 225
force:recordEdit 226
force:recordSave 306
force:recordSaveSuccess 306
force:recordView 226
force:refreshView 307
force:sendMessage 308
forceChatter:feed 227
format() 72
G
globalID 59
H
Handling Input Field Errors 168
Helpers 162
HTML, supported tags 319
HTML, unescaping 48
I
Inheritance 199, 203
Input Field Validation 168
328
Index
Interfaces
marker 202
Introduction 12
J
JavaScript
access control 168
API calls 173
attribute values 160
calling component methods 172
component 161
get() and set() methods 160
libraries 159
sharing code in bundle 162
JavaScript console 209
JavaScript cookbook 173
L
Label
setting via parent attribute 72
Label parameters 72
Labels 7071
Lifecycle 168
Lightning 2
Lightning App Builder
configuring custom components 107, 109110, 145
CSS tips 145
Lightning components
Lightning Experience 103
Salesforce1 102
Lightning Experience
add Lightning components 103
lntg:selectSObject 308
loading data 20
Localization 73
Log messages 209
ltng:require 228
M
Markup 178
N
Namespace
creating 42
default 42
examples 43
explicit 42
implicit 42
organization 42
Namespace (continued)
prefix 42
O
Object-oriented development
inheritance 199
Online version 5
Open source 3
P
Package 4142
Packaging 194, 206
Prerequisites 7
Q
Queueing
queueing server-side actions 185
Quick start, install package 10
quick start, summary 30
R
Reference
Components 218
doc app 212
overview 211
Renderers 164
Rendering lifecycle 135
Rerendering 168
S
Salesforce1
add Lightning components 102
Server-Side Controllers
action queueing 185
calling actions 183
creating 182
overview 182
Storage service
adapters 203
initializing 204
MemoryAdapter 203
SmartStore 203
WebSQL 203
Styles 178
T
Tags
aura:component 218
aura:expression 219
329
Index
Tags (continued)
aura:html 219
aura:if 220
aura:iteration 220
aura:renderIf 221
aura:template 222
aura:text 222
aura:unescapedHtml 222
force:canvasApp 223
force:inputField 224
force:outputField 225
force:recordEdit 226
force:recordView 226
forceChatter:feed 227
ltng:require 228
ui:actionMenuItem 229
ui:button 230
ui:checkboxMenuItem 232
ui:inputCheckbox 234
ui:inputCurrency 236
ui:inputDate 238
ui:inputDateTime 241
ui:inputDefaultError 244
ui:inputEmail 246
ui:inputNumber 248
ui:inputPhone 251
ui:inputRadio 253
ui:inputRichText 256
ui:inputSecret 258
ui:inputSelect 260
ui:inputSelectOption 264
ui:inputText 265
ui:inputTextArea 267
ui:inputURL 270
ui:menu 272
ui:menuItem 276
ui:menuItemSeparator 277
ui:menuList 277
ui:menuTrigger 279
ui:menuTriggerLink 280
ui:message 281
ui:outputCheckbox 282
ui:outputCurrency 284
ui:outputDate 285
ui:outputDateTime 287
ui:outputEmail 289
ui:outputNumber 290
ui:outputPhone 291
ui:outputRichText 293
Tags (continued)
ui:outputText 294
ui:outputTextArea 295
ui:outputURL 297
ui:radioMenuItem 298
ui:spinner 300
Ternary operator 59
Themes
vendor prefixes 146
Tokens
design 146149
U
ui components
actionMenuItem 95
aura:component inheritance 77
button 89
checkbox 87
checkboxMenuItem 95
inputCurrency 82
inputDate 81
inputDateTime 81
inputDefaultError 94
inputEmail 84
inputNumber 82
inputPhone 84
inputRadio 88
inputRichText 84, 86
inputSecret 84
inputSelect 91
inputSelect, using Apex 93
inputText 84
inputTextArea 84
inputURL 84
menu 95
menuItemSeparator 95
menuTrigger 95
menuTriggerLink 95
outputCurrency 82
outputDate 81
outputDateTime 81
outputEmail 84
outputNumber 82
outputPhone 84
outputRichText 84, 86
outputText 84
outputTextArea 84
outputURL 84
radioMenuItem 95
330
Index
ui components overview 80
ui events 79
ui:actionMenuItem 229
ui:button 230
ui:checkboxMenuItem 232
ui:clearErrors 309
ui:collapse 309
ui:expand 310
ui:inputCheckbox 234
ui:inputCurrency 236
ui:inputDate 238
ui:inputDateTime 241
ui:inputDefaultError 244
ui:inputEmail 246
ui:inputNumber 248
ui:inputPhone 251
ui:inputRadio 253
ui:inputRichText 256
ui:inputSecret 258
ui:inputSelect 260
ui:inputSelectOption 264
ui:inputText 265
ui:inputTextArea 267
ui:inputURL 270
ui:menu 272
ui:menuFocusChange 310
ui:menuItem 276
ui:menuItemSeparator 277
ui:menuList 277
ui:menuSelect 311
ui:menuTrigger 279
ui:menuTriggerLink 280
ui:menuTriggerPress 312
ui:message 281
ui:outputCheckbox 282
ui:outputCurrency 284
ui:outputDate 285
ui:outputDateTime 287
ui:outputEmail 289
ui:outputNumber 290
ui:outputPhone 291
ui:outputRichText 293
ui:outputText 294
ui:outputTextArea 295
ui:outputURL 297
ui:radioMenuItem 298
ui:spinner 300
ui:validationError 312
V
Value providers
$Browser 61
$Label 71
versioning 56
Visualforce 104
W
Warnings 210
331