@cdx-ui/primitives 0.0.1-beta.3 → 0.0.1-beta.30
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/README.md +49 -24
- package/lib/commonjs/checkbox/createCheckboxRoot.web.js +8 -3
- package/lib/commonjs/checkbox/createCheckboxRoot.web.js.map +1 -1
- package/lib/commonjs/field/createFieldLabel.js.map +1 -1
- package/lib/commonjs/index.js +36 -0
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/input/createInputField.js +5 -0
- package/lib/commonjs/input/createInputField.js.map +1 -1
- package/lib/commonjs/list-item/context.js +11 -0
- package/lib/commonjs/list-item/context.js.map +1 -0
- package/lib/commonjs/list-item/createListItemContent.js +30 -0
- package/lib/commonjs/list-item/createListItemContent.js.map +1 -0
- package/lib/commonjs/list-item/createListItemDescription.js +25 -0
- package/lib/commonjs/list-item/createListItemDescription.js.map +1 -0
- package/lib/commonjs/list-item/createListItemLeadingSlot.js +34 -0
- package/lib/commonjs/list-item/createListItemLeadingSlot.js.map +1 -0
- package/lib/commonjs/list-item/createListItemMeta.js +25 -0
- package/lib/commonjs/list-item/createListItemMeta.js.map +1 -0
- package/lib/commonjs/list-item/createListItemRoot.js +157 -0
- package/lib/commonjs/list-item/createListItemRoot.js.map +1 -0
- package/lib/commonjs/list-item/createListItemSectionHeader.js +54 -0
- package/lib/commonjs/list-item/createListItemSectionHeader.js.map +1 -0
- package/lib/commonjs/list-item/createListItemTitle.js +25 -0
- package/lib/commonjs/list-item/createListItemTitle.js.map +1 -0
- package/lib/commonjs/list-item/createListItemTrailingSlot.js +28 -0
- package/lib/commonjs/list-item/createListItemTrailingSlot.js.map +1 -0
- package/lib/commonjs/list-item/index.js +55 -0
- package/lib/commonjs/list-item/index.js.map +1 -0
- package/lib/commonjs/list-item/types.js +6 -0
- package/lib/commonjs/list-item/types.js.map +1 -0
- package/lib/commonjs/radio/context.js +14 -0
- package/lib/commonjs/radio/context.js.map +1 -0
- package/lib/commonjs/radio/createRadioGroup.js +66 -0
- package/lib/commonjs/radio/createRadioGroup.js.map +1 -0
- package/lib/commonjs/radio/createRadioIndicator.js +43 -0
- package/lib/commonjs/radio/createRadioIndicator.js.map +1 -0
- package/lib/commonjs/radio/createRadioLabel.js +38 -0
- package/lib/commonjs/radio/createRadioLabel.js.map +1 -0
- package/lib/commonjs/radio/createRadioRoot.js +95 -0
- package/lib/commonjs/radio/createRadioRoot.js.map +1 -0
- package/lib/commonjs/radio/createRadioRoot.web.js +87 -0
- package/lib/commonjs/radio/createRadioRoot.web.js.map +1 -0
- package/lib/commonjs/radio/index.js +26 -0
- package/lib/commonjs/radio/index.js.map +1 -0
- package/lib/commonjs/radio/types.js +6 -0
- package/lib/commonjs/radio/types.js.map +1 -0
- package/lib/commonjs/radio/useRadioRoot.js +64 -0
- package/lib/commonjs/radio/useRadioRoot.js.map +1 -0
- package/lib/commonjs/select/createSelectTrigger.js +17 -4
- package/lib/commonjs/select/createSelectTrigger.js.map +1 -1
- package/lib/commonjs/tile/context.js +30 -0
- package/lib/commonjs/tile/context.js.map +1 -0
- package/lib/commonjs/tile/createTileContent.js +30 -0
- package/lib/commonjs/tile/createTileContent.js.map +1 -0
- package/lib/commonjs/tile/createTileDescription.js +28 -0
- package/lib/commonjs/tile/createTileDescription.js.map +1 -0
- package/lib/commonjs/tile/createTileGroup.js +112 -0
- package/lib/commonjs/tile/createTileGroup.js.map +1 -0
- package/lib/commonjs/tile/createTileIndicator.js +46 -0
- package/lib/commonjs/tile/createTileIndicator.js.map +1 -0
- package/lib/commonjs/tile/createTileLeadingSlot.js +34 -0
- package/lib/commonjs/tile/createTileLeadingSlot.js.map +1 -0
- package/lib/commonjs/tile/createTileRoot.js +133 -0
- package/lib/commonjs/tile/createTileRoot.js.map +1 -0
- package/lib/commonjs/tile/createTileTitle.js +28 -0
- package/lib/commonjs/tile/createTileTitle.js.map +1 -0
- package/lib/commonjs/tile/createTileTrailingSlot.js +35 -0
- package/lib/commonjs/tile/createTileTrailingSlot.js.map +1 -0
- package/lib/commonjs/tile/index.js +55 -0
- package/lib/commonjs/tile/index.js.map +1 -0
- package/lib/commonjs/tile/types.js +6 -0
- package/lib/commonjs/tile/types.js.map +1 -0
- package/lib/module/checkbox/createCheckboxRoot.web.js +8 -2
- package/lib/module/checkbox/createCheckboxRoot.web.js.map +1 -1
- package/lib/module/field/createFieldLabel.js.map +1 -1
- package/lib/module/index.js +3 -0
- package/lib/module/index.js.map +1 -1
- package/lib/module/input/createInputField.js +5 -0
- package/lib/module/input/createInputField.js.map +1 -1
- package/lib/module/list-item/context.js +5 -0
- package/lib/module/list-item/context.js.map +1 -0
- package/lib/module/list-item/createListItemContent.js +24 -0
- package/lib/module/list-item/createListItemContent.js.map +1 -0
- package/lib/module/list-item/createListItemDescription.js +19 -0
- package/lib/module/list-item/createListItemDescription.js.map +1 -0
- package/lib/module/list-item/createListItemLeadingSlot.js +28 -0
- package/lib/module/list-item/createListItemLeadingSlot.js.map +1 -0
- package/lib/module/list-item/createListItemMeta.js +19 -0
- package/lib/module/list-item/createListItemMeta.js.map +1 -0
- package/lib/module/list-item/createListItemRoot.js +151 -0
- package/lib/module/list-item/createListItemRoot.js.map +1 -0
- package/lib/module/list-item/createListItemSectionHeader.js +48 -0
- package/lib/module/list-item/createListItemSectionHeader.js.map +1 -0
- package/lib/module/list-item/createListItemTitle.js +19 -0
- package/lib/module/list-item/createListItemTitle.js.map +1 -0
- package/lib/module/list-item/createListItemTrailingSlot.js +22 -0
- package/lib/module/list-item/createListItemTrailingSlot.js.map +1 -0
- package/lib/module/list-item/index.js +39 -0
- package/lib/module/list-item/index.js.map +1 -0
- package/lib/module/list-item/types.js +4 -0
- package/lib/module/list-item/types.js.map +1 -0
- package/lib/module/radio/context.js +7 -0
- package/lib/module/radio/context.js.map +1 -0
- package/lib/module/radio/createRadioGroup.js +61 -0
- package/lib/module/radio/createRadioGroup.js.map +1 -0
- package/lib/module/radio/createRadioIndicator.js +38 -0
- package/lib/module/radio/createRadioIndicator.js.map +1 -0
- package/lib/module/radio/createRadioLabel.js +33 -0
- package/lib/module/radio/createRadioLabel.js.map +1 -0
- package/lib/module/radio/createRadioRoot.js +90 -0
- package/lib/module/radio/createRadioRoot.js.map +1 -0
- package/lib/module/radio/createRadioRoot.web.js +82 -0
- package/lib/module/radio/createRadioRoot.web.js.map +1 -0
- package/lib/module/radio/index.js +22 -0
- package/lib/module/radio/index.js.map +1 -0
- package/lib/module/radio/types.js +4 -0
- package/lib/module/radio/types.js.map +1 -0
- package/lib/module/radio/useRadioRoot.js +60 -0
- package/lib/module/radio/useRadioRoot.js.map +1 -0
- package/lib/module/select/createSelectTrigger.js +19 -6
- package/lib/module/select/createSelectTrigger.js.map +1 -1
- package/lib/module/tile/context.js +21 -0
- package/lib/module/tile/context.js.map +1 -0
- package/lib/module/tile/createTileContent.js +24 -0
- package/lib/module/tile/createTileContent.js.map +1 -0
- package/lib/module/tile/createTileDescription.js +22 -0
- package/lib/module/tile/createTileDescription.js.map +1 -0
- package/lib/module/tile/createTileGroup.js +106 -0
- package/lib/module/tile/createTileGroup.js.map +1 -0
- package/lib/module/tile/createTileIndicator.js +40 -0
- package/lib/module/tile/createTileIndicator.js.map +1 -0
- package/lib/module/tile/createTileLeadingSlot.js +28 -0
- package/lib/module/tile/createTileLeadingSlot.js.map +1 -0
- package/lib/module/tile/createTileRoot.js +127 -0
- package/lib/module/tile/createTileRoot.js.map +1 -0
- package/lib/module/tile/createTileTitle.js +22 -0
- package/lib/module/tile/createTileTitle.js.map +1 -0
- package/lib/module/tile/createTileTrailingSlot.js +29 -0
- package/lib/module/tile/createTileTrailingSlot.js.map +1 -0
- package/lib/module/tile/index.js +39 -0
- package/lib/module/tile/index.js.map +1 -0
- package/lib/module/tile/types.js +4 -0
- package/lib/module/tile/types.js.map +1 -0
- package/lib/typescript/checkbox/createCheckboxRoot.web.d.ts +4 -0
- package/lib/typescript/checkbox/createCheckboxRoot.web.d.ts.map +1 -1
- package/lib/typescript/checkbox/useCheckboxRoot.d.ts +2 -0
- package/lib/typescript/checkbox/useCheckboxRoot.d.ts.map +1 -1
- package/lib/typescript/field/createFieldLabel.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +3 -0
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/input/createInputField.d.ts.map +1 -1
- package/lib/typescript/list-item/context.d.ts +6 -0
- package/lib/typescript/list-item/context.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemContent.d.ts +3 -0
- package/lib/typescript/list-item/createListItemContent.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemDescription.d.ts +3 -0
- package/lib/typescript/list-item/createListItemDescription.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemLeadingSlot.d.ts +4 -0
- package/lib/typescript/list-item/createListItemLeadingSlot.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemMeta.d.ts +3 -0
- package/lib/typescript/list-item/createListItemMeta.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemRoot.d.ts +4 -0
- package/lib/typescript/list-item/createListItemRoot.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemSectionHeader.d.ts +4 -0
- package/lib/typescript/list-item/createListItemSectionHeader.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemTitle.d.ts +3 -0
- package/lib/typescript/list-item/createListItemTitle.d.ts.map +1 -0
- package/lib/typescript/list-item/createListItemTrailingSlot.d.ts +3 -0
- package/lib/typescript/list-item/createListItemTrailingSlot.d.ts.map +1 -0
- package/lib/typescript/list-item/index.d.ts +16 -0
- package/lib/typescript/list-item/index.d.ts.map +1 -0
- package/lib/typescript/list-item/types.d.ts +86 -0
- package/lib/typescript/list-item/types.d.ts.map +1 -0
- package/lib/typescript/radio/context.d.ts +21 -0
- package/lib/typescript/radio/context.d.ts.map +1 -0
- package/lib/typescript/radio/createRadioGroup.d.ts +3 -0
- package/lib/typescript/radio/createRadioGroup.d.ts.map +1 -0
- package/lib/typescript/radio/createRadioIndicator.d.ts +5 -0
- package/lib/typescript/radio/createRadioIndicator.d.ts.map +1 -0
- package/lib/typescript/radio/createRadioLabel.d.ts +5 -0
- package/lib/typescript/radio/createRadioLabel.d.ts.map +1 -0
- package/lib/typescript/radio/createRadioRoot.d.ts +3 -0
- package/lib/typescript/radio/createRadioRoot.d.ts.map +1 -0
- package/lib/typescript/radio/createRadioRoot.web.d.ts +3 -0
- package/lib/typescript/radio/createRadioRoot.web.d.ts.map +1 -0
- package/lib/typescript/radio/index.d.ts +10 -0
- package/lib/typescript/radio/index.d.ts.map +1 -0
- package/lib/typescript/radio/types.d.ts +54 -0
- package/lib/typescript/radio/types.d.ts.map +1 -0
- package/lib/typescript/radio/useRadioRoot.d.ts +151 -0
- package/lib/typescript/radio/useRadioRoot.d.ts.map +1 -0
- package/lib/typescript/select/createSelectTrigger.d.ts.map +1 -1
- package/lib/typescript/tile/context.d.ts +9 -0
- package/lib/typescript/tile/context.d.ts.map +1 -0
- package/lib/typescript/tile/createTileContent.d.ts +3 -0
- package/lib/typescript/tile/createTileContent.d.ts.map +1 -0
- package/lib/typescript/tile/createTileDescription.d.ts +3 -0
- package/lib/typescript/tile/createTileDescription.d.ts.map +1 -0
- package/lib/typescript/tile/createTileGroup.d.ts +4 -0
- package/lib/typescript/tile/createTileGroup.d.ts.map +1 -0
- package/lib/typescript/tile/createTileIndicator.d.ts +4 -0
- package/lib/typescript/tile/createTileIndicator.d.ts.map +1 -0
- package/lib/typescript/tile/createTileLeadingSlot.d.ts +4 -0
- package/lib/typescript/tile/createTileLeadingSlot.d.ts.map +1 -0
- package/lib/typescript/tile/createTileRoot.d.ts +4 -0
- package/lib/typescript/tile/createTileRoot.d.ts.map +1 -0
- package/lib/typescript/tile/createTileTitle.d.ts +3 -0
- package/lib/typescript/tile/createTileTitle.d.ts.map +1 -0
- package/lib/typescript/tile/createTileTrailingSlot.d.ts +9 -0
- package/lib/typescript/tile/createTileTrailingSlot.d.ts.map +1 -0
- package/lib/typescript/tile/index.d.ts +15 -0
- package/lib/typescript/tile/index.d.ts.map +1 -0
- package/lib/typescript/tile/types.d.ts +119 -0
- package/lib/typescript/tile/types.d.ts.map +1 -0
- package/package.json +5 -2
- package/src/checkbox/createCheckboxRoot.web.tsx +6 -2
- package/src/field/createFieldLabel.tsx +4 -1
- package/src/index.ts +3 -0
- package/src/input/createInputField.tsx +6 -0
- package/src/list-item/context.tsx +5 -0
- package/src/list-item/createListItemContent.tsx +23 -0
- package/src/list-item/createListItemDescription.tsx +19 -0
- package/src/list-item/createListItemLeadingSlot.tsx +30 -0
- package/src/list-item/createListItemMeta.tsx +17 -0
- package/src/list-item/createListItemRoot.tsx +178 -0
- package/src/list-item/createListItemSectionHeader.tsx +53 -0
- package/src/list-item/createListItemTitle.tsx +17 -0
- package/src/list-item/createListItemTrailingSlot.tsx +21 -0
- package/src/list-item/index.ts +88 -0
- package/src/list-item/types.ts +122 -0
- package/src/radio/context.tsx +21 -0
- package/src/radio/createRadioGroup.tsx +67 -0
- package/src/radio/createRadioIndicator.tsx +32 -0
- package/src/radio/createRadioLabel.tsx +28 -0
- package/src/radio/createRadioRoot.tsx +100 -0
- package/src/radio/createRadioRoot.web.tsx +81 -0
- package/src/radio/index.ts +37 -0
- package/src/radio/types.ts +67 -0
- package/src/radio/useRadioRoot.ts +69 -0
- package/src/select/createSelectTrigger.tsx +26 -3
- package/src/tile/context.tsx +23 -0
- package/src/tile/createTileContent.tsx +23 -0
- package/src/tile/createTileDescription.tsx +19 -0
- package/src/tile/createTileGroup.tsx +134 -0
- package/src/tile/createTileIndicator.tsx +38 -0
- package/src/tile/createTileLeadingSlot.tsx +30 -0
- package/src/tile/createTileRoot.tsx +124 -0
- package/src/tile/createTileTitle.tsx +19 -0
- package/src/tile/createTileTrailingSlot.tsx +25 -0
- package/src/tile/index.ts +88 -0
- package/src/tile/types.ts +153 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React, { forwardRef } from 'react';
|
|
4
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
5
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
|
+
export const createListItemTitle = Base => /*#__PURE__*/forwardRef(({
|
|
7
|
+
children,
|
|
8
|
+
style,
|
|
9
|
+
...props
|
|
10
|
+
}, ref) => /*#__PURE__*/_jsx(Base, {
|
|
11
|
+
...props,
|
|
12
|
+
...dataAttributes({
|
|
13
|
+
slot: 'list-item-title'
|
|
14
|
+
}),
|
|
15
|
+
ref: ref,
|
|
16
|
+
style: style,
|
|
17
|
+
children: children
|
|
18
|
+
}));
|
|
19
|
+
//# sourceMappingURL=createListItemTitle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","forwardRef","dataAttributes","jsx","_jsx","createListItemTitle","Base","children","style","props","ref","slot"],"sourceRoot":"../../../src","sources":["list-item/createListItemTitle.tsx"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,SAASC,cAAc,QAAQ,yBAAyB;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAGzD,OAAO,MAAMC,mBAAmB,GAAQC,IAA4B,iBAClEL,UAAU,CAAC,CAAC;EAAEM,QAAQ;EAAEC,KAAK;EAAE,GAAGC;AAA2B,CAAC,EAAEC,GAAuB,kBACrFN,IAAA,CAACE,IAAI;EAAA,GACEG,KAAK;EAAA,GACNP,cAAc,CAAC;IACjBS,IAAI,EAAE;EACR,CAAC,CAAC;EACFD,GAAG,EAAEA,GAAoB;EACzBF,KAAK,EAAEA,KAAM;EAAAD,QAAA,EAEZA;AAAQ,CACL,CACP,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React, { forwardRef } from 'react';
|
|
4
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
5
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
|
+
const shrinkZero = {
|
|
7
|
+
flexShrink: 0
|
|
8
|
+
};
|
|
9
|
+
export const createListItemTrailingSlot = Base => /*#__PURE__*/forwardRef(({
|
|
10
|
+
children,
|
|
11
|
+
style,
|
|
12
|
+
...props
|
|
13
|
+
}, ref) => /*#__PURE__*/_jsx(Base, {
|
|
14
|
+
...props,
|
|
15
|
+
...dataAttributes({
|
|
16
|
+
slot: 'list-item-trailing'
|
|
17
|
+
}),
|
|
18
|
+
ref: ref,
|
|
19
|
+
style: [shrinkZero, style],
|
|
20
|
+
children: children
|
|
21
|
+
}));
|
|
22
|
+
//# sourceMappingURL=createListItemTrailingSlot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","forwardRef","dataAttributes","jsx","_jsx","shrinkZero","flexShrink","createListItemTrailingSlot","Base","children","style","props","ref","slot"],"sourceRoot":"../../../src","sources":["list-item/createListItemTrailingSlot.tsx"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,SAASC,cAAc,QAAQ,yBAAyB;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAGzD,MAAMC,UAAU,GAAG;EAAEC,UAAU,EAAE;AAAW,CAAC;AAE7C,OAAO,MAAMC,0BAA0B,GAAQC,IAA4B,iBACzEP,UAAU,CACR,CAAC;EAAEQ,QAAQ;EAAEC,KAAK;EAAE,GAAGC;AAAkC,CAAC,EAAEC,GAAuB,kBACjFR,IAAA,CAACI,IAAI;EAAA,GACEG,KAAK;EAAA,GACNT,cAAc,CAAC;IACjBW,IAAI,EAAE;EACR,CAAC,CAAC;EACFD,GAAG,EAAEA,GAAoB;EACzBF,KAAK,EAAE,CAACL,UAAU,EAAEK,KAAK,CAAE;EAAAD,QAAA,EAE1BA;AAAQ,CACL,CAEV,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { createListItemContent } from './createListItemContent';
|
|
4
|
+
import { createListItemDescription } from './createListItemDescription';
|
|
5
|
+
import { createListItemLeadingSlot } from './createListItemLeadingSlot';
|
|
6
|
+
import { createListItemMeta } from './createListItemMeta';
|
|
7
|
+
import { createListItemRoot } from './createListItemRoot';
|
|
8
|
+
import { createListItemSectionHeader } from './createListItemSectionHeader';
|
|
9
|
+
import { createListItemTitle } from './createListItemTitle';
|
|
10
|
+
import { createListItemTrailingSlot } from './createListItemTrailingSlot';
|
|
11
|
+
export { ListItemProvider, useListItemContext } from './context';
|
|
12
|
+
export function createListItem(BaseComponents) {
|
|
13
|
+
const ListItem = createListItemRoot(BaseComponents.View, BaseComponents.Pressable);
|
|
14
|
+
const LeadingSlot = createListItemLeadingSlot(BaseComponents.LeadingSlot);
|
|
15
|
+
const Content = createListItemContent(BaseComponents.Content);
|
|
16
|
+
const Title = createListItemTitle(BaseComponents.Title);
|
|
17
|
+
const Description = createListItemDescription(BaseComponents.Description);
|
|
18
|
+
const Meta = createListItemMeta(BaseComponents.Meta);
|
|
19
|
+
const TrailingSlot = createListItemTrailingSlot(BaseComponents.TrailingSlot);
|
|
20
|
+
const SectionHeader = createListItemSectionHeader(BaseComponents.SectionHeader);
|
|
21
|
+
ListItem.displayName = 'ListItemPrimitive';
|
|
22
|
+
LeadingSlot.displayName = 'ListItemPrimitive.LeadingSlot';
|
|
23
|
+
Content.displayName = 'ListItemPrimitive.Content';
|
|
24
|
+
Title.displayName = 'ListItemPrimitive.Title';
|
|
25
|
+
Description.displayName = 'ListItemPrimitive.Description';
|
|
26
|
+
Meta.displayName = 'ListItemPrimitive.Meta';
|
|
27
|
+
TrailingSlot.displayName = 'ListItemPrimitive.TrailingSlot';
|
|
28
|
+
SectionHeader.displayName = 'ListItemPrimitive.SectionHeader';
|
|
29
|
+
return Object.assign(ListItem, {
|
|
30
|
+
LeadingSlot,
|
|
31
|
+
Content,
|
|
32
|
+
Title,
|
|
33
|
+
Description,
|
|
34
|
+
Meta,
|
|
35
|
+
TrailingSlot,
|
|
36
|
+
SectionHeader
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createListItemContent","createListItemDescription","createListItemLeadingSlot","createListItemMeta","createListItemRoot","createListItemSectionHeader","createListItemTitle","createListItemTrailingSlot","ListItemProvider","useListItemContext","createListItem","BaseComponents","ListItem","View","Pressable","LeadingSlot","Content","Title","Description","Meta","TrailingSlot","SectionHeader","displayName","Object","assign"],"sourceRoot":"../../../src","sources":["list-item/index.ts"],"mappings":";;AACA,SAASA,qBAAqB,QAAQ,yBAAyB;AAC/D,SAASC,yBAAyB,QAAQ,6BAA6B;AACvE,SAASC,yBAAyB,QAAQ,6BAA6B;AACvE,SAASC,kBAAkB,QAAQ,sBAAsB;AACzD,SAASC,kBAAkB,QAAQ,sBAAsB;AACzD,SAASC,2BAA2B,QAAQ,+BAA+B;AAC3E,SAASC,mBAAmB,QAAQ,uBAAuB;AAC3D,SAASC,0BAA0B,QAAQ,8BAA8B;AAoBzE,SAASC,gBAAgB,EAAEC,kBAAkB,QAAQ,WAAW;AAEhE,OAAO,SAASC,cAAcA,CAU5BC,cAUD,EAAE;EACD,MAAMC,QAAQ,GAAGR,kBAAkB,CAACO,cAAc,CAACE,IAAI,EAAEF,cAAc,CAACG,SAAS,CAAC;EAClF,MAAMC,WAAW,GAAGb,yBAAyB,CAACS,cAAc,CAACI,WAAW,CAAC;EACzE,MAAMC,OAAO,GAAGhB,qBAAqB,CAACW,cAAc,CAACK,OAAO,CAAC;EAC7D,MAAMC,KAAK,GAAGX,mBAAmB,CAACK,cAAc,CAACM,KAAK,CAAC;EACvD,MAAMC,WAAW,GAAGjB,yBAAyB,CAACU,cAAc,CAACO,WAAW,CAAC;EACzE,MAAMC,IAAI,GAAGhB,kBAAkB,CAACQ,cAAc,CAACQ,IAAI,CAAC;EACpD,MAAMC,YAAY,GAAGb,0BAA0B,CAACI,cAAc,CAACS,YAAY,CAAC;EAC5E,MAAMC,aAAa,GAAGhB,2BAA2B,CAACM,cAAc,CAACU,aAAa,CAAC;EAE/ET,QAAQ,CAACU,WAAW,GAAG,mBAAmB;EAC1CP,WAAW,CAACO,WAAW,GAAG,+BAA+B;EACzDN,OAAO,CAACM,WAAW,GAAG,2BAA2B;EACjDL,KAAK,CAACK,WAAW,GAAG,yBAAyB;EAC7CJ,WAAW,CAACI,WAAW,GAAG,+BAA+B;EACzDH,IAAI,CAACG,WAAW,GAAG,wBAAwB;EAC3CF,YAAY,CAACE,WAAW,GAAG,gCAAgC;EAC3DD,aAAa,CAACC,WAAW,GAAG,iCAAiC;EAE7D,OAAOC,MAAM,CAACC,MAAM,CAACZ,QAAQ,EAAE;IAC7BG,WAAW;IACXC,OAAO;IACPC,KAAK;IACLC,WAAW;IACXC,IAAI;IACJC,YAAY;IACZC;EACF,CAAC,CAAC;AAUJ","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["list-item/types.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { createContext } from '@cdx-ui/utils';
|
|
5
|
+
export const [RadioProvider, useRadioContext] = createContext('RadioContext');
|
|
6
|
+
export const RadioGroupContext = /*#__PURE__*/React.createContext(null);
|
|
7
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","createContext","RadioProvider","useRadioContext","RadioGroupContext"],"sourceRoot":"../../../src","sources":["radio/context.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,aAAa,QAAQ,eAAe;AAI7C,OAAO,MAAM,CAACC,aAAa,EAAEC,eAAe,CAAC,GAAGF,aAAa,CAAqB,cAAc,CAAC;AAWjG,OAAO,MAAMG,iBAAiB,gBAAGJ,KAAK,CAACC,aAAa,CAI1C,IAAI,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { useFormControlContext } from '@cdx-ui/utils';
|
|
5
|
+
import { useRadioGroup } from '@react-native-aria/radio';
|
|
6
|
+
import { useRadioGroupState } from '@react-stately/radio';
|
|
7
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
8
|
+
import { RadioGroupContext } from './context';
|
|
9
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
10
|
+
export const createRadioGroup = BaseRadioGroup => /*#__PURE__*/forwardRef(({
|
|
11
|
+
children,
|
|
12
|
+
...props
|
|
13
|
+
}, ref) => {
|
|
14
|
+
const formControlContext = useFormControlContext();
|
|
15
|
+
const combinedProps = {
|
|
16
|
+
...formControlContext,
|
|
17
|
+
...props
|
|
18
|
+
};
|
|
19
|
+
const radioGroupState = useRadioGroupState({
|
|
20
|
+
...combinedProps,
|
|
21
|
+
validationState: combinedProps.isInvalid ? 'invalid' : 'valid'
|
|
22
|
+
});
|
|
23
|
+
const {
|
|
24
|
+
radioGroupProps
|
|
25
|
+
} = useRadioGroup({
|
|
26
|
+
...combinedProps,
|
|
27
|
+
'aria-label': combinedProps['aria-label']
|
|
28
|
+
}, radioGroupState);
|
|
29
|
+
const isDisabled = combinedProps.isDisabled ?? false;
|
|
30
|
+
const isInvalid = combinedProps.isInvalid ?? false;
|
|
31
|
+
const isRequired = combinedProps.isRequired ?? false;
|
|
32
|
+
const isReadOnly = combinedProps.isReadOnly ?? false;
|
|
33
|
+
return /*#__PURE__*/_jsx(RadioGroupContext.Provider, {
|
|
34
|
+
value: {
|
|
35
|
+
state: {
|
|
36
|
+
isDisabled,
|
|
37
|
+
isInvalid,
|
|
38
|
+
isRequired,
|
|
39
|
+
isReadOnly,
|
|
40
|
+
isSelected: value => radioGroupState.selectedValue === value,
|
|
41
|
+
selectValue: value => radioGroupState.setSelectedValue(value)
|
|
42
|
+
},
|
|
43
|
+
radioGroupState,
|
|
44
|
+
name: combinedProps.name
|
|
45
|
+
},
|
|
46
|
+
children: /*#__PURE__*/_jsx(BaseRadioGroup, {
|
|
47
|
+
...radioGroupProps,
|
|
48
|
+
...combinedProps,
|
|
49
|
+
ref: ref,
|
|
50
|
+
"aria-required": isRequired || undefined,
|
|
51
|
+
"aria-readonly": isReadOnly || undefined,
|
|
52
|
+
...dataAttributes({
|
|
53
|
+
slot: 'radio-group',
|
|
54
|
+
disabled: isDisabled,
|
|
55
|
+
invalid: isInvalid
|
|
56
|
+
}),
|
|
57
|
+
children: children
|
|
58
|
+
})
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
//# sourceMappingURL=createRadioGroup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["forwardRef","useFormControlContext","useRadioGroup","useRadioGroupState","dataAttributes","RadioGroupContext","jsx","_jsx","createRadioGroup","BaseRadioGroup","children","props","ref","formControlContext","combinedProps","radioGroupState","validationState","isInvalid","radioGroupProps","isDisabled","isRequired","isReadOnly","Provider","value","state","isSelected","selectedValue","selectValue","setSelectedValue","name","undefined","slot","disabled","invalid"],"sourceRoot":"../../../src","sources":["radio/createRadioGroup.tsx"],"mappings":";;AAAA,SAASA,UAAU,QAAQ,OAAO;AAClC,SAASC,qBAAqB,QAAQ,eAAe;AACrD,SAASC,aAAa,QAAQ,0BAA0B;AACxD,SAASC,kBAAkB,QAAQ,sBAAsB;AACzD,SAASC,cAAc,QAAQ,yBAAyB;AACxD,SAASC,iBAAiB,QAAQ,WAAW;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAG9C,OAAO,MAAMC,gBAAgB,GAAQC,cAAsC,iBACzET,UAAU,CAAC,CAAC;EAAEU,QAAQ;EAAE,GAAGC;AAAwB,CAAC,EAAEC,GAAkB,KAAK;EAC3E,MAAMC,kBAAkB,GAAGZ,qBAAqB,CAAC,CAAC;EAElD,MAAMa,aAAa,GAAG;IACpB,GAAGD,kBAAkB;IACrB,GAAGF;EACL,CAAC;EAED,MAAMI,eAAe,GAAGZ,kBAAkB,CAAC;IACzC,GAAGW,aAAa;IAChBE,eAAe,EAAEF,aAAa,CAACG,SAAS,GAAG,SAAS,GAAG;EACzD,CAAC,CAAC;EAEF,MAAM;IAAEC;EAAgB,CAAC,GAAGhB,aAAa,CACvC;IACE,GAAGY,aAAa;IAChB,YAAY,EAAEA,aAAa,CAAC,YAAY;EAC1C,CAAC,EACDC,eACF,CAAC;EAED,MAAMI,UAAU,GAAGL,aAAa,CAACK,UAAU,IAAI,KAAK;EACpD,MAAMF,SAAS,GAAGH,aAAa,CAACG,SAAS,IAAI,KAAK;EAClD,MAAMG,UAAU,GAAGN,aAAa,CAACM,UAAU,IAAI,KAAK;EACpD,MAAMC,UAAU,GAAGP,aAAa,CAACO,UAAU,IAAI,KAAK;EAEpD,oBACEd,IAAA,CAACF,iBAAiB,CAACiB,QAAQ;IACzBC,KAAK,EAAE;MACLC,KAAK,EAAE;QACLL,UAAU;QACVF,SAAS;QACTG,UAAU;QACVC,UAAU;QACVI,UAAU,EAAGF,KAAa,IAAKR,eAAe,CAACW,aAAa,KAAKH,KAAK;QACtEI,WAAW,EAAGJ,KAAa,IAAKR,eAAe,CAACa,gBAAgB,CAACL,KAAK;MACxE,CAAC;MACDR,eAAe;MACfc,IAAI,EAAEf,aAAa,CAACe;IACtB,CAAE;IAAAnB,QAAA,eAEFH,IAAA,CAACE,cAAc;MAAA,GACTS,eAAe;MAAA,GACdJ,aAAa;MAClBF,GAAG,EAAEA,GAAI;MACT,iBAAeQ,UAAU,IAAIU,SAAU;MACvC,iBAAeT,UAAU,IAAIS,SAAU;MAAA,GACnC1B,cAAc,CAAC;QACjB2B,IAAI,EAAE,aAAa;QACnBC,QAAQ,EAAEb,UAAU;QACpBc,OAAO,EAAEhB;MACX,CAAC,CAAC;MAAAP,QAAA,EAEDA;IAAQ,CACK;EAAC,CACS,CAAC;AAEjC,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
5
|
+
import { useRadioContext } from './context';
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
+
export const createRadioIndicator = BaseRadioIndicator => /*#__PURE__*/forwardRef(({
|
|
8
|
+
children,
|
|
9
|
+
className,
|
|
10
|
+
...props
|
|
11
|
+
}, ref) => {
|
|
12
|
+
const {
|
|
13
|
+
isChecked,
|
|
14
|
+
isDisabled,
|
|
15
|
+
isHovered,
|
|
16
|
+
isInvalid,
|
|
17
|
+
isReadOnly,
|
|
18
|
+
isPressed,
|
|
19
|
+
isFocusVisible
|
|
20
|
+
} = useRadioContext();
|
|
21
|
+
return /*#__PURE__*/_jsx(BaseRadioIndicator, {
|
|
22
|
+
className: className,
|
|
23
|
+
...dataAttributes({
|
|
24
|
+
slot: 'radio-indicator',
|
|
25
|
+
hover: isHovered,
|
|
26
|
+
checked: isChecked,
|
|
27
|
+
disabled: isDisabled,
|
|
28
|
+
focusVisible: isFocusVisible,
|
|
29
|
+
invalid: isInvalid,
|
|
30
|
+
readonly: isReadOnly,
|
|
31
|
+
active: isPressed
|
|
32
|
+
}),
|
|
33
|
+
...props,
|
|
34
|
+
ref: ref,
|
|
35
|
+
children: children
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=createRadioIndicator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["forwardRef","dataAttributes","useRadioContext","jsx","_jsx","createRadioIndicator","BaseRadioIndicator","children","className","props","ref","isChecked","isDisabled","isHovered","isInvalid","isReadOnly","isPressed","isFocusVisible","slot","hover","checked","disabled","focusVisible","invalid","readonly","active"],"sourceRoot":"../../../src","sources":["radio/createRadioIndicator.tsx"],"mappings":";;AAAA,SAASA,UAAU,QAAQ,OAAO;AAClC,SAASC,cAAc,QAAQ,yBAAyB;AACxD,SAASC,eAAe,QAAQ,WAAW;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAG5C,OAAO,MAAMC,oBAAoB,GAAQC,kBAA0C,iBACjFN,UAAU,CACR,CAAC;EAAEO,QAAQ;EAAEC,SAAS;EAAE,GAAGC;AAAM,CAAC,EAAEC,GAAG,KAAK;EAC1C,MAAM;IAAEC,SAAS;IAAEC,UAAU;IAAEC,SAAS;IAAEC,SAAS;IAAEC,UAAU;IAAEC,SAAS;IAAEC;EAAe,CAAC,GAC1Ff,eAAe,CAAC,CAAC;EAEnB,oBACEE,IAAA,CAACE,kBAAkB;IACjBE,SAAS,EAAEA,SAAU;IAAA,GACjBP,cAAc,CAAC;MACjBiB,IAAI,EAAE,iBAAiB;MACvBC,KAAK,EAAEN,SAAS;MAChBO,OAAO,EAAET,SAAS;MAClBU,QAAQ,EAAET,UAAU;MACpBU,YAAY,EAAEL,cAAc;MAC5BM,OAAO,EAAET,SAAS;MAClBU,QAAQ,EAAET,UAAU;MACpBU,MAAM,EAAET;IACV,CAAC,CAAC;IAAA,GACGP,KAAK;IACVC,GAAG,EAAEA,GAAI;IAAAH,QAAA,EAERA;EAAQ,CACS,CAAC;AAEzB,CACF,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
5
|
+
import { useRadioContext } from './context';
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
+
export const createRadioLabel = BaseRadioLabel => /*#__PURE__*/forwardRef(({
|
|
8
|
+
children,
|
|
9
|
+
className,
|
|
10
|
+
...props
|
|
11
|
+
}, ref) => {
|
|
12
|
+
const {
|
|
13
|
+
isChecked,
|
|
14
|
+
isDisabled,
|
|
15
|
+
isHovered,
|
|
16
|
+
isInvalid,
|
|
17
|
+
isReadOnly
|
|
18
|
+
} = useRadioContext();
|
|
19
|
+
return /*#__PURE__*/_jsx(BaseRadioLabel, {
|
|
20
|
+
className: className,
|
|
21
|
+
...dataAttributes({
|
|
22
|
+
hover: isHovered,
|
|
23
|
+
checked: isChecked,
|
|
24
|
+
disabled: isDisabled,
|
|
25
|
+
invalid: isInvalid,
|
|
26
|
+
readonly: isReadOnly
|
|
27
|
+
}),
|
|
28
|
+
...props,
|
|
29
|
+
ref: ref,
|
|
30
|
+
children: children
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=createRadioLabel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["forwardRef","dataAttributes","useRadioContext","jsx","_jsx","createRadioLabel","BaseRadioLabel","children","className","props","ref","isChecked","isDisabled","isHovered","isInvalid","isReadOnly","hover","checked","disabled","invalid","readonly"],"sourceRoot":"../../../src","sources":["radio/createRadioLabel.tsx"],"mappings":";;AAAA,SAASA,UAAU,QAAQ,OAAO;AAClC,SAASC,cAAc,QAAQ,yBAAyB;AACxD,SAASC,eAAe,QAAQ,WAAW;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAG5C,OAAO,MAAMC,gBAAgB,GAAQC,cAAsC,iBACzEN,UAAU,CACR,CAAC;EAAEO,QAAQ;EAAEC,SAAS;EAAE,GAAGC;AAAM,CAAC,EAAEC,GAAG,KAAK;EAC1C,MAAM;IAAEC,SAAS;IAAEC,UAAU;IAAEC,SAAS;IAAEC,SAAS;IAAEC;EAAW,CAAC,GAAGb,eAAe,CAAC,CAAC;EAErF,oBACEE,IAAA,CAACE,cAAc;IACbE,SAAS,EAAEA,SAAU;IAAA,GACjBP,cAAc,CAAC;MACjBe,KAAK,EAAEH,SAAS;MAChBI,OAAO,EAAEN,SAAS;MAClBO,QAAQ,EAAEN,UAAU;MACpBO,OAAO,EAAEL,SAAS;MAClBM,QAAQ,EAAEL;IACZ,CAAC,CAAC;IAAA,GACGN,KAAK;IACVC,GAAG,EAAEA,GAAI;IAAAH,QAAA,EAERA;EAAQ,CACK,CAAC;AAErB,CACF,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { composeEventHandlers } from '@cdx-ui/utils';
|
|
5
|
+
import { useFocus } from '@react-native-aria/focus';
|
|
6
|
+
import { usePress } from '@react-native-aria/interactions';
|
|
7
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
8
|
+
import { RadioProvider } from './context';
|
|
9
|
+
import { useRadioRoot } from './useRadioRoot';
|
|
10
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
+
export const createRadioRoot = (BaseRadio, RadioIndicator) => /*#__PURE__*/forwardRef(({
|
|
12
|
+
onPressIn,
|
|
13
|
+
onPressOut,
|
|
14
|
+
onHoverIn,
|
|
15
|
+
onHoverOut,
|
|
16
|
+
onFocus,
|
|
17
|
+
onBlur,
|
|
18
|
+
children,
|
|
19
|
+
...props
|
|
20
|
+
}, ref) => {
|
|
21
|
+
const {
|
|
22
|
+
isHovered: isHoveredProp,
|
|
23
|
+
isDisabled: isDisabledProp,
|
|
24
|
+
isInvalid: isInvalidProp,
|
|
25
|
+
isReadOnly: isReadOnlyProp,
|
|
26
|
+
isPressed: isPressedProp,
|
|
27
|
+
isFocused: isFocusedProp,
|
|
28
|
+
isFocusVisible
|
|
29
|
+
} = props;
|
|
30
|
+
const {
|
|
31
|
+
combinedProps,
|
|
32
|
+
isInvalid,
|
|
33
|
+
isReadOnly,
|
|
34
|
+
inputProps,
|
|
35
|
+
isChecked,
|
|
36
|
+
isDisabled,
|
|
37
|
+
isHovered,
|
|
38
|
+
hoverProps,
|
|
39
|
+
mergedRef
|
|
40
|
+
} = useRadioRoot(props, ref);
|
|
41
|
+
const {
|
|
42
|
+
focusProps,
|
|
43
|
+
isFocused
|
|
44
|
+
} = useFocus();
|
|
45
|
+
const {
|
|
46
|
+
pressProps,
|
|
47
|
+
isPressed
|
|
48
|
+
} = usePress({
|
|
49
|
+
isDisabled: isDisabled || isDisabledProp
|
|
50
|
+
});
|
|
51
|
+
return /*#__PURE__*/_jsx(BaseRadio, {
|
|
52
|
+
disabled: isDisabled || isDisabledProp,
|
|
53
|
+
...pressProps,
|
|
54
|
+
...combinedProps,
|
|
55
|
+
...inputProps,
|
|
56
|
+
ref: mergedRef,
|
|
57
|
+
role: "radio",
|
|
58
|
+
onPressIn: composeEventHandlers(onPressIn, pressProps.onPressIn),
|
|
59
|
+
onPressOut: composeEventHandlers(onPressOut, pressProps.onPressOut),
|
|
60
|
+
onHoverIn: composeEventHandlers(onHoverIn, hoverProps.onHoverIn),
|
|
61
|
+
onHoverOut: composeEventHandlers(onHoverOut, hoverProps.onHoverOut),
|
|
62
|
+
onFocus: composeEventHandlers(onFocus, focusProps.onFocus),
|
|
63
|
+
onBlur: composeEventHandlers(onBlur, focusProps.onBlur),
|
|
64
|
+
...dataAttributes({
|
|
65
|
+
slot: 'radio',
|
|
66
|
+
checked: isChecked,
|
|
67
|
+
disabled: isDisabled || isDisabledProp,
|
|
68
|
+
hover: isHovered || isHoveredProp,
|
|
69
|
+
invalid: isInvalid || isInvalidProp,
|
|
70
|
+
readonly: isReadOnly || isReadOnlyProp,
|
|
71
|
+
active: isPressed,
|
|
72
|
+
focus: isFocused,
|
|
73
|
+
focusVisible: isFocusVisible
|
|
74
|
+
}),
|
|
75
|
+
children: /*#__PURE__*/_jsxs(RadioProvider, {
|
|
76
|
+
value: {
|
|
77
|
+
isChecked,
|
|
78
|
+
isDisabled: isDisabled || isDisabledProp,
|
|
79
|
+
isHovered: isHovered || isHoveredProp,
|
|
80
|
+
isInvalid: isInvalid || isInvalidProp,
|
|
81
|
+
isReadOnly: isReadOnly || isReadOnlyProp,
|
|
82
|
+
isPressed: isPressed || isPressedProp,
|
|
83
|
+
isFocused: isFocused || isFocusedProp,
|
|
84
|
+
isFocusVisible
|
|
85
|
+
},
|
|
86
|
+
children: [/*#__PURE__*/_jsx(RadioIndicator, {}), children]
|
|
87
|
+
})
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
//# sourceMappingURL=createRadioRoot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["forwardRef","composeEventHandlers","useFocus","usePress","dataAttributes","RadioProvider","useRadioRoot","jsx","_jsx","jsxs","_jsxs","createRadioRoot","BaseRadio","RadioIndicator","onPressIn","onPressOut","onHoverIn","onHoverOut","onFocus","onBlur","children","props","ref","isHovered","isHoveredProp","isDisabled","isDisabledProp","isInvalid","isInvalidProp","isReadOnly","isReadOnlyProp","isPressed","isPressedProp","isFocused","isFocusedProp","isFocusVisible","combinedProps","inputProps","isChecked","hoverProps","mergedRef","focusProps","pressProps","disabled","role","slot","checked","hover","invalid","readonly","active","focus","focusVisible","value"],"sourceRoot":"../../../src","sources":["radio/createRadioRoot.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { forwardRef } from 'react';
|
|
4
|
+
import { VisuallyHidden } from '@react-aria/visually-hidden';
|
|
5
|
+
import { mergeProps } from '@react-aria/utils';
|
|
6
|
+
import { useFocusRing } from '@react-native-aria/focus';
|
|
7
|
+
import { dataAttributes } from '../utils/dataAttributes';
|
|
8
|
+
import { RadioProvider } from './context';
|
|
9
|
+
import { useRadioRoot } from './useRadioRoot';
|
|
10
|
+
|
|
11
|
+
// TODO: Keyboard focus is not working as expected
|
|
12
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
13
|
+
export const createRadioRoot = (BaseRadio, RadioIndicator) => /*#__PURE__*/forwardRef(({
|
|
14
|
+
children,
|
|
15
|
+
...props
|
|
16
|
+
}, ref) => {
|
|
17
|
+
const {
|
|
18
|
+
isHovered: isHoveredProp,
|
|
19
|
+
isFocusVisible: isFocusVisibleProp,
|
|
20
|
+
isDisabled: isDisabledProp,
|
|
21
|
+
isInvalid: isInvalidProp,
|
|
22
|
+
isReadOnly: isReadOnlyProp,
|
|
23
|
+
isFocused,
|
|
24
|
+
isPressed
|
|
25
|
+
} = props;
|
|
26
|
+
const {
|
|
27
|
+
combinedProps,
|
|
28
|
+
isInvalid,
|
|
29
|
+
isReadOnly,
|
|
30
|
+
inputProps,
|
|
31
|
+
labelProps,
|
|
32
|
+
isChecked,
|
|
33
|
+
isDisabled,
|
|
34
|
+
isHovered,
|
|
35
|
+
mergedRef,
|
|
36
|
+
inputRef
|
|
37
|
+
} = useRadioRoot(props, ref, {
|
|
38
|
+
useInputRefForAria: true
|
|
39
|
+
});
|
|
40
|
+
const {
|
|
41
|
+
focusProps,
|
|
42
|
+
isFocusVisible
|
|
43
|
+
} = useFocusRing();
|
|
44
|
+
return /*#__PURE__*/_jsx(BaseRadio, {
|
|
45
|
+
...mergeProps(combinedProps, labelProps, focusProps),
|
|
46
|
+
ref: mergedRef,
|
|
47
|
+
role: "label"
|
|
48
|
+
// eslint-disable-next-line react-native-a11y/has-valid-accessibility-role
|
|
49
|
+
,
|
|
50
|
+
accessibilityRole: "label",
|
|
51
|
+
...dataAttributes({
|
|
52
|
+
slot: 'radio',
|
|
53
|
+
checked: isChecked,
|
|
54
|
+
disabled: isDisabled || isDisabledProp,
|
|
55
|
+
hover: isHovered || isHoveredProp,
|
|
56
|
+
invalid: isInvalid || isInvalidProp,
|
|
57
|
+
readonly: isReadOnly || isReadOnlyProp,
|
|
58
|
+
active: isPressed,
|
|
59
|
+
focus: isFocused,
|
|
60
|
+
focusVisible: isFocusVisible || isFocusVisibleProp
|
|
61
|
+
}),
|
|
62
|
+
children: /*#__PURE__*/_jsxs(RadioProvider, {
|
|
63
|
+
value: {
|
|
64
|
+
isChecked,
|
|
65
|
+
isDisabled: isDisabled || isDisabledProp,
|
|
66
|
+
isFocusVisible: isFocusVisible || isFocusVisibleProp,
|
|
67
|
+
isHovered: isHovered || isHoveredProp,
|
|
68
|
+
isInvalid: isInvalid || isInvalidProp,
|
|
69
|
+
isReadOnly: isReadOnly || isReadOnlyProp,
|
|
70
|
+
isPressed,
|
|
71
|
+
isFocused
|
|
72
|
+
},
|
|
73
|
+
children: [/*#__PURE__*/_jsx(VisuallyHidden, {
|
|
74
|
+
children: /*#__PURE__*/_jsx("input", {
|
|
75
|
+
...inputProps,
|
|
76
|
+
ref: inputRef
|
|
77
|
+
})
|
|
78
|
+
}), /*#__PURE__*/_jsx(RadioIndicator, {}), children]
|
|
79
|
+
})
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
//# sourceMappingURL=createRadioRoot.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["forwardRef","VisuallyHidden","mergeProps","useFocusRing","dataAttributes","RadioProvider","useRadioRoot","jsx","_jsx","jsxs","_jsxs","createRadioRoot","BaseRadio","RadioIndicator","children","props","ref","isHovered","isHoveredProp","isFocusVisible","isFocusVisibleProp","isDisabled","isDisabledProp","isInvalid","isInvalidProp","isReadOnly","isReadOnlyProp","isFocused","isPressed","combinedProps","inputProps","labelProps","isChecked","mergedRef","inputRef","useInputRefForAria","focusProps","role","accessibilityRole","slot","checked","disabled","hover","invalid","readonly","active","focus","focusVisible","value"],"sourceRoot":"../../../src","sources":["radio/createRadioRoot.web.tsx"],"mappings":";;AAAA,SAASA,UAAU,QAAQ,OAAO;AAClC,SAASC,cAAc,QAAQ,6BAA6B;AAC5D,SAASC,UAAU,QAAQ,mBAAmB;AAC9C,SAASC,YAAY,QAAQ,0BAA0B;AACvD,SAASC,cAAc,QAAQ,yBAAyB;AACxD,SAASC,aAAa,QAAQ,WAAW;AAEzC,SAASC,YAAY,QAAQ,gBAAgB;;AAE7C;AAAA,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAEA,OAAO,MAAMC,eAAe,GAAGA,CAC7BC,SAAiC,EACjCC,cAAwC,kBAExCb,UAAU,CAAC,CAAC;EAAEc,QAAQ;EAAE,GAAGC;AAAmB,CAAC,EAAEC,GAAkB,KAAK;EACtE,MAAM;IACJC,SAAS,EAAEC,aAAa;IACxBC,cAAc,EAAEC,kBAAkB;IAClCC,UAAU,EAAEC,cAAc;IAC1BC,SAAS,EAAEC,aAAa;IACxBC,UAAU,EAAEC,cAAc;IAC1BC,SAAS;IACTC;EACF,CAAC,GAAGb,KAAK;EAET,MAAM;IACJc,aAAa;IACbN,SAAS;IACTE,UAAU;IACVK,UAAU;IACVC,UAAU;IACVC,SAAS;IACTX,UAAU;IACVJ,SAAS;IACTgB,SAAS;IACTC;EACF,CAAC,GAAG5B,YAAY,CAACS,KAAK,EAAEC,GAAG,EAAE;IAAEmB,kBAAkB,EAAE;EAAK,CAAC,CAAC;EAE1D,MAAM;IAAEC,UAAU;IAAEjB;EAAe,CAAC,GAAGhB,YAAY,CAAC,CAAC;EAErD,oBACEK,IAAA,CAACI,SAAS;IAAA,GACJV,UAAU,CAAC2B,aAAa,EAASE,UAAU,EAASK,UAAiB,CAAC;IAC1EpB,GAAG,EAAEiB,SAAU;IACfI,IAAI,EAAC;IACL;IAAA;IACAC,iBAAiB,EAAC,OAAO;IAAA,GACrBlC,cAAc,CAAC;MACjBmC,IAAI,EAAE,OAAO;MACbC,OAAO,EAAER,SAAS;MAClBS,QAAQ,EAAEpB,UAAU,IAAIC,cAAc;MACtCoB,KAAK,EAAEzB,SAAS,IAAIC,aAAa;MACjCyB,OAAO,EAAEpB,SAAS,IAAIC,aAAa;MACnCoB,QAAQ,EAAEnB,UAAU,IAAIC,cAAc;MACtCmB,MAAM,EAAEjB,SAAS;MACjBkB,KAAK,EAAEnB,SAAS;MAChBoB,YAAY,EAAE5B,cAAc,IAAIC;IAClC,CAAC,CAAC;IAAAN,QAAA,eAEFJ,KAAA,CAACL,aAAa;MACZ2C,KAAK,EAAE;QACLhB,SAAS;QACTX,UAAU,EAAEA,UAAU,IAAIC,cAAc;QACxCH,cAAc,EAAEA,cAAc,IAAIC,kBAAkB;QACpDH,SAAS,EAAEA,SAAS,IAAIC,aAAa;QACrCK,SAAS,EAAEA,SAAS,IAAIC,aAAa;QACrCC,UAAU,EAAEA,UAAU,IAAIC,cAAc;QACxCE,SAAS;QACTD;MACF,CAAE;MAAAb,QAAA,gBAEFN,IAAA,CAACP,cAAc;QAAAa,QAAA,eACbN,IAAA;UAAA,GAAWsB,UAAU;UAAEd,GAAG,EAAEkB;QAAS,CAAE;MAAC,CAC1B,CAAC,eACjB1B,IAAA,CAACK,cAAc,IAAE,CAAC,EACjBC,QAAQ;IAAA,CACI;EAAC,CACP,CAAC;AAEhB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { createRadioGroup } from './createRadioGroup';
|
|
4
|
+
import { createRadioIndicator } from './createRadioIndicator';
|
|
5
|
+
import { createRadioLabel } from './createRadioLabel';
|
|
6
|
+
import { createRadioRoot } from './createRadioRoot';
|
|
7
|
+
export function createRadio(BaseComponents) {
|
|
8
|
+
const Indicator = createRadioIndicator(BaseComponents.Indicator);
|
|
9
|
+
const Radio = createRadioRoot(BaseComponents.Root, Indicator);
|
|
10
|
+
const Label = createRadioLabel(BaseComponents.Label);
|
|
11
|
+
const Group = createRadioGroup(BaseComponents.Group);
|
|
12
|
+
Radio.displayName = 'RadioPrimitive';
|
|
13
|
+
Indicator.displayName = 'RadioPrimitive.Indicator';
|
|
14
|
+
Label.displayName = 'RadioPrimitive.Label';
|
|
15
|
+
Group.displayName = 'RadioPrimitive.Group';
|
|
16
|
+
return Object.assign(Radio, {
|
|
17
|
+
Indicator,
|
|
18
|
+
Label,
|
|
19
|
+
Group
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createRadioGroup","createRadioIndicator","createRadioLabel","createRadioRoot","createRadio","BaseComponents","Indicator","Radio","Root","Label","Group","displayName","Object","assign"],"sourceRoot":"../../../src","sources":["radio/index.ts"],"mappings":";;AACA,SAASA,gBAAgB,QAAQ,oBAAoB;AACrD,SAASC,oBAAoB,QAAQ,wBAAwB;AAC7D,SAASC,gBAAgB,QAAQ,oBAAoB;AACrD,SAASC,eAAe,QAAQ,mBAAmB;AAWnD,OAAO,SAASC,WAAWA,CAAgCC,cAK1D,EAAE;EACD,MAAMC,SAAS,GAAGL,oBAAoB,CAACI,cAAc,CAACC,SAAS,CAAC;EAChE,MAAMC,KAAK,GAAGJ,eAAe,CAACE,cAAc,CAACG,IAAI,EAAEF,SAAS,CAAC;EAC7D,MAAMG,KAAK,GAAGP,gBAAgB,CAACG,cAAc,CAACI,KAAK,CAAC;EACpD,MAAMC,KAAK,GAAGV,gBAAgB,CAACK,cAAc,CAACK,KAAK,CAAC;EAEpDH,KAAK,CAACI,WAAW,GAAG,gBAAgB;EACpCL,SAAS,CAACK,WAAW,GAAG,0BAA0B;EAClDF,KAAK,CAACE,WAAW,GAAG,sBAAsB;EAC1CD,KAAK,CAACC,WAAW,GAAG,sBAAsB;EAE1C,OAAOC,MAAM,CAACC,MAAM,CAACN,KAAK,EAAE;IAC1BD,SAAS;IACTG,KAAK;IACLC;EACF,CAAC,CAAC;AACJ","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["radio/types.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { useContext, useRef } from 'react';
|
|
4
|
+
import { mergeRefs, useFormControlContext } from '@cdx-ui/utils';
|
|
5
|
+
import { useRadio } from '@react-native-aria/radio';
|
|
6
|
+
import { useHover } from '@react-native-aria/interactions';
|
|
7
|
+
import { RadioGroupContext } from './context';
|
|
8
|
+
export function useRadioRoot(props, ref, {
|
|
9
|
+
useInputRefForAria = false
|
|
10
|
+
} = {}) {
|
|
11
|
+
const formControlContext = useFormControlContext();
|
|
12
|
+
const {
|
|
13
|
+
isInvalid,
|
|
14
|
+
isReadOnly,
|
|
15
|
+
...combinedProps
|
|
16
|
+
} = {
|
|
17
|
+
...formControlContext,
|
|
18
|
+
...props
|
|
19
|
+
};
|
|
20
|
+
const radioGroupContext = useContext(RadioGroupContext);
|
|
21
|
+
if (!radioGroupContext) {
|
|
22
|
+
throw new Error('Radio must be rendered inside a Radio.Group. Standalone Radio is not supported.');
|
|
23
|
+
}
|
|
24
|
+
const rootRef = useRef(null);
|
|
25
|
+
const inputRef = useRef(null);
|
|
26
|
+
const mergedRootRef = mergeRefs(ref, rootRef);
|
|
27
|
+
const ariaLabel = combinedProps['aria-label'] || combinedProps.value || 'Radio';
|
|
28
|
+
const radio = useRadio({
|
|
29
|
+
...combinedProps,
|
|
30
|
+
'aria-label': ariaLabel,
|
|
31
|
+
isReadOnly: isReadOnly || radioGroupContext.state.isReadOnly,
|
|
32
|
+
isDisabled: combinedProps.isDisabled || radioGroupContext.state.isDisabled
|
|
33
|
+
}, radioGroupContext.radioGroupState, useInputRefForAria ? inputRef : rootRef);
|
|
34
|
+
const {
|
|
35
|
+
inputProps,
|
|
36
|
+
labelProps
|
|
37
|
+
} = radio;
|
|
38
|
+
const {
|
|
39
|
+
checked: isChecked,
|
|
40
|
+
disabled: isDisabled
|
|
41
|
+
} = inputProps;
|
|
42
|
+
const {
|
|
43
|
+
hoverProps,
|
|
44
|
+
isHovered
|
|
45
|
+
} = useHover({}, rootRef);
|
|
46
|
+
return {
|
|
47
|
+
combinedProps,
|
|
48
|
+
isInvalid: isInvalid || radioGroupContext.state.isInvalid,
|
|
49
|
+
isReadOnly: isReadOnly || radioGroupContext.state.isReadOnly,
|
|
50
|
+
inputProps,
|
|
51
|
+
labelProps: labelProps ?? {},
|
|
52
|
+
isChecked,
|
|
53
|
+
isDisabled,
|
|
54
|
+
isHovered,
|
|
55
|
+
hoverProps,
|
|
56
|
+
mergedRef: mergedRootRef,
|
|
57
|
+
inputRef
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=useRadioRoot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useContext","useRef","mergeRefs","useFormControlContext","useRadio","useHover","RadioGroupContext","useRadioRoot","props","ref","useInputRefForAria","formControlContext","isInvalid","isReadOnly","combinedProps","radioGroupContext","Error","rootRef","inputRef","mergedRootRef","ariaLabel","value","radio","state","isDisabled","radioGroupState","inputProps","labelProps","checked","isChecked","disabled","hoverProps","isHovered","mergedRef"],"sourceRoot":"../../../src","sources":["radio/useRadioRoot.ts"],"mappings":";;AAAA,SAASA,UAAU,EAAEC,MAAM,QAAQ,OAAO;AAC1C,SAASC,SAAS,EAAEC,qBAAqB,QAAQ,eAAe;AAChE,SAASC,QAAQ,QAAQ,0BAA0B;AACnD,SAASC,QAAQ,QAAQ,iCAAiC;AAC1D,SAASC,iBAAiB,QAAQ,WAAW;AAO7C,OAAO,SAASC,YAAYA,CAC1BC,KAAkB,EAClBC,GAAwB,EACxB;EAAEC,kBAAkB,GAAG;AAA2B,CAAC,GAAG,CAAC,CAAC,EACxD;EACA,MAAMC,kBAAkB,GAAGR,qBAAqB,CAAC,CAAC;EAElD,MAAM;IAAES,SAAS;IAAEC,UAAU;IAAE,GAAGC;EAAc,CAAC,GAAG;IAClD,GAAGH,kBAAkB;IACrB,GAAGH;EACL,CAAC;EAED,MAAMO,iBAAiB,GAAGf,UAAU,CAACM,iBAAiB,CAAC;EAEvD,IAAI,CAACS,iBAAiB,EAAE;IACtB,MAAM,IAAIC,KAAK,CACb,iFACF,CAAC;EACH;EAEA,MAAMC,OAAO,GAAGhB,MAAM,CAAC,IAAI,CAAC;EAC5B,MAAMiB,QAAQ,GAAGjB,MAAM,CAA0B,IAAI,CAAC;EACtD,MAAMkB,aAAa,GAAGjB,SAAS,CAACO,GAAG,EAASQ,OAAc,CAAC;EAC3D,MAAMG,SAAS,GAAGN,aAAa,CAAC,YAAY,CAAC,IAAIA,aAAa,CAACO,KAAK,IAAI,OAAO;EAE/E,MAAMC,KAAK,GAAGlB,QAAQ,CACpB;IACE,GAAGU,aAAa;IAChB,YAAY,EAAEM,SAAS;IACvBP,UAAU,EAAEA,UAAU,IAAIE,iBAAiB,CAACQ,KAAK,CAACV,UAAU;IAC5DW,UAAU,EAAEV,aAAa,CAACU,UAAU,IAAIT,iBAAiB,CAACQ,KAAK,CAACC;EAClE,CAAC,EACDT,iBAAiB,CAACU,eAAe,EAChCf,kBAAkB,GAAGQ,QAAQ,GAAGD,OACnC,CAAC;EAED,MAAM;IAAES,UAAU;IAAEC;EAAW,CAAC,GAAGL,KAElC;EAED,MAAM;IAAEM,OAAO,EAAEC,SAAS;IAAEC,QAAQ,EAAEN;EAAW,CAAC,GAAGE,UAAU;EAE/D,MAAM;IAAEK,UAAU;IAAEC;EAAU,CAAC,GAAG3B,QAAQ,CAAC,CAAC,CAAC,EAAEY,OAAO,CAAC;EAEvD,OAAO;IACLH,aAAa;IACbF,SAAS,EAAEA,SAAS,IAAIG,iBAAiB,CAACQ,KAAK,CAACX,SAAS;IACzDC,UAAU,EAAEA,UAAU,IAAIE,iBAAiB,CAACQ,KAAK,CAACV,UAAU;IAC5Da,UAAU;IACVC,UAAU,EAAEA,UAAU,IAAI,CAAC,CAAC;IAC5BE,SAAS;IACTL,UAAU;IACVQ,SAAS;IACTD,UAAU;IACVE,SAAS,EAAEd,aAAa;IACxBD;EACF,CAAC;AACH","ignoreList":[]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import { forwardRef, useCallback, useLayoutEffect, useMemo, useRef } from 'react';
|
|
3
|
+
import { forwardRef, useCallback, useLayoutEffect, useMemo, useRef, useState } from 'react';
|
|
4
4
|
import { Platform } from 'react-native';
|
|
5
|
-
import { composeEventHandlers, mergeRefs, useFormControlContext } from '@cdx-ui/utils';
|
|
5
|
+
import { composeEventHandlers, mergeRefs, useFormControlContext, useReportFormControlLabelFocus } from '@cdx-ui/utils';
|
|
6
6
|
import { useFocus, useFocusRing } from '@react-native-aria/focus';
|
|
7
7
|
import { useHover, usePress } from '@react-native-aria/interactions';
|
|
8
8
|
import { dataAttributes } from '../utils/dataAttributes';
|
|
@@ -52,6 +52,7 @@ export const createSelectTrigger = BaseTrigger => /*#__PURE__*/forwardRef(({
|
|
|
52
52
|
isHovered,
|
|
53
53
|
hoverProps
|
|
54
54
|
} = useHover();
|
|
55
|
+
const [triggerFocused, setTriggerFocused] = useState(false);
|
|
55
56
|
const handlePress = useCallback(e => {
|
|
56
57
|
if (e?.type === 'keyup' && e.key === 'Enter') {
|
|
57
58
|
return;
|
|
@@ -76,13 +77,25 @@ export const createSelectTrigger = BaseTrigger => /*#__PURE__*/forwardRef(({
|
|
|
76
77
|
}
|
|
77
78
|
}
|
|
78
79
|
}, [disabled, setOpen]);
|
|
80
|
+
|
|
81
|
+
// `useFocus()` on Pressable can stay true on native after blur; use explicit focus/blur handlers.
|
|
82
|
+
const isLabelActive = Platform.select({
|
|
83
|
+
web: Boolean((isFocusedProp || isFocused || open) && !disabled),
|
|
84
|
+
default: Boolean((open || triggerFocused) && !disabled)
|
|
85
|
+
});
|
|
86
|
+
useReportFormControlLabelFocus(isLabelActive);
|
|
87
|
+
useLayoutEffect(() => {
|
|
88
|
+
if (!open) {
|
|
89
|
+
setTriggerFocused(false);
|
|
90
|
+
}
|
|
91
|
+
}, [open]);
|
|
79
92
|
const interactionState = useMemo(() => ({
|
|
80
93
|
hover: isHoveredProp || isHovered,
|
|
81
|
-
focus: isFocusedProp || isFocused,
|
|
94
|
+
focus: isFocusedProp || isFocused || open,
|
|
82
95
|
active: isActiveProp || isActive,
|
|
83
96
|
disabled: !!disabled,
|
|
84
97
|
focusVisible: isFocusVisibleProp || isFocusVisible
|
|
85
|
-
}), [isHoveredProp, isHovered, isFocusedProp, isFocused, isActiveProp, isActive, disabled, isFocusVisibleProp, isFocusVisible]);
|
|
98
|
+
}), [isHoveredProp, isHovered, isFocusedProp, isFocused, isActiveProp, isActive, disabled, isFocusVisibleProp, isFocusVisible, open]);
|
|
86
99
|
|
|
87
100
|
/**
|
|
88
101
|
* Native: `Pressable` has no usable programmatic `.focus()` (unlike `TextInput`).
|
|
@@ -164,8 +177,8 @@ export const createSelectTrigger = BaseTrigger => /*#__PURE__*/forwardRef(({
|
|
|
164
177
|
onPressOut: composeEventHandlers(props?.onPressOut, pressProps.onPressOut),
|
|
165
178
|
onHoverIn: composeEventHandlers(props?.onHoverIn, hoverProps.onHoverIn),
|
|
166
179
|
onHoverOut: composeEventHandlers(props?.onHoverOut, hoverProps.onHoverOut),
|
|
167
|
-
onFocus: composeEventHandlers(composeEventHandlers(props?.onFocus, focusProps.onFocus), focusRingProps.onFocus),
|
|
168
|
-
onBlur: composeEventHandlers(composeEventHandlers(props?.onBlur, focusProps.onBlur), focusRingProps.onBlur),
|
|
180
|
+
onFocus: composeEventHandlers(composeEventHandlers(props?.onFocus, focusProps.onFocus), focusRingProps.onFocus, () => setTriggerFocused(true)),
|
|
181
|
+
onBlur: composeEventHandlers(composeEventHandlers(props?.onBlur, focusProps.onBlur), focusRingProps.onBlur, () => setTriggerFocused(false)),
|
|
169
182
|
...webKeyboardProps,
|
|
170
183
|
children: typeof children === 'function' ? children(interactionState) : children
|
|
171
184
|
})
|