From 091024e946c390fda21f345caab29bb8ee35e4d2 Mon Sep 17 00:00:00 2001 From: bekzod Date: Thu, 14 Sep 2017 19:08:13 +0500 Subject: [PATCH] allow numeric `0` key to work with `get` helper --- packages/ember-glimmer/lib/helpers/get.js | 2 +- .../tests/integration/helpers/get-test.js | 17 +++++++++++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/packages/ember-glimmer/lib/helpers/get.js b/packages/ember-glimmer/lib/helpers/get.js index feaaaae4ed4..5d568b3724b 100644 --- a/packages/ember-glimmer/lib/helpers/get.js +++ b/packages/ember-glimmer/lib/helpers/get.js @@ -90,7 +90,7 @@ class GetHelperReference extends CachedReference { let path = this.lastPath = this.pathReference.value(); if (path !== lastPath) { - if (path) { + if (path !== undefined && path !== null) { let pathType = typeof path; if (pathType === 'string') { diff --git a/packages/ember-glimmer/tests/integration/helpers/get-test.js b/packages/ember-glimmer/tests/integration/helpers/get-test.js index d9643264bae..cfd94b96324 100644 --- a/packages/ember-glimmer/tests/integration/helpers/get-test.js +++ b/packages/ember-glimmer/tests/integration/helpers/get-test.js @@ -75,6 +75,23 @@ moduleFor('Helpers test: {{get}}', class extends RenderingTest { this.assertText('[First][Second][Third]'); } + + ['@test should be able to get an array value with numeric keys']() { + this.render(`{{#each numbers as |num index|}}[{{get numbers index}}]{{/each}}`, { + numbers: [1, 2, 3], + }); + + this.assertText('[1][2][3]'); + + this.runTask(() => this.rerender()); + + this.assertText('[1][2][3]'); + + this.runTask(() => set(this.context, 'numbers', [3, 2, 1])); + + this.assertText('[3][2][1]'); + } + ['@test should be able to get an object value with a bound/dynamic key']() { this.render(`[{{get colors key}}] [{{if true (get colors key)}}]`, { colors: { apple: 'red', banana: 'yellow' },