-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Request for suggestions: Add find
, find_index
, has
, and reject
filters to arrays
#1849
Comments
👍
Would Have you considered |
Would adding the ability to work with nested keys be a trivial add? i.e. {{ section.blocks | find: "settings.product.id", product.id }} |
I feel like IMHO, |
These all are pretty useful! An addition to boolean support idea of @galenking, comparison filters would also be really useful. {% assign collections_to_show = collections | where_compare: 'products_count', '>=', 0 %} or {% assign collections_to_show = collections | greater: 'products_count', 0 %}
{% assign collections_to_show = collections | greater_or_equal: 'products_count', 0 %} or {% assign collections_to_show = collections | where_gt: 'products_count', 0 %}
{% assign collections_to_show = collections | where_gte: 'products_count', 0 %} |
|
Pending PR for |
Should |
Author: Shopify
Expected end date: December 5, 2024
Background
Handling arrays in Liquid is challenging.
Developers often need to iterate over arrays to find items or check for their presence. This pattern results in imperative code and verbose templates, which detract from the simplicity and declarative nature that Liquid aims to promote.
⏭️ Upcoming: In a different proposal, we'll tackle improvements to the
where
filter and its limitation of only filtering based on equality. That's so crucial, we aim to handle that separately.Proposal
We should introduce new filters to make it easier to perform common tasks such as extracting or checking the presence of an item in an array. This will make Liquid templates simpler, less verbose, and more declarative.
All filters proposed here do not mutate the source object and return a new instance as a result of the operation:
1.
find
andfind_index
The
find
andfind_index
filters return, respectively, the item and the index of the item with the specified property value; otherwise, they returnnil
.2.
has
Returns
true
when the array includes an item with the specified property value; otherwise, returnsfalse
.Source
3.
reject
Works almost like the where filter, but returns an array excluding items with the specified property value.
Source
Call for suggestions
We welcome any feedback or opinions on this proposal. Please share your thoughts by December 5, 2024. Your input is valuable as we prepare to begin active development on this initiative.
The text was updated successfully, but these errors were encountered: