Sha256: 92bb10bd0b80ad22e73329362c3c8444c12e7800e20f8400b74ee0d115777c4e

Contents?: true

Size: 1.78 KB

Versions: 15

Compression:

Stored size: 1.78 KB

Contents

# Encourage use of liquid tag for consecutive statements (LiquidTag)

Recommends using `{% liquid ... %}` if 4 or more consecutive liquid tags (`{% ... %}`) are found.

## Check Details

This check is aimed at eliminating repetitive tag markers (`{%` and `%}`) in theme files.

:-1: Example of **incorrect** code for this check:

```liquid
{% if collection.image.size != 0 %}
{%   assign collection_image = collection.image %}
{% elsif collection.products.first.size != 0 and collection.products.first.media != empty %}
{%   assign collection_image = collection.products.first.featured_media.preview_image %}
{% else %}
{%   assign collection_image = nil %}
{% endif %}
```

:+1: Example of **correct** code for this check:

```liquid
{%- liquid
  if collection.image.size != 0
    assign collection_image = collection.image
  elsif collection.products.first.size != 0 and collection.products.first.media != empty
    assign collection_image = collection.products.first.featured_media.preview_image
  else
    assign collection_image = nil
  endif
-%}
```

## Check Options

The default configuration for this check is the following:

```yaml
LiquidTag:
  enabled: true
  min_consecutive_statements: 4
```

### `min_consecutive_statements`

The `min_consecutive_statements` option (Default: `4`) determines the maximum (inclusive) number of consecutive statements before the check recommends a refactor.

## When Not To Use It

It's safe to disable this rule.

## Version

This check has been introduced in Theme Check 0.1.0.

## Resources

- [`{% liquid %}` Tag Reference][liquid]
- [Rule Source][codesource]
- [Documentation Source][docsource]

[liquid]: https://shopify.dev/docs/themes/liquid/reference/tags/theme-tags#liquid
[codesource]: /lib/theme_check/checks/liquid_tag.rb
[docsource]: /docs/checks/liquid_tag.md

Version data entries

15 entries across 15 versions & 1 rubygems

Version Path
theme-check-0.10.2 docs/checks/liquid_tag.md
theme-check-0.10.1 docs/checks/liquid_tag.md
theme-check-0.10.0 docs/checks/liquid_tag.md
theme-check-0.9.1 docs/checks/liquid_tag.md
theme-check-0.9.0 docs/checks/liquid_tag.md
theme-check-0.8.3 docs/checks/liquid_tag.md
theme-check-0.8.2 docs/checks/liquid_tag.md
theme-check-0.8.1 docs/checks/liquid_tag.md
theme-check-0.8.0 docs/checks/liquid_tag.md
theme-check-0.7.3 docs/checks/liquid_tag.md
theme-check-0.7.2 docs/checks/liquid_tag.md
theme-check-0.7.1 docs/checks/liquid_tag.md
theme-check-0.7.0 docs/checks/liquid_tag.md
theme-check-0.6.0 docs/checks/liquid_tag.md
theme-check-0.5.0 docs/checks/liquid_tag.md