fix: normalize both nav urls before comparing
This commit is contained in:
parent
ef133b7dca
commit
a7e0b36d82
2 changed files with 13 additions and 4 deletions
|
@ -1,10 +1,10 @@
|
||||||
---
|
---
|
||||||
import IconMapper from "@components/IconMapper.astro";
|
import IconMapper from "@components/IconMapper.astro";
|
||||||
import { removeTrailingSlash } from "@utils/helpers/general.js";
|
import { normalizePath } from "@utils/helpers/general.js";
|
||||||
|
|
||||||
const { url, title, icon } = Astro.props;
|
const { url, title, icon } = Astro.props;
|
||||||
const isHttp = url?.startsWith("http");
|
const isHttp = url?.startsWith("http");
|
||||||
const isActive = Astro.url.pathname === removeTrailingSlash(url);
|
const isActive = normalizePath(Astro.url.pathname) === normalizePath(url);
|
||||||
---
|
---
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
|
@ -36,7 +36,7 @@ export const parseCountryField = (countryField) => {
|
||||||
.reduce(
|
.reduce(
|
||||||
(countries, delimiter) =>
|
(countries, delimiter) =>
|
||||||
countries.flatMap((country) => country.split(delimiter)),
|
countries.flatMap((country) => country.split(delimiter)),
|
||||||
[countryField]
|
[countryField],
|
||||||
)
|
)
|
||||||
.map(getCountryName)
|
.map(getCountryName)
|
||||||
.join(", ");
|
.join(", ");
|
||||||
|
@ -110,7 +110,16 @@ export const md = (string) => markdown.render(string);
|
||||||
|
|
||||||
// urls
|
// urls
|
||||||
export const encodeAmp = (url) => url.replace(/&/g, "&");
|
export const encodeAmp = (url) => url.replace(/&/g, "&");
|
||||||
export const removeTrailingSlash = (url) => url.replace(/\/$/, "");
|
|
||||||
|
export const removeTrailingSlash = (url) => {
|
||||||
|
if (!url) return "";
|
||||||
|
return url.replace(/\/+$/, "");
|
||||||
|
};
|
||||||
|
|
||||||
|
export const normalizePath = (path) => {
|
||||||
|
if (!path) return "/";
|
||||||
|
return removeTrailingSlash(path).toLowerCase();
|
||||||
|
};
|
||||||
|
|
||||||
export const isExcludedPath = (path, exclusions) =>
|
export const isExcludedPath = (path, exclusions) =>
|
||||||
exclusions.some((exclusion) => path.includes(exclusion));
|
exclusions.some((exclusion) => path.includes(exclusion));
|
||||||
|
|
Reference in a new issue