From 682328bda287a85eb6cefd98abc95a2d42634fb2 Mon Sep 17 00:00:00 2001 From: Jason Smith Date: Wed, 18 Oct 2023 14:46:51 +1100 Subject: [PATCH] fix(nuxt-ripple): :bug: filter out alerts with missing type relation --- .../site/alerts/site-alerts-mapping.ts | 26 ++++++++++--------- 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/packages/nuxt-ripple/mapping/site/alerts/site-alerts-mapping.ts b/packages/nuxt-ripple/mapping/site/alerts/site-alerts-mapping.ts index 0dae29c9f1..27d4536383 100644 --- a/packages/nuxt-ripple/mapping/site/alerts/site-alerts-mapping.ts +++ b/packages/nuxt-ripple/mapping/site/alerts/site-alerts-mapping.ts @@ -47,19 +47,21 @@ const getAlertVariantForType = ( } export const map = (src: TideApiResponse): TideAlert[] => { - const alerts = (src.site_alerts || []).map((rawAlert): TideAlert => { - const alertType = rawAlert.field_alert_type.name - const link = getLinkFromField(rawAlert, 'field_call_to_action') + const alerts = (src.site_alerts || []) + .filter((rawAlert: any) => rawAlert.field_alert_type) + .map((rawAlert: any) => { + const alertType = rawAlert.field_alert_type.name + const link = getLinkFromField(rawAlert, 'field_call_to_action') - return { - alertId: rawAlert.id, - variant: getAlertVariantForType(alertType), - iconName: getIconForType(alertType), - message: rawAlert.title || '', - linkText: link?.text || '', - linkUrl: link?.url || '' - } - }) + return { + alertId: rawAlert.id, + variant: getAlertVariantForType(alertType), + iconName: getIconForType(alertType), + message: rawAlert.title || '', + linkText: link?.text || '', + linkUrl: link?.url || '' + } + }) return sortAlertsByPriority(alerts) }