From c278200c18524544aae53ab471d0923f03f7b8e0 Mon Sep 17 00:00:00 2001 From: Adam Tanner Date: Sat, 18 May 2024 11:08:04 -0400 Subject: [PATCH 1/2] fix: allow liquidMethodMissing to return any supported value type --- src/drop/drop.ts | 2 +- test/integration/drop/drop.spec.ts | 16 ++++++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/src/drop/drop.ts b/src/drop/drop.ts index f9ea608904..9fe2c530ba 100644 --- a/src/drop/drop.ts +++ b/src/drop/drop.ts @@ -1,5 +1,5 @@ export abstract class Drop { - public liquidMethodMissing (key: string | number): Promise | string | undefined { + public liquidMethodMissing (key: string | number): Promise | any | undefined { return undefined } } diff --git a/test/integration/drop/drop.spec.ts b/test/integration/drop/drop.spec.ts index f4f874b481..bf299cefe8 100644 --- a/test/integration/drop/drop.spec.ts +++ b/test/integration/drop/drop.spec.ts @@ -83,4 +83,20 @@ describe('drop/drop', function () { const html = await liquid.parseAndRender(tpl, { address, customer }) expect(html).toBe('test') }) + it('should support returning supported value types from liquidMethodMissing', async function () { + class DynamicTypeDrop extends Drop { + liquidMethodMissing (key: string) { + switch (key) { + case 'number': return 42 + case 'string': return 'foo' + case 'boolean': return true + case 'array': return [1, 2, 3] + case 'object': return { foo: 'bar' } + case 'drop': return new CustomDrop() + } + } + } + const html = await liquid.parseAndRender(`{{obj.number}} {{obj.string}} {{obj.boolean}} {{obj.array | first}} {{obj.object.foo}} {{obj.drop.getName}}`, { obj: new DynamicTypeDrop() }) + expect(html).toBe('42 foo true 1 bar GET NAME') + }) }) From 271e6ee7d6568ced4236e264d50a916dae312696 Mon Sep 17 00:00:00 2001 From: Adam Tanner <27502+admtnnr@users.noreply.github.com> Date: Sun, 19 May 2024 07:54:52 -0400 Subject: [PATCH 2/2] Update src/drop/drop.ts Co-authored-by: Jun Yang --- src/drop/drop.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/drop/drop.ts b/src/drop/drop.ts index 9fe2c530ba..74b4e152fd 100644 --- a/src/drop/drop.ts +++ b/src/drop/drop.ts @@ -1,5 +1,5 @@ export abstract class Drop { - public liquidMethodMissing (key: string | number): Promise | any | undefined { + public liquidMethodMissing (key: string | number): Promise | any { return undefined } }