@bookjane2/bookjane-design-library 9.0.24 → 9.0.26
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/BKJDialog/BKJDialog.d.ts.map +1 -1
- package/lib/components/BKJDialog/BKJDialog.js +12 -2
- package/lib/components/BKJDialog/BKJDialog.js.map +1 -1
- package/lib/components/BKJDialog/BKJDialog.stories.d.ts +1 -0
- package/lib/components/BKJDialog/BKJDialog.stories.d.ts.map +1 -1
- package/lib/components/BKJDialog/BKJDialog.stories.js +14 -2
- package/lib/components/BKJDialog/BKJDialog.stories.js.map +1 -1
- package/lib/components/BKJDialog/BKJDialog.styled.d.ts +1 -1
- package/lib/components/BKJDialog/BKJDialog.styled.d.ts.map +1 -1
- package/lib/components/BKJDialog/BKJDialog.styled.js +8 -1
- package/lib/components/BKJDialog/BKJDialog.styled.js.map +1 -1
- package/lib/components/BKJDialog/BKJDialog.test.d.ts +2 -0
- package/lib/components/BKJDialog/BKJDialog.test.d.ts.map +1 -0
- package/lib/components/BKJDialog/BKJDialog.test.js +117 -0
- package/lib/components/BKJDialog/BKJDialog.test.js.map +1 -0
- package/lib/components/BKJDialog/BKJDialog.types.d.ts +1 -1
- package/lib/components/BKJDialog/BKJDialog.types.d.ts.map +1 -1
- package/lib/components/BKJIcon/BKJIcon.d.ts.map +1 -1
- package/lib/components/BKJIcon/BKJIcon.js +9 -5
- package/lib/components/BKJIcon/BKJIcon.js.map +1 -1
- package/lib/components/BKJIcon/BKJIcon.test.d.ts +2 -0
- package/lib/components/BKJIcon/BKJIcon.test.d.ts.map +1 -0
- package/lib/components/BKJIcon/BKJIcon.test.js +51 -0
- package/lib/components/BKJIcon/BKJIcon.test.js.map +1 -0
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAsC,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"BKJDialog.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAsC,MAAM,OAAO,CAAC;AAa/D,OAAO,EAA6B,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAY/E,eAAO,MAAM,SAAS,EAAE,EAAE,CAAC,eAAe,CA+DzC,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { forwardRef, useCallback, useEffect } from 'react';
|
|
3
|
+
import { useId, useObjectRef } from '@react-aria/utils';
|
|
3
4
|
import { BKJButton } from '../BKJButton/index.js';
|
|
4
5
|
import { BKJDialogWrapper, Title, Text, CloseIcon, ButtonGroup, TextWrapper, CloseIconWrapper, } from './BKJDialog.styled.js';
|
|
5
6
|
const CancelVariantMap = {
|
|
@@ -10,7 +11,9 @@ const ActionVariantMap = {
|
|
|
10
11
|
Danger: 'RedSolid',
|
|
11
12
|
Default: 'PurpleSolid',
|
|
12
13
|
};
|
|
13
|
-
export const BKJDialog = forwardRef(({ variant, title, text, cancelLabel, actionLabel, onAction, onCancel, onClose, ...rest },
|
|
14
|
+
export const BKJDialog = forwardRef(({ variant, title, text, cancelLabel, actionLabel, onAction, onCancel, onClose, ...rest }, forwardedRef) => {
|
|
15
|
+
const wrapperRef = useObjectRef(forwardedRef);
|
|
16
|
+
const titleId = useId();
|
|
14
17
|
const handleKeyUp = useCallback((event) => {
|
|
15
18
|
if (event.key === 'Escape') {
|
|
16
19
|
onClose();
|
|
@@ -22,6 +25,13 @@ export const BKJDialog = forwardRef(({ variant, title, text, cancelLabel, action
|
|
|
22
25
|
document.removeEventListener('keyup', handleKeyUp);
|
|
23
26
|
};
|
|
24
27
|
}, [handleKeyUp]);
|
|
25
|
-
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
const previouslyFocused = document.activeElement;
|
|
30
|
+
wrapperRef.current?.focus();
|
|
31
|
+
return () => {
|
|
32
|
+
previouslyFocused?.focus();
|
|
33
|
+
};
|
|
34
|
+
}, [wrapperRef]);
|
|
35
|
+
return (_jsxs(BKJDialogWrapper, { role: "dialog", "aria-modal": "true", "aria-labelledby": titleId, tabIndex: -1, ...rest, variant: variant, ref: wrapperRef, children: [_jsx(CloseIconWrapper, { onClick: onClose, type: "button", "aria-label": "Close", children: _jsx(CloseIcon, { iconName: "CloseBold" }) }), _jsxs(TextWrapper, { children: [_jsx(Title, { id: titleId, children: title }), _jsx(Text, { children: text })] }), _jsxs(ButtonGroup, { children: [_jsx(BKJButton, { variant: CancelVariantMap[variant], onClick: onCancel, children: cancelLabel }), _jsx(BKJButton, { variant: ActionVariantMap[variant], onClick: onAction, children: actionLabel })] })] }));
|
|
26
36
|
});
|
|
27
37
|
//# sourceMappingURL=BKJDialog.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAM,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EACL,gBAAgB,EAChB,KAAK,EACL,IAAI,EACJ,SAAS,EACT,WAAW,EACX,WAAW,EACX,gBAAgB,GACjB,MAAM,oBAAoB,CAAC;AAG5B,MAAM,gBAAgB,GAAiE;IACrF,MAAM,EAAE,gBAAgB;IACxB,OAAO,EAAE,gBAAgB;CAC1B,CAAC;AAEF,MAAM,gBAAgB,GAAiE;IACrF,MAAM,EAAE,UAAU;IAClB,OAAO,EAAE,aAAa;CACvB,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAwB,UAAU,CACtD,CACE,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,EACxF,
|
|
1
|
+
{"version":3,"file":"BKJDialog.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAM,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EACL,gBAAgB,EAChB,KAAK,EACL,IAAI,EACJ,SAAS,EACT,WAAW,EACX,WAAW,EACX,gBAAgB,GACjB,MAAM,oBAAoB,CAAC;AAG5B,MAAM,gBAAgB,GAAiE;IACrF,MAAM,EAAE,gBAAgB;IACxB,OAAO,EAAE,gBAAgB;CAC1B,CAAC;AAEF,MAAM,gBAAgB,GAAiE;IACrF,MAAM,EAAE,UAAU;IAClB,OAAO,EAAE,aAAa;CACvB,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAwB,UAAU,CACtD,CACE,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,EACxF,YAAY,EACZ,EAAE;IACF,MAAM,UAAU,GAAG,YAAY,CAAC,YAAY,CAAC,CAAC;IAC9C,MAAM,OAAO,GAAG,KAAK,EAAE,CAAC;IAExB,MAAM,WAAW,GAAG,WAAW,CAC7B,CAAC,KAAoB,EAAE,EAAE;QACvB,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;YAC3B,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC,EACD,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAChD,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QACrD,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;IAElB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,iBAAiB,GAAG,QAAQ,CAAC,aAAmC,CAAC;QACvE,UAAU,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;QAC5B,OAAO,GAAG,EAAE;YACV,iBAAiB,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjB,OAAO,CACL,MAAC,gBAAgB,IACf,IAAI,EAAC,QAAQ,gBACF,MAAM,qBACA,OAAO,EACxB,QAAQ,EAAE,CAAC,CAAC,KACR,IAAI,EACR,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE,UAAU,aAEf,KAAC,gBAAgB,IAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAC,QAAQ,gBAAY,OAAO,YAClE,KAAC,SAAS,IAAC,QAAQ,EAAC,WAAW,GAAG,GACjB,EAEnB,MAAC,WAAW,eACV,KAAC,KAAK,IAAC,EAAE,EAAE,OAAO,YAAG,KAAK,GAAS,EACnC,KAAC,IAAI,cAAE,IAAI,GAAQ,IACP,EAEd,MAAC,WAAW,eACV,KAAC,SAAS,IAAC,OAAO,EAAE,gBAAgB,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,QAAQ,YAC7D,WAAW,GACF,EAEZ,KAAC,SAAS,IAAC,OAAO,EAAE,gBAAgB,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,QAAQ,YAC7D,WAAW,GACF,IACA,IACG,CACpB,CAAC;AACJ,CAAC,CACF,CAAC"}
|
|
@@ -30,4 +30,5 @@ declare const _default: {
|
|
|
30
30
|
};
|
|
31
31
|
export default _default;
|
|
32
32
|
export declare const Default: import("@storybook/core/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, IBKJDialogProps>;
|
|
33
|
+
export declare const Danger: import("@storybook/core/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, IBKJDialogProps>;
|
|
33
34
|
//# sourceMappingURL=BKJDialog.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.stories.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpD,wBA4BE;
|
|
1
|
+
{"version":3,"file":"BKJDialog.stories.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpD,wBA4BE;AAiBF,eAAO,MAAM,OAAO,2GAAoB,CAAC;AAUzC,eAAO,MAAM,MAAM,2GAAoB,CAAC"}
|
|
@@ -29,8 +29,12 @@ export default {
|
|
|
29
29
|
},
|
|
30
30
|
},
|
|
31
31
|
};
|
|
32
|
-
const Template = (args) => (_jsx(BKJDialog, { ...args,
|
|
33
|
-
alert('
|
|
32
|
+
const Template = (args) => (_jsx(BKJDialog, { ...args, onAction: () => {
|
|
33
|
+
alert('submit button click');
|
|
34
|
+
}, onCancel: () => {
|
|
35
|
+
alert('cancel button close');
|
|
36
|
+
}, onClose: () => {
|
|
37
|
+
alert('x button close');
|
|
34
38
|
} }));
|
|
35
39
|
export const Default = Template.bind({});
|
|
36
40
|
Default.args = {
|
|
@@ -40,4 +44,12 @@ Default.args = {
|
|
|
40
44
|
cancelLabel: 'Cancel',
|
|
41
45
|
actionLabel: 'Confirm',
|
|
42
46
|
};
|
|
47
|
+
export const Danger = Template.bind({});
|
|
48
|
+
Danger.args = {
|
|
49
|
+
variant: 'Danger',
|
|
50
|
+
title: 'Delete shift?',
|
|
51
|
+
text: 'This action cannot be undone.',
|
|
52
|
+
cancelLabel: 'Cancel',
|
|
53
|
+
actionLabel: 'Delete',
|
|
54
|
+
};
|
|
43
55
|
//# sourceMappingURL=BKJDialog.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.stories.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAE,MAAM,GAAG,CAAC;AAG9B,eAAe;IACb,KAAK,EAAE,kBAAkB;IACzB,SAAS,EAAE,SAAS;IACpB,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE;gBACP,IAAI,EAAE,QAAQ;aACf;YACD,MAAM,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC;SAC9B;QACD,KAAK,EAAE;YACL,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,QAAQ;SACf;QACD,IAAI,EAAE;YACJ,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,QAAQ;SACf;QACD,WAAW,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,QAAQ;SACf;QACD,WAAW,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,QAAQ;SACf;KACF;CACF,CAAC;AAEF,MAAM,QAAQ,GAA6B,CAAC,IAAI,EAAE,EAAE,CAAC,CACnD,KAAC,SAAS,OACJ,IAAI,EACR,OAAO,EAAE,GAAG,EAAE;QACZ,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"BKJDialog.stories.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,SAAS,EAAE,MAAM,GAAG,CAAC;AAG9B,eAAe;IACb,KAAK,EAAE,kBAAkB;IACzB,SAAS,EAAE,SAAS;IACpB,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE;gBACP,IAAI,EAAE,QAAQ;aACf;YACD,MAAM,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC;SAC9B;QACD,KAAK,EAAE;YACL,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,QAAQ;SACf;QACD,IAAI,EAAE;YACJ,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,QAAQ;SACf;QACD,WAAW,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,QAAQ;SACf;QACD,WAAW,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,QAAQ;SACf;KACF;CACF,CAAC;AAEF,MAAM,QAAQ,GAA6B,CAAC,IAAI,EAAE,EAAE,CAAC,CACnD,KAAC,SAAS,OACJ,IAAI,EACR,QAAQ,EAAE,GAAG,EAAE;QACb,KAAK,CAAC,qBAAqB,CAAC,CAAC;IAC/B,CAAC,EACD,QAAQ,EAAE,GAAG,EAAE;QACb,KAAK,CAAC,qBAAqB,CAAC,CAAC;IAC/B,CAAC,EACD,OAAO,EAAE,GAAG,EAAE;QACZ,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAC1B,CAAC,GACD,CACH,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAEzC,OAAO,CAAC,IAAI,GAAG;IACb,OAAO,EAAE,SAAS;IAClB,KAAK,EAAE,qBAAqB;IAC5B,IAAI,EAAE,40BAA40B;IACl1B,WAAW,EAAE,QAAQ;IACrB,WAAW,EAAE,SAAS;CACvB,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAExC,MAAM,CAAC,IAAI,GAAG;IACZ,OAAO,EAAE,QAAQ;IACjB,KAAK,EAAE,eAAe;IACtB,IAAI,EAAE,+BAA+B;IACrC,WAAW,EAAE,QAAQ;IACrB,WAAW,EAAE,QAAQ;CACtB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export declare const BKJDialogWrapper: import("styled-components/dist/types").IStyledComponentBase<"web", any> & string;
|
|
2
|
-
export declare const CloseIconWrapper: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").
|
|
2
|
+
export declare const CloseIconWrapper: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, never>> & string;
|
|
3
3
|
export declare const CloseIcon: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<Pick<import("../BKJIcon/BKJIcon.types.js").IBKJIconProps & {
|
|
4
4
|
children?: import("react").ReactNode;
|
|
5
5
|
}, "string" | "target" | "name" | "filter" | "fill" | "values" | "style" | "id" | "type" | "end" | "alphabetic" | "ideographic" | "mathematical" | "accumulate" | "local" | "color" | "hanging" | "unicode" | "clip" | "stroke" | "x" | "y" | "width" | "css" | "children" | "crossOrigin" | "height" | "href" | "max" | "media" | "method" | "min" | "className" | "lang" | "tabIndex" | "role" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "key" | "clipPath" | "mask" | "path" | "offset" | "alignmentBaseline" | "baselineShift" | "clipRule" | "colorInterpolation" | "colorInterpolationFilters" | "cursor" | "cx" | "cy" | "d" | "direction" | "display" | "dominantBaseline" | "fillOpacity" | "fillRule" | "floodColor" | "floodOpacity" | "fontFamily" | "fontSize" | "fontSizeAdjust" | "fontStretch" | "fontStyle" | "fontVariant" | "fontWeight" | "imageRendering" | "letterSpacing" | "lightingColor" | "markerEnd" | "markerMid" | "markerStart" | "opacity" | "order" | "overflow" | "paintOrder" | "pointerEvents" | "r" | "rotate" | "rx" | "ry" | "scale" | "shapeRendering" | "stopColor" | "stopOpacity" | "strokeDasharray" | "strokeDashoffset" | "strokeLinecap" | "strokeLinejoin" | "strokeMiterlimit" | "strokeOpacity" | "strokeWidth" | "textAnchor" | "textDecoration" | "textRendering" | "transform" | "unicodeBidi" | "vectorEffect" | "visibility" | "wordSpacing" | "writingMode" | "iconName" | "spacing" | "secondaryColor" | "accentHeight" | "additive" | "allowReorder" | "amplitude" | "arabicForm" | "ascent" | "attributeName" | "attributeType" | "autoReverse" | "azimuth" | "baseFrequency" | "baseProfile" | "bbox" | "begin" | "bias" | "by" | "calcMode" | "capHeight" | "clipPathUnits" | "colorProfile" | "colorRendering" | "contentScriptType" | "contentStyleType" | "decelerate" | "descent" | "diffuseConstant" | "divisor" | "dur" | "dx" | "dy" | "edgeMode" | "elevation" | "enableBackground" | "exponent" | "externalResourcesRequired" | "filterRes" | "filterUnits" | "focusable" | "format" | "from" | "fx" | "fy" | "g1" | "g2" | "glyphName" | "glyphOrientationHorizontal" | "glyphOrientationVertical" | "glyphRef" | "gradientTransform" | "gradientUnits" | "horizAdvX" | "horizOriginX" | "in2" | "in" | "intercept" | "k1" | "k2" | "k3" | "k4" | "k" | "kernelMatrix" | "kernelUnitLength" | "kerning" | "keyPoints" | "keySplines" | "keyTimes" | "lengthAdjust" | "limitingConeAngle" | "markerHeight" | "markerUnits" | "markerWidth" | "maskContentUnits" | "maskUnits" | "mode" | "numOctaves" | "operator" | "orient" | "orientation" | "origin" | "overlinePosition" | "overlineThickness" | "panose1" | "pathLength" | "patternContentUnits" | "patternTransform" | "patternUnits" | "points" | "pointsAtX" | "pointsAtY" | "pointsAtZ" | "preserveAlpha" | "preserveAspectRatio" | "primitiveUnits" | "radius" | "refX" | "refY" | "renderingIntent" | "repeatCount" | "repeatDur" | "requiredExtensions" | "requiredFeatures" | "restart" | "result" | "seed" | "slope" | "specularConstant" | "specularExponent" | "speed" | "spreadMethod" | "startOffset" | "stdDeviation" | "stemh" | "stemv" | "stitchTiles" | "strikethroughPosition" | "strikethroughThickness" | "surfaceScale" | "systemLanguage" | "tableValues" | "targetX" | "targetY" | "textLength" | "to" | "u1" | "u2" | "underlinePosition" | "underlineThickness" | "unicodeRange" | "unitsPerEm" | "vAlphabetic" | "version" | "vertAdvY" | "vertOriginX" | "vertOriginY" | "vHanging" | "vIdeographic" | "viewBox" | "viewTarget" | "vMathematical" | "widths" | "x1" | "x2" | "xChannelSelector" | "xHeight" | "xlinkActuate" | "xlinkArcrole" | "xlinkHref" | "xlinkRole" | "xlinkShow" | "xlinkTitle" | "xlinkType" | "xmlBase" | "xmlLang" | "xmlns" | "xmlnsXlink" | "xmlSpace" | "y1" | "y2" | "yChannelSelector" | "z" | "zoomAndPan"> & {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.styled.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.styled.tsx"],"names":[],"mappings":"AASA,eAAO,MAAM,gBAAgB,
|
|
1
|
+
{"version":3,"file":"BKJDialog.styled.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.styled.tsx"],"names":[],"mappings":"AASA,eAAO,MAAM,gBAAgB,kFAkB5B,CAAC;AAEF,eAAO,MAAM,gBAAgB,yOAgB5B,CAAC;AAEF,eAAO,MAAM,SAAS;;;;+IAAoB,CAAC;AAE3C,eAAO,MAAM,WAAW,6NAUvB,CAAC;AAEF,eAAO,MAAM,KAAK,6NAKjB,CAAC;AAEF,eAAO,MAAM,IAAI,6NAKhB,CAAC;AAEF,eAAO,MAAM,WAAW,6NAUvB,CAAC"}
|
|
@@ -13,9 +13,16 @@ export const BKJDialogWrapper = styled.div `
|
|
|
13
13
|
box-shadow: 0px 2px 8px rgba(13, 51, 32, 0.3);
|
|
14
14
|
border-radius: 8px;
|
|
15
15
|
|
|
16
|
+
&:focus {
|
|
17
|
+
outline: none;
|
|
18
|
+
}
|
|
19
|
+
|
|
16
20
|
${({ theme, variant }) => theme.dialog[variant]}
|
|
17
21
|
`;
|
|
18
|
-
export const CloseIconWrapper = styled.
|
|
22
|
+
export const CloseIconWrapper = styled.button `
|
|
23
|
+
border: none;
|
|
24
|
+
background: transparent;
|
|
25
|
+
font: inherit;
|
|
19
26
|
position: absolute;
|
|
20
27
|
display: flex;
|
|
21
28
|
justify-content: center;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.styled.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.styled.tsx"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAQrC,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAwB
|
|
1
|
+
{"version":3,"file":"BKJDialog.styled.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.styled.tsx"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAQrC,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAwB;;;;;;;;;;;;;;;;;IAiB9D,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;CAChD,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;;qBAaxB,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc;;;CAG9D,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,CAAA,EAAE,CAAC;AAE3C,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;;CAUpC,CAAC;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAA;IAC3B,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW;;;;CAIzC,CAAC;AAEF,MAAM,CAAC,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAA;IAC1B,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW;;;;CAIzC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAA;;;;4BAIT,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW;;;;;;CAMlE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BKJDialog.test.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.test.tsx"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { fireEvent, screen } from '@testing-library/react';
|
|
4
|
+
import userEvent from '@testing-library/user-event';
|
|
5
|
+
import { renderAndCheckA11y, renderWithTheme } from '../../test-utils/index.js';
|
|
6
|
+
import { BKJDialog } from './BKJDialog.js';
|
|
7
|
+
const noop = () => undefined;
|
|
8
|
+
const baseProps = {
|
|
9
|
+
variant: 'Default',
|
|
10
|
+
title: 'Edit shift details?',
|
|
11
|
+
text: 'Are you sure you want to continue?',
|
|
12
|
+
cancelLabel: 'Cancel',
|
|
13
|
+
actionLabel: 'Confirm',
|
|
14
|
+
onAction: noop,
|
|
15
|
+
onCancel: noop,
|
|
16
|
+
onClose: noop,
|
|
17
|
+
};
|
|
18
|
+
describe('BKJDialog', () => {
|
|
19
|
+
describe('Accessibility (FR-010)', () => {
|
|
20
|
+
it('Default variant has no a11y violations', async () => {
|
|
21
|
+
const { axeResults } = await renderAndCheckA11y(_jsx(BKJDialog, { ...baseProps }));
|
|
22
|
+
expect(axeResults).toHaveNoViolations();
|
|
23
|
+
});
|
|
24
|
+
it('Danger variant has no a11y violations', async () => {
|
|
25
|
+
const { axeResults } = await renderAndCheckA11y(_jsx(BKJDialog, { ...baseProps, variant: "Danger", title: "Delete shift?", text: "This action cannot be undone.", actionLabel: "Delete" }));
|
|
26
|
+
expect(axeResults).toHaveNoViolations();
|
|
27
|
+
});
|
|
28
|
+
it('with consumer aria-label override has no a11y violations', async () => {
|
|
29
|
+
const { axeResults } = await renderAndCheckA11y(_jsx(BKJDialog, { ...baseProps, "aria-label": "Custom dialog name" }));
|
|
30
|
+
expect(axeResults).toHaveNoViolations();
|
|
31
|
+
});
|
|
32
|
+
it('unmounted state has no a11y violations', async () => {
|
|
33
|
+
const { axeResults } = await renderAndCheckA11y(_jsx(_Fragment, {}));
|
|
34
|
+
expect(axeResults).toHaveNoViolations();
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
describe('Behavioural contracts (FR-011)', () => {
|
|
38
|
+
it('(a) renders role="dialog" for variant="Default"', () => {
|
|
39
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps }));
|
|
40
|
+
expect(screen.getByRole('dialog')).toBeInTheDocument();
|
|
41
|
+
});
|
|
42
|
+
it('(b) renders role="dialog" for variant="Danger"', () => {
|
|
43
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps, variant: "Danger", actionLabel: "Delete" }));
|
|
44
|
+
expect(screen.getByRole('dialog')).toBeInTheDocument();
|
|
45
|
+
});
|
|
46
|
+
it('(c) renders aria-modal="true"', () => {
|
|
47
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps }));
|
|
48
|
+
const wrapper = screen.getByRole('dialog');
|
|
49
|
+
expect(wrapper.getAttribute('aria-modal')).toBe('true');
|
|
50
|
+
});
|
|
51
|
+
it('(d) aria-labelledby value matches Title element id', () => {
|
|
52
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps }));
|
|
53
|
+
const wrapper = screen.getByRole('dialog');
|
|
54
|
+
const titleElement = screen.getByText('Edit shift details?');
|
|
55
|
+
const ariaLabelledBy = wrapper.getAttribute('aria-labelledby');
|
|
56
|
+
expect(ariaLabelledBy).toBeTruthy();
|
|
57
|
+
expect(ariaLabelledBy).toBe(titleElement.getAttribute('id'));
|
|
58
|
+
});
|
|
59
|
+
it('(e) consumer-passed role and aria-label via ...rest override the variant-derived defaults', () => {
|
|
60
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps, role: "alertdialog", "aria-label": "Custom name" }));
|
|
61
|
+
const wrapper = screen.getByRole('alertdialog');
|
|
62
|
+
expect(wrapper.getAttribute('role')).toBe('alertdialog');
|
|
63
|
+
expect(wrapper.getAttribute('aria-label')).toBe('Custom name');
|
|
64
|
+
});
|
|
65
|
+
it('(f) on mount, document.activeElement is the wrapper', () => {
|
|
66
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps }));
|
|
67
|
+
const wrapper = screen.getByRole('dialog');
|
|
68
|
+
expect(document.activeElement).toBe(wrapper);
|
|
69
|
+
});
|
|
70
|
+
it('(g) on unmount, focus returns to the previously-focused trigger', async () => {
|
|
71
|
+
const user = userEvent.setup();
|
|
72
|
+
const Sandbox = () => {
|
|
73
|
+
const [open, setOpen] = useState(false);
|
|
74
|
+
return (_jsxs(_Fragment, { children: [_jsx("button", { type: "button", onClick: () => setOpen(true), children: "Open dialog" }), open && (_jsx(BKJDialog, { ...baseProps, onCancel: () => setOpen(false), onAction: () => setOpen(false), onClose: () => setOpen(false) }))] }));
|
|
75
|
+
};
|
|
76
|
+
renderWithTheme(_jsx(Sandbox, {}));
|
|
77
|
+
const trigger = screen.getByRole('button', { name: /open dialog/i });
|
|
78
|
+
trigger.focus();
|
|
79
|
+
expect(document.activeElement).toBe(trigger);
|
|
80
|
+
await user.click(trigger);
|
|
81
|
+
const wrapper = screen.getByRole('dialog');
|
|
82
|
+
expect(document.activeElement).toBe(wrapper);
|
|
83
|
+
const closeButton = screen.getByRole('button', { name: /close/i });
|
|
84
|
+
await user.click(closeButton);
|
|
85
|
+
expect(screen.queryByRole('dialog')).toBeNull();
|
|
86
|
+
expect(document.activeElement).toBe(trigger);
|
|
87
|
+
});
|
|
88
|
+
it('(h) close button is a native <button> with type="button" and aria-label="Close"', () => {
|
|
89
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps }));
|
|
90
|
+
const closeButton = screen.getByRole('button', { name: /close/i });
|
|
91
|
+
expect(closeButton.tagName).toBe('BUTTON');
|
|
92
|
+
expect(closeButton.getAttribute('type')).toBe('button');
|
|
93
|
+
expect(closeButton.getAttribute('aria-label')).toBe('Close');
|
|
94
|
+
expect(closeButton.getAttribute('role')).toBeNull();
|
|
95
|
+
expect(closeButton.getAttribute('tabindex')).toBeNull();
|
|
96
|
+
});
|
|
97
|
+
it('(i) Enter and Space on focused close button each call onClose once', async () => {
|
|
98
|
+
const user = userEvent.setup();
|
|
99
|
+
const onClose = jest.fn();
|
|
100
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps, onClose: onClose }));
|
|
101
|
+
const closeButton = screen.getByRole('button', { name: /close/i });
|
|
102
|
+
closeButton.focus();
|
|
103
|
+
await user.keyboard('{Enter}');
|
|
104
|
+
expect(onClose).toHaveBeenCalledTimes(1);
|
|
105
|
+
onClose.mockReset();
|
|
106
|
+
await user.keyboard(' ');
|
|
107
|
+
expect(onClose).toHaveBeenCalledTimes(1);
|
|
108
|
+
});
|
|
109
|
+
it('(j) Escape on document calls onClose once', () => {
|
|
110
|
+
const onClose = jest.fn();
|
|
111
|
+
renderWithTheme(_jsx(BKJDialog, { ...baseProps, onClose: onClose }));
|
|
112
|
+
fireEvent.keyUp(document, { key: 'Escape' });
|
|
113
|
+
expect(onClose).toHaveBeenCalledTimes(1);
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
//# sourceMappingURL=BKJDialog.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BKJDialog.test.js","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJDialog.types.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,eAAgB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC3E,OAAO,EAAE,yBAAyB,CAAC;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,GAAG,EAAE,GAAG,CAAC;
|
|
1
|
+
{"version":3,"file":"BKJDialog.types.d.ts","sourceRoot":"","sources":["../../../src/components/BKJDialog/BKJDialog.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,WAAW,eAAgB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC3E,OAAO,EAAE,yBAAyB,CAAC;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,GAAG,CAAC,EAAE,GAAG,CAAC;CACX;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;IAC5B,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;CAC5B;AAED,MAAM,MAAM,yBAAyB,GAAG,MAAM,eAAe,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJIcon.d.ts","sourceRoot":"","sources":["../../../src/components/BKJIcon/BKJIcon.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"BKJIcon.d.ts","sourceRoot":"","sources":["../../../src/components/BKJIcon/BKJIcon.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAuB,MAAM,iBAAiB,CAAC;AAErE,eAAO,MAAM,OAAO,EAAE,EAAE,CAAC,aAAa,CAarC,CAAC"}
|
|
@@ -3,11 +3,15 @@ import { BKJIconComponentMap } from './BKJIcon.types.js';
|
|
|
3
3
|
export const BKJIcon = (props) => {
|
|
4
4
|
const { iconName, fontSize = 24, secondaryColor, color, ...rest } = props;
|
|
5
5
|
const IconComponent = BKJIconComponentMap[iconName];
|
|
6
|
-
const _props = {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
6
|
+
const _props = {
|
|
7
|
+
'aria-hidden': true,
|
|
8
|
+
fontSize,
|
|
9
|
+
...rest,
|
|
10
|
+
};
|
|
11
|
+
if (color)
|
|
12
|
+
_props['color'] = color;
|
|
13
|
+
if (secondaryColor)
|
|
14
|
+
_props['secondaryColor'] = secondaryColor;
|
|
11
15
|
return _jsx(IconComponent, { ..._props });
|
|
12
16
|
};
|
|
13
17
|
//# sourceMappingURL=BKJIcon.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BKJIcon.js","sourceRoot":"","sources":["../../../src/components/BKJIcon/BKJIcon.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"BKJIcon.js","sourceRoot":"","sources":["../../../src/components/BKJIcon/BKJIcon.tsx"],"names":[],"mappings":";AACA,OAAO,EAAiB,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAErE,MAAM,CAAC,MAAM,OAAO,GAAsB,CAAC,KAAK,EAAe,EAAE;IAC/D,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;IAC1E,MAAM,aAAa,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAEpD,MAAM,MAAM,GAAG;QACb,aAAa,EAAE,IAAI;QACnB,QAAQ;QACR,GAAG,IAAI;KACR,CAAC;IACF,IAAI,KAAK;QAAE,MAAM,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC;IACnC,IAAI,cAAc;QAAE,MAAM,CAAC,gBAAgB,CAAC,GAAG,cAAc,CAAC;IAE9D,OAAO,KAAC,aAAa,OAAK,MAAM,GAAI,CAAC;AACvC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BKJIcon.test.d.ts","sourceRoot":"","sources":["../../../src/components/BKJIcon/BKJIcon.test.tsx"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { renderAndCheckA11y, renderWithTheme } from '../../test-utils/index.js';
|
|
3
|
+
import { BKJIcon } from './BKJIcon.js';
|
|
4
|
+
import { BKJIconComponentMap } from './BKJIcon.types.js';
|
|
5
|
+
describe('BKJIcon', () => {
|
|
6
|
+
describe('Accessibility (FR-008)', () => {
|
|
7
|
+
it('decorative <svg> has no a11y violations', async () => {
|
|
8
|
+
const { axeResults } = await renderAndCheckA11y(_jsx(BKJIcon, { iconName: "Search" }));
|
|
9
|
+
expect(axeResults).toHaveNoViolations();
|
|
10
|
+
});
|
|
11
|
+
it('all icons axe-clean (one combined render)', async () => {
|
|
12
|
+
const { axeResults } = await renderAndCheckA11y(_jsx("div", { children: Object.keys(BKJIconComponentMap).map((name) => (_jsx(BKJIcon, { iconName: name }, name))) }));
|
|
13
|
+
expect(axeResults).toHaveNoViolations();
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
describe('Behavioural contracts (FR-009)', () => {
|
|
17
|
+
it('(a) renders <svg> with aria-hidden="true"', () => {
|
|
18
|
+
const { container } = renderWithTheme(_jsx(BKJIcon, { iconName: "Search" }));
|
|
19
|
+
const svg = container.querySelector('svg');
|
|
20
|
+
expect(svg).not.toBeNull();
|
|
21
|
+
expect(svg.getAttribute('aria-hidden')).toBe('true');
|
|
22
|
+
});
|
|
23
|
+
it('(b) renders <svg> without role', () => {
|
|
24
|
+
const { container } = renderWithTheme(_jsx(BKJIcon, { iconName: "Search" }));
|
|
25
|
+
const svg = container.querySelector('svg');
|
|
26
|
+
expect(svg.getAttribute('role')).toBeNull();
|
|
27
|
+
});
|
|
28
|
+
it('(c) consumer aria-hidden={false} via ...rest overrides default', () => {
|
|
29
|
+
const { container } = renderWithTheme(_jsx(BKJIcon, { iconName: "Search", "aria-hidden": false }));
|
|
30
|
+
const svg = container.querySelector('svg');
|
|
31
|
+
expect(['false', null]).toContain(svg.getAttribute('aria-hidden'));
|
|
32
|
+
});
|
|
33
|
+
it('(d) decorative-by-default applies even when consumer passes aria-label', () => {
|
|
34
|
+
const { container } = renderWithTheme(_jsx(BKJIcon, { iconName: "Warning", "aria-label": "Warning" }));
|
|
35
|
+
const svg = container.querySelector('svg');
|
|
36
|
+
expect(svg.getAttribute('aria-hidden')).toBe('true');
|
|
37
|
+
expect(svg.getAttribute('role')).toBeNull();
|
|
38
|
+
expect(svg.getAttribute('aria-label')).toBe('Warning');
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
describe.each(Object.keys(BKJIconComponentMap))('BKJIcon[%s] decorative-mode contract (FR-008 b)', (iconName) => {
|
|
42
|
+
it('renders <svg> with aria-hidden="true" and no role', () => {
|
|
43
|
+
const { container } = renderWithTheme(_jsx(BKJIcon, { iconName: iconName }));
|
|
44
|
+
const svg = container.querySelector('svg');
|
|
45
|
+
expect(svg).not.toBeNull();
|
|
46
|
+
expect(svg.getAttribute('aria-hidden')).toBe('true');
|
|
47
|
+
expect(svg.getAttribute('role')).toBeNull();
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
//# sourceMappingURL=BKJIcon.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BKJIcon.test.js","sourceRoot":"","sources":["../../../src/components/BKJIcon/BKJIcon.test.tsx"],"names":[],"mappings":"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"}
|