0.0
No release in over 3 years
Low commit activity in last 3 years
Adds better support for arrays and hashes in Liquid
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 13
~> 3.10

Runtime

>= 3, < 5
 Project Readme

Liquid Arrays

Adds better support for arrays and hashes in Liquid. Liquid only comes with support for creating arrays using split and iteration for arrays and hashes. This adds support for standard array and hash operations, such as creation, insertion, replacement, and deletion.

Requirements

Liquid Arrays requires at least Liquid 3 but has no other dependencies.

Installation

Bundler

Add this line to your application's Gemfile:

gem 'liquid-arrays'

NOTE: You may alternatively want to use a version constraint

And then run the command:

$ bundle install

Gem

Run the command:

$ gem install liquid-arrays

Error Handling

Error handling uses Liquid's error modes to determine how to handle errors. Please see Liquid - Error Modes for more information.

Usage

There are several tags that will modify arrays and hashes in various ways. Each tag has various attributes that specify information about the operation. The syntax for the tags and attributes is as follows:

{% tag_name attribute:value attribute:value %}

Some tags will have a default attribute which can be used if only one attribute needs specified, like so:

{% tag_name value %}

Types

Aside from the standard Liquid types, inline arrays and hashes may also be defined and used for appropriate attributes. The syntax for each is as follows:

{% tag_name array:value1,value2,value3 %}
{% tag_name hash:key1>value1,key2>value2 %}

Note: If an array is defined with a single variable and that variable contains an array, that array will be used instead of being the first element.

array_create tag

Creates an array with opinional initial items. If the variable is already defined it will reassign it.

Attribute Required Type Description
array Yes (default) Variable The array to create
items No Array The initial items

Example

{% array_create values1 %}
{% array_create array:values2 items:"value1",2 %}
values1 => []
values2 => ["value1", 2]

array_add tag

Adds a value to the end of an array. If the array doesn't exist, it will create it first.

Attribute Required Type Description
array If outside array block Variable The array to modify
value Yes (default) Any The value to add

Example

{% assign var = "a" %}
{% array_add array:values value:var %}
{% array_add array:values value:1 %}
{% array_add array:values value:true %}
values => ["a", 1, true]

array_delete tag

Deletes an index or all occurrences of a value from an array. If an index is used, it must be within the interval [0, length).

Attribute Required Type Description
array If outside array block Variable The array to modify
index If no value Integer or Variable The index to delete
value If no index Any The value to delete

Example

values => ["a", "b", "c", "a"]
{% array_delete array:values index:1 %}
{% array_delete array:values value:"a" %}
values => ["c"]

array_insert tag

Inserts a value into an array at an index. The index must be within the interval [0, length]. The array must already exist and will not be created if it does not.

Attribute Required Type Description
array If outside array block Variable The array to modify
index Yes Integer or Variable The index to insert at
value Yes Any The value to insert

Example

values => ["a", "b", "c"]
{% array_insert array:values index:0 value:"z" %}
{% array_insert array:values index:2 value:"y" %}
values => ["z", "a", "y", "b", "c"]

array_replace tag

Replaces the value at an index in an array. The index must be within the interval [0, length).

Attribute Required Type Description
array If outside array block Variable The array to modify
index Yes Integer or Variable The index to replace
value Yes Any The value to replace with

Example

values => ["a", "b", "c"]
{% array_replace array:values index:0 value:"z" %}
{% array_replace array:values index:2 value:"y" %}
values => ["z", "b", "y"]

array block tag

Allows for the modification of an array without having to specify the array for every operation. If the array doesn't exist, it will create an empty array.

Attribute Required Type Description
array Yes (default) Variable The array to modify

Example

{% array values %}
  {% array_add "a" %}
  {% array_add "b" %}
  {% array_insert index:1 value:"z" %}
{% endarray %}
values => ["a", "z", "b"]

hash_create tag

Creates a hash with opinional initial entries. If the variable is already defined it will reassign it.

Attribute Required Type Description
hash Yes (default) Variable The hash to create
entries No Hash The initial entries

Example

{% hash_create values1 %}
{% hash_create hash:values2 entries:"key1">"a","key2",3 %}
values1 => {}
values2 => {"key1" => "a", "key2" => 3}

hash_set tag

Sets a key-value mapping in a hash, either adding it if it doesn't already exist or replacing the existing mapping for the key. If the hash doesn't exist, it will create it first.

Attribute Required Type Description
hash If outside hash block Variable The hash to modify
key Yes Any The key to map the value to
value Yes Any The value to map to the key

Example

{% hash_set hash:values key:"key1" value:"a" %}
{% hash_set hash:values key:"key2" value:3 %}
{% hash_set hash:values key:"key3" value:false %}
values => {"key1" => "a", "key2" => 3, "key3" => false}

hash_delete tag

Deletes a key-value mapping from a hash for a key.

Attribute Required Type Description
hash If outside hash block Variable The hash to modify
key Yes (default) Any The key to remove the mapping for

Example

values => {"key1" => "a", "key2" => 3, "key3" => false}
{% hash_delete hash:values key:"key1" %}
{% hash_delete hash:values key:"key2" %}
values => {"key3" => false}

hash block tag

Allows for the modification of a hash without having to specify the hash for
every operation. If the hash doesn't exist, it will create an empty hash.

Attribute Required Type Description
hash Yes (default) Variable The hash to modify

Example

{% hash values %}
  {% hash_set key:"key1" value:"a" %}
  {% hash_set key:"key2" value:"b" %}
  {% hash_set key:"key3" value:"c" %}
  {% hash_delete "key2" %}
{% endhash %}
values => {"key1" => "a", "key3" => "c"}

License

Liquid Arrays is licensed under Apache License 2.0. You may also refer to the included LICENSE.txt file.