Skip to content

Commit

Permalink
feat: support allow_false for default filter, see #435
Browse files Browse the repository at this point in the history
  • Loading branch information
harttle committed Jan 2, 2022
1 parent e94e386 commit c756191
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 5 deletions.
19 changes: 19 additions & 0 deletions docs/source/filters/default.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,4 +44,23 @@ Output
2.99
```

## Allowing `false`

{% since %}v9.32.0{% endsince %}

To allow variables to return `false` instead of the default value, you can use the `allow_false` parameter.

Input

```liquid
{% assign display_price = false %}
{{ display_price | default: true, allow_false: true }}
```

Output

```text
false
```

[falsy]: ../tutorials/truthy-and-falsy.html
19 changes: 19 additions & 0 deletions docs/source/zh-cn/filters/default.md
Original file line number Diff line number Diff line change
Expand Up @@ -42,4 +42,23 @@ title: default
2.99
```

## 允许 `false`

{% since %}v9.32.0{% endsince %}

为了允许让 `false` 直接输出而不是用默认值,可以用 `allow_false` 参数。

输入

```liquid
{% assign display_price = false %}
{{ display_price | default: true, allow_false: true }}
```

输出

```text
false
```

[falsy]: ../tutorials/truthy-and-falsy.html
13 changes: 8 additions & 5 deletions src/builtin/filters/object.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,13 @@ import { isFalsy } from '../../render/boolean'
import { isArray, isString, toValue } from '../../util/underscore'
import { FilterImpl } from '../../template/filter/filter-impl'

export function Default<T1, T2> (this: FilterImpl, v: string | T1, arg: T2): string | T1 | T2 {
if (isArray(v) || isString(v)) return v.length ? v : arg
return isFalsy(toValue(v), this.context) ? arg : v
export function Default<T1 extends boolean, T2> (this: FilterImpl, value: T1, defaultValue: T2, ...args: Array<[string, any]>): T1 | T2 {
if (isArray(value) || isString(value)) return value.length ? value : defaultValue
value = toValue(value)
if (value === false && (new Map(args)).get('allow_false')) return false as T1
return isFalsy(value, this.context) ? defaultValue : value
}
export function json (v: any) {
return JSON.stringify(v)

export function json (value: any) {
return JSON.stringify(value)
}
3 changes: 3 additions & 0 deletions test/integration/builtin/filters/object.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,9 @@ describe('filters/object', function () {
it('undefined should use default', async () => expect(await liquid.parseAndRender('{{not_defined | default: "a"}}')).to.equal('a'))
it('true should not use default', async () => expect(await liquid.parseAndRender('{{true | default: "a"}}')).to.equal('true'))
it('0 should not use default', async () => expect(await liquid.parseAndRender('{{0 | default: "a"}}')).to.equal('0'))
it('should output false when allow_false=true', async () => expect(await liquid.parseAndRender('{{false | default: true, allow_false: true}}')).to.equal('false'))
it('should output default without allow_false', async () => expect(await liquid.parseAndRender('{{false | default: true}}')).to.equal('true'))
it('should output default when allow_false=false', async () => expect(await liquid.parseAndRender('{{false | default: true, allow_false: false}}')).to.equal('true'))
})
describe('json', function () {
it('should stringify string', async () => expect(await liquid.parseAndRender('{{"foo" | json}}')).to.equal('"foo"'))
Expand Down

0 comments on commit c756191

Please sign in to comment.