diff --git a/.changeset/thin-icons-pay.md b/.changeset/thin-icons-pay.md new file mode 100644 index 0000000000..ba814dc834 --- /dev/null +++ b/.changeset/thin-icons-pay.md @@ -0,0 +1,6 @@ +--- +"@digdir/designsystemet-react": patch +--- + +ToggleGroup: Active item equality check is now strict +Tabs: Active item equality check is now strict diff --git a/apps/theme/app/testside/FullBaseTest/FullBaseTest.tsx b/apps/theme/app/testside/FullBaseTest/FullBaseTest.tsx index 5032d013d7..3a9ab86278 100644 --- a/apps/theme/app/testside/FullBaseTest/FullBaseTest.tsx +++ b/apps/theme/app/testside/FullBaseTest/FullBaseTest.tsx @@ -104,10 +104,10 @@ export const FullBaseTest = () => { let bgDefault = blueColors[99]; let bgSubtle = blueColors[95]; - if (theme == 'dark') { + if (theme === 'dark') { bgDefault = blueColors[9]; bgSubtle = blueColors[13]; - } else if (theme == 'contrast') { + } else if (theme === 'contrast') { bgDefault = blueColors[0]; bgSubtle = blueColors[5]; } diff --git a/apps/theme/components/ColorPicker/ColorPicker.tsx b/apps/theme/components/ColorPicker/ColorPicker.tsx index 2113a1054a..59e2652338 100644 --- a/apps/theme/components/ColorPicker/ColorPicker.tsx +++ b/apps/theme/components/ColorPicker/ColorPicker.tsx @@ -54,8 +54,8 @@ export const ColorPicker = ({ className={cl( classes.status, 'ds-focus', - colorError == 'decorative' && classes.statusYellow, - colorError == 'interaction' && classes.statusOrange, + colorError === 'decorative' && classes.statusYellow, + colorError === 'interaction' && classes.statusOrange, )} > {colorError === 'none' && ( @@ -64,7 +64,7 @@ export const ColorPicker = ({ {colorError === 'decorative' && ( )} - {colorError == 'interaction' && ( + {colorError === 'interaction' && ( )} @@ -75,14 +75,14 @@ export const ColorPicker = ({ 'Denne fargen har god nok kontrast og kan brukes normalt i systemet.'}
- {colorError == 'decorative' && ( + {colorError === 'decorative' && (
Vær oppmerksom på at Base Default fargen har mindre enn 3:1 kontrast mot bakgrunnsfargene. Se alle kontrastgrensene inne på hver farge.
)} - {colorError == 'interaction' && ( + {colorError === 'interaction' && (
Base Default fargen har ikke god nok kontrast mot hvit eller svart tekst på tvers av Base fargene. diff --git a/biome.jsonc b/biome.jsonc index 0b66172bd5..7d452748a4 100644 --- a/biome.jsonc +++ b/biome.jsonc @@ -74,8 +74,7 @@ "useSelfClosingElements": "off" }, "suspicious": { - "noArrayIndexKey": "off", - "noDoubleEquals": "off" // TODO: Enable this rule + "noArrayIndexKey": "off" } }, "ignore": [] diff --git a/packages/cli/src/colors/colorUtils.ts b/packages/cli/src/colors/colorUtils.ts index 4077dda2d0..f4f398340d 100644 --- a/packages/cli/src/colors/colorUtils.ts +++ b/packages/cli/src/colors/colorUtils.ts @@ -29,7 +29,7 @@ export const hexToCssHsl = (hex: string, valuesOnly = false) => { let h = 0; let s = 0; let l = (max + min) / 2; - if (max == min) { + if (max === min) { h = s = 0; // achromatic } else { const d = max - min; @@ -68,11 +68,11 @@ export const hexToHSL = (H: string) => { let r = 0; let g = 0; let b = 0; - if (H.length == 4) { + if (H.length === 4) { r = parseInt('0x' + H[1] + H[1]); g = parseInt('0x' + H[2] + H[2]); b = parseInt('0x' + H[3] + H[3]); - } else if (H.length == 7) { + } else if (H.length === 7) { r = parseInt('0x' + H[1] + H[2]); g = parseInt('0x' + H[3] + H[4]); b = parseInt('0x' + H[5] + H[6]); @@ -88,9 +88,9 @@ export const hexToHSL = (H: string) => { const cmax = Math.max(r, g, b); const delta = cmax - cmin; - if (delta == 0) h = 0; - else if (cmax == r) h = ((g - b) / delta) % 6; - else if (cmax == g) h = (b - r) / delta + 2; + if (delta === 0) h = 0; + else if (cmax === r) h = ((g - b) / delta) % 6; + else if (cmax === g) h = (b - r) / delta + 2; else h = (r - g) / delta + 4; h = Math.round(h * 60); @@ -98,7 +98,7 @@ export const hexToHSL = (H: string) => { if (h < 0) h += 360; l = (cmax + cmin) / 2; - s = delta == 0 ? 0 : delta / (1 - Math.abs(2 * l - 1)); + s = delta === 0 ? 0 : delta / (1 - Math.abs(2 * l - 1)); s = +(s * 100).toFixed(1); l = +(l * 100).toFixed(1); @@ -178,9 +178,9 @@ export const HSLToHex = (h: number, s: number, l: number) => { b = parseInt(Math.round((b + m) * 255).toString(16), 16); // Prepend 0s, if necessary - if (r.toString().length == 1) r = parseInt('0' + r.toString(), 10); - if (g.toString().length == 1) g = parseInt('0' + g.toString(), 10); - if (b.toString().length == 1) b = parseInt('0' + b.toString(), 10); + if (r.toString().length === 1) r = parseInt('0' + r.toString(), 10); + if (g.toString().length === 1) g = parseInt('0' + g.toString(), 10); + if (b.toString().length === 1) b = parseInt('0' + b.toString(), 10); return '#' + r + g + b; }; diff --git a/packages/react/src/components/Tabs/TabContent.tsx b/packages/react/src/components/Tabs/TabContent.tsx index 7d67071a5f..4f3fdc3e6d 100644 --- a/packages/react/src/components/Tabs/TabContent.tsx +++ b/packages/react/src/components/Tabs/TabContent.tsx @@ -21,7 +21,7 @@ export type TabContentProps = { export const TabContent = forwardRef( ({ children, value, className, ...rest }, ref) => { const { value: tabsValue, size } = useContext(TabsContext); - const active = value == tabsValue; + const active = value === tabsValue; return ( <> diff --git a/packages/react/src/components/Tabs/useTab.ts b/packages/react/src/components/Tabs/useTab.ts index e18fb2cca6..c208418f71 100644 --- a/packages/react/src/components/Tabs/useTab.ts +++ b/packages/react/src/components/Tabs/useTab.ts @@ -22,7 +22,7 @@ export const useTabItem: UseTab = (props: TabProps) => { return { ...rest, id: buttonId, - 'aria-selected': tabs.value == value, + 'aria-selected': tabs.value === value, role: 'tab', size: tabs.size, onClick: () => { diff --git a/packages/react/src/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.ts b/packages/react/src/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.ts index 8fc1c6cfa7..76a22ed693 100644 --- a/packages/react/src/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.ts +++ b/packages/react/src/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.ts @@ -24,7 +24,7 @@ export const useToggleGroupItem: UseToggleGroupItem = ( const genValue = useId(); const toggleGroup = useContext(ToggleGroupContext); const value = props.value ?? genValue; - const active = toggleGroup.value == value; + const active = toggleGroup.value === value; const buttonId = `togglegroup-item-${useId()}`; return { diff --git a/packages/react/src/utilities/RovingFocus/RovingFocusItem.tsx b/packages/react/src/utilities/RovingFocus/RovingFocusItem.tsx index 6bbf0f97d7..b590ffa790 100644 --- a/packages/react/src/utilities/RovingFocus/RovingFocusItem.tsx +++ b/packages/react/src/utilities/RovingFocus/RovingFocusItem.tsx @@ -42,7 +42,7 @@ export const RovingFocusItem = forwardRef( const Component = asChild ? Slot : 'div'; const focusValue = - value ?? (typeof rest.children == 'string' ? rest.children : ''); + value ?? (typeof rest.children === 'string' ? rest.children : ''); const { getOrderedItems, getRovingProps, orientation } = useRovingFocus(focusValue);