Skip to main content

Notifications

Community site session details

Community site session details

Session Id :
Service | Customer Service, Contact Center, Fie...
Suggested answer

Power Pages Portal - Custom Form

(2) ShareShare
ReportReport
Posted on by 8
Hi,
 
I'm trying to build portal site using power pages based on Dataverse tables. Instead of using built in form which is basically designed based on Model driven app will it allow us to create custom Layout form using HTML + Liquid Code or JS? Because when I try to create, I'm repeatedly facing Liquid Error?
 
Liquid error: Value cannot be null. Parameter name: source
 
  • Suggested answer
    Daivat Vartak (v-9davar) Profile Picture
    4,709 Super User 2025 Season 1 on at
    Power Pages Portal - Custom Form
    Hello CU20030939-0,
     

    You've hit on a common point of frustration when trying to customize Power Pages forms beyond the standard Dataverse form rendering. The "Liquid error: Value cannot be null. Parameter name: source" error is a frequent indicator that you're attempting to access or manipulate data in a way that Power Pages' Liquid engine isn't expecting.

    Understanding the Limitations:

    • Power Pages Form Rendering: While you can embed Liquid code and JavaScript within Power Pages, the core rendering of Dataverse forms is still largely controlled by the platform's internal mechanisms.
    • Built-in Form Behavior: Power Pages forms, by default, rely heavily on the metadata and configuration defined within the Dataverse table and its corresponding model-driven form. This means they are designed to work within the constraints of that structure.
    • Liquid Limitations: Liquid is primarily intended for templating and dynamic content display, not for completely replacing the form's data handling and submission logic.

    •  

    Why You're Getting the Liquid Error:

    • Data Source Issues: The "Value cannot be null. Parameter name: source" error typically arises when Liquid is trying to access data from a source that doesn't exist or is null.
    • Incorrect Context: This often happens when you're trying to directly manipulate form fields or data without the necessary context provided by Power Pages' form rendering process.
    • Direct Field Access: Directly accessing Dataverse table fields within Liquid without using the proper form-related Liquid objects and methods can lead to this error.

    •  

    Can You Create Custom Layout Forms Using HTML + Liquid + JavaScript?

    • Partial Customization: Yes, you can achieve a degree of customization using HTML, Liquid, and JavaScript. However, you cannot completely bypass the underlying form handling.
    • HTML for Layout: You can use HTML to create custom layouts and styles for your form elements.
    • Liquid for Dynamic Content: Liquid can be used to dynamically populate form fields with data or to conditionally display form elements.
    • JavaScript for Client-Side Logic: JavaScript can be used for client-side validation, interactivity, and some level of data manipulation.

    •  

    How to Approach Custom Forms in Power Pages:

    1. Use Entity Forms as a Foundation:

      • It's generally recommended to start with the standard Entity Form component.
      • This provides the necessary data context and handles the basic form submission logic 

    2. Enhance with Liquid:

       

      • Use Liquid to customize the form's appearance and behavior.

      • You can use Liquid to:

        • Pre-populate fields with data.
        • Conditionally display fields or sections.
        • Format field values.  

    3. Add JavaScript for Client-Side Functionality:

      • Use JavaScript for client-side validation and interactivity.

      • You can use JavaScript to:

        • Validate form input.
        • Dynamically show/hide form elements.
        • Perform calculations.

        •  

    4. Avoid Direct Dataverse Field Manipulation in Liquid:

       

      • Instead of directly accessing Dataverse table fields, use the form-related Liquid objects and methods provided by Power Pages.
      • Refer to the Power Pages documentation for the correct Liquid syntax to work with forms.

    5. Use Web API for Advanced Data Operations:

       

      • For more complex data operations (e.g., retrieving related records, updating data), use the Power Pages Web API.
      • This allows you to interact with Dataverse data from your JavaScript code.


      •  

    Example Scenario (Partial Customization):

    • Custom Layout: Use HTML to create a custom layout for your form, including custom CSS for styling.

    • Dynamic Data: Use Liquid to pre-populate a field with the current user's name:
      <input type="text" value="{{ user.fullname }}" />

    • Client-Side Validation: Use JavaScript to validate the form input before submission.

     

    Important Considerations:

    • Security: Be mindful of security when using JavaScript to manipulate form data.
    • Performance: Optimize your Liquid and JavaScript code for performance.
    • Maintainability: Keep your code clean and well-documented.
    • Power Pages Documentation: Refer to the official Power Pages documentation for the latest information on Liquid and JavaScript usage.

    •  

    In summary, while you can't completely replace the Power Pages form rendering with custom HTML + Liquid, you can achieve a significant level of customization by enhancing the standard Entity Form with Liquid and JavaScript. Focus on using Liquid for dynamic content and JavaScript for client-side logic, while relying on the Entity Form for core data handling.

     
    If my answer was helpful, please click Like, and if it solved your problem, please mark it as verified to help other community members find more. If you have further questions, please feel free to contact me.
     
    My response was crafted with AI assistance and tailored to provide detailed and actionable guidance for your Microsoft Dynamics 365 query.
     
    Regards,
    Daivat Vartak
  • Suggested answer
    Tom_Gioielli Profile Picture
    1,069 on at
    Power Pages Portal - Custom Form
    I was able to find this blog post that seems like it may be related. Maybe something in there to point you in the right direction?
     

Under review

Thank you for your reply! To ensure a great experience for everyone, your content is awaiting approval by our Community Managers. Please check back later.

Helpful resources

Quick Links

🌸 Community Spring Festival 2025 Challenge 🌸

WIN Power Platform Community Conference 2025 tickets!

Jonas ”Jones” Melgaard – Community Spotlight

We are honored to recognize Jonas "Jones" Melgaard as our April 2025…

Kudos to the March Top 10 Community Stars!

Thanks for all your good work in the Community!

Leaderboard

#1
André Arnaud de Calavon Profile Picture

André Arnaud de Cal... 293,354 Super User 2025 Season 1

#2
Martin Dráb Profile Picture

Martin Dráb 232,498 Most Valuable Professional

#3
nmaenpaa Profile Picture

nmaenpaa 101,158 Moderator

Leaderboard

Featured topics

Product updates

Dynamics 365 release plans