Friday, May 6, 2022

Data Binding

 Data binding is a technique, where the data stays in sync between the component and the view.

Whenever the user updates the data in the view, LWC updates the component. When the component gets new data, the LWC updates the view.

Data Binding is of  two  types:

One-way Data Binding:

One-way data binding is a situation where information flows in only one direction in our case from the controller to the template(HTML).

Two-Way Binding:

Two-way data binding in LWC will help users to exchange data from the controller to the template and form template to the controller.

 It will help users to establish communication bi-directionally.

  • The Lightning Web Components programming model has given us some decorators that add functionality to property or function.
  • @track is the decorator that helps us to track a private property's value and re-render a component when it changes.
  • Tracked properties are also called private reactive properties.
  • @track helps us to achieve two-way data binding

Track a property only if you want the component to re-render when the property's value changes.

Note: Don't track every private property.

 

Saturday, April 30, 2022

Salesforce LMS


Lightning Message Service (LMS) is the Salesforce technology of its kind that facilitates communication between Visualforce, Lightning Web Components, and Aura Components on a Salesforce Lightning Page.



 With the launch of LMS, Salesforce developers obtained a simple and seamless API for publishing messages throughout the Lightning Experience platform and subscribed to messages that originated from anywhere within Lightning Experience.

·         In LWC we can access Lightning Message Channel with the scoped module @salesforce/messageChannel.

·         In Visualforce, we can use global variable $MessageChannel.

·         In Aura, use lightning:messageChannel in your component

Create Lightning Message Channel

Currently we can create Lightning Message channel with Metadata API. You can create the same with the help of VsCode.

  You need to create one DX project then you need to place your message channel definition with the suffix .messageChannel-meta.xml in the force-app/main/default/messageChannels directory. like below folder structure.



 Sample Message-meta.xml

<?xml version="1.0" encoding="UTF-8"?>

<LightningMessageChannel xmlns="https://soap.sforce.com/2006/04/metadata">

    <masterLabel>Counter</masterLabel>

    <isExposed>True</isExposed>

    <lightningMessageFields>

        <fieldName>operator</fieldName>

    </lightningMessageFields>

    <lightningMessageFields>

        <fieldName>constant</fieldName>

    </lightningMessageFields>

</LightningMessageChannel>

Import a Message Channel:

Here’s how to import a Lightning message channel that a component can use to communicate via the Lightning Message Service.

// Syntax

import channelName from '@salesforce/messageChannel/channelReference';

// Syntax for resources in a managed package

import channelName from '@salesforce/messageChannel/namespace__channelReference';

// Example

import recordSelected from '@salesforce/messageChannel/Record_Selected__c';

channelName—An imported symbol that identifies the message channel.

channelReference—The API name of the message channel.

namespace—If the message channel is in a managed package, this value is the namespace of the managed package. If the message channel is not in a managed package, do not include a namespace.

Restrictions in LMS:

Here are several restrictions to the Lightning Message Service.

 >Under the following circumstances, you are unable to utilise LMS:

· Salesforce Mobile

· Communities

· AppExchange

Note:

LMS cannot be used to communicate with VF page contained in an iframe in Aura/LWC.

Examples of data that you can pass in a message include strings, numbers, booleans, and objects. A message cannot contain functions and symbols.

The lightning:messageChannel component is only available in Lightning Experience. 

Saturday, April 23, 2022

Custom settings vs Custom Metadata

 Custom settings are similar to custom objects and enable application developers to create custom sets of data, as well as create and associate custom data for an organization, profile, or specific user.

All custom settings data is exposed in the application cache, which enables efficient access without the cost of repeated queries to the database. This data can then be used by formula fields, validation rules, flows, Apex.

Custom metadata is customizable, deployable, packageable, and upgradeable application metadata.


Monday, April 11, 2022

Salesforce Source-driven Development

 In source-driven development, the source is organized into artifacts based on group features or customizations that are delivered together. Salesforce DX incorporates the artifact-based approach to organizing the source. 

There is the ability to shift the source of truth from the org to a version control system (VCS), along with the use of popular collaboration technologies including Git and other test-build automation tools.

A Salesforce DX project is a local directory structure of your metadata in source format. It lets you develop and test with Salesforce DX tooling.

Salesforce DX allows developers to use Git and source repositories when doing any sorts of development on Salesforce platform.

Scratch orgs are a central feature of Salesforce DX. The Scratch org is a source-driven and disposable deployment of Salesforce code and metadata.

Dev Hub allows you to create and manage scratch orgs. It is also essential create and manage second-generation packages, and use Einstein features.




Wednesday, March 30, 2022

Salesforce Vlocity Dataraptor

 Vlocity DataRaptor moves data into and out of Vlocity applications. It's commonly referred to as an extract, transform, and load application.

DataRaptors allows you to read and write data to and from your Salesforce org.

 There are four types of DataRaptor: 

Turbo Extract, Extract, Transform, and Load.

Turbo Extract: Read data from a single Salesforce object type, with support for fields from related objects. Then select the fields to include. Formulas and complex field mappings aren’t supported.

Extract: Read data from Salesforce objects and output JSON or XML with complex field mappings. Formulas are supported. We can data from one or more Objects.

Transform: Perform intermediate data transformations without reading from or writing to Salesforce. Formulas are supported.

Load: Update Salesforce data from JSON or XML input. Formulas are supported.

With DataRaptor:

  • No coding is required because it abstracts queries.
  • Any DataRaptor can be saved, exported, and reused.

Monday, March 21, 2022

Salesforce Content Security Policy

 The Lightning Component framework uses Content Security Policy (CSP) to impose restrictions on content. 

The main objective is to help prevent cross-site scripting (XSS) and other code injection attacks.To use third-party APIs that make requests to an external (non-Salesforce) server or to use a WebSocket connection, add a CSP Trusted Site.

CSP is a W3C standard that defines rules to control the source of content that can be loaded on a page. All CSP rules work at the page level and apply to all components and libraries.

When you define a CSP Trusted Site, the site’s URL is added to the list of allowed sites for the following directives in the CSP header.

connect-src

frame-src

img-src

style-src

font-src

media-src


This change to the CSP header directives allows Lightning components to load resources, such as images, styles, and fonts, from the site. It also allows client-side code to make requests to the site.


Note: 

  • LEX - CSP header is approved only for your organization’s Lightning Experience.
  • Communities - CSP header is approved only for your organization’s Lightning Communities.
  •  You can’t load JavaScript resources from a third-party site, even if it’s a CSP Trusted Site. To use a JavaScript library from a third-party site, add it to a static resource, and then add the static resource to your component. After the library is loaded from the static resource, you can use it as normal.


Friday, March 4, 2022

Error : " Installing plugin @salesforce/lwc-dev-server... ! " when installing in my Visual Studio in Windows

Steps to fix the above Issue:

====================

1. Installation of Nodejs software and disconnect from office network VPN (if connected).

2. >Install node gyp by running 

      npm install -g node-gyp

    >In command prompt or whatever command-line interface you use.

3. And then after that, you can run 

     npm install --global --production windows-build-tools

4. And finally tried the below command it worked after 2 3 times..

     sfdx plugins:install @salesforce/lwc-dev-server

ES12 new Features