From 078c5db325bfd2eb21ae16733b97fb10531caafd Mon Sep 17 00:00:00 2001 From: illiakovalenko Date: Thu, 25 Jul 2024 11:28:58 +0300 Subject: [PATCH 1/2] [sitecore-jss] isFieldValueEmpty can't handle null, undefined values --- .../sitecore-jss/src/layout/utils.test.ts | 32 +++++++++++++++++++ packages/sitecore-jss/src/layout/utils.ts | 4 +++ 2 files changed, 36 insertions(+) diff --git a/packages/sitecore-jss/src/layout/utils.test.ts b/packages/sitecore-jss/src/layout/utils.test.ts index c72228eb21..bcade6e434 100644 --- a/packages/sitecore-jss/src/layout/utils.test.ts +++ b/packages/sitecore-jss/src/layout/utils.test.ts @@ -216,5 +216,37 @@ describe('sitecore-jss layout utils', () => { expect(result).to.be.false; }); }); + + describe('null', () => { + it('should return true if field value is null', () => { + const field = { + value: null, + }; + const result = isFieldValueEmpty(field); + expect(result).to.be.true; + }); + + it('should return true if value is null', () => { + const field = null; + const result = isFieldValueEmpty(field as any); + expect(result).to.be.true; + }); + }); + + describe('undefined', () => { + it('should return true if field value is undefined', () => { + const field = { + value: undefined, + }; + const result = isFieldValueEmpty(field); + expect(result).to.be.true; + }); + + it('should return true if value is undefined', () => { + const field = undefined; + const result = isFieldValueEmpty(field as any); + expect(result).to.be.true; + }); + }) }); }); diff --git a/packages/sitecore-jss/src/layout/utils.ts b/packages/sitecore-jss/src/layout/utils.ts index 9d7521868c..bb09356476 100644 --- a/packages/sitecore-jss/src/layout/utils.ts +++ b/packages/sitecore-jss/src/layout/utils.ts @@ -100,6 +100,10 @@ export function isFieldValueEmpty(field: GenericFieldValue | Partial): bo const isDateFieldEmpty = (fieldValue: GenericFieldValue) => fieldValue === EMPTY_DATE_FIELD_VALUE; const isEmpty = (fieldValue: GenericFieldValue) => { + if (fieldValue === null || fieldValue === undefined) { + return true; + } + if (typeof fieldValue === 'object') { return ( isImageFieldEmpty(fieldValue) && From 31145241f5fefab4fd1dd03e26d8916715ff6a2c Mon Sep 17 00:00:00 2001 From: illiakovalenko Date: Thu, 25 Jul 2024 11:33:07 +0300 Subject: [PATCH 2/2] Updated CHANGELOG --- CHANGELOG.md | 2 +- packages/sitecore-jss/src/layout/utils.test.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e07d73d205..3d71a0a88f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -35,7 +35,7 @@ Our versioning strategy is as follows: ### 🛠 Breaking Change -* Editing Integration Support: ([#1776](https://github.com/Sitecore/jss/pull/1776))([#1792](https://github.com/Sitecore/jss/pull/1792))([#1773](https://github.com/Sitecore/jss/pull/1773))([#1797](https://github.com/Sitecore/jss/pull/1797))([#1800](https://github.com/Sitecore/jss/pull/1800))([#1803](https://github.com/Sitecore/jss/pull/1803))([#1806](https://github.com/Sitecore/jss/pull/1806))([#1809](https://github.com/Sitecore/jss/pull/1809))([#1814](https://github.com/Sitecore/jss/pull/1814))([#1816](https://github.com/Sitecore/jss/pull/1816))([#1819](https://github.com/Sitecore/jss/pull/1819))([#1828](https://github.com/Sitecore/jss/pull/1828))([#1835](https://github.com/Sitecore/jss/pull/1835)) ([#1849](https://github.com/Sitecore/jss/pull/1849)) +* Editing Integration Support: ([#1776](https://github.com/Sitecore/jss/pull/1776))([#1792](https://github.com/Sitecore/jss/pull/1792))([#1773](https://github.com/Sitecore/jss/pull/1773))([#1797](https://github.com/Sitecore/jss/pull/1797))([#1800](https://github.com/Sitecore/jss/pull/1800))([#1803](https://github.com/Sitecore/jss/pull/1803))([#1806](https://github.com/Sitecore/jss/pull/1806))([#1809](https://github.com/Sitecore/jss/pull/1809))([#1814](https://github.com/Sitecore/jss/pull/1814))([#1816](https://github.com/Sitecore/jss/pull/1816))([#1819](https://github.com/Sitecore/jss/pull/1819))([#1828](https://github.com/Sitecore/jss/pull/1828))([#1835](https://github.com/Sitecore/jss/pull/1835))([#1849](https://github.com/Sitecore/jss/pull/1849))([#1831](https://github.com/Sitecore/jss/pull/1831))([#1854](https://github.com/Sitecore/jss/pull/1854)) * `[sitecore-jss-react]` Introduces `PlaceholderMetadata` component which supports the hydration of chromes on Pages by rendering the components and placeholders with required metadata. * `[sitecore-jss]` Chromes are hydrated based on the basis of new `editMode` property derived from LayoutData, which is defined as an enum consisting of `metadata` and `chromes`. * `ComponentConsumerProps` is removed. You might need to reuse `WithSitecoreContextProps` type. diff --git a/packages/sitecore-jss/src/layout/utils.test.ts b/packages/sitecore-jss/src/layout/utils.test.ts index bcade6e434..4085625777 100644 --- a/packages/sitecore-jss/src/layout/utils.test.ts +++ b/packages/sitecore-jss/src/layout/utils.test.ts @@ -247,6 +247,6 @@ describe('sitecore-jss layout utils', () => { const result = isFieldValueEmpty(field as any); expect(result).to.be.true; }); - }) + }); }); });