Building an App with the frostillic.us Framework, Part 6
Jul 23, 2014, 2:46 PM
- Building an App with the frostillic.us Framework, Part 1
- Building an App with the frostillic.us Framework, Part 2
- Building an App with the frostillic.us Framework, Part 3
- Building an App with the frostillic.us Framework, Part 4
- Building an App with the frostillic.us Framework, Part 5
- Building an App with the frostillic.us Framework, Part 6
- Building an App with the frostillic.us Framework, Part 7
- Define the data model
- Create the view and add it to an XPage
- Create the editing page
- Add validation and translation to the model
- Add notification to the model
- Add sorting to the view
- Basic servlet
- REST with Angular.js
Add sorting to the view
This step in the framework example is very similar to the second in that there's nothing particularly Framework-y about it.
Technically, the work in the title of this step is already done: I had already enabled click-to-sort and set sortable="true"
in the XSP source. That on its own is enough to, as with a normal view, enable both available sort directions in the view panel:
So... that was easy! While we're at it, we'll go back in and add a categorized column. This, too, has no gotchas:
In my case, Designer gave this category a programmatic name of "$4", so we'll use that in the modified XSP for the view panel:
<xp:viewPanel value="#{Notes.all}" pageName="/note.xsp"> <xp:this.facets> <xp:pager xp:key="headerPager" id="pager1" partialRefresh="true" layout="Previous Group Next" /> </xp:this.facets> <xp:viewColumn columnName="$4"/> <xp:viewColumn columnName="Title" displayAs="link"> <xp:viewColumnHeader value="Title" sortable="true"/> </xp:viewColumn> <xp:viewColumn columnName="Body"> <xp:viewColumnHeader value="Body"/> </xp:viewColumn> </xp:viewPanel>
This gives us the categorized column we expect, including the ability to collapse the categories like normal:
And, well, that's it too. Because of my extensive use of view features on the back end, Framework collections inherit the same features and (most of) the performance of the existing view data sources. That's a lot of the point: taking these model collections and using them in the ways you're used to using views in XPages apps is meant to be easy and not something you have to think too much about.