data:image/s3,"s3://crabby-images/e4c63/e4c636700369da7198a677e5cc9b556332e390c9" alt=""
A Power Apps Component Framework (PCF) control that provides dynamic, configurable buttons based on Dataverse settings. This control allows you to create flexible, context-aware buttons that can be used for custom actions and navigation in your Power Apps forms.
PCFSmartButtons.mp4
- Dynamic Button Configuration: Configure buttons directly in Dataverse without code changes
- Visibility Conditions: Show/hide buttons based on dynamic expressions
- Custom Actions: Execute custom scripts or navigate to URLs
- Field Value Integration: Use record field values in button labels, tooltips, and URLs
- Smart Caching: Optimized performance through intelligent caching of record data
- Error Handling: Robust error handling and graceful fallbacks
- Fluent UI Integration: Modern, consistent UI using Fluent UI components
The easiest way to install the control is to download and import the solution from the releases page. You can choose either:
- Managed Solution: For production environments (recommended)
- Unmanaged Solution: For development environments
The solution package includes:
- The PCF Smart Button control
- Button Configuration table
Create records in the Button Configuration table with the following fields:
- Name: Unique identifier for the button configuration
- Table Name: Entity/table the button appears on (e.g., 'contact')
- Button Label: The text to display on the button
- Button Tooltip: Hover text for the button (optional)
- Button Position: Numeric order for button placement
- Button Icon: Fluent UI icon name (optional) - Browse available icons
- Visibility Expression: Condition for showing/hiding button
- URL: The URL to navigate to when clicked (optional)
- Show as: Choose between Button or Link display
- Action Script: Custom script to execute on click (optional)
Here's an example of a fully configured button:
Name: Test Button 1
Table Name: contact
Button Label: This is a label {parentcustomerid.parentaccountid.websiteurl}
Button Tooltip: This is a tooltip {parentcustomerid.parentaccountid.websiteurl}
Button Position: 1
Button Icon: Send
Visibility Expression: {parentcustomerid.parentaccountid.websiteurl} != null
URL: {parentcustomerid.parentaccountid.websiteurl}
Show as: Button
Action Script: window.open("{parentcustomerid.parentaccountid.websiteurl}")
All text fields (Label, Tooltip, URL, Visibility Expression, and Action Script) support dynamic tokens:
- Use curly braces to reference field values:
{fieldname}
- Access related records using dot notation:
{lookup.fieldname}
- Chain multiple lookups:
{parentcustomerid.parentaccountid.websiteurl}
- Support for async/await operations
- Full access to form context and Xrm object
- Example with async operation:
await Xrm.Navigation.openUrl("{websiteurl}");
- Uses Fluent UI icons (formerly Fabric icons)
- Browse available icons at UI Fabric Icons
- Use the friendly name from the icon gallery in the Button Icon field
JavaScript expressions that determine button visibility:
// Show only if website URL exists
{parentcustomerid.parentaccountid.websiteurl} != null
// Show based on status
{statuscode} === 1
// Complex conditions
{revenue} > 10000 && {statuscode} === 1
- Node.js
- npm
- Power Platform CLI (PAC)
- Visual Studio Code (recommended)
-
Install Power Platform CLI globally:
npm install -g @microsoft/power-apps-cli
-
Install dependencies:
npm install
-
Create authentication profile:
pac auth create --url https://yourorg.crm.dynamics.com
-
Create a new PCF project (if starting from scratch):
pac pcf init --namespace YourNamespace --name YourControlName --template field
-
Build the control:
npm run build
-
Start the test harness:
npm start watch
-
Build the solution:
pac solution build
-
Package the solution:
pac solution pack
-
Push to your environment:
pac pcf push --publisher-prefix YourPrefix
npm run build
npm test
We welcome contributions! Please see our contribution guide for details.
This project is licensed under the MIT License - see the LICENSE file for details.
For issues and feature requests, please open an issue on GitHub.