From c48b620e034bc56a643a47afc51c8d3646554658 Mon Sep 17 00:00:00 2001 From: Caius-Bonus <123886836+Caius-Bonus@users.noreply.github.com> Date: Mon, 23 Oct 2023 10:37:56 +0200 Subject: [PATCH] Fix inconsistencies in `slugify` between frontend and core implementation (#18297) --- src/common/string/slugify.ts | 36 ++++++++++++++++++++++------------- test/common/string/slugify.ts | 9 +++++++-- 2 files changed, 30 insertions(+), 15 deletions(-) diff --git a/src/common/string/slugify.ts b/src/common/string/slugify.ts index e9901faa7619..ddf378059cbf 100644 --- a/src/common/string/slugify.ts +++ b/src/common/string/slugify.ts @@ -1,19 +1,29 @@ // https://gist.github.com/hagemann/382adfc57adbd5af078dc93feef01fe1 export const slugify = (value: string, delimiter = "_") => { const a = - "àáäâãåăæąçćčđďèéěėëêęğǵḧìíïîįłḿǹńňñòóöôœøṕŕřßşśšșťțùúüûǘůűūųẃẍÿýźžż·/_,:;"; - const b = `aaaaaaaaacccddeeeeeeegghiiiiilmnnnnooooooprrsssssttuuuuuuuuuwxyyzzz${delimiter}${delimiter}${delimiter}${delimiter}${delimiter}${delimiter}`; + "àáâäæãåāăąçćčđďèéêëēėęěğǵḧîïíīįìıİłḿñńǹňôöòóœøōõőṕŕřßśšşșťțûüùúūǘůűųẃẍÿýžźż·"; + const b = `aaaaaaaaaacccddeeeeeeeegghiiiiiiiilmnnnnoooooooooprrsssssttuuuuuuuuuwxyyzzz${delimiter}`; const p = new RegExp(a.split("").join("|"), "g"); - return value - .toString() - .toLowerCase() - .replace(/\s+/g, delimiter) // Replace spaces with delimiter - .replace(p, (c) => b.charAt(a.indexOf(c))) // Replace special characters - .replace(/&/g, `${delimiter}and${delimiter}`) // Replace & with 'and' - .replace(/[^\w-]+/g, "") // Remove all non-word characters - .replace(/-/g, delimiter) // Replace - with delimiter - .replace(new RegExp(`(${delimiter})\\1+`, "g"), "$1") // Replace multiple delimiters with single delimiter - .replace(new RegExp(`^${delimiter}+`), "") // Trim delimiter from start of text - .replace(new RegExp(`${delimiter}+$`), ""); // Trim delimiter from end of text + let slugified; + + if (value === "") { + slugified = ""; + } else { + slugified = value + .toString() + .toLowerCase() + .replace(p, (c) => b.charAt(a.indexOf(c))) // Replace special characters + .replace(/(?<=\d),(?=\d)/g, "") // Remove Commas between numbers + .replace(/[^a-z0-9]+/g, delimiter) // Replace all non-word characters + .replace(new RegExp(`(${delimiter})\\1+`, "g"), "$1") // Replace multiple delimiters with single delimiter + .replace(new RegExp(`^${delimiter}+`), "") // Trim delimiter from start of text + .replace(new RegExp(`${delimiter}+$`), ""); // Trim delimiter from end of text + + if (slugified === "") { + slugified = "unknown"; + } + } + + return slugified; }; diff --git a/test/common/string/slugify.ts b/test/common/string/slugify.ts index 7252fbbb47c9..e5e06970bd27 100644 --- a/test/common/string/slugify.ts +++ b/test/common/string/slugify.ts @@ -6,12 +6,15 @@ describe("slugify", () => { assert.strictEqual(slugify("abc"), "abc"); assert.strictEqual(slugify("ABC"), "abc"); assert.strictEqual(slugify("abc DEF"), "abc_def"); + assert.strictEqual(slugify("abc.DEF"), "abc_def"); + assert.strictEqual(slugify("1`-=~!@#$%^&*()_+[];',./{}:\"<>?\\| aA"), "1_aa"); assert.strictEqual(slugify("abc-DEF"), "abc_def"); assert.strictEqual(slugify("abc_DEF"), "abc_def"); + assert.strictEqual(slugify("1,1"), "11"); assert.strictEqual(slugify("abc å DEF"), "abc_a_def"); assert.strictEqual(slugify("abc:DEF"), "abc_def"); - assert.strictEqual(slugify("abc&DEF"), "abc_and_def"); - assert.strictEqual(slugify("abc^^DEF"), "abcdef"); + assert.strictEqual(slugify("abc&DEF"), "abc_def"); + assert.strictEqual(slugify("abc^^DEF"), "abc_def"); assert.strictEqual(slugify("abc DEF"), "abc_def"); assert.strictEqual(slugify("_abc DEF"), "abc_def"); assert.strictEqual(slugify("abc DEF_"), "abc_def"); @@ -20,6 +23,8 @@ describe("slugify", () => { assert.strictEqual(slugify("abc - DEF - ghi"), "abc_def_ghi"); assert.strictEqual(slugify("abc---DEF---ghi"), "abc_def_ghi"); assert.strictEqual(slugify("___abc___DEF___ghi___"), "abc_def_ghi"); + assert.strictEqual(slugify("___"), "unknown"); + assert.strictEqual(slugify(""), ""); // With custom delimiter assert.strictEqual(slugify("abc def", "-"), "abc-def");