@bookjane2/bookjane-design-library 8.3.0 → 8.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/components/BKJTypography/BKJTypography.d.ts +1 -2
- package/lib/components/BKJTypography/BKJTypography.d.ts.map +1 -1
- package/lib/components/BKJTypography/BKJTypography.js +4 -4
- package/lib/components/BKJTypography/BKJTypography.js.map +1 -1
- package/lib/components/BKJTypography/BKJTypography.stories.d.ts +7 -1
- package/lib/components/BKJTypography/BKJTypography.stories.d.ts.map +1 -1
- package/lib/components/BKJTypography/BKJTypography.stories.js +21 -1
- package/lib/components/BKJTypography/BKJTypography.stories.js.map +1 -1
- package/lib/components/BKJTypography/BKJTypography.styled.d.ts +2 -10
- package/lib/components/BKJTypography/BKJTypography.styled.d.ts.map +1 -1
- package/lib/components/BKJTypography/BKJTypography.styled.js +6 -23
- package/lib/components/BKJTypography/BKJTypography.styled.js.map +1 -1
- package/lib/components/BKJTypography/BKJTypography.test.d.ts +2 -0
- package/lib/components/BKJTypography/BKJTypography.test.d.ts.map +1 -0
- package/lib/components/BKJTypography/BKJTypography.test.js +89 -0
- package/lib/components/BKJTypography/BKJTypography.test.js.map +1 -0
- package/lib/components/BKJTypography/BKJTypography.types.d.ts +8 -5
- package/lib/components/BKJTypography/BKJTypography.types.d.ts.map +1 -1
- package/lib/components/VisuallyHidden/VisuallyHidden.d.ts +3 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.d.ts.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.js +6 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.stories.d.ts +11 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.stories.d.ts.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.stories.js +12 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.stories.js.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.styled.d.ts +3 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.styled.d.ts.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.styled.js +27 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.styled.js.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.test.d.ts +2 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.test.d.ts.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.test.js +88 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.test.js.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.types.d.ts +11 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.types.d.ts.map +1 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.types.js +2 -0
- package/lib/components/VisuallyHidden/VisuallyHidden.types.js.map +1 -0
- package/lib/components/VisuallyHidden/index.d.ts +2 -0
- package/lib/components/VisuallyHidden/index.d.ts.map +1 -0
- package/lib/components/VisuallyHidden/index.js +2 -0
- package/lib/components/VisuallyHidden/index.js.map +1 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.d.ts.map +1 -1
- package/lib/components/index.js +1 -0
- package/lib/components/index.js.map +1 -1
- package/package.json +4 -1
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { FC } from 'react';
|
|
2
1
|
import { IBKJTypographyProps } from './BKJTypography.types.js';
|
|
3
|
-
export declare const BKJTypography:
|
|
2
|
+
export declare const BKJTypography: ({ variant, element, as: asProp, children, ...rest }: IBKJTypographyProps) => JSX.Element;
|
|
4
3
|
//# sourceMappingURL=BKJTypography.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BKJTypography.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,eAAO,MAAM,aAAa,GAAI,qDAM3B,mBAAmB,gBAOrB,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import {
|
|
3
|
-
export const BKJTypography = ({ variant = 'Body', element = 'span', children, }) => {
|
|
4
|
-
const
|
|
5
|
-
return _jsx(
|
|
2
|
+
import { StyledTypography } from './BKJTypography.styled.js';
|
|
3
|
+
export const BKJTypography = ({ variant = 'Body', element = 'span', as: asProp, children, ...rest }) => {
|
|
4
|
+
const resolvedAs = asProp || element;
|
|
5
|
+
return (_jsx(StyledTypography, { as: resolvedAs, "$variant": variant, ...rest, children: children }));
|
|
6
6
|
};
|
|
7
7
|
//# sourceMappingURL=BKJTypography.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"BKJTypography.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAG1D,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC5B,OAAO,GAAG,MAAM,EAChB,OAAO,GAAG,MAAM,EAChB,EAAE,EAAE,MAAM,EACV,QAAQ,EACR,GAAG,IAAI,EACa,EAAE,EAAE;IACxB,MAAM,UAAU,GAAG,MAAM,IAAI,OAAO,CAAC;IACrC,OAAO,CACL,KAAC,gBAAgB,IAAC,EAAE,EAAE,UAAU,cAAY,OAAO,KAAM,IAAI,YAC1D,QAAQ,GACQ,CACpB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { StoryFn } from '@storybook/react';
|
|
1
2
|
import { IBKJTypographyProps } from './BKJTypography.types.js';
|
|
2
3
|
declare const _default: {
|
|
3
4
|
title: string;
|
|
4
|
-
component:
|
|
5
|
+
component: ({ variant, element, as: asProp, children, ...rest }: IBKJTypographyProps) => JSX.Element;
|
|
5
6
|
argTypes: {
|
|
6
7
|
variant: {
|
|
7
8
|
name: string;
|
|
@@ -11,6 +12,10 @@ declare const _default: {
|
|
|
11
12
|
name: string;
|
|
12
13
|
options: string[];
|
|
13
14
|
};
|
|
15
|
+
as: {
|
|
16
|
+
name: string;
|
|
17
|
+
options: string[];
|
|
18
|
+
};
|
|
14
19
|
children: {
|
|
15
20
|
name: string;
|
|
16
21
|
type: string;
|
|
@@ -19,4 +24,5 @@ declare const _default: {
|
|
|
19
24
|
};
|
|
20
25
|
export default _default;
|
|
21
26
|
export declare const Default: import("@storybook/core/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, IBKJTypographyProps>;
|
|
27
|
+
export declare const HeadingHierarchy: StoryFn;
|
|
22
28
|
//# sourceMappingURL=BKJTypography.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.stories.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.stories.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BKJTypography.stories.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;;;;;;;;;;AAE5D,wBA6CE;AAIF,eAAO,MAAM,OAAO,+GAAoB,CAAC;AAMzC,eAAO,MAAM,gBAAgB,EAAE,OAqB9B,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { BKJTypography } from './index.js';
|
|
3
3
|
export default {
|
|
4
4
|
title: 'Basic Elements/BKJTypography',
|
|
@@ -24,6 +24,22 @@ export default {
|
|
|
24
24
|
name: 'Element',
|
|
25
25
|
options: ['h1', 'h2', 'h3', 'h4', 'span', 'b', 'p'],
|
|
26
26
|
},
|
|
27
|
+
as: {
|
|
28
|
+
name: 'As (Semantic Element)',
|
|
29
|
+
options: [
|
|
30
|
+
'h1',
|
|
31
|
+
'h2',
|
|
32
|
+
'h3',
|
|
33
|
+
'h4',
|
|
34
|
+
'h5',
|
|
35
|
+
'h6',
|
|
36
|
+
'p',
|
|
37
|
+
'span',
|
|
38
|
+
'label',
|
|
39
|
+
'legend',
|
|
40
|
+
'caption',
|
|
41
|
+
],
|
|
42
|
+
},
|
|
27
43
|
children: {
|
|
28
44
|
name: 'Text',
|
|
29
45
|
type: 'string',
|
|
@@ -35,4 +51,8 @@ export const Default = Template.bind({});
|
|
|
35
51
|
Default.args = {
|
|
36
52
|
children: 'Lorem ipsum',
|
|
37
53
|
};
|
|
54
|
+
export const HeadingHierarchy = () => (_jsxs("div", { children: [_jsx(BKJTypography, { as: "h1", variant: "H1", children: "Heading Level 1 (h1)" }), _jsx(BKJTypography, { as: "h2", variant: "H2", children: "Heading Level 2 (h2)" }), _jsx(BKJTypography, { as: "h3", variant: "H3", children: "Heading Level 3 (h3)" }), _jsx(BKJTypography, { as: "h4", variant: "H4", children: "Heading Level 4 (h4)" }), _jsx(BKJTypography, { as: "h5", variant: "Bold", children: "Heading Level 5 (h5)" }), _jsx(BKJTypography, { as: "h6", variant: "CaptionBold", children: "Heading Level 6 (h6)" })] }));
|
|
55
|
+
HeadingHierarchy.parameters = {
|
|
56
|
+
controls: { disable: true },
|
|
57
|
+
};
|
|
38
58
|
//# sourceMappingURL=BKJTypography.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.stories.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,aAAa,EAAE,MAAM,GAAG,CAAC;AAGlC,eAAe;IACb,KAAK,EAAE,8BAA8B;IACrC,SAAS,EAAE,aAAa;IACxB,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE;gBACP,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,MAAM;gBACN,eAAe;gBACf,MAAM;gBACN,SAAS;gBACT,aAAa;gBACb,QAAQ;gBACR,UAAU;aACX;SACF;QACD,OAAO,EAAE;YACP,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC;SACpD;QACD,QAAQ,EAAE;YACR,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,QAAQ;SACf;KACF;CACF,CAAC;AAEF,MAAM,QAAQ,GAAiC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAC,aAAa,OAAK,IAAI,GAAI,CAAC;AAErF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAEzC,OAAO,CAAC,IAAI,GAAG;IACb,QAAQ,EAAE,aAAa;CACxB,CAAC"}
|
|
1
|
+
{"version":3,"file":"BKJTypography.stories.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,aAAa,EAAE,MAAM,GAAG,CAAC;AAGlC,eAAe;IACb,KAAK,EAAE,8BAA8B;IACrC,SAAS,EAAE,aAAa;IACxB,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE;gBACP,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,MAAM;gBACN,eAAe;gBACf,MAAM;gBACN,SAAS;gBACT,aAAa;gBACb,QAAQ;gBACR,UAAU;aACX;SACF;QACD,OAAO,EAAE;YACP,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC;SACpD;QACD,EAAE,EAAE;YACF,IAAI,EAAE,uBAAuB;YAC7B,OAAO,EAAE;gBACP,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,IAAI;gBACJ,GAAG;gBACH,MAAM;gBACN,OAAO;gBACP,QAAQ;gBACR,SAAS;aACV;SACF;QACD,QAAQ,EAAE;YACR,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,QAAQ;SACf;KACF;CACF,CAAC;AAEF,MAAM,QAAQ,GAAiC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAC,aAAa,OAAK,IAAI,GAAI,CAAC;AAErF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAEzC,OAAO,CAAC,IAAI,GAAG;IACb,QAAQ,EAAE,aAAa;CACxB,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAY,GAAG,EAAE,CAAC,CAC7C,0BACE,KAAC,aAAa,IAAC,EAAE,EAAC,IAAI,EAAC,OAAO,EAAC,IAAI,qCAEnB,EAChB,KAAC,aAAa,IAAC,EAAE,EAAC,IAAI,EAAC,OAAO,EAAC,IAAI,qCAEnB,EAChB,KAAC,aAAa,IAAC,EAAE,EAAC,IAAI,EAAC,OAAO,EAAC,IAAI,qCAEnB,EAChB,KAAC,aAAa,IAAC,EAAE,EAAC,IAAI,EAAC,OAAO,EAAC,IAAI,qCAEnB,EAChB,KAAC,aAAa,IAAC,EAAE,EAAC,IAAI,EAAC,OAAO,EAAC,MAAM,qCAErB,EAChB,KAAC,aAAa,IAAC,EAAE,EAAC,IAAI,EAAC,OAAO,EAAC,aAAa,qCAE5B,IACZ,CACP,CAAC;AAEF,gBAAgB,CAAC,UAAU,GAAG;IAC5B,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;CAC5B,CAAC"}
|
|
@@ -1,11 +1,3 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare const
|
|
3
|
-
h1: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, IBKJTypographyStyledElement>> & string;
|
|
4
|
-
h2: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, IBKJTypographyStyledElement>> & string;
|
|
5
|
-
h3: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, IBKJTypographyStyledElement>> & string;
|
|
6
|
-
h4: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, IBKJTypographyStyledElement>> & string;
|
|
7
|
-
span: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, IBKJTypographyStyledElement>> & string;
|
|
8
|
-
b: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, IBKJTypographyStyledElement>> & string;
|
|
9
|
-
p: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLParagraphElement>, HTMLParagraphElement>, IBKJTypographyStyledElement>> & string;
|
|
10
|
-
};
|
|
1
|
+
import { IStyledTypographyProps } from './BKJTypography.types.js';
|
|
2
|
+
export declare const StyledTypography: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, IStyledTypographyProps>> & string;
|
|
11
3
|
//# sourceMappingURL=BKJTypography.styled.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.styled.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.styled.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"BKJTypography.styled.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.styled.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,eAAO,MAAM,gBAAgB,6PAK5B,CAAC"}
|
|
@@ -1,25 +1,8 @@
|
|
|
1
1
|
import styled from 'styled-components';
|
|
2
|
-
export const
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
`,
|
|
9
|
-
h3: styled.h3 `
|
|
10
|
-
${({ theme, $variant }) => theme.typography[$variant]};
|
|
11
|
-
`,
|
|
12
|
-
h4: styled.h4 `
|
|
13
|
-
${({ theme, $variant }) => theme.typography[$variant]};
|
|
14
|
-
`,
|
|
15
|
-
span: styled.span `
|
|
16
|
-
${({ theme, $variant }) => theme.typography[$variant]};
|
|
17
|
-
`,
|
|
18
|
-
b: styled.b `
|
|
19
|
-
${({ theme, $variant }) => theme.typography[$variant]};
|
|
20
|
-
`,
|
|
21
|
-
p: styled.p `
|
|
22
|
-
${({ theme, $variant }) => theme.typography[$variant]};
|
|
23
|
-
`,
|
|
24
|
-
};
|
|
2
|
+
export const StyledTypography = styled.span `
|
|
3
|
+
margin: 0;
|
|
4
|
+
padding: 0;
|
|
5
|
+
border: 0;
|
|
6
|
+
${({ theme, $variant }) => theme.typography[$variant]};
|
|
7
|
+
`;
|
|
25
8
|
//# sourceMappingURL=BKJTypography.styled.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.styled.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.styled.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAGvC,MAAM,CAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"BKJTypography.styled.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.styled.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAGvC,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAwB;;;;IAI/D,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC;CACtD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BKJTypography.test.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.test.tsx"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { render } from '@testing-library/react';
|
|
3
|
+
import { axe, toHaveNoViolations } from 'jest-axe';
|
|
4
|
+
import { BKJTypography } from './BKJTypography.js';
|
|
5
|
+
import { BKJThemeProvider } from '../../providers/BKJThemeProvider/index.js';
|
|
6
|
+
expect.extend(toHaveNoViolations);
|
|
7
|
+
const renderWithTheme = (component) => {
|
|
8
|
+
return render(_jsx(BKJThemeProvider, { children: component }));
|
|
9
|
+
};
|
|
10
|
+
describe('US1: Semantic heading rendering', () => {
|
|
11
|
+
it('renders as h1 when as="h1" is passed', () => {
|
|
12
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h1", variant: "H1", children: "Heading 1" }));
|
|
13
|
+
expect(getByRole('heading', { level: 1 })).toBeInTheDocument();
|
|
14
|
+
});
|
|
15
|
+
it('renders as h2 when as="h2" is passed', () => {
|
|
16
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h2", variant: "H2", children: "Heading 2" }));
|
|
17
|
+
expect(getByRole('heading', { level: 2 })).toBeInTheDocument();
|
|
18
|
+
});
|
|
19
|
+
it('renders as h3 when as="h3" is passed', () => {
|
|
20
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h3", variant: "H3", children: "Heading 3" }));
|
|
21
|
+
expect(getByRole('heading', { level: 3 })).toBeInTheDocument();
|
|
22
|
+
});
|
|
23
|
+
it('renders as h4 when as="h4" is passed', () => {
|
|
24
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h4", variant: "H4", children: "Heading 4" }));
|
|
25
|
+
expect(getByRole('heading', { level: 4 })).toBeInTheDocument();
|
|
26
|
+
});
|
|
27
|
+
it('renders as h5 when as="h5" is passed', () => {
|
|
28
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h5", variant: "Body", children: "Heading 5" }));
|
|
29
|
+
expect(getByRole('heading', { level: 5 })).toBeInTheDocument();
|
|
30
|
+
});
|
|
31
|
+
it('renders as h6 when as="h6" is passed', () => {
|
|
32
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h6", variant: "Caption", children: "Heading 6" }));
|
|
33
|
+
expect(getByRole('heading', { level: 6 })).toBeInTheDocument();
|
|
34
|
+
});
|
|
35
|
+
it('has no accessibility violations for heading hierarchy', async () => {
|
|
36
|
+
const { container } = renderWithTheme(_jsxs("main", { children: [_jsx(BKJTypography, { as: "h1", variant: "H1", children: "Main Title" }), _jsx(BKJTypography, { as: "h2", variant: "H2", children: "Section" }), _jsx(BKJTypography, { as: "h3", variant: "H3", children: "Subsection" }), _jsx(BKJTypography, { as: "h4", variant: "H4", children: "Detail" }), _jsx(BKJTypography, { as: "h5", variant: "Body", children: "Sub-detail" }), _jsx(BKJTypography, { as: "h6", variant: "Caption", children: "Fine print" })] }));
|
|
37
|
+
const results = await axe(container);
|
|
38
|
+
expect(results).toHaveNoViolations();
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
describe('US2: Backward-compatible default behavior', () => {
|
|
42
|
+
it('renders as span by default when no as or element prop is provided', () => {
|
|
43
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { children: "Default text" }));
|
|
44
|
+
expect(getByText('Default text').tagName).toBe('SPAN');
|
|
45
|
+
});
|
|
46
|
+
it('renders correct element when element prop is used without as', () => {
|
|
47
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { element: "h1", variant: "H1", children: "Element heading" }));
|
|
48
|
+
expect(getByRole('heading', { level: 1 })).toBeInTheDocument();
|
|
49
|
+
});
|
|
50
|
+
it('renders as p when element="p" is used without as', () => {
|
|
51
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { element: "p", children: "Paragraph via element" }));
|
|
52
|
+
expect(getByText('Paragraph via element').tagName).toBe('P');
|
|
53
|
+
});
|
|
54
|
+
it('renders as b when element="b" is used without as', () => {
|
|
55
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { element: "b", variant: "Bold", children: "Bold via element" }));
|
|
56
|
+
expect(getByText('Bold via element').tagName).toBe('B');
|
|
57
|
+
});
|
|
58
|
+
it('as prop takes precedence over element when both provided', () => {
|
|
59
|
+
const { getByRole } = renderWithTheme(_jsx(BKJTypography, { as: "h2", element: "h3", variant: "H2", children: "Precedence test" }));
|
|
60
|
+
expect(getByRole('heading', { level: 2 })).toBeInTheDocument();
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
describe('US3: Non-heading semantic elements', () => {
|
|
64
|
+
it('renders as p when as="p" is passed', () => {
|
|
65
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { as: "p", children: "Paragraph text" }));
|
|
66
|
+
expect(getByText('Paragraph text').tagName).toBe('P');
|
|
67
|
+
});
|
|
68
|
+
it('renders as label when as="label" is passed', () => {
|
|
69
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { as: "label", children: "Label text" }));
|
|
70
|
+
expect(getByText('Label text').tagName).toBe('LABEL');
|
|
71
|
+
});
|
|
72
|
+
it('renders as legend when as="legend" is passed', () => {
|
|
73
|
+
const { getByText } = renderWithTheme(_jsx("fieldset", { children: _jsx(BKJTypography, { as: "legend", children: "Legend text" }) }));
|
|
74
|
+
expect(getByText('Legend text').tagName).toBe('LEGEND');
|
|
75
|
+
});
|
|
76
|
+
it('renders as caption when as="caption" is passed', () => {
|
|
77
|
+
const { getByText } = renderWithTheme(_jsxs("table", { children: [_jsx(BKJTypography, { as: "caption", children: "Caption text" }), _jsx("tbody", { children: _jsx("tr", { children: _jsx("td", { children: "data" }) }) })] }));
|
|
78
|
+
expect(getByText('Caption text').tagName).toBe('CAPTION');
|
|
79
|
+
});
|
|
80
|
+
it('forwards htmlFor attribute when as="label"', () => {
|
|
81
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { as: "label", htmlFor: "email-input", children: "Email" }));
|
|
82
|
+
expect(getByText('Email')).toHaveAttribute('for', 'email-input');
|
|
83
|
+
});
|
|
84
|
+
it('renders as span when as="span" is explicitly passed', () => {
|
|
85
|
+
const { getByText } = renderWithTheme(_jsx(BKJTypography, { as: "span", children: "Explicit span" }));
|
|
86
|
+
expect(getByText('Explicit span').tagName).toBe('SPAN');
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
//# sourceMappingURL=BKJTypography.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BKJTypography.test.js","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
|
-
import { ReactNode } from 'react';
|
|
1
|
+
import { HTMLAttributes, ReactNode } from 'react';
|
|
2
2
|
import { Interpolation } from 'styled-components';
|
|
3
|
-
export interface
|
|
3
|
+
export interface IStyledTypographyProps {
|
|
4
4
|
$variant: BKJTypographyVariantType;
|
|
5
5
|
}
|
|
6
|
-
export interface IBKJTypographyProps {
|
|
7
|
-
variant
|
|
8
|
-
element
|
|
6
|
+
export interface IBKJTypographyProps extends HTMLAttributes<HTMLElement> {
|
|
7
|
+
variant?: BKJTypographyVariantType;
|
|
8
|
+
element?: BKJTypographyElementType;
|
|
9
|
+
as?: BKJTypographyAsType;
|
|
9
10
|
children: ReactNode;
|
|
11
|
+
[key: string]: unknown;
|
|
10
12
|
}
|
|
13
|
+
export type BKJTypographyAsType = 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6' | 'p' | 'span' | 'label' | 'legend' | 'caption';
|
|
11
14
|
export interface IBKJThemeTypography {
|
|
12
15
|
H1: Interpolation<any>;
|
|
13
16
|
H2: Interpolation<any>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJTypography.types.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"BKJTypography.types.d.ts","sourceRoot":"","sources":["../../../src/components/BKJTypography/BKJTypography.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,sBAAsB;IACrC,QAAQ,EAAE,wBAAwB,CAAC;CACpC;AAED,MAAM,WAAW,mBAAoB,SAAQ,cAAc,CAAC,WAAW,CAAC;IACtE,OAAO,CAAC,EAAE,wBAAwB,CAAC;IACnC,OAAO,CAAC,EAAE,wBAAwB,CAAC;IACnC,EAAE,CAAC,EAAE,mBAAmB,CAAC;IACzB,QAAQ,EAAE,SAAS,CAAC;IACpB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,MAAM,mBAAmB,GAC3B,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,GAAG,GACH,MAAM,GACN,OAAO,GACP,QAAQ,GACR,SAAS,CAAC;AAEd,MAAM,WAAW,mBAAmB;IAClC,EAAE,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACvB,EAAE,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACvB,EAAE,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACvB,EAAE,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACvB,IAAI,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACzB,aAAa,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAClC,IAAI,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IACzB,OAAO,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAC5B,WAAW,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAChC,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAC3B,QAAQ,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;CAC9B;AAED,MAAM,MAAM,wBAAwB,GAChC,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,IAAI,GACJ,MAAM,GACN,eAAe,GACf,MAAM,GACN,SAAS,GACT,aAAa,GACb,QAAQ,GACR,UAAU,CAAC;AACf,MAAM,MAAM,wBAAwB,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.d.ts","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAE9D,eAAO,MAAM,cAAc,GAAI,wBAAgC,oBAAoB,gBAElF,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { StyledVisuallyHidden } from './VisuallyHidden.styled.js';
|
|
3
|
+
export const VisuallyHidden = ({ focusable = false, ...rest }) => {
|
|
4
|
+
return _jsx(StyledVisuallyHidden, { "$focusable": focusable, ...rest });
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=VisuallyHidden.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.js","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAG/D,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,SAAS,GAAG,KAAK,EAAE,GAAG,IAAI,EAAwB,EAAE,EAAE;IACrF,OAAO,KAAC,oBAAoB,kBAAa,SAAS,KAAM,IAAI,GAAI,CAAC;AACnE,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { StoryFn } from '@storybook/react';
|
|
2
|
+
declare const _default: {
|
|
3
|
+
title: string;
|
|
4
|
+
component: ({ focusable, ...rest }: import("./VisuallyHidden.types.js").IVisuallyHiddenProps) => JSX.Element;
|
|
5
|
+
};
|
|
6
|
+
export default _default;
|
|
7
|
+
export declare const Default: StoryFn;
|
|
8
|
+
export declare const AsHeading: StoryFn;
|
|
9
|
+
export declare const AsLabel: StoryFn;
|
|
10
|
+
export declare const SkipLink: StoryFn;
|
|
11
|
+
//# sourceMappingURL=VisuallyHidden.stories.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.stories.d.ts","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;;;;;AAI3C,wBAGE;AAEF,eAAO,MAAM,OAAO,EAAE,OAarB,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,OAiBvB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,OAarB,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,OAgBtB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { VisuallyHidden } from './VisuallyHidden.js';
|
|
3
|
+
import { BKJTheme, BKJThemeProvider } from '../../providers/BKJThemeProvider/index.js';
|
|
4
|
+
export default {
|
|
5
|
+
title: 'Utilities/VisuallyHidden',
|
|
6
|
+
component: VisuallyHidden,
|
|
7
|
+
};
|
|
8
|
+
export const Default = () => (_jsx(BKJThemeProvider, { theme: BKJTheme, children: _jsxs("div", { children: [_jsx("p", { children: "The button below contains visually hidden text that screen readers will announce. Inspect the DOM to see the hidden content." }), _jsxs("button", { type: "button", children: [_jsx("span", { "aria-hidden": "true", children: "\u2715" }), _jsx(VisuallyHidden, { children: "Close dialog" })] })] }) }));
|
|
9
|
+
export const AsHeading = () => (_jsx(BKJThemeProvider, { theme: BKJTheme, children: _jsxs("div", { children: [_jsxs("p", { children: ["The section below has a visually hidden heading (", `<h2>`, ") that provides structure for screen readers. Inspect the DOM to see it."] }), _jsxs("section", { "aria-labelledby": "filter-heading", children: [_jsx(VisuallyHidden, { as: "h2", id: "filter-heading", children: "Filter options" }), _jsxs("label", { children: ["Search: ", _jsx("input", { type: "text", placeholder: "Type to filter..." })] })] })] }) }));
|
|
10
|
+
export const AsLabel = () => (_jsx(BKJThemeProvider, { theme: BKJTheme, children: _jsxs("div", { children: [_jsx("p", { children: "The input below has a visually hidden label. Screen readers will announce the label when the input receives focus." }), _jsx(VisuallyHidden, { as: "label", htmlFor: "search-input", children: "Search the site" }), _jsx("input", { id: "search-input", type: "text", placeholder: "Search..." })] }) }));
|
|
11
|
+
export const SkipLink = () => (_jsx(BKJThemeProvider, { theme: BKJTheme, children: _jsxs("div", { children: [_jsx("p", { children: "Press Tab to reveal the skip navigation link below." }), _jsx(VisuallyHidden, { as: "a", href: "#main-content", focusable: true, children: "Skip to main content" }), _jsxs("nav", { children: [_jsx("a", { href: "#home", children: "Home" }), " | ", _jsx("a", { href: "#about", children: "About" }), " | ", _jsx("a", { href: "#contact", children: "Contact" })] }), _jsxs("main", { id: "main-content", children: [_jsx("h1", { children: "Main Content" }), _jsx("p", { children: "This is the main content area. The skip link jumps directly here." })] })] }) }));
|
|
12
|
+
//# sourceMappingURL=VisuallyHidden.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.stories.js","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAE9E,eAAe;IACb,KAAK,EAAE,0BAA0B;IACjC,SAAS,EAAE,cAAc;CAC1B,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAY,GAAG,EAAE,CAAC,CACpC,KAAC,gBAAgB,IAAC,KAAK,EAAE,QAAQ,YAC/B,0BACE,uJAGI,EACJ,kBAAQ,IAAI,EAAC,QAAQ,aACnB,8BAAkB,MAAM,uBAAgB,EACxC,KAAC,cAAc,+BAA8B,IACtC,IACL,GACW,CACpB,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAY,GAAG,EAAE,CAAC,CACtC,KAAC,gBAAgB,IAAC,KAAK,EAAE,QAAQ,YAC/B,0BACE,6EACoD,MAAM,gFAEtD,EACJ,sCAAyB,gBAAgB,aACvC,KAAC,cAAc,IAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,gBAAgB,+BAE1B,EACjB,wCACU,gBAAO,IAAI,EAAC,MAAM,EAAC,WAAW,EAAC,mBAAmB,GAAG,IACvD,IACA,IACN,GACW,CACpB,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAY,GAAG,EAAE,CAAC,CACpC,KAAC,gBAAgB,IAAC,KAAK,EAAE,QAAQ,YAC/B,0BACE,6IAGI,EACJ,KAAC,cAAc,IAAC,EAAE,EAAC,OAAO,EAAC,OAAO,EAAC,cAAc,gCAEhC,EACjB,gBAAO,EAAE,EAAC,cAAc,EAAC,IAAI,EAAC,MAAM,EAAC,WAAW,EAAC,WAAW,GAAG,IAC3D,GACW,CACpB,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAY,GAAG,EAAE,CAAC,CACrC,KAAC,gBAAgB,IAAC,KAAK,EAAE,QAAQ,YAC/B,0BACE,8EAA0D,EAC1D,KAAC,cAAc,IAAC,EAAE,EAAC,GAAG,EAAC,IAAI,EAAC,eAAe,EAAC,SAAS,2CAEpC,EACjB,0BACE,YAAG,IAAI,EAAC,OAAO,qBAAS,SAAG,YAAG,IAAI,EAAC,QAAQ,sBAAU,SAAG,YAAG,IAAI,EAAC,UAAU,wBAAY,IAClF,EACN,gBAAM,EAAE,EAAC,cAAc,aACrB,wCAAqB,EACrB,4FAAwE,IACnE,IACH,GACW,CACpB,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { IStyledVisuallyHiddenProps } from './VisuallyHidden.types.js';
|
|
2
|
+
export declare const StyledVisuallyHidden: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, IStyledVisuallyHiddenProps>> & string;
|
|
3
|
+
//# sourceMappingURL=VisuallyHidden.styled.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.styled.d.ts","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.styled.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AAEpE,eAAO,MAAM,oBAAoB,iQAyBhC,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
export const StyledVisuallyHidden = styled.span `
|
|
3
|
+
position: absolute;
|
|
4
|
+
width: 1px;
|
|
5
|
+
height: 1px;
|
|
6
|
+
padding: 0;
|
|
7
|
+
margin: -1px;
|
|
8
|
+
overflow: hidden;
|
|
9
|
+
clip: rect(0, 0, 0, 0);
|
|
10
|
+
white-space: nowrap;
|
|
11
|
+
border: 0;
|
|
12
|
+
|
|
13
|
+
${({ $focusable }) => $focusable &&
|
|
14
|
+
`
|
|
15
|
+
&:focus,
|
|
16
|
+
&:focus-within {
|
|
17
|
+
position: static;
|
|
18
|
+
width: auto;
|
|
19
|
+
height: auto;
|
|
20
|
+
margin: 0;
|
|
21
|
+
overflow: visible;
|
|
22
|
+
clip: auto;
|
|
23
|
+
white-space: normal;
|
|
24
|
+
}
|
|
25
|
+
`}
|
|
26
|
+
`;
|
|
27
|
+
//# sourceMappingURL=VisuallyHidden.styled.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.styled.js","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.styled.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAGvC,MAAM,CAAC,MAAM,oBAAoB,GAAG,MAAM,CAAC,IAAI,CAA4B;;;;;;;;;;;IAWvE,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,CACnB,UAAU;IACV;;;;;;;;;;;GAWD;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.test.d.ts","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.test.tsx"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { render, fireEvent } from '@testing-library/react';
|
|
3
|
+
import { axe, toHaveNoViolations } from 'jest-axe';
|
|
4
|
+
import { VisuallyHidden } from './VisuallyHidden.js';
|
|
5
|
+
import { BKJThemeProvider } from '../../providers/BKJThemeProvider/index.js';
|
|
6
|
+
expect.extend(toHaveNoViolations);
|
|
7
|
+
const renderWithTheme = (component) => {
|
|
8
|
+
return render(_jsx(BKJThemeProvider, { children: component }));
|
|
9
|
+
};
|
|
10
|
+
describe('VisuallyHidden', () => {
|
|
11
|
+
describe('US1: Screen reader content', () => {
|
|
12
|
+
it('renders children text in the DOM', () => {
|
|
13
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { children: "Hidden label" }));
|
|
14
|
+
expect(getByText('Hidden label')).toBeInTheDocument();
|
|
15
|
+
});
|
|
16
|
+
it('applies visually hidden CSS styles', () => {
|
|
17
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { children: "Hidden label" }));
|
|
18
|
+
const element = getByText('Hidden label');
|
|
19
|
+
const styles = window.getComputedStyle(element);
|
|
20
|
+
expect(styles.position).toBe('absolute');
|
|
21
|
+
expect(styles.width).toBe('1px');
|
|
22
|
+
expect(styles.height).toBe('1px');
|
|
23
|
+
expect(styles.overflow).toBe('hidden');
|
|
24
|
+
});
|
|
25
|
+
it('renders without errors when no children are provided', () => {
|
|
26
|
+
const { container } = renderWithTheme(_jsx(VisuallyHidden, { children: undefined }));
|
|
27
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
describe('US2: Polymorphic element rendering', () => {
|
|
31
|
+
it('renders as a span by default', () => {
|
|
32
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { children: "Default element" }));
|
|
33
|
+
// span has no implicit ARIA role, so we use the DOM element check
|
|
34
|
+
expect(getByText('Default element').tagName).toBe('SPAN');
|
|
35
|
+
});
|
|
36
|
+
it('renders as a div when as="div" is passed', () => {
|
|
37
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { as: "div", children: "Div element" }));
|
|
38
|
+
expect(getByText('Div element').tagName).toBe('DIV');
|
|
39
|
+
});
|
|
40
|
+
it('renders as an h2 when as="h2" is passed', () => {
|
|
41
|
+
const { getByRole } = renderWithTheme(_jsx(VisuallyHidden, { as: "h2", children: "Section heading" }));
|
|
42
|
+
expect(getByRole('heading', { level: 2 })).toBeInTheDocument();
|
|
43
|
+
});
|
|
44
|
+
it('forwards HTML attributes to the rendered element', () => {
|
|
45
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { id: "sr-label", className: "custom-class", children: "Attributed element" }));
|
|
46
|
+
const element = getByText('Attributed element');
|
|
47
|
+
expect(element).toHaveAttribute('id', 'sr-label');
|
|
48
|
+
expect(element).toHaveClass('custom-class');
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
describe('US3: Focusable skip links', () => {
|
|
52
|
+
it('does not change styles when focused and focusable is false', () => {
|
|
53
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { children: "Not focusable" }));
|
|
54
|
+
const element = getByText('Not focusable');
|
|
55
|
+
fireEvent.focus(element);
|
|
56
|
+
const styles = window.getComputedStyle(element);
|
|
57
|
+
expect(styles.position).toBe('absolute');
|
|
58
|
+
expect(styles.width).toBe('1px');
|
|
59
|
+
expect(styles.height).toBe('1px');
|
|
60
|
+
});
|
|
61
|
+
it('renders without error when focusable is true', () => {
|
|
62
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { as: "a", focusable: true, children: "Skip to content" }));
|
|
63
|
+
expect(getByText('Skip to content')).toBeInTheDocument();
|
|
64
|
+
});
|
|
65
|
+
it('applies hidden styles in default state when focusable is true', () => {
|
|
66
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { as: "a", focusable: true, children: "Skip to content" }));
|
|
67
|
+
const element = getByText('Skip to content');
|
|
68
|
+
const styles = window.getComputedStyle(element);
|
|
69
|
+
expect(styles.position).toBe('absolute');
|
|
70
|
+
expect(styles.width).toBe('1px');
|
|
71
|
+
});
|
|
72
|
+
it('can receive focus when focusable is true', () => {
|
|
73
|
+
const handleFocus = jest.fn();
|
|
74
|
+
const { getByText } = renderWithTheme(_jsx(VisuallyHidden, { as: "a", href: "#main", focusable: true, onFocus: handleFocus, children: "Skip to main content" }));
|
|
75
|
+
const element = getByText('Skip to main content');
|
|
76
|
+
fireEvent.focus(element);
|
|
77
|
+
expect(handleFocus).toHaveBeenCalledTimes(1);
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
describe('Accessibility', () => {
|
|
81
|
+
it('has no accessibility violations', async () => {
|
|
82
|
+
const { container } = renderWithTheme(_jsxs("button", { type: "button", children: [_jsx("span", { "aria-hidden": "true", children: "X" }), _jsx(VisuallyHidden, { children: "Close" })] }));
|
|
83
|
+
const results = await axe(container);
|
|
84
|
+
expect(results).toHaveNoViolations();
|
|
85
|
+
});
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
//# sourceMappingURL=VisuallyHidden.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.test.js","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { HTMLAttributes, ElementType, ReactNode } from 'react';
|
|
2
|
+
export interface IVisuallyHiddenProps extends HTMLAttributes<HTMLElement> {
|
|
3
|
+
children: ReactNode;
|
|
4
|
+
as?: ElementType;
|
|
5
|
+
focusable?: boolean;
|
|
6
|
+
[key: string]: unknown;
|
|
7
|
+
}
|
|
8
|
+
export interface IStyledVisuallyHiddenProps {
|
|
9
|
+
$focusable?: boolean;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=VisuallyHidden.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.types.d.ts","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAE/D,MAAM,WAAW,oBAAqB,SAAQ,cAAc,CAAC,WAAW,CAAC;IACvE,QAAQ,EAAE,SAAS,CAAC;IACpB,EAAE,CAAC,EAAE,WAAW,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;IAGpB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,0BAA0B;IACzC,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VisuallyHidden.types.js","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/VisuallyHidden.types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/VisuallyHidden/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC"}
|
|
@@ -44,4 +44,5 @@ export * from './BKJDropdownMenu/index.js';
|
|
|
44
44
|
export * from './MobileBKJDropdownMenu/index.js';
|
|
45
45
|
export * from './BKJPillDropdown/index.js';
|
|
46
46
|
export * from './BKJTimeInput/index.js';
|
|
47
|
+
export * from './VisuallyHidden/index.js';
|
|
47
48
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,QAAQ,CAAC;AACvB,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,QAAQ,CAAC;AACvB,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC"}
|
package/lib/components/index.js
CHANGED
|
@@ -44,4 +44,5 @@ export * from './BKJDropdownMenu/index.js';
|
|
|
44
44
|
export * from './MobileBKJDropdownMenu/index.js';
|
|
45
45
|
export * from './BKJPillDropdown/index.js';
|
|
46
46
|
export * from './BKJTimeInput/index.js';
|
|
47
|
+
export * from './VisuallyHidden/index.js';
|
|
47
48
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,QAAQ,CAAC;AACvB,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,QAAQ,CAAC;AACvB,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bookjane2/bookjane-design-library",
|
|
3
|
-
"version": "8.3.
|
|
3
|
+
"version": "8.3.2",
|
|
4
4
|
"main": "./lib/index.js",
|
|
5
5
|
"typings": "./lib/index.d.ts",
|
|
6
6
|
"engines": {
|
|
@@ -64,6 +64,7 @@
|
|
|
64
64
|
"@types/google-map-react": "2.1.10",
|
|
65
65
|
"@types/google.maps": "3.58.1",
|
|
66
66
|
"@types/jest": "26.0.23",
|
|
67
|
+
"@types/jest-axe": "^3.5.9",
|
|
67
68
|
"@types/lodash": "4.17.20",
|
|
68
69
|
"@types/node": "20.17.0",
|
|
69
70
|
"@types/react": "17.0.8",
|
|
@@ -79,7 +80,9 @@
|
|
|
79
80
|
"eslint": "9.37.0",
|
|
80
81
|
"husky": "6.0.0",
|
|
81
82
|
"jest": "29.7.0",
|
|
83
|
+
"jest-axe": "^9.0.0",
|
|
82
84
|
"jest-environment-jsdom": "29.7.0",
|
|
85
|
+
"jest-util": "^29.7.0",
|
|
83
86
|
"lint-staged": "11.0.0",
|
|
84
87
|
"prettier": "2.3.0",
|
|
85
88
|
"react": "17.0.2",
|