Below is the quick step by step guide to get started (sort of Hello World example)
- Install NPM (that comes with Node.js)
- Install Visual Studio 2017 or later or Download .NET Core 2.2 along with Visual Studio Code.
- Create the new folder for the project, and in Developer Command Prompt for VS 2017 navigate to the folder and run the below command to create a new component project
pac pcf init
– -namespace <namespace for the component>
– -name <name of the component>
– -template <component type>
data:image/s3,"s3://crabby-images/b6330/b633067e89d6503fe9eb4dba1087269de6c1014a" alt=""
It adds the following files in the folder.
data:image/s3,"s3://crabby-images/ac203/ac203de9802846fa19a4b2dd826aaacd726c751e" alt=""
- Next run npm install command to install the project dependencies.
data:image/s3,"s3://crabby-images/6537c/6537ca6b91db05e2dd8e9d3bfc395d3e24084076" alt=""
- Open the ControlManifest.Input.xml file created inside the folder created with the control’s name.
data:image/s3,"s3://crabby-images/94789/947897948835991bef9b37e8f5d3ed99ed2ea050" alt=""
data:image/s3,"s3://crabby-images/958c4/958c4d78724cd6475f64fc3bfdf1d9134bcb2fed" alt=""
- Here we have opened it in Visual Studio Code, for this simple example purpose let us not change the default values.
- Open the index.ts which wherein we’d be writing code for our custom control
data:image/s3,"s3://crabby-images/f7c29/f7c2995d2ed9102ddd4b1f41390c73f0fb195ef0" alt=""
- Add the following line of code to add a label control that will display that GUID of the record.
data:image/s3,"s3://crabby-images/580f8/580f898fc5592120649874217a7f45321a4f39b5" alt=""
- Run npm run build command to build the control
data:image/s3,"s3://crabby-images/7764a/7764a78e9a05d06930c51921c3851fc0a76e69d8" alt=""
- To test the control run npm start command
data:image/s3,"s3://crabby-images/2bb86/2bb8660b819c1a7889586e78ae5913e64d767333" alt=""
*Use ctrl + c è to terminate the job.
data:image/s3,"s3://crabby-images/f7568/f7568b15b10100c5177ba755a3edf6d64ef5f1ed" alt=""
- Create a new folder to hold the solution
data:image/s3,"s3://crabby-images/50bf7/50bf72a845a94e1b1004f1cf3b0c7656007d856a" alt=""
- Run the below command to define the publisher name and prefix and initialize the solution files creation
pac solution init --publisher-name [publisher name] --publisher-prefix [publisher prefix]
pac solution init --publisher-name PCFControls --publisher-prefix tst
data:image/s3,"s3://crabby-images/2224b/2224b964af948a5c9251d09d9d7ee36e71fd6490" alt=""
- Run the below command to add reference to our custom control in the solution
pac solution add-reference – -path [path to pcfproj file]
i.e. reference of the below path.
data:image/s3,"s3://crabby-images/2100b/2100bd3700a308597f7a28474a27aaaec1a61bd2" alt=""
data:image/s3,"s3://crabby-images/12e12/12e1262699fcb1349f5bac06f5d7d848b7a9162d" alt=""
- This creates the file with extension cdsproj
data:image/s3,"s3://crabby-images/50b18/50b182fb83955120e0335b90bbca5238760bb17c" alt=""
- To generate Zip File run the below command in the Developer Command Prompt for Visual Studio 2017
- MSBUILD /t:restore
- MSBUILD
data:image/s3,"s3://crabby-images/d1414/d14148ed7372f5e6c0e2942becc944c4205441da" alt=""
data:image/s3,"s3://crabby-images/65d39/65d39849bc7d7b88368d4afb6181a8e8640aff6a" alt=""
- This adds the Solution zip in the bin Debug folder.
data:image/s3,"s3://crabby-images/bdafa/bdafa2614778e5dcf5479e3bb70b6557c08e7695" alt=""
- To get both managed and unmanaged solution, update the cdsproj file
data:image/s3,"s3://crabby-images/90f75/90f750df0c199044b92577088e60d733923ee01f" alt=""
- We can see both managed and unmanaged solution created.
data:image/s3,"s3://crabby-images/7328b/7328b927053c0846de46f22e83f24892d4ad032f" alt=""
- Import the solution in Dynamics 365 CE and open any of the entity’s form. Here we have created a new text field named GUID in the Contact form and have set our custom control for that field.
data:image/s3,"s3://crabby-images/2de18/2de18f4372de9f23ecff16b166305cbd0f047426" alt=""
For reference à
data:image/s3,"s3://crabby-images/200b1/200b1839a39a50a6a003128252d1ecec201a3070" alt=""
- After publishing the changes, we can see the GUID being displayed in the form.
data:image/s3,"s3://crabby-images/0af26/0af2610e89738f72e8b548eee1194147b50d2785" alt=""
- To update the control, change the version for it in the ControlManifest.Input.xml
data:image/s3,"s3://crabby-images/f7e8b/f7e8b419619d5e6fc9ae05cda1bc43cbcfdd4ca4" alt=""
Followed by
- npm run build
- msbuild
- Importing the new solution file generated
In a nutshell below are the high-level steps à
1. Install npm
2. Install PowerApps CLI
3. Install Visual Studio 2017 or later
4. Create a new folder for the project.
5. Navigate to the folder in Developer Command Prompt and run the following command to create the component project
PAC PCF INIT –NAMESPACE <COMPONENT NAMESPACE> –NAME <COMPONENT NAME> –TEMPLATE <COMPONENT TYPE>
data:image/s3,"s3://crabby-images/f2ee8/f2ee830cce084ef5d332408141b0bf061243c474" alt="1"
6. Install the project dependencies using below command
NPM -INSTALL
7. Update ControlManifest.Input.xml
8. Update index.ts
9. Build the project
NPM RUN BUILD
10. Use the below command to test the component
NPM START
11. Create a folder for holding the solution zip and related files. Navigate to that folder and run the below command.
PAC SOLUTION INIT – -PUBLISHERNAME [PUBLISHER NAME] – -CUSTOMIZATIONPREFIX [PUBLISHER PREFIX]
data:image/s3,"s3://crabby-images/f4db0/f4db01238aa33494e8dcb50bab0df21d7981794c" alt="2"
12. Add reference of the custom component in the solution
PAC SOLUTION ADD-REFERENCE – -PATH [PATH TO PCFPROJ FILE]
data:image/s3,"s3://crabby-images/3942a/3942a565dfb618aece1a7174fa05507206ae15bd" alt="3"
13. To create the Solution Zip File
MSBUILD /T:RESTORE
MSBUILD
data:image/s3,"s3://crabby-images/9253c/9253c7e98a292722b48f4fe8cdfd9bc475bfd5c6" alt="4"
14. Import the solution file and use it inside Dynamics 365 CE.
lastly – Don’t forget to check the wonderful PCF Gallery
https://pcf.gallery/
Hope it helps..
No comments:
Post a Comment