Power Platform
JavaScript Development
Hands-on experience developing JavaScript
for Power Platform Model-Driven Applications
I have been working with Dynamics CRM/365 (now the Power Platform) since 2005 and have written a tens of thousands of lines of JavaScript over the years and shared countless blog articles as I found tips and techniques for using JavaScript in the product. Here is my first blog post, on how to hide a tab in CRM 3.0.
I obtained my Microsoft Certified Training certification in order to teach what I learned to others. I started out using the Microsoft-supplied materials but I wasn't satisfied with their depth - so I created my own, which is what you see here.
As you review the contents of this page, please keep the following in mind:
I have a lot of experience with the Dynamics platform
I have done everything there is to do with Business Rules but need more
I am good enough, smart enough, and you know what? People like me
I am ready to take our user interface experience to the next level, and only JavaScript can help me
It is resume update season and I need a gift
The Microsoft Power Platform is maturing at an astounding rate - with changes happening on a weekly, if not daily basis.
This can make things extremely difficult to keep up with.
I am committed to sharing what I learn as I learn it.
My processional mantra: A rising tide raises all boats, has never been more true.
Want to come along for the ride?
This course is evergreen and always changing and adapting to new additions and changes that the Microsoft Power Platform product team throws at us. This means I will constantly be adding new tools, techniques, and tutorials as we move forward into the future.
Even today, as I launch the third-iteration of this course, I am actively adding new comment that I have worked out within the past two months. LOTS of fun stuff is coming!
Power Platform JavaScript development can be complex but it doesn't have to be daunting. Based on years of experience teaching JavaScript development, I have created a curriculum that takes a lot of the pain out of the equation.
Let’s take a look at what this course has to offer:
Each module is broken into a lessons consisting of articles, presentations, and exercises to help you learn a specific part of the Model-Driven apps Client API.
No, you may complete them in any order that you wish.
However, based on teaching JavaScript development courses like this for years, I have put the information in order that I feel would be most advantageous for you to learn.
This is a one-time investment. You get unlimited use of all of the content, sample code, and tutorials, for as long as you want.
Where possible, I try to include real-world samples from actual projects that I have worked on (or am working on).
Again: The goal is to jump-start your ability to utilize JavaScript in a Model-Driven Power Platform application to add functionality not usually
NEW!! JavaScript Development Community
Announcements
About This Course
JavaScript Development Training Roadmap
A Note About Versions
An Introduction to JavaScript
JavaScript or Business Rules?
Business Rules Review (encore Free Webinar Friday presentation)
Revision History
Assemble Your Toolbox
Install the Sample Entity Solution
Creating a New Visual Studio Solution
Setting up your Development Environment
The Problem with Browser Caching
The reality of working with two versions of the Dynamics 365 web interface
Solution to Why is the form editor not working correctly?
New Form Editor or Classic Form Editor?
Reloading Pages in Google Chrome and New Edge Browser
Dynamics 365 Object Model (v8.2)
Dynamics 365 CE Object Model (v9.x)
Common Object Model Methods
Understanding Form Field Attributes and Controls
Working with the v9 Object Model
Introduction to the Execution Context object
Using the executionContext.getFormContext Method
Show Me How: Creating your own object model
JavaScript Web Resource Basics
Show Me How: Create Your First JavaScript Library
Note on Event Handlers
Working with the OnLoad, OnSave, and OnChange Event Handlers
A quick tour of the Form Library Event Handlers
TIP: Removing All JavaScript from a Form
Test Your Knowledge
Webinar Replay: Introduction to Customizations
Webinar Replay: The Art and Science of Model-Driven App Design
Webinar Replay: Eliminating Technical Debt
Webinar Replay: Join the PCF Revolution
JavaScript code for this lesson
Working with Data Methods
Getting and Setting Field Values
Exercise: Getting and Setting Field Values
Show Me How: Getting and Setting Field Values (from Visual Studio)
Setting the field requirement level
Exercise: Setting the Field Requirement Level
Show Me How: Setting the Field Requirement Level
Using the setSubmitMode Method
getAttributeType and getFormat methods
Test Your Knowledge
Additional Data Methods
Finding: Hidden field still required
Source Code for this Lesson
Introduction
L1: Working with Controls
E1: Setting the visibility of a Field
Lesson Learned: Which field, exactly, are you showing or hiding?
E2: Disable a Field
E3: Set a Field's Focus
S3: Set a Field's Focus
L2: Using the getAttribute Method
L3: Using the getControlType Method
Working with Control-Level Notifications
Show Me How: Working with Control Notifications
**** IMPORTANT NOTES ON THIS MODULE ****
Q: Test Your Knowledge
Accessing Controls in the Header and Footer
Accessing Controls in Business Process Flows
Sample code for this lesson
Working with Tabs
Exercise: Setting the Label of a Tab
Show Me How: Setting the Label of a Tab
Exercise: Showing a Tab
Show Me How: Showing a Tab
Exercise: Setting the DisplayState of a tab
Show Me How: Setting the DisplayState of a tab
Show Me How: Adding a custom entity to a Unifiied Interface Application
Show Me How: Running the exercises in the UCI interface
Test Your Knowledge
Bonus Code: Set field visibility based on a Tab's visibility
Sample code for this lesson
Working with Sections
Exercise: Showing a Hidden Section
Show Me How: Showing a Hidden Section
Exercise: Setting the Section Label
Show Me How: Setting the Section Label
Sample Code: Only allow a single checkbox in a section to be checked
Test Your Knowledge
Under Construction! -- But here is where we are headed
Sample code for this chapter
DYNAMICS CRM JavaScript Debugging Basics (webinar replay)
Learning to read a JavaScript error stack trace
A note about this lesson
Debugging JavaScript Solution
Introduction to JavaScript Debugging using Chrome and Internet Explorer
Exercises: Debugging JavaScript - All Labs
Show Me How: Exercise 2
Show Me How: Exercise 3
Show Me How: Exercise 4
Show Me How: Exercise 5
Show Me How: Exercise 6
Show Me How: Exercise 7
Show Me How: Exercise 8
Sample code for this lesson
Introduction to OptionSets and OptionSet Methods
Working with OptionSets
Exercise 1: Using the getInitialValue Method
Show Me How: Using the getInitialValue Method
Exercise 2: Using the getOption Method
Show Me How: Using the getOption Method
Exercise 3: Using the getOptions Method
Show Me How: Using the getOptions Method
Exercise 4: Using the getSelectedOption Method
Show Me How: Using the getSelectedOption Method
Exercise 5: Using the getText Method
Show Me How: Using the getText Method
Exercise 6: Using the clearOptions and addOptions Methods
Show Me How: Using the clearOptions and addOptions Methods
Exercise 7: Use the removeOption Method
Show Me How: Use the removeOption Method
Test Your Knowledge
Bonus: Show Me How: Creating a Dependent OptionSet - Part 1
Bonus: Show Me How: Creating a Dependent Option Set - Part 2
Tech Tip: Extract selected options to a string
L1: Working with the Lookup Data Type
Working with Lookups
Test Your Knowledge
Show Me How Bonus: Working with addCustomView
Sample - addCustomView
Sample Code for this lesson
formContext Collections
Working with JavaScript Collections
Collections Exercises
Show Me How: Build and Display a List of Navigation Items
Show Me How: Build and Display a List of Sections
Show Me How: Build and Display a List of OptionSet Fields
Test Your Knowledge
Form Types
Exercise: Using the getFormType Method
Show Me How: Using the getFormType Method
Form Notifications
Exercise: Using Form Notifications
Show Me How: Using Form Notifications
close Method
refreshRibbon Method
Additional Methods
Test Your Knowledge
Xrm.Navigation Class Overview
Sample code for this module
Working with the Xrm.Navigation Methods
openAlertDialog Notes
Exercise: Using the openAlertDialog Method
Show Me How: Using openAlertDialog
Exercise: Using the openConfirmDialog Method
Show Me How: Using the openConfirmDialog Method
Using the openErrorDialog Method
Using the openFile Method
Exercise: Using the openForm Method
Show Me How: Using the openForm Method
Exercise: Using the openForm (quick create) method
Show Me How: Using the openForm - Quick Create Method
Using the openUrl Method
Exercise: Using the openUrl Method
Show Me How: Using the openUrl Method
Using the openWebResource Method
Exercise: Using the openWebResource Method
Show Me How: Using the openWebResource Method
Test Your Knowledge
Advanced JavaScript (async and await) Methods and Browser Support
Lesson Notes
Show Me How: Working with Async and Await methods
Exercise: Using the getEventSource Method
Show Me How: Using the getEventSource Method
setSharedVariable and getSharedVariable Methods
Sample Code for this Module
getSaveMode Method Return Values
Exercise: Working with the getSaveMode Method
Show Me How: Working with the getSaveMode Method
Exercise: Using the getEventArgs and preventDefault Methods
Show Me How: Using the getEventArgs and preventDefault Methods
Clean Up Your Exercises
Test Your Knowledge
Sample code for this lesson
Client-Side Events Overview
Exercise: Using the addOnChange Method
Show Me How: Using the addOnChange Method
Exercise: Using the fireOnChange Method
Show Me How: Using the fireOnChange Method
Using the removeOnChange Method
Using the addOnSave Method
Using the removeOnSave Method
Using the close Method
Using the Xrm.Page.data.entity.save Method
Test Your Knowledge
Xrm.WebApi Overview
CRM REST Builder Overview
Sample code for this module
Introduction
Working with the getClient, getClientState, and getFormFactor Methods
Working with the getAllowedStatusTransitions Method
Working with the getEntityMetadata Method
Working with the getLearningPathAttributeName Method
Working with the getResourceString Method
Working with the invokeProcessAction Method
Working with the lookupObjects Method
Working with the refreshParentGrid Method
Working with the showProgressIndicator and closeProgressIndicator Methods
Show Me How: Working with the showProgressindicator and closeProgressIndicator
Working with the Xrm.Utility.getGlobalContext Object
Working with clientContext.client Methods
Working with getGlobalContext.organizationSettings
Working with getGlobalContext().userSettings
Under Construction! -- But here is where we are headed
Sample code for this chapter
Sample code for this chapter
Working with Grids - Part 1 - Setup
Introduction to the Grids API
Working with Grids - Part 2 - Understanding the Grid Hierarchy
GridControl Methods
Grid Methods
Show Me How: Working with the Grid
GridRow methods
GetRowData Methods
GridEntity Methods
GridAttribute Methods
GridCell Methods
ViewSelector Methods
Overview - formContext.ui.process
Overview - formContext.data.process
Source code for this module
Overview
Exercise: Working with iFrames
Show Me How: Working with iFrames
Show Me How: Working with the OnReadyStateComplete Event
Overview
Sample code for this module
Xrm.Encoding Overview
Show Me How: Using Xrm.Encoding
Xrm.Device Overview
Xrm.Device.getPosition
Show Me How: Using Xrm.Device.getPosition
Show Me How: Using Xrm.Device.getBarcode
Show Me How: Adding the entityimage field to the Sample Entity - Part 1
Show Me How: Using Xrm.Device.captureImage
Working with the Form Selector Methods
Form Selector Part 1 - Creating a new form
Form Selector Part 2 - Switching forms using JavaScript
Working with formContext.ui.navigation Methods
Xrm.Panel Overview
No, I have a free Introduction to JavaScript course, on this site that you may review to get you jump started.
Most of the content is pre-recorded and new content will be made available every Saturday. Some modules will be face-to-face, because of the nature of the content.
No. You can complete the work at your own pace, in any time-frame you wish.
The course has a built-in community forum should questions arise.
We will try and have one live meeting per month to catch up and discuss what questions people may have in a live environment. That is really dependent on my schedule.
In addition, some of the lessons are taught live because of their complexity, it is just better to review the topics in person.
Recordings of live-lessons or meet-ups will be available for those who can't attend in person.
That will totally depend on the week. I would say to dedicate two hours per week to review the material and perform the exercises. You may require less, but you may also require more.
Additionally, if you feel that one of the modules is not something you would need at the present time, you can always skip it and come back to it later, when it is more relevant to the projects you are working on.
Well, for one, you have strenghened your knowledge of the customizations aspects of Dynamics 365.