@fluentui/react-card 0.0.0-nightly-20230317-1454.1 → 0.0.0-nightly-20230321-0440.1
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/CHANGELOG.json +15 -15
- package/CHANGELOG.md +10 -10
- package/lib/Card.js +1 -1
- package/lib/Card.js.map +1 -1
- package/lib/CardFooter.js +1 -1
- package/lib/CardFooter.js.map +1 -1
- package/lib/CardHeader.js +1 -1
- package/lib/CardHeader.js.map +1 -1
- package/lib/CardPreview.js +1 -1
- package/lib/CardPreview.js.map +1 -1
- package/lib/components/Card/Card.js +6 -6
- package/lib/components/Card/Card.js.map +1 -1
- package/lib/components/Card/Card.types.js +1 -1
- package/lib/components/Card/Card.types.js.map +1 -1
- package/lib/components/Card/CardContext.js +9 -4
- package/lib/components/Card/CardContext.js.map +1 -1
- package/lib/components/Card/index.js +6 -6
- package/lib/components/Card/index.js.map +1 -1
- package/lib/components/Card/renderCard.js +11 -5
- package/lib/components/Card/renderCard.js.map +1 -1
- package/lib/components/Card/useCard.js +20 -20
- package/lib/components/Card/useCard.js.map +1 -1
- package/lib/components/Card/useCardContextValue.js.map +1 -1
- package/lib/components/Card/useCardSelectable.js +10 -10
- package/lib/components/Card/useCardSelectable.js.map +1 -1
- package/lib/components/Card/useCardStyles.js +14 -14
- package/lib/components/Card/useCardStyles.js.map +1 -1
- package/lib/components/CardFooter/CardFooter.js +5 -5
- package/lib/components/CardFooter/CardFooter.js.map +1 -1
- package/lib/components/CardFooter/CardFooter.types.js.map +1 -1
- package/lib/components/CardFooter/index.js +5 -5
- package/lib/components/CardFooter/index.js.map +1 -1
- package/lib/components/CardFooter/renderCardFooter.js +7 -3
- package/lib/components/CardFooter/renderCardFooter.js.map +1 -1
- package/lib/components/CardFooter/useCardFooter.js +4 -5
- package/lib/components/CardFooter/useCardFooter.js.map +1 -1
- package/lib/components/CardFooter/useCardFooterStyles.js +3 -3
- package/lib/components/CardFooter/useCardFooterStyles.js.map +1 -1
- package/lib/components/CardHeader/CardHeader.js +5 -5
- package/lib/components/CardHeader/CardHeader.js.map +1 -1
- package/lib/components/CardHeader/CardHeader.types.js.map +1 -1
- package/lib/components/CardHeader/index.js +5 -5
- package/lib/components/CardHeader/index.js.map +1 -1
- package/lib/components/CardHeader/renderCardHeader.js +13 -3
- package/lib/components/CardHeader/renderCardHeader.js.map +1 -1
- package/lib/components/CardHeader/useCardHeader.js +10 -10
- package/lib/components/CardHeader/useCardHeader.js.map +1 -1
- package/lib/components/CardHeader/useCardHeaderStyles.js +7 -7
- package/lib/components/CardHeader/useCardHeaderStyles.js.map +1 -1
- package/lib/components/CardPreview/CardPreview.js +5 -5
- package/lib/components/CardPreview/CardPreview.js.map +1 -1
- package/lib/components/CardPreview/CardPreview.types.js.map +1 -1
- package/lib/components/CardPreview/index.js +5 -5
- package/lib/components/CardPreview/index.js.map +1 -1
- package/lib/components/CardPreview/renderCardPreview.js +7 -3
- package/lib/components/CardPreview/renderCardPreview.js.map +1 -1
- package/lib/components/CardPreview/useCardPreview.js +9 -9
- package/lib/components/CardPreview/useCardPreview.js.map +1 -1
- package/lib/components/CardPreview/useCardPreviewStyles.js +3 -3
- package/lib/components/CardPreview/useCardPreviewStyles.js.map +1 -1
- package/lib/index.js +5 -5
- package/lib/index.js.map +1 -1
- package/lib-commonjs/Card.js +4 -5
- package/lib-commonjs/Card.js.map +1 -1
- package/lib-commonjs/CardFooter.js +4 -5
- package/lib-commonjs/CardFooter.js.map +1 -1
- package/lib-commonjs/CardHeader.js +4 -5
- package/lib-commonjs/CardHeader.js.map +1 -1
- package/lib-commonjs/CardPreview.js +4 -5
- package/lib-commonjs/CardPreview.js.map +1 -1
- package/lib-commonjs/components/Card/Card.js +17 -18
- package/lib-commonjs/components/Card/Card.js.map +1 -1
- package/lib-commonjs/components/Card/Card.types.js +2 -5
- package/lib-commonjs/components/Card/Card.types.js.map +1 -1
- package/lib-commonjs/components/Card/CardContext.js +30 -26
- package/lib-commonjs/components/Card/CardContext.js.map +1 -1
- package/lib-commonjs/components/Card/index.js +9 -10
- package/lib-commonjs/components/Card/index.js.map +1 -1
- package/lib-commonjs/components/Card/renderCard.js +25 -16
- package/lib-commonjs/components/Card/renderCard.js.map +1 -1
- package/lib-commonjs/components/Card/useCard.js +94 -81
- package/lib-commonjs/components/Card/useCard.js.map +1 -1
- package/lib-commonjs/components/Card/useCardContextValue.js +11 -11
- package/lib-commonjs/components/Card/useCardContextValue.js.map +1 -1
- package/lib-commonjs/components/Card/useCardSelectable.js +117 -130
- package/lib-commonjs/components/Card/useCardSelectable.js.map +1 -1
- package/lib-commonjs/components/Card/useCardStyles.js +336 -738
- package/lib-commonjs/components/Card/useCardStyles.js.map +1 -1
- package/lib-commonjs/components/CardFooter/CardFooter.js +15 -16
- package/lib-commonjs/components/CardFooter/CardFooter.js.map +1 -1
- package/lib-commonjs/components/CardFooter/CardFooter.types.js +2 -3
- package/lib-commonjs/components/CardFooter/CardFooter.types.js.map +1 -1
- package/lib-commonjs/components/CardFooter/index.js +8 -9
- package/lib-commonjs/components/CardFooter/index.js.map +1 -1
- package/lib-commonjs/components/CardFooter/renderCardFooter.js +20 -13
- package/lib-commonjs/components/CardFooter/renderCardFooter.js.map +1 -1
- package/lib-commonjs/components/CardFooter/useCardFooter.js +30 -23
- package/lib-commonjs/components/CardFooter/useCardFooter.js.map +1 -1
- package/lib-commonjs/components/CardFooter/useCardFooterStyles.js +33 -45
- package/lib-commonjs/components/CardFooter/useCardFooterStyles.js.map +1 -1
- package/lib-commonjs/components/CardHeader/CardHeader.js +15 -16
- package/lib-commonjs/components/CardHeader/CardHeader.js.map +1 -1
- package/lib-commonjs/components/CardHeader/CardHeader.types.js +2 -3
- package/lib-commonjs/components/CardHeader/CardHeader.types.js.map +1 -1
- package/lib-commonjs/components/CardHeader/index.js +8 -9
- package/lib-commonjs/components/CardHeader/index.js.map +1 -1
- package/lib-commonjs/components/CardHeader/renderCardHeader.js +26 -13
- package/lib-commonjs/components/CardHeader/renderCardHeader.js.map +1 -1
- package/lib-commonjs/components/CardHeader/useCardHeader.js +64 -50
- package/lib-commonjs/components/CardHeader/useCardHeader.js.map +1 -1
- package/lib-commonjs/components/CardHeader/useCardHeaderStyles.js +67 -88
- package/lib-commonjs/components/CardHeader/useCardHeaderStyles.js.map +1 -1
- package/lib-commonjs/components/CardPreview/CardPreview.js +15 -16
- package/lib-commonjs/components/CardPreview/CardPreview.js.map +1 -1
- package/lib-commonjs/components/CardPreview/CardPreview.types.js +2 -3
- package/lib-commonjs/components/CardPreview/CardPreview.types.js.map +1 -1
- package/lib-commonjs/components/CardPreview/index.js +8 -9
- package/lib-commonjs/components/CardPreview/index.js.map +1 -1
- package/lib-commonjs/components/CardPreview/renderCardPreview.js +20 -13
- package/lib-commonjs/components/CardPreview/renderCardPreview.js.map +1 -1
- package/lib-commonjs/components/CardPreview/useCardPreview.js +60 -51
- package/lib-commonjs/components/CardPreview/useCardPreview.js.map +1 -1
- package/lib-commonjs/components/CardPreview/useCardPreviewStyles.js +37 -53
- package/lib-commonjs/components/CardPreview/useCardPreviewStyles.js.map +1 -1
- package/lib-commonjs/index.js +153 -40
- package/lib-commonjs/index.js.map +1 -1
- package/package.json +10 -9
- package/.swcrc +0 -39
@@ -1,22 +1,19 @@
|
|
1
1
|
"use strict";
|
2
|
+
|
2
3
|
Object.defineProperty(exports, "__esModule", {
|
3
|
-
|
4
|
-
});
|
5
|
-
Object.defineProperty(exports, "useCard_unstable", {
|
6
|
-
enumerable: true,
|
7
|
-
get: ()=>useCard_unstable
|
4
|
+
value: true
|
8
5
|
});
|
9
|
-
|
10
|
-
const
|
11
|
-
const
|
12
|
-
const
|
13
|
-
const
|
14
|
-
const
|
6
|
+
exports.useCard_unstable = void 0;
|
7
|
+
const React = /*#__PURE__*/require("react");
|
8
|
+
const react_utilities_1 = /*#__PURE__*/require("@fluentui/react-utilities");
|
9
|
+
const react_tabster_1 = /*#__PURE__*/require("@fluentui/react-tabster");
|
10
|
+
const useCardSelectable_1 = /*#__PURE__*/require("./useCardSelectable");
|
11
|
+
const CardContext_1 = /*#__PURE__*/require("./CardContext");
|
15
12
|
const focusMap = {
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
13
|
+
off: undefined,
|
14
|
+
'no-tab': 'limited-trap-focus',
|
15
|
+
'tab-exit': 'limited',
|
16
|
+
'tab-only': 'unlimited'
|
20
17
|
};
|
21
18
|
/**
|
22
19
|
* Create the state for interactive cards.
|
@@ -25,71 +22,87 @@ const focusMap = {
|
|
25
22
|
* and control focus properties based on that.
|
26
23
|
*
|
27
24
|
* @param props - props from this instance of Card
|
28
|
-
*/
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
...groupperAttrs,
|
46
|
-
tabIndex: 0
|
47
|
-
};
|
48
|
-
return {
|
49
|
-
interactive,
|
50
|
-
focusAttributes: focusMode === "off" ? null : interactiveFocusAttributes
|
51
|
-
};
|
25
|
+
*/
|
26
|
+
const useCardInteractive = ({
|
27
|
+
focusMode = 'off',
|
28
|
+
...props
|
29
|
+
}) => {
|
30
|
+
const interactive = ['onClick', 'onDoubleClick', 'onMouseUp', 'onMouseDown', 'onPointerUp', 'onPointerDown', 'onTouchStart', 'onTouchEnd', 'onDragStart', 'onDragEnd'].some(prop => props[prop]);
|
31
|
+
const groupperAttrs = react_tabster_1.useFocusableGroup({
|
32
|
+
tabBehavior: focusMap[interactive ? 'no-tab' : focusMode]
|
33
|
+
});
|
34
|
+
const interactiveFocusAttributes = {
|
35
|
+
...groupperAttrs,
|
36
|
+
tabIndex: 0
|
37
|
+
};
|
38
|
+
return {
|
39
|
+
interactive,
|
40
|
+
focusAttributes: focusMode === 'off' ? null : interactiveFocusAttributes
|
41
|
+
};
|
52
42
|
};
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
43
|
+
/**
|
44
|
+
* Create the state required to render Card.
|
45
|
+
*
|
46
|
+
* The returned state can be modified with hooks such as useCardStyles_unstable,
|
47
|
+
* before being passed to renderCard_unstable.
|
48
|
+
*
|
49
|
+
* @param props - props from this instance of Card
|
50
|
+
* @param ref - reference to the root element of Card
|
51
|
+
*/
|
52
|
+
const useCard_unstable = (props, ref) => {
|
53
|
+
const {
|
54
|
+
appearance = 'filled',
|
55
|
+
orientation = 'vertical',
|
56
|
+
size = 'medium'
|
57
|
+
} = props;
|
58
|
+
const [referenceId, setReferenceId] = React.useState(CardContext_1.cardContextDefaultValue.selectableA11yProps.referenceId);
|
59
|
+
const [referenceLabel, setReferenceLabel] = React.useState(CardContext_1.cardContextDefaultValue.selectableA11yProps.referenceId);
|
60
|
+
const cardBaseRef = react_tabster_1.useFocusWithin();
|
61
|
+
const {
|
62
|
+
selectable,
|
63
|
+
selected,
|
64
|
+
selectableCardProps,
|
65
|
+
selectFocused,
|
66
|
+
checkboxSlot,
|
67
|
+
floatingActionSlot
|
68
|
+
} = useCardSelectable_1.useCardSelectable(props, {
|
69
|
+
referenceId,
|
70
|
+
referenceLabel
|
71
|
+
}, cardBaseRef);
|
72
|
+
const cardRef = react_utilities_1.useMergedRefs(cardBaseRef, ref);
|
73
|
+
const {
|
74
|
+
interactive,
|
75
|
+
focusAttributes
|
76
|
+
} = useCardInteractive(props);
|
77
|
+
return {
|
78
|
+
appearance,
|
79
|
+
orientation,
|
80
|
+
size,
|
81
|
+
interactive,
|
82
|
+
selectable,
|
83
|
+
selectFocused,
|
84
|
+
selected,
|
85
|
+
selectableA11yProps: {
|
86
|
+
setReferenceId,
|
87
|
+
referenceId,
|
88
|
+
referenceLabel,
|
89
|
+
setReferenceLabel
|
90
|
+
},
|
91
|
+
components: {
|
92
|
+
root: 'div',
|
93
|
+
floatingAction: 'div',
|
94
|
+
checkbox: 'input'
|
95
|
+
},
|
96
|
+
root: react_utilities_1.getNativeElementProps('div', {
|
97
|
+
ref: cardRef,
|
98
|
+
role: 'group',
|
99
|
+
...focusAttributes,
|
100
|
+
...props,
|
101
|
+
...selectableCardProps
|
102
|
+
}),
|
103
|
+
floatingAction: floatingActionSlot,
|
104
|
+
checkbox: checkboxSlot
|
105
|
+
};
|
106
|
+
};
|
107
|
+
exports.useCard_unstable = useCard_unstable;
|
95
108
|
//# sourceMappingURL=useCard.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["
|
1
|
+
{"version":3,"names":["React","require","react_utilities_1","react_tabster_1","useCardSelectable_1","CardContext_1","focusMap","off","undefined","useCardInteractive","focusMode","props","interactive","some","prop","groupperAttrs","useFocusableGroup","tabBehavior","interactiveFocusAttributes","tabIndex","focusAttributes","useCard_unstable","ref","appearance","orientation","size","referenceId","setReferenceId","useState","cardContextDefaultValue","selectableA11yProps","referenceLabel","setReferenceLabel","cardBaseRef","useFocusWithin","selectable","selected","selectableCardProps","selectFocused","checkboxSlot","floatingActionSlot","useCardSelectable","cardRef","useMergedRefs","components","root","floatingAction","checkbox","getNativeElementProps","role","exports"],"sources":["../../../../../../../../../packages/react-components/react-card/src/components/Card/useCard.ts"],"sourcesContent":["import * as React from 'react';\nimport { getNativeElementProps, useMergedRefs } from '@fluentui/react-utilities';\nimport { useFocusableGroup, useFocusWithin } from '@fluentui/react-tabster';\n\nimport type { CardProps, CardState } from './Card.types';\nimport { useCardSelectable } from './useCardSelectable';\nimport { cardContextDefaultValue } from './CardContext';\n\nconst focusMap = {\n off: undefined,\n 'no-tab': 'limited-trap-focus',\n 'tab-exit': 'limited',\n 'tab-only': 'unlimited',\n} as const;\n\n/**\n * Create the state for interactive cards.\n *\n * This internal hook defines if the card is interactive\n * and control focus properties based on that.\n *\n * @param props - props from this instance of Card\n */\nconst useCardInteractive = ({ focusMode = 'off', ...props }: CardProps) => {\n const interactive = (\n [\n 'onClick',\n 'onDoubleClick',\n 'onMouseUp',\n 'onMouseDown',\n 'onPointerUp',\n 'onPointerDown',\n 'onTouchStart',\n 'onTouchEnd',\n 'onDragStart',\n 'onDragEnd',\n ] as (keyof React.HTMLAttributes<HTMLElement>)[]\n ).some(prop => props[prop]);\n\n const groupperAttrs = useFocusableGroup({\n tabBehavior: focusMap[interactive ? 'no-tab' : focusMode],\n });\n\n const interactiveFocusAttributes = {\n ...groupperAttrs,\n tabIndex: 0,\n };\n\n return {\n interactive,\n focusAttributes: focusMode === 'off' ? null : interactiveFocusAttributes,\n };\n};\n\n/**\n * Create the state required to render Card.\n *\n * The returned state can be modified with hooks such as useCardStyles_unstable,\n * before being passed to renderCard_unstable.\n *\n * @param props - props from this instance of Card\n * @param ref - reference to the root element of Card\n */\nexport const useCard_unstable = (props: CardProps, ref: React.Ref<HTMLDivElement>): CardState => {\n const { appearance = 'filled', orientation = 'vertical', size = 'medium' } = props;\n\n const [referenceId, setReferenceId] = React.useState(cardContextDefaultValue.selectableA11yProps.referenceId);\n const [referenceLabel, setReferenceLabel] = React.useState(cardContextDefaultValue.selectableA11yProps.referenceId);\n\n const cardBaseRef = useFocusWithin<HTMLDivElement>();\n const { selectable, selected, selectableCardProps, selectFocused, checkboxSlot, floatingActionSlot } =\n useCardSelectable(props, { referenceId, referenceLabel }, cardBaseRef);\n\n const cardRef = useMergedRefs(cardBaseRef, ref);\n\n const { interactive, focusAttributes } = useCardInteractive(props);\n\n return {\n appearance,\n orientation,\n size,\n interactive,\n selectable,\n selectFocused,\n selected,\n selectableA11yProps: {\n setReferenceId,\n referenceId,\n referenceLabel,\n setReferenceLabel,\n },\n\n components: {\n root: 'div',\n floatingAction: 'div',\n checkbox: 'input',\n },\n\n root: getNativeElementProps('div', {\n ref: cardRef,\n role: 'group',\n ...focusAttributes,\n ...props,\n ...selectableCardProps,\n }),\n\n floatingAction: floatingActionSlot,\n checkbox: checkboxSlot,\n };\n};\n"],"mappings":"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"}
|
@@ -1,15 +1,15 @@
|
|
1
1
|
"use strict";
|
2
|
+
|
2
3
|
Object.defineProperty(exports, "__esModule", {
|
3
|
-
|
4
|
-
});
|
5
|
-
Object.defineProperty(exports, "useCardContextValue", {
|
6
|
-
enumerable: true,
|
7
|
-
get: ()=>useCardContextValue
|
4
|
+
value: true
|
8
5
|
});
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
6
|
+
exports.useCardContextValue = void 0;
|
7
|
+
function useCardContextValue({
|
8
|
+
selectableA11yProps
|
9
|
+
}) {
|
10
|
+
return {
|
11
|
+
selectableA11yProps
|
12
|
+
};
|
13
|
+
}
|
14
|
+
exports.useCardContextValue = useCardContextValue;
|
15
15
|
//# sourceMappingURL=useCardContextValue.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["
|
1
|
+
{"version":3,"names":["useCardContextValue","selectableA11yProps","exports"],"sources":["../../../../../../../../../packages/react-components/react-card/src/components/Card/useCardContextValue.ts"],"sourcesContent":["import type { CardContextValue, CardState } from './Card.types';\n\nexport function useCardContextValue({ selectableA11yProps }: CardState): CardContextValue {\n return { selectableA11yProps };\n}\n"],"mappings":";;;;;;AAEA,SAAgBA,mBAAmBA,CAAC;EAAEC;AAAmB,CAAa;EACpE,OAAO;IAAEA;EAAmB,CAAE;AAChC;AAFAC,OAAA,CAAAF,mBAAA,GAAAA,mBAAA"}
|
@@ -1,136 +1,123 @@
|
|
1
1
|
"use strict";
|
2
|
+
|
2
3
|
Object.defineProperty(exports, "__esModule", {
|
3
|
-
|
4
|
-
});
|
5
|
-
Object.defineProperty(exports, "useCardSelectable", {
|
6
|
-
enumerable: true,
|
7
|
-
get: ()=>useCardSelectable
|
4
|
+
value: true
|
8
5
|
});
|
9
|
-
|
10
|
-
const
|
11
|
-
const
|
12
|
-
const
|
13
|
-
const
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
}
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
isCardSelected,
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
return {
|
111
|
-
onClick: (0, _reactUtilities.mergeCallbacks)(onClick, onChangeHandler),
|
112
|
-
onKeyDown: (0, _reactUtilities.mergeCallbacks)(onKeyDown, onKeyDownHandler)
|
113
|
-
};
|
114
|
-
}, [
|
115
|
-
isSelectable,
|
116
|
-
onChangeHandler,
|
117
|
-
onClick,
|
118
|
-
onKeyDown,
|
119
|
-
onKeyDownHandler
|
120
|
-
]);
|
121
|
-
_react.useEffect(()=>setIsCardSelected(Boolean(defaultSelected ?? selected)), [
|
122
|
-
defaultSelected,
|
123
|
-
selected,
|
124
|
-
setIsCardSelected
|
125
|
-
]);
|
6
|
+
exports.useCardSelectable = void 0;
|
7
|
+
const React = /*#__PURE__*/require("react");
|
8
|
+
const react_utilities_1 = /*#__PURE__*/require("@fluentui/react-utilities");
|
9
|
+
const keyboard_keys_1 = /*#__PURE__*/require("@fluentui/keyboard-keys");
|
10
|
+
const react_tabster_1 = /*#__PURE__*/require("@fluentui/react-tabster");
|
11
|
+
/**
|
12
|
+
* @internal
|
13
|
+
*
|
14
|
+
* Create the state related to selectable cards.
|
15
|
+
*
|
16
|
+
* This internal hook controls all the logic for selectable cards and is
|
17
|
+
* intended to be used alongside with useCard_unstable.
|
18
|
+
*
|
19
|
+
* @param props - props from this instance of Card
|
20
|
+
* @param a11yProps - accessibility props shared between elements of the card
|
21
|
+
* @param ref - reference to the root element of Card
|
22
|
+
*/
|
23
|
+
const useCardSelectable = (props, {
|
24
|
+
referenceLabel,
|
25
|
+
referenceId
|
26
|
+
}, cardRef) => {
|
27
|
+
const {
|
28
|
+
checkbox = {},
|
29
|
+
selected,
|
30
|
+
defaultSelected,
|
31
|
+
onSelectionChange,
|
32
|
+
floatingAction,
|
33
|
+
onClick,
|
34
|
+
onKeyDown
|
35
|
+
} = props;
|
36
|
+
const {
|
37
|
+
findAllFocusable
|
38
|
+
} = react_tabster_1.useFocusFinders();
|
39
|
+
const checkboxRef = React.useRef(null);
|
40
|
+
const isSelectable = [selected, defaultSelected, onSelectionChange].some(prop => typeof prop !== 'undefined');
|
41
|
+
const [isCardSelected, setIsCardSelected] = React.useState(false);
|
42
|
+
const [isSelectFocused, setIsSelectFocused] = React.useState(false);
|
43
|
+
const shouldRestrictTriggerAction = React.useCallback(event => {
|
44
|
+
if (!cardRef.current) {
|
45
|
+
return false;
|
46
|
+
}
|
47
|
+
const focusableElements = findAllFocusable(cardRef.current);
|
48
|
+
const target = event.target;
|
49
|
+
const isElementInFocusableGroup = focusableElements.some(element => element.contains(target));
|
50
|
+
const isCheckboxSlot = (checkboxRef === null || checkboxRef === void 0 ? void 0 : checkboxRef.current) === target;
|
51
|
+
return isElementInFocusableGroup && !isCheckboxSlot;
|
52
|
+
}, [cardRef, findAllFocusable]);
|
53
|
+
const onChangeHandler = React.useCallback(event => {
|
54
|
+
if (shouldRestrictTriggerAction(event)) {
|
55
|
+
return;
|
56
|
+
}
|
57
|
+
const newCheckedValue = !isCardSelected;
|
58
|
+
setIsCardSelected(newCheckedValue);
|
59
|
+
if (onSelectionChange) {
|
60
|
+
onSelectionChange(event, {
|
61
|
+
selected: newCheckedValue
|
62
|
+
});
|
63
|
+
}
|
64
|
+
}, [onSelectionChange, isCardSelected, shouldRestrictTriggerAction]);
|
65
|
+
const onKeyDownHandler = React.useCallback(event => {
|
66
|
+
if ([keyboard_keys_1.Enter].includes(event.key)) {
|
67
|
+
event.preventDefault();
|
68
|
+
onChangeHandler(event);
|
69
|
+
}
|
70
|
+
}, [onChangeHandler]);
|
71
|
+
const checkboxSlot = React.useMemo(() => {
|
72
|
+
if (!isSelectable || floatingAction) {
|
73
|
+
return;
|
74
|
+
}
|
75
|
+
const selectableCheckboxProps = {};
|
76
|
+
if (referenceId) {
|
77
|
+
selectableCheckboxProps['aria-labelledby'] = referenceId;
|
78
|
+
} else if (referenceLabel) {
|
79
|
+
selectableCheckboxProps['aria-label'] = referenceLabel;
|
80
|
+
}
|
81
|
+
return react_utilities_1.resolveShorthand(checkbox, {
|
82
|
+
defaultProps: {
|
83
|
+
ref: checkboxRef,
|
84
|
+
type: 'checkbox',
|
85
|
+
checked: isCardSelected,
|
86
|
+
onChange: event => onChangeHandler(event),
|
87
|
+
onFocus: () => setIsSelectFocused(true),
|
88
|
+
onBlur: () => setIsSelectFocused(false),
|
89
|
+
...selectableCheckboxProps
|
90
|
+
}
|
91
|
+
});
|
92
|
+
}, [checkbox, floatingAction, isCardSelected, isSelectable, onChangeHandler, referenceId, referenceLabel]);
|
93
|
+
const floatingActionSlot = React.useMemo(() => {
|
94
|
+
if (!floatingAction) {
|
95
|
+
return;
|
96
|
+
}
|
97
|
+
return react_utilities_1.resolveShorthand(floatingAction, {
|
98
|
+
defaultProps: {
|
99
|
+
ref: checkboxRef
|
100
|
+
}
|
101
|
+
});
|
102
|
+
}, [floatingAction]);
|
103
|
+
const selectableCardProps = React.useMemo(() => {
|
104
|
+
if (!isSelectable) {
|
105
|
+
return null;
|
106
|
+
}
|
126
107
|
return {
|
127
|
-
|
128
|
-
|
129
|
-
selectFocused: isSelectFocused,
|
130
|
-
selectableCardProps,
|
131
|
-
checkboxSlot,
|
132
|
-
floatingActionSlot
|
108
|
+
onClick: react_utilities_1.mergeCallbacks(onClick, onChangeHandler),
|
109
|
+
onKeyDown: react_utilities_1.mergeCallbacks(onKeyDown, onKeyDownHandler)
|
133
110
|
};
|
134
|
-
}
|
135
|
-
|
111
|
+
}, [isSelectable, onChangeHandler, onClick, onKeyDown, onKeyDownHandler]);
|
112
|
+
React.useEffect(() => setIsCardSelected(Boolean(defaultSelected !== null && defaultSelected !== void 0 ? defaultSelected : selected)), [defaultSelected, selected, setIsCardSelected]);
|
113
|
+
return {
|
114
|
+
selected: isCardSelected,
|
115
|
+
selectable: isSelectable,
|
116
|
+
selectFocused: isSelectFocused,
|
117
|
+
selectableCardProps,
|
118
|
+
checkboxSlot,
|
119
|
+
floatingActionSlot
|
120
|
+
};
|
121
|
+
};
|
122
|
+
exports.useCardSelectable = useCardSelectable;
|
136
123
|
//# sourceMappingURL=useCardSelectable.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["
|
1
|
+
{"version":3,"names":["React","require","react_utilities_1","keyboard_keys_1","react_tabster_1","useCardSelectable","props","referenceLabel","referenceId","cardRef","checkbox","selected","defaultSelected","onSelectionChange","floatingAction","onClick","onKeyDown","findAllFocusable","useFocusFinders","checkboxRef","useRef","isSelectable","some","prop","isCardSelected","setIsCardSelected","useState","isSelectFocused","setIsSelectFocused","shouldRestrictTriggerAction","useCallback","event","current","focusableElements","target","isElementInFocusableGroup","element","contains","isCheckboxSlot","onChangeHandler","newCheckedValue","onKeyDownHandler","Enter","includes","key","preventDefault","checkboxSlot","useMemo","selectableCheckboxProps","resolveShorthand","defaultProps","ref","type","checked","onChange","onFocus","onBlur","floatingActionSlot","selectableCardProps","mergeCallbacks","useEffect","Boolean","selectable","selectFocused","exports"],"sources":["../../../../../../../../../packages/react-components/react-card/src/components/Card/useCardSelectable.ts"],"sourcesContent":["import * as React from 'react';\nimport { mergeCallbacks, resolveShorthand } from '@fluentui/react-utilities';\nimport { Enter } from '@fluentui/keyboard-keys';\nimport { useFocusFinders } from '@fluentui/react-tabster';\n\nimport type { CardContextValue, CardOnSelectionChangeEvent, CardProps, CardSlots } from './Card.types';\n\n/**\n * @internal\n *\n * Create the state related to selectable cards.\n *\n * This internal hook controls all the logic for selectable cards and is\n * intended to be used alongside with useCard_unstable.\n *\n * @param props - props from this instance of Card\n * @param a11yProps - accessibility props shared between elements of the card\n * @param ref - reference to the root element of Card\n */\nexport const useCardSelectable = (\n props: CardProps,\n { referenceLabel, referenceId }: Pick<CardContextValue['selectableA11yProps'], 'referenceId' | 'referenceLabel'>,\n cardRef: React.RefObject<HTMLDivElement>,\n) => {\n const { checkbox = {}, selected, defaultSelected, onSelectionChange, floatingAction, onClick, onKeyDown } = props;\n\n const { findAllFocusable } = useFocusFinders();\n\n const checkboxRef = React.useRef<HTMLInputElement>(null);\n\n const isSelectable = [selected, defaultSelected, onSelectionChange].some(prop => typeof prop !== 'undefined');\n\n const [isCardSelected, setIsCardSelected] = React.useState(false);\n const [isSelectFocused, setIsSelectFocused] = React.useState(false);\n\n const shouldRestrictTriggerAction = React.useCallback(\n (event: CardOnSelectionChangeEvent) => {\n if (!cardRef.current) {\n return false;\n }\n\n const focusableElements = findAllFocusable(cardRef.current);\n const target = event.target as HTMLElement;\n const isElementInFocusableGroup = focusableElements.some(element => element.contains(target));\n const isCheckboxSlot = checkboxRef?.current === target;\n\n return isElementInFocusableGroup && !isCheckboxSlot;\n },\n [cardRef, findAllFocusable],\n );\n\n const onChangeHandler = React.useCallback(\n (event: CardOnSelectionChangeEvent) => {\n if (shouldRestrictTriggerAction(event)) {\n return;\n }\n\n const newCheckedValue = !isCardSelected;\n\n setIsCardSelected(newCheckedValue);\n\n if (onSelectionChange) {\n onSelectionChange(event, { selected: newCheckedValue });\n }\n },\n [onSelectionChange, isCardSelected, shouldRestrictTriggerAction],\n );\n\n const onKeyDownHandler = React.useCallback(\n (event: React.KeyboardEvent<HTMLElement>) => {\n if ([Enter].includes(event.key)) {\n event.preventDefault();\n onChangeHandler(event);\n }\n },\n [onChangeHandler],\n );\n\n const checkboxSlot = React.useMemo(() => {\n if (!isSelectable || floatingAction) {\n return;\n }\n\n const selectableCheckboxProps: CardSlots['checkbox'] = {};\n\n if (referenceId) {\n selectableCheckboxProps['aria-labelledby'] = referenceId;\n } else if (referenceLabel) {\n selectableCheckboxProps['aria-label'] = referenceLabel;\n }\n\n return resolveShorthand(checkbox, {\n defaultProps: {\n ref: checkboxRef,\n type: 'checkbox',\n checked: isCardSelected,\n onChange: (event: React.ChangeEvent<HTMLInputElement>) => onChangeHandler(event),\n onFocus: () => setIsSelectFocused(true),\n onBlur: () => setIsSelectFocused(false),\n ...selectableCheckboxProps,\n },\n });\n }, [checkbox, floatingAction, isCardSelected, isSelectable, onChangeHandler, referenceId, referenceLabel]);\n\n const floatingActionSlot = React.useMemo(() => {\n if (!floatingAction) {\n return;\n }\n\n return resolveShorthand(floatingAction, {\n defaultProps: {\n ref: checkboxRef,\n },\n });\n }, [floatingAction]);\n\n const selectableCardProps = React.useMemo(() => {\n if (!isSelectable) {\n return null;\n }\n\n return {\n onClick: mergeCallbacks(onClick, onChangeHandler),\n onKeyDown: mergeCallbacks(onKeyDown, onKeyDownHandler),\n };\n }, [isSelectable, onChangeHandler, onClick, onKeyDown, onKeyDownHandler]);\n\n React.useEffect(\n () => setIsCardSelected(Boolean(defaultSelected ?? selected)),\n [defaultSelected, selected, setIsCardSelected],\n );\n\n return {\n selected: isCardSelected,\n selectable: isSelectable,\n selectFocused: isSelectFocused,\n selectableCardProps,\n checkboxSlot,\n floatingActionSlot,\n };\n};\n"],"mappings":"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"}
|