Introduction
A new UI toolkit from Salesforce called Lightning Design System provides UI patterns and specialized components. Here, we are going to implement Lightning Design System in Visualforce page. We normally design the Visualforce page with the Salesforce standard CSS and tags that incorporate standard style. Modern enterprise apps are created through Salesforce lightning since it uses the Lightning CSS. To implement the lightning design in Visualforce page, Salesforce now released lightning CSS and guidelines to use those style classes in html and apex tags. This gives better user experience that is consistent with Salesforce core features. Let us see how we can implement this style.
Stylesheet
We can download the design system from the below link
https://lightningdesignsystem.com/downloads/
Either we can clone it from GitHub or download the zip file. Salesforce also provides a tool for us to create custom-scoped CSS. For your information
https://tools.lightningdesignsystem.com/css-customizer
Here using the CSS-customizer, I have added my own scoping class called “MST” and generated the zip file. This includes pre-built CSS framework, font and icons. We now upload the file in static resource.
LDS in Visual Force Page
To use the stylesheet in VF page
<apex:stylesheet value=”{!URLFOR($Resource.SLDS_Custom, ‘assets/styles/salesforce-lightning-design-system-vf.css’)}” />
Assets includes styles for Visualforce and style which is specially compiled for lightning.
Components
Lightning Design System reflects the pattern and components that support the Salesforce product. I have used some components in this article. Let see how the components are used in Visualforce page.
Global Header
The global header applicable across all contexts in the page/app
data:image/s3,"s3://crabby-images/f922b/f922b3ab3f8076cf5261c44a06695f2aa9ed2b18" alt="lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/0863b/0863b3ac0599f29c8f55fd62bb80b7ad9f3293b5" alt=""
Global Navigation
This contains list of navigation links, App Launcher, App Name, and Pages that the App includes.
data:image/s3,"s3://crabby-images/59c7c/59c7c0b6fb48e8bc2cb4d1fb2e1957915eb3ad05" alt="lightning design system"
data:image/s3,"s3://crabby-images/fb75f/fb75fa279e0e7faf12baafa004b6c7f2b3a6e072" alt=""
Screenshot
data:image/s3,"s3://crabby-images/bc565/bc56542357f6ba10e349a61754225496d547dadb" alt=""
Here I have used two tabs to navigate and perform CRUD operation in a custom object. List item tab lists all the created records. JQuery is used to navigate over the tabs.
Forms
The form contains interactive lightning design to submit information
Input text box
data:image/s3,"s3://crabby-images/9075c/9075cd970a375315cc98b459b2517d570aa8032e" alt="lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/6a4b9/6a4b909ddbed3459d8e78b8d6785a428c4bbf9e4" alt=""
Select List
The actual lightning style is done using <select> element which can also be implemented in <apex:selectList>
data:image/s3,"s3://crabby-images/a6d7c/a6d7c15aba3663f5f46107cd5e0698f3ef8667b4" alt="lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/89218/892184a9377cf1ae6fdba888e4a4651c636109fd" alt="salesforce lightning design system"
Checkbox
To ensure that checkboxes look same everywhere, Salesforce use a custom DOM.
data:image/s3,"s3://crabby-images/b7c5d/b7c5d794ad2af1e78b87f8bea39b5d1f43ec82c4" alt="salesforce lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/66507/665078f3810af491bf0433c8d2ff5d4220f906de" alt=""
In this stock app a script is used to convert the selected Ids to JSON and pass it to the method through <apex:actionFunction>.
data:image/s3,"s3://crabby-images/a8847/a88475dc72557a4dbdca27f2a33c546e2b9a8c90" alt=""
Docked Form Footer
The Form footer has buttons. The actual lightning button style is done using <button> element which can also be implemented in <apex: commandlink >
data:image/s3,"s3://crabby-images/8e5c2/8e5c2449086785ad7853c76715f2e87307afcaea" alt="salesforce lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/87295/872955a1ccbef898cb6c7c0de10e0d028634aa73" alt=""
Data Tables
Data tables are enhanced version of html table. Here to display dynamic data, <apex:repeat> is used to iterate the table row.
data:image/s3,"s3://crabby-images/0ab65/0ab651ac6f99ee8bc3f9c0c0fe6dbff3303ba78a" alt="salesforce lightning design system"
data:image/s3,"s3://crabby-images/07a26/07a26aaba12640a952fd05856ddcd4c31f568463" alt="salesforce lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/b2a4c/b2a4c12cd32ce321c9b60985101f66cc1bafc49a" alt="salesforce lightning design system"
Spinners
CSS loading indicators are used to show while retrieving data or when the page loads.
data:image/s3,"s3://crabby-images/7b88d/7b88d6f1b88937b3b179ea9e3a4163a044fd2ee5" alt="salesforce lightning design system"
Screenshot
data:image/s3,"s3://crabby-images/78281/782818ff96d27aa6f8251af123a430aa52773646" alt="salesforce lightning design system"
Also, the other items–Utilities Grid, Alignment, Spacing, Notifications (To display the information or error message popup) are used in this stock app.
Grid:
Lightning Design System grid provides a flexible user experience, and it is mobile-first. It includes helper classes such as alignment, padding etc., which we can alter.
For example, in this stock app, grid CSS is used to display the record detail and history information of the respective record on the page.
Screenshot
data:image/s3,"s3://crabby-images/c8f92/c8f925d91d9ee21093ce743aec4a07e75f8d2c66" alt="salesforce lightning design system examples"
Other Screenshots:
Home:
data:image/s3,"s3://crabby-images/8db0d/8db0d959b7b54a212e959b1a14001cdca657d91b" alt="salesforce lightning design system examples"
Validation Popup:
data:image/s3,"s3://crabby-images/ae727/ae7270c8db164c495ac286847911aee35b7745ad" alt="salesforce lightning design system examples"
Create Record:
data:image/s3,"s3://crabby-images/ae727/ae7270c8db164c495ac286847911aee35b7745ad" alt="salesforce lightning design system examples"
List Page:
data:image/s3,"s3://crabby-images/ae727/ae7270c8db164c495ac286847911aee35b7745ad" alt="salesforce lightning design system examples"
Detail page:
data:image/s3,"s3://crabby-images/c4e5d/c4e5d93b37bf6428d3d5b03de307cc1fcc2c2012" alt="salesforce lightning design system examples"
Delete Record:
data:image/s3,"s3://crabby-images/414a1/414a1e4e85e9d2cdfaab89cc4a51c401b9fe0fb7" alt="salesforce lightning design system examples"
Edit Record:
data:image/s3,"s3://crabby-images/d0d09/d0d09dd74f892381cea43fbff67329bedf075481" alt="salesforce lightning design system examples"
Summary
The default Salesforce features can be used with Lightning Design System. Tags like <apex:pageblock> are not supported in Lightning Design System which means this follows default style but can be customized and overridden by adding custom styles. Use Lightning Design to help users work better, smarter, and faster.
Web Reference Links
https://lightningdesignsystem.com/
https://lightningdesignsystem.com/platforms/visualforce/
https://trailhead.salesforce.com/en/lightning_design_system/lightning-design-system2