diff --git a/src/transform/liquid/conditions.ts b/src/transform/liquid/conditions.ts index 5fa44f4a..ad3e8b39 100644 --- a/src/transform/liquid/conditions.ts +++ b/src/transform/liquid/conditions.ts @@ -205,7 +205,7 @@ function inlineConditions( return { result: start + result + end, - lastIndex: start.length + result.length, + lastIndex: start.length + result.length - tailLinebreak(ifTag.rawEnd).length, ifCon, }; } diff --git a/test/liquid/conditions.test.ts b/test/liquid/conditions.test.ts index eb405b1c..548a28f9 100644 --- a/test/liquid/conditions.test.ts +++ b/test/liquid/conditions.test.ts @@ -217,6 +217,42 @@ describe('Conditions', () => { {% endnote %} `); }); + + test('Falsy block condition after truthly block condition', () => { + expect( + conditions( + trim` + Start + + Before + {% if product == "A" %} + Truthly + {% endif %} + {% if product == "B" %} + Falsy + {% endif %} + After + + End + `, + { + product: 'A', + }, + '', + { + sourceMap: {}, + }, + ), + ).toEqual(trim` + Start + + Before + Truthly + After + + End + `); + }); }); describe('Conditions', () => {