From 6310ed83404700724dfe793ea00e63cd04b54e6b Mon Sep 17 00:00:00 2001 From: edemirbag <17883910+edemirbag@users.noreply.github.com> Date: Wed, 20 Mar 2024 17:26:26 +0000 Subject: [PATCH] - Provide a flexible mechanism for key-based lookup with fallback options in support of content updates related to ASL-4413 - Include tests to validate that the snippet component can correctly handle fallbacks when attempting to retrieve templates --- src/snippet/index.jsx | 18 ++++++++++++++++-- src/snippet/index.spec.jsx | 12 ++++++++++++ 2 files changed, 28 insertions(+), 2 deletions(-) diff --git a/src/snippet/index.jsx b/src/snippet/index.jsx index 27fc7849..141620c3 100644 --- a/src/snippet/index.jsx +++ b/src/snippet/index.jsx @@ -4,13 +4,27 @@ import { connect } from 'react-redux'; import Markdown from '../markdown'; import { render } from 'mustache'; +function getTemplate(content, primary, fallback) { + const keysToTry = [primary, ...(Array.isArray(fallback) ? fallback : [fallback])]; + + for (let key of keysToTry) { + const template = get(content, key); + if (template != undefined) { + return template; + } + } + + return undefined; +} + export const Snippet = ({ content, children, optional, fallback, ...props }) => { - const str = get(content, children, get(content, fallback)); + const str = getTemplate(content, children, fallback); if (str === undefined && optional) { return null; + } if (str === undefined) { - throw new Error(`Failed to lookup content snippet: ${children}`); + return `Failed to lookup content snippet: ${children}`; } if (typeof str !== 'string') { throw new Error(`Invalid content snippet for key ${children}: ${JSON.stringify(str)}`); diff --git a/src/snippet/index.spec.jsx b/src/snippet/index.spec.jsx index 10fe9312..04d2ff18 100644 --- a/src/snippet/index.spec.jsx +++ b/src/snippet/index.spec.jsx @@ -42,4 +42,16 @@ two` expect(wrapper.html()).toEqual(paragraphs); }); + test('can accept single fallback', () => { + const wrapper = render(