data:image/s3,"s3://crabby-images/7887f/7887fabc05579146b4564ec4a2ff6374e715db49" alt=""
Clicking on one of these commands updates the sortorder attribute of the selected content item:
data:image/s3,"s3://crabby-images/5ed33/5ed33d5fb8580512ca7216acfa6d761534733343" alt=""
Clicking on the sorting options allows business users to sort the subitems of the current item based on a number of criteria:
data:image/s3,"s3://crabby-images/fb54a/fb54ace0f62cab49a5f79547289f35c822df8394" alt=""
Rendering logic will implicitly recognize this sort order, such that the following rendering will respect the sortorder field:
<xsl:for-each select="$home/item[@key='vehicles']/item">
<sc:link>
<sc:image field="menu image" />
<sc:text field="menu title" />
</sc:link>
</xsl:for-each>
Sitecore allows developers to implement their own sorting algorithms (http://sdn5.sitecore.net/Scrapbook/Understanding%20the%20Sort%20Order.aspx). Algorithms can be specified under /sitecore/system/settings/subitems sorting. For example, to sort items by a date field, developers can use the following approach:
public class ItemComparer : IComparer
{
private string _fieldName;
public ItemComparer()
{
}
public ItemComparer(string fieldName)
{
_fieldName = fieldName;
}
public int Compare(object x, object y)
{
Item item1 = x as Item;
Item item2 = y as Item;
if (_fieldName == null)
{
_fieldName = "date";
}
Sitecore.Data.Fields.DateField date1 = (Sitecore.Data.Fields.DateField)item1.Fields[_fieldName];
Sitecore.Data.Fields.DateField date2 = (Sitecore.Data.Fields.DateField)item2.Fields[_fieldName];
return System.DateTime.Compare(date1.DateTime,
date2.DateTime);
}
}
This class can be used in your code-behind as follows:
// get an array of the Items:
Item[] i = Sitecore.Context.Database.SelectItems("
// sort it using your comparer:
Array.Sort(i, new ItemComparer());
// use the sorted array:
foreach (Sitecore.Data.Items.Item thisItem in i) {
// do something with each item
}
No comments:
Post a Comment