Developer Student Guide
Page Templates
Table of Contents
Lesson: Liquid Templating
Exercise: Add Liquid to the Copy Page
Edit the copy of a Web Page
Add some basic Liquid content
Exercise: Create a new Snippet and render it using Liquid
Create a Snippet record
Edit the copy of a Web Page
Exercise: Add Liquid to a front-side-editable Snippet
Edit a Snippet through front-side editing
Add a greeting to the current user
Exercise: Add Liquid to a front-side-editable Snippet
Add a new Web Template Record in the CRM
Lesson: Page Template
In this lesson we will study the process of creating a new .aspx Page Template in our Web Project.
Exercise: Add a new Page Template
In this exercise we will add a new Page Template to your web project that can be used for future exercises in this chapter. The Page Template will be a fairly bare-bones template with minimal functionality, which we will add functionality to over the course of this chapter.
In VS 2012
- Open Visual Studio 2012.
- Select File Open Project
- Navigate to: C:\Program Files\ADXSTUDIO\XrmPortals\7.X.XXXX\Samples.
- Select AdxstudioPortals.sln then click the Open button
- In the Solution Explorer, expand the project: MasterPortal
- Navigate to the Pages folder
- Right-click on the pages Folder and select Add > New Item
- Choose Web Form using Master Page
- Name it “Example.aspx”
- Click Add
- Choose WebFormsContent.master as the master page
- A new page will appear with blank Content tags – you can remove all of them except the “MainContent” Content tag if you wish.
- Inside the “MainContent” Content tag; Copy and paste the following markup:
crm:CrmEntityDataSourceID="CurrentEntity"DataItem="<%$ CrmSiteMap: Current %>"runat="server"/>
adx:PropertyDataSourceID="CurrentEntity"PropertyName="adx_copy"EditType="html"runat="server"/>
- Just below the @Page declaration, add:
<%@ImportNamespace="Adxstudio.Xrm.Web.Mvc.Html"%>
- Change the class definition of the page (in the code behind) so that it inherits from PortalPage:
publicpartialclassExample : PortalPage
In CRM:
- Navigate to Portals Websites
- Open the Community Portal (or Training Portal) website entity in the CRM
- Navigate to related Page Templates using the right-most upper navigation dropdown (or use the sub-grid)
- Just above the grid, click the button to Add a New Page Template
- Complete the following Fields:
- Name: Example Template
- Website: Basic Portal
- Rewrite URL: ~/Pages/Example.aspx
- Click Save
- Navigate to related Web Pages
- Click the Add New Web Page button
- Complete the following fields:
- Name: Example Page
- Website: Basic Portal
- Parent Page:Contentor Workspace
- Partial Url: example
- Page Template: Example Template
- Publishing State: Published
- Copy: This is my example page
- Set the value of the Summary field to: This is the Summary
- On the Ribbon, click the Save button, then close the window
- Now rebuild the project in VS 2012
- Navigate to the Portal and navigate to the new example page you just created
Exercise: Add a Property Control
In this Exercise we will add a property control which will display an attribute from the current page.
Visual Studio
- Navigate to the Pages folder.
- Open Example.aspx you created earlier.
- Copy the following markup:
adx:PropertyID="Summary"DataSourceID="CurrentEntity"
PropertyName="adx_summary" EditType="text"
runat="server"/>
- And paste it beneath the <crm:CrmEntityDataSource> control already on the page
- Note that the only thing different between this control and the other <crm:Property> control on this page is that the data is being drawn from the summary attribute of the web page rather than the adx_copy.
- Save and rebuild.
- Navigate to your portal
- When the Example page loads, you should now see the title you added in Step 2 displayed just above the Example page copy.
- Note the Datasource that both property controls on the page are data-binding to:
crm:CrmEntityDataSourceID="CurrentEntity"DataItem="<%$ CrmSiteMap: Current %>"runat="server"/>
Exercise: Use the Attribute Helpers
- Got your Example.aspx Page Template handy? Great, because we are going to keep using that for everything from now on, just because. Add the following to the markup inside the MainContent content placeholder:
<%=Html.Attribute("adx_copy") %>
- Save all.
- Now rebuild the project in VS2012
- Navigate to the Portal and navigate to the new example page you just created.
Experiment
1)Experiment with the different ways to use the Attribute Helpers:
<%=Html.Attribute(Html.Website(), "adx_name") %>
<%=Html.TextAttribute("adx_title") %>
<%=Html.HtmlAttribute("adx_summary") %>
<%=Html.AttributeLiteral("adx_copy") %>
Exercise: Use the Site Setting Helpers
IN CRM
- Navigate to Portals > Websites > Basic Portal
- Navigate to Site Settings
- Create a new Site Setting:
- Name: Example Boolean Setting
- Value: true or false
- Save & Close
In Vs 2012
- Open Example.aspx
- Add the following to the markup:
<%if (Html.BooleanSetting("Example Boolean Setting") ?? false) %>
<% { %>
p The Boolean Setting is set to true!/p
% }else { %>
p The Boolean Setting is set to false! </p
<% } %>
- Save all
- Rebuild the project
- Browse to the portal and open up the example page
Experiment
1)Try creating a setting that takes an integer value and use the Html.IntegerSetting() helper to get and use this value.
Exercise 3: Use the Site Marker Helpers
- Navigate to Basic Portal in the CRM
- Create the News page as a child page of the home page if you have not already done so (this was done in an earlier exercise) Partial Url: news
- Click on the Site Markers navigation item.
- On the Ribbon, click the Add New Site Marker button. This site marker will specify the destination of the hyperlink that we will be placing on the page template (and the link will always point to that page)
- Complete the following fields:
- Name: My News
- Web Site: Community Portal (or Training Portal)
- Page: News
- On the Ribbon, click the Save and Close button.
- In VS 2012, Open Example.aspx
- Add the following to the markup of the page, In the “Main Content” content area:
<%=Html.SiteMarkerLink("My News") %>
- Save and rebuild the project then browse to see the results
Exercise: Use the Snippet Helpers
- In the CRM, open Portals > Websites > Basic Portal
- Navigate to Content Snippets
- Create a new Content Snippet:
- Name: Example Content Snippet
- Value: This is a Snippet.
- Save & Close
In VS 2012
- Open Example.aspx
- Add the following to the markup of the page, In the “Main Content” content area:
%=Html.TextSnippet("Example Content Snippet") %>
- Save all, rebuild, and browse to see the results.
Experiment
1)Experiment with different ways to use the Snippet Helpers according to the usages below. You can also create new Content snippets and try different values for those snippets.
<%=Html.HtmlSnippet("Example Content Snippet") %>
<%=Html.Snippet("Example Content Snippet") %>
<%=Html.SnippetLiteral("Example Content Snippet") %>
Exercise: Use the Web Link Helpers
In this exercise, we will utilize the MVC Web Links Helpers to render the links of a Web Link Set in the CRM.
- Under Basic Portal, Click on the related Web Link Sets navigation item (top right-hand dropdown)
- On the Ribbon, click the Add New Web Link Set button.
- In the Name field, enter: Blogs We Follow.
- On the Ribbon, click the Save button.
- Click the Web Links related navigation item.
- On the Ribbon, click the Add New Web Link button.
- Complete the following fields:
- Name: Mitch’s Blog
- Web Link Set: Blogs We Follow
- Website: Community Portal (or Training Portal)
- External Url:
- Publishing State: Published
- Display Order: 1
- Open in New Window: Yes
- Leave the remainder of the fields at their default values.
- On the Ribbon, click the Save and Close button.
- On the Ribbon, click the Add New Web Link button.
- Complete the following fields:
- Name: Basic Portal Homepage
- Web Link Set: Blogs We Follow
- Website: Community Portal (or Training Portal)
- Page: Home
- Publishing State: Published
- Display Order: 2
- Open in New Window: No
- Leave the remainder of the fields at their default values.
- On the Ribbon, click the Save and Close button.
In VS 2012
- Open Example.aspx
- Add the following Code to the MainContent content placeholder area:
<%foreach (var link inHtml.WebLinkSet("Blogs We Follow").WebLinks) %>
<% { %>
p<%=Html.WebLink(link) %</p
<% } %>
- Save and rebuild the project, then browse to see the result.
Experiment
1)Experiment with different ways to render Web Link Sets. Html.WebLinks is essentially equivalent to the <adx:Weblinks> web control. Html.WebLinksDropdown, on the other hand, gives more advancing rendering of bootstrap dropdowns for sub menus, etc. Play with the different options.
Exercise: Add a CrmMetadataDataSource control
Visual Studio
- Navigate to the Web project. In this exercise we will be binding a drop down list to our CrmMetadataDataSource
- Open Example.aspx
- Insert the following code within the “ContentBottom” <asp:Content> tag:
crm:CrmMetadataDataSource
ID="SatisfactionSource"
runat="server"
AttributeName="customersatisfactioncode"
EntityName="incident"
SortExpression="LabelDESC"/>
asp:Label
AssociatedControlID="Satisfaction"
runat="server"
Text="Satisfaction"/>
asp:DropDownList
ID="Satisfaction"
runat="server"
DataSourceID="SatisfactionSource"
DataTextField="OptionLabel"
DataValueField="OptionValue"/>
- Build the project. Navigate to the Portal
- When the home page is displayed, you should see a drop-down list containing customer satisfaction codes from the Case entity within CRM.
1