Datastore Item

Datastore Item

{{ datastore_item }}

Name Type Description
object_type String Will always be datastore_item
is_valid Boolean True if this references a published datastore_item
guid String The unique identifier for this datastore_item
value String Synonymn for guid
name text The name of the datastore_item
title text The title of the datastore_item
linked_title String A link to the datastore_item if it has a URL, or the escaped title if not
datastore_guid String The unique identifier of the related datastore
datastore datastore Reference to the related datastore object
tags tags The list of tags associated with this datastore_item
authors authors The list of authors associated with this datastore_item
has_url Boolean True if the datastore_item has a URL
include_in_search Boolean Whether or not this datastore_item should be returned in on-site search results
domain_name text The domain name used by the URL for this datastore_item
url text The portion of the URL for this datastore_item following the domain name
full_url String The full URL for this datastore_item including the scheme, domain name, and path
visited Boolean Whether or not the user has visited this URL previously in their current session. Note that this will always be false if the user has not allowed session permission (see the Permissions and Personalization documentation). Using this property prevents the page from being fast-cached
template_guid String The unique identifier for the template that would be used to respond to this URL
template template The template that would be used to respond to this URL
canonical_url url The canonical URL if this is not the original source of content for this URL
browser_title text The browser title to use for this URL
meta_description textarea The meta description for this URL
meta_robots text The meta robots for this URL
keywords textarea The SEO keywords for this URL
search_entity_guid String The unique identifier for the entity that search results should be directed to (if this datastore_item does not have a URL)
search_entity entity The entity that search results should be directed to (if this datastore_item does not have a URL)
folder_guid String The unique identifier for the folder that contains this datastore_item.
folder folder The folder that contains this datastore_item.
field_id String The identifier for this field
label String The label for this field
output String The default output that the datastore_item produces when output directly to the template. The default output may change at any time. Template developers should avoid using this and should handle the output of datastore items themselves
data data Object containing the custom fields on this datastore_item
* String Specific custom fields may be accessed using {{ entity.fieldid }} or {{datastore_item['field-id']}}

{{ datastore_items }}

Contains multiple datastore_items.

Name Type Description
output String The default output that the datastore_items will produce when it is output directly to the template - using the "output_in_list" property of each datastore_item in the items list

{% datastore_item %}

{% datastore_item
var|set|assign
 
Optional. Specify either "var", "set" or "assign" to change which scope this datastore_item is stored on. "var" is the default behavior.
variable_name
 
Specify a variable name in order to save this datastore_item to a variable. If not specified, it will be output to the template instead.
output_to_template
 
If included the datastore_item will be output directly to the template.
=
%}

{% datastore_items %}

{% datastore_items
var|set|assign
 
Optional. Specify either "var", "set" or "assign" to change which scope this datastore_items is stored on. "var" is the default behavior.
variable_name
 
Specify a variable name in order to save this datastore_items to a variable. If not specified, it will be output to the template instead.
output_to_template
 
If included the datastore_items will be output directly to the template.
=
prepend:value
 
Prepend the specified datastore_items before the fetched results. All prepended input will be returned in the same order that it is input. Value may one or more datastore_items, a guid, or a string.
append:value
 
Append the specified datastore_items after the fetched results. All appended input will be returned in the same order that it is input. Value may one or more datastore_items, a guid, or a string.
exclude:value
 
Prevent the specified datastore_items from being included in the fetched results. Has no affect on prepended and appended items. Value may one or more datastore_items, a guid, or a string.
exclude_prepended:true
 
Specifically exclude all prepended datastore_items from the fetched results. If "unique:true" is specified this is the default behavior, although you may also specify "exclude_prepended:false" to allow any prepended items to be fetched along with other results anyway.
exclude_appended:true
 
Specifically exclude all appended datastore_items from the fetched results. This is false by default - even if "unique:true" is specified - so that results are returned in the proper order.
unique:true
 
If set to true, each of the resulting lists (prepended, fetched, appended, and items) will be unique, although there may be duplicates between the prepended, fetched, and appended lists. The "items" list will include objects in the order in which they appear - with prepended items first, then fetched items, then appended items.
max_size:number
 
If specified, then the "items" list will only include up to the specified number of datastore_items. The "limit" may be automatically lowered to only fetch the maximum number of articles that will be included in "items" following prepended items. Note that this may also impact both the "page" and "total_pages" values. In order to use pagination with a list loaded using "max_size" use "start" instead of "page" and "limit".
%}

Examples

Sample Datastore Item Queries

Copy
Simple query: {% datastore_items items = datastore:"Hotels" query:"number_of_rooms > 100 AND average_room_price <= 100" %} Complex query: {% capture query %} is_vegan OR ( number_of_ingredients < 6 AND ( NOT ingredients contains chicken -ingredients contains pork - ingredients LIKE 'beef' {% if other_meat_to_avoid is_valid %} AND !(ingredients CONTAINS "{{other_meat_to_avoid | replace: '"', '""' }}") {% endif %} ) AND NOT ( 'contains_dairy' OR ingredients contains egg ) ) {% endcapture %} {% datastore_items items = datastore:'Recipes' query:query %} Query multiple configurable fields: {% set query = "" %} {% set fieldvalue = request.query_params['fieldvalue'] | urldecode %} {% if request.query_params['fieldnames'] is_valid and fieldvalue is_valid %} {% var fieldnames = request.query_params['fieldnames'] | urldecode | split: ',' %} {% var queryparts = '' | compact %} {% for field in fieldnames %} {% capture querypart %}{{field}} = "{{fieldvalue | replace: '"', '""'}}"{% endcapture %} {% set queryparts = queryparts | concat: querypart %} {% endfor %} {% set query = queryparts | join: ' OR ' %} {% endif %} {% datastore_items items = datastore:entity query:query %}