@radix-ui/react-label 0.1.5-rc.10 → 0.1.5-rc.14

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/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- var e,r,t,n=require("@radix-ui/react-id").useId,l=require("@radix-ui/react-primitive").Primitive,u=require("@radix-ui/react-compose-refs").useComposedRefs,o=require("@radix-ui/react-context").createContext,i=(e={},r=require("react"),Object.keys(r).forEach((function(t){"default"!==t&&"__esModule"!==t&&Object.defineProperty(e,t,{enumerable:!0,get:function(){return r[t]}})})),e),a=(t=require("@babel/runtime/helpers/extends"))&&t.__esModule?t.default:t;const[c,s]=o("Label",{id:void 0,controlRef:{current:null}}),d=/*#__PURE__*/i.forwardRef(((e,r)=>{const{htmlFor:t,id:o,...s}=e,d=i.useRef(null),f=i.useRef(null),b=u(r,f),v=n(o);return i.useEffect((()=>{if(t){const e=document.getElementById(t);if(f.current&&e){const r=()=>e.getAttribute("aria-labelledby"),t=[r(),v].filter(Boolean).join(" ");return e.setAttribute("aria-labelledby",t),d.current=e,()=>{var t;const n=null===(t=r())||void 0===t?void 0:t.replace(v,"");""===n?e.removeAttribute("aria-labelledby"):n&&e.setAttribute("aria-labelledby",n)}}}}),[v,t]),/*#__PURE__*/i.createElement(c,{id:v,controlRef:d},/*#__PURE__*/i.createElement(l.span,a({role:"label",id:v},s,{ref:b,onMouseDown:r=>{var t;null===(t=e.onMouseDown)||void 0===t||t.call(e,r),!r.defaultPrevented&&r.detail>1&&r.preventDefault()},onClick:r=>{var t;if(null===(t=e.onClick)||void 0===t||t.call(e,r),!d.current||r.defaultPrevented)return;const n=d.current.contains(r.target),l=!0===r.isTrusted;!n&&l&&(d.current.click(),d.current.focus())}})))}));exports.Label=d;exports.useLabelContext=e=>{const r=s("LabelConsumer"),{controlRef:t}=r;return i.useEffect((()=>{e&&(t.current=e)}),[e,t]),r.id};const f=d;exports.Root=f;
1
+ var e,r,t,n=require("@radix-ui/react-id").useId,l=require("@radix-ui/react-primitive").Primitive,u=require("@radix-ui/react-compose-refs").useComposedRefs,o=require("@radix-ui/react-context").createContext,i=(e={},r=require("react"),Object.keys(r).forEach((function(t){"default"!==t&&"__esModule"!==t&&Object.defineProperty(e,t,{enumerable:!0,get:function(){return r[t]}})})),e),a=(t=require("@babel/runtime/helpers/extends"))&&t.__esModule?t.default:t;const[c,s]=o("Label",{id:void 0,controlRef:{current:null}}),d=/*#__PURE__*/i.forwardRef(((e,r)=>{const{htmlFor:t,id:o,...s}=e,d=i.useRef(null),f=i.useRef(null),b=u(r,f),v=n(o);return i.useEffect((()=>{if(t){const e=document.getElementById(t);if(f.current&&e){const r=()=>e.getAttribute("aria-labelledby"),t=[v,r()].filter(Boolean).join(" ");return e.setAttribute("aria-labelledby",t),d.current=e,()=>{var t;const n=null===(t=r())||void 0===t?void 0:t.replace(v,"");""===n?e.removeAttribute("aria-labelledby"):n&&e.setAttribute("aria-labelledby",n)}}}}),[v,t]),/*#__PURE__*/i.createElement(c,{id:v,controlRef:d},/*#__PURE__*/i.createElement(l.span,a({role:"label",id:v},s,{ref:b,onMouseDown:r=>{var t;null===(t=e.onMouseDown)||void 0===t||t.call(e,r),!r.defaultPrevented&&r.detail>1&&r.preventDefault()},onClick:r=>{var t;if(null===(t=e.onClick)||void 0===t||t.call(e,r),!d.current||r.defaultPrevented)return;const n=d.current.contains(r.target),l=!0===r.isTrusted;!n&&l&&(d.current.click(),d.current.focus())}})))}));exports.Label=d;exports.useLabelContext=e=>{const r=s("LabelConsumer"),{controlRef:t}=r;return i.useEffect((()=>{e&&(t.current=e)}),[e,t]),r.id};const f=d;exports.Root=f;
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"mappings":"IAYgCA,EAAMC,EAZNC,yMAYAF,KAAMC,mBACpCE,OAAOC,KAAKH,GAAQI,SAAQ,SAASC,GACvB,YAARA,GAA6B,eAARA,GAIzBH,OAAOI,eAAeP,EAAMM,EAAK,CAC/BE,YAAY,EACZC,IAAK,WACH,OAAOR,EAAOK,SAKbN,MA1BuBE,8CAClBA,EAAEQ,WAAaR,EAAES,QAAUT,ECWzC,MAGOU,EAAeC,GAAuBC,EAHhC,QAGuE,CAClFC,QAAIC,EACJC,WAAY,CAAEC,QAAS,QASnBC,eAAQC,EAAMC,YAAqC,CAACC,EAAOC,KAC/D,MAAMC,QAAEA,EAAST,GAAIU,KAAWC,GAAeJ,EACzCL,EAAaG,EAAMO,OAA2B,MAC9CC,EAAMR,EAAMO,OAAwB,MACpCE,EAAeC,EAAgBP,EAAcK,GAC7Cb,EAAKgB,EAAMN,GA2BjB,OAzBAL,EAAMY,WAAU,KACd,GAAIR,EAAS,CACX,MAAMS,EAAUC,SAASC,eAAeX,GAExC,GADcI,EAAIV,SACLe,EAAS,CACpB,MAAMG,EAAe,IAAMH,EAAQI,aAAa,mBAC1CC,EAAiB,CAACF,IAAgBrB,GAAIwB,OAAOC,SAASC,KAAK,KAGjE,OAFAR,EAAQS,aAAa,kBAAmBJ,GACxCrB,EAAWC,QAAUe,EACd,KAAM,IAAAU,EAKX,MAAML,EAAc,QAAAK,EAAGP,WAAH,IAAAO,OAAA,EAAGA,EAAgBC,QAAQ7B,EAAI,IAC5B,KAAnBuB,EACFL,EAAQY,gBAAgB,mBACfP,GACTL,EAAQS,aAAa,kBAAmBJ,QAK/C,CAACvB,EAAIS,iBAGNsB,EAAAC,cAACC,EAAD,CAAejC,GAAIA,EAAIE,WAAYA,gBACjC6B,EAAAC,cAACE,EAAUC,KAAXC,EAAA,CACEC,KAAK,QACLrC,GAAIA,GACAW,EAHN,CAIEE,IAAKC,EACLwB,YAAcC,IAAU,IAAAC,EACtB,QAAAA,EAAAjC,EAAM+B,mBAAN,IAAAE,GAAAA,EAAAC,KAAAlC,EAAoBgC,IAEfA,EAAMG,kBAAoBH,EAAMI,OAAS,GAAGJ,EAAMK,kBAEzDC,QAAUN,IAAU,IAAAO,EAElB,GADA,QAAAA,EAAAvC,EAAMsC,eAAN,IAAAC,GAAAA,EAAAL,KAAAlC,EAAgBgC,IACXrC,EAAWC,SAAWoC,EAAMG,iBAAkB,OACnD,MAAMK,EAAoB7C,EAAWC,QAAQ6C,SAAST,EAAMU,QAGtDC,GAAkC,IAApBX,EAAMY,WAMrBJ,GAAqBG,IACxBhD,EAAWC,QAAQiD,QACnBlD,EAAWC,QAAQkD,yDAYNnC,IACvB,MAAMoC,EAAUxD,EAAoB,kBAC9BI,WAAEA,GAAeoD,EAMvB,OAJAjD,EAAMY,WAAU,KACVC,IAAShB,EAAWC,QAAUe,KACjC,CAACA,EAAShB,IAENoD,EAAQtD,IAGjB,MAAMuD,EAAOnD","sources":["./node_modules/@parcel/scope-hoisting/lib/helpers.js","./packages/react/label/src/Label.tsx"],"sourcesContent":["function $parcel$interopDefault(a) {\n return a && a.__esModule ? a.default : a;\n}\n\nfunction $parcel$defineInteropFlag(a) {\n Object.defineProperty(a, '__esModule', {value: true});\n}\n\nfunction $parcel$reexport(e, n, v) {\n Object.defineProperty(e, n, {get: v, enumerable: true});\n}\n\nfunction $parcel$exportWildcard(dest, source) {\n Object.keys(source).forEach(function(key) {\n if (key === 'default' || key === '__esModule') {\n return;\n }\n\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function get() {\n return source[key];\n },\n });\n });\n\n return dest;\n}\n\nfunction $parcel$missingModule(name) {\n var err = new Error(\"Cannot find module '\" + name + \"'\");\n err.code = 'MODULE_NOT_FOUND';\n throw err;\n}\n\nvar $parcel$global =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {};\n","import * as React from 'react';\nimport { createContext } from '@radix-ui/react-context';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { useId } from '@radix-ui/react-id';\n\nimport type * as Radix from '@radix-ui/react-primitive';\n\n/* -------------------------------------------------------------------------------------------------\n * Label\n * -----------------------------------------------------------------------------------------------*/\n\nconst NAME = 'Label';\n\ntype LabelContextValue = { id?: string; controlRef: React.MutableRefObject<HTMLElement | null> };\nconst [LabelProvider, useLabelContextImpl] = createContext<LabelContextValue>(NAME, {\n id: undefined,\n controlRef: { current: null },\n});\n\ntype LabelElement = React.ElementRef<typeof Primitive.span>;\ntype PrimitiveSpanProps = Radix.ComponentPropsWithoutRef<typeof Primitive.span>;\ninterface LabelProps extends PrimitiveSpanProps {\n htmlFor?: string;\n}\n\nconst Label = React.forwardRef<LabelElement, LabelProps>((props, forwardedRef) => {\n const { htmlFor, id: idProp, ...labelProps } = props;\n const controlRef = React.useRef<HTMLElement | null>(null);\n const ref = React.useRef<HTMLSpanElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const id = useId(idProp);\n\n React.useEffect(() => {\n if (htmlFor) {\n const element = document.getElementById(htmlFor);\n const label = ref.current;\n if (label && element) {\n const getAriaLabel = () => element.getAttribute('aria-labelledby');\n const ariaLabelledBy = [getAriaLabel(), id].filter(Boolean).join(' ');\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n controlRef.current = element;\n return () => {\n /**\n * We get the latest attribute value because at the time that this cleanup fires,\n * the values from the closure may have changed.\n */\n const ariaLabelledBy = getAriaLabel()?.replace(id, '');\n if (ariaLabelledBy === '') {\n element.removeAttribute('aria-labelledby');\n } else if (ariaLabelledBy) {\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n }\n };\n }\n }\n }, [id, htmlFor]);\n\n return (\n <LabelProvider id={id} controlRef={controlRef}>\n <Primitive.span\n role=\"label\"\n id={id}\n {...labelProps}\n ref={composedRefs}\n onMouseDown={(event) => {\n props.onMouseDown?.(event);\n // prevent text selection when double clicking label\n if (!event.defaultPrevented && event.detail > 1) event.preventDefault();\n }}\n onClick={(event) => {\n props.onClick?.(event);\n if (!controlRef.current || event.defaultPrevented) return;\n const isClickingControl = controlRef.current.contains(event.target as Node);\n // Ensure event was generated by a user action\n // https://developer.mozilla.org/en-US/docs/Web/API/Event/isTrusted\n const isUserClick = event.isTrusted === true;\n /**\n * When a label is wrapped around the control it labels, we trigger the appropriate events\n * on the control when the label is clicked. We do nothing if the user is already clicking the\n * control inside the label.\n */\n if (!isClickingControl && isUserClick) {\n controlRef.current.click();\n controlRef.current.focus();\n }\n }}\n />\n </LabelProvider>\n );\n});\n\nLabel.displayName = NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst useLabelContext = (element?: HTMLElement | null) => {\n const context = useLabelContextImpl('LabelConsumer');\n const { controlRef } = context;\n\n React.useEffect(() => {\n if (element) controlRef.current = element;\n }, [element, controlRef]);\n\n return context.id;\n};\n\nconst Root = Label;\n\nexport {\n Label,\n //\n Root,\n //\n useLabelContext,\n};\nexport type { LabelProps };\n"],"names":["dest","source","a","Object","keys","forEach","key","defineProperty","enumerable","get","__esModule","default","LabelProvider","useLabelContextImpl","createContext","id","undefined","controlRef","current","Label","React","forwardRef","props","forwardedRef","htmlFor","idProp","labelProps","useRef","ref","composedRefs","useComposedRefs","useId","useEffect","element","document","getElementById","getAriaLabel","getAttribute","ariaLabelledBy","filter","Boolean","join","setAttribute","_getAriaLabel","replace","removeAttribute","_react","createElement","$cc55afdc86a89367fbda1ce67c935ecf$var$LabelProvider","Primitive","span","_babelRuntimeHelpersExtends","role","onMouseDown","event","_props$onMouseDown","call","defaultPrevented","detail","preventDefault","onClick","_props$onClick","isClickingControl","contains","target","isUserClick","isTrusted","click","focus","context","Root"],"version":3,"file":"index.js.map"}
1
+ {"mappings":"IAYgCA,EAAMC,EAZNC,yMAYAF,KAAMC,mBACpCE,OAAOC,KAAKH,GAAQI,SAAQ,SAASC,GACvB,YAARA,GAA6B,eAARA,GAIzBH,OAAOI,eAAeP,EAAMM,EAAK,CAC/BE,YAAY,EACZC,IAAK,WACH,OAAOR,EAAOK,SAKbN,MA1BuBE,8CAClBA,EAAEQ,WAAaR,EAAES,QAAUT,ECWzC,MAGOU,EAAeC,GAAuBC,EAHhC,QAGuE,CAClFC,QAAIC,EACJC,WAAY,CAAEC,QAAS,QASnBC,eAAQC,EAAMC,YAAqC,CAACC,EAAOC,KAC/D,MAAMC,QAAEA,EAAST,GAAIU,KAAWC,GAAeJ,EACzCL,EAAaG,EAAMO,OAA2B,MAC9CC,EAAMR,EAAMO,OAAwB,MACpCE,EAAeC,EAAgBP,EAAcK,GAC7Cb,EAAKgB,EAAMN,GA2BjB,OAzBAL,EAAMY,WAAU,KACd,GAAIR,EAAS,CACX,MAAMS,EAAUC,SAASC,eAAeX,GAExC,GADcI,EAAIV,SACLe,EAAS,CACpB,MAAMG,EAAe,IAAMH,EAAQI,aAAa,mBAC1CC,EAAiB,CAACvB,EAAIqB,KAAgBG,OAAOC,SAASC,KAAK,KAGjE,OAFAR,EAAQS,aAAa,kBAAmBJ,GACxCrB,EAAWC,QAAUe,EACd,KAAM,IAAAU,EAKX,MAAML,EAAc,QAAAK,EAAGP,WAAH,IAAAO,OAAA,EAAGA,EAAgBC,QAAQ7B,EAAI,IAC5B,KAAnBuB,EACFL,EAAQY,gBAAgB,mBACfP,GACTL,EAAQS,aAAa,kBAAmBJ,QAK/C,CAACvB,EAAIS,iBAGNsB,EAAAC,cAACC,EAAD,CAAejC,GAAIA,EAAIE,WAAYA,gBACjC6B,EAAAC,cAACE,EAAUC,KAAXC,EAAA,CACEC,KAAK,QACLrC,GAAIA,GACAW,EAHN,CAIEE,IAAKC,EACLwB,YAAcC,IAAU,IAAAC,EACtB,QAAAA,EAAAjC,EAAM+B,mBAAN,IAAAE,GAAAA,EAAAC,KAAAlC,EAAoBgC,IAEfA,EAAMG,kBAAoBH,EAAMI,OAAS,GAAGJ,EAAMK,kBAEzDC,QAAUN,IAAU,IAAAO,EAElB,GADA,QAAAA,EAAAvC,EAAMsC,eAAN,IAAAC,GAAAA,EAAAL,KAAAlC,EAAgBgC,IACXrC,EAAWC,SAAWoC,EAAMG,iBAAkB,OACnD,MAAMK,EAAoB7C,EAAWC,QAAQ6C,SAAST,EAAMU,QAGtDC,GAAkC,IAApBX,EAAMY,WAMrBJ,GAAqBG,IACxBhD,EAAWC,QAAQiD,QACnBlD,EAAWC,QAAQkD,yDAYNnC,IACvB,MAAMoC,EAAUxD,EAAoB,kBAC9BI,WAAEA,GAAeoD,EAMvB,OAJAjD,EAAMY,WAAU,KACVC,IAAShB,EAAWC,QAAUe,KACjC,CAACA,EAAShB,IAENoD,EAAQtD,IAGjB,MAAMuD,EAAOnD","sources":["./node_modules/@parcel/scope-hoisting/lib/helpers.js","./packages/react/label/src/Label.tsx"],"sourcesContent":["function $parcel$interopDefault(a) {\n return a && a.__esModule ? a.default : a;\n}\n\nfunction $parcel$defineInteropFlag(a) {\n Object.defineProperty(a, '__esModule', {value: true});\n}\n\nfunction $parcel$reexport(e, n, v) {\n Object.defineProperty(e, n, {get: v, enumerable: true});\n}\n\nfunction $parcel$exportWildcard(dest, source) {\n Object.keys(source).forEach(function(key) {\n if (key === 'default' || key === '__esModule') {\n return;\n }\n\n Object.defineProperty(dest, key, {\n enumerable: true,\n get: function get() {\n return source[key];\n },\n });\n });\n\n return dest;\n}\n\nfunction $parcel$missingModule(name) {\n var err = new Error(\"Cannot find module '\" + name + \"'\");\n err.code = 'MODULE_NOT_FOUND';\n throw err;\n}\n\nvar $parcel$global =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : {};\n","import * as React from 'react';\nimport { createContext } from '@radix-ui/react-context';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { useId } from '@radix-ui/react-id';\n\nimport type * as Radix from '@radix-ui/react-primitive';\n\n/* -------------------------------------------------------------------------------------------------\n * Label\n * -----------------------------------------------------------------------------------------------*/\n\nconst NAME = 'Label';\n\ntype LabelContextValue = { id?: string; controlRef: React.MutableRefObject<HTMLElement | null> };\nconst [LabelProvider, useLabelContextImpl] = createContext<LabelContextValue>(NAME, {\n id: undefined,\n controlRef: { current: null },\n});\n\ntype LabelElement = React.ElementRef<typeof Primitive.span>;\ntype PrimitiveSpanProps = Radix.ComponentPropsWithoutRef<typeof Primitive.span>;\ninterface LabelProps extends PrimitiveSpanProps {\n htmlFor?: string;\n}\n\nconst Label = React.forwardRef<LabelElement, LabelProps>((props, forwardedRef) => {\n const { htmlFor, id: idProp, ...labelProps } = props;\n const controlRef = React.useRef<HTMLElement | null>(null);\n const ref = React.useRef<HTMLSpanElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const id = useId(idProp);\n\n React.useEffect(() => {\n if (htmlFor) {\n const element = document.getElementById(htmlFor);\n const label = ref.current;\n if (label && element) {\n const getAriaLabel = () => element.getAttribute('aria-labelledby');\n const ariaLabelledBy = [id, getAriaLabel()].filter(Boolean).join(' ');\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n controlRef.current = element;\n return () => {\n /**\n * We get the latest attribute value because at the time that this cleanup fires,\n * the values from the closure may have changed.\n */\n const ariaLabelledBy = getAriaLabel()?.replace(id, '');\n if (ariaLabelledBy === '') {\n element.removeAttribute('aria-labelledby');\n } else if (ariaLabelledBy) {\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n }\n };\n }\n }\n }, [id, htmlFor]);\n\n return (\n <LabelProvider id={id} controlRef={controlRef}>\n <Primitive.span\n role=\"label\"\n id={id}\n {...labelProps}\n ref={composedRefs}\n onMouseDown={(event) => {\n props.onMouseDown?.(event);\n // prevent text selection when double clicking label\n if (!event.defaultPrevented && event.detail > 1) event.preventDefault();\n }}\n onClick={(event) => {\n props.onClick?.(event);\n if (!controlRef.current || event.defaultPrevented) return;\n const isClickingControl = controlRef.current.contains(event.target as Node);\n // Ensure event was generated by a user action\n // https://developer.mozilla.org/en-US/docs/Web/API/Event/isTrusted\n const isUserClick = event.isTrusted === true;\n /**\n * When a label is wrapped around the control it labels, we trigger the appropriate events\n * on the control when the label is clicked. We do nothing if the user is already clicking the\n * control inside the label.\n */\n if (!isClickingControl && isUserClick) {\n controlRef.current.click();\n controlRef.current.focus();\n }\n }}\n />\n </LabelProvider>\n );\n});\n\nLabel.displayName = NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst useLabelContext = (element?: HTMLElement | null) => {\n const context = useLabelContextImpl('LabelConsumer');\n const { controlRef } = context;\n\n React.useEffect(() => {\n if (element) controlRef.current = element;\n }, [element, controlRef]);\n\n return context.id;\n};\n\nconst Root = Label;\n\nexport {\n Label,\n //\n Root,\n //\n useLabelContext,\n};\nexport type { LabelProps };\n"],"names":["dest","source","a","Object","keys","forEach","key","defineProperty","enumerable","get","__esModule","default","LabelProvider","useLabelContextImpl","createContext","id","undefined","controlRef","current","Label","React","forwardRef","props","forwardedRef","htmlFor","idProp","labelProps","useRef","ref","composedRefs","useComposedRefs","useId","useEffect","element","document","getElementById","getAriaLabel","getAttribute","ariaLabelledBy","filter","Boolean","join","setAttribute","_getAriaLabel","replace","removeAttribute","_react","createElement","$cc55afdc86a89367fbda1ce67c935ecf$var$LabelProvider","Primitive","span","_babelRuntimeHelpersExtends","role","onMouseDown","event","_props$onMouseDown","call","defaultPrevented","detail","preventDefault","onClick","_props$onClick","isClickingControl","contains","target","isUserClick","isTrusted","click","focus","context","Root"],"version":3,"file":"index.js.map"}
@@ -1,2 +1,2 @@
1
- import{useId as e}from"@radix-ui/react-id";import{Primitive as t}from"@radix-ui/react-primitive";import{useComposedRefs as r}from"@radix-ui/react-compose-refs";import{createContext as o}from"@radix-ui/react-context";import*as l from"react";import n from"@babel/runtime/helpers/esm/extends";const[i,a]=o("Label",{id:void 0,controlRef:{current:null}});export const Label=/*#__PURE__*/l.forwardRef(((o,a)=>{const{htmlFor:c,id:u,...s}=o,d=l.useRef(null),f=l.useRef(null),m=r(a,f),b=e(u);return l.useEffect((()=>{if(c){const e=document.getElementById(c);if(f.current&&e){const t=()=>e.getAttribute("aria-labelledby"),r=[t(),b].filter(Boolean).join(" ");return e.setAttribute("aria-labelledby",r),d.current=e,()=>{var r;const o=null===(r=t())||void 0===r?void 0:r.replace(b,"");""===o?e.removeAttribute("aria-labelledby"):o&&e.setAttribute("aria-labelledby",o)}}}}),[b,c]),/*#__PURE__*/l.createElement(i,{id:b,controlRef:d},/*#__PURE__*/l.createElement(t.span,n({role:"label",id:b},s,{ref:m,onMouseDown:e=>{var t;null===(t=o.onMouseDown)||void 0===t||t.call(o,e),!e.defaultPrevented&&e.detail>1&&e.preventDefault()},onClick:e=>{var t;if(null===(t=o.onClick)||void 0===t||t.call(o,e),!d.current||e.defaultPrevented)return;const r=d.current.contains(e.target),l=!0===e.isTrusted;!r&&l&&(d.current.click(),d.current.focus())}})))}));/*#__PURE__*/export const useLabelContext=e=>{const t=a("LabelConsumer"),{controlRef:r}=t;return l.useEffect((()=>{e&&(r.current=e)}),[e,r]),t.id};export const Root=Label;
1
+ import{useId as e}from"@radix-ui/react-id";import{Primitive as t}from"@radix-ui/react-primitive";import{useComposedRefs as r}from"@radix-ui/react-compose-refs";import{createContext as o}from"@radix-ui/react-context";import*as l from"react";import n from"@babel/runtime/helpers/esm/extends";const[i,a]=o("Label",{id:void 0,controlRef:{current:null}});export const Label=/*#__PURE__*/l.forwardRef(((o,a)=>{const{htmlFor:c,id:u,...s}=o,d=l.useRef(null),f=l.useRef(null),m=r(a,f),b=e(u);return l.useEffect((()=>{if(c){const e=document.getElementById(c);if(f.current&&e){const t=()=>e.getAttribute("aria-labelledby"),r=[b,t()].filter(Boolean).join(" ");return e.setAttribute("aria-labelledby",r),d.current=e,()=>{var r;const o=null===(r=t())||void 0===r?void 0:r.replace(b,"");""===o?e.removeAttribute("aria-labelledby"):o&&e.setAttribute("aria-labelledby",o)}}}}),[b,c]),/*#__PURE__*/l.createElement(i,{id:b,controlRef:d},/*#__PURE__*/l.createElement(t.span,n({role:"label",id:b},s,{ref:m,onMouseDown:e=>{var t;null===(t=o.onMouseDown)||void 0===t||t.call(o,e),!e.defaultPrevented&&e.detail>1&&e.preventDefault()},onClick:e=>{var t;if(null===(t=o.onClick)||void 0===t||t.call(o,e),!d.current||e.defaultPrevented)return;const r=d.current.contains(e.target),l=!0===e.isTrusted;!r&&l&&(d.current.click(),d.current.focus())}})))}));/*#__PURE__*/export const useLabelContext=e=>{const t=a("LabelConsumer"),{controlRef:r}=t;return l.useEffect((()=>{e&&(r.current=e)}),[e,r]),t.id};export const Root=Label;
2
2
  //# sourceMappingURL=index.module.js.map
@@ -1 +1 @@
1
- {"mappings":"kSAYA,MAGOA,EAAeC,GAAuBC,EAHhC,QAGuE,CAClFC,QAAIC,EACJC,WAAY,CAAEC,QAAS,eASzB,MAAMC,mBAAQC,EAAMC,YAAqC,CAACC,EAAOC,KAC/D,MAAMC,QAAEA,EAAST,GAAIU,KAAWC,GAAeJ,EACzCL,EAAaG,EAAMO,OAA2B,MAC9CC,EAAMR,EAAMO,OAAwB,MACpCE,EAAeC,EAAgBP,EAAcK,GAC7Cb,EAAKgB,EAAMN,GA2BjB,OAzBAL,EAAMY,WAAU,KACd,GAAIR,EAAS,CACX,MAAMS,EAAUC,SAASC,eAAeX,GAExC,GADcI,EAAIV,SACLe,EAAS,CACpB,MAAMG,EAAe,IAAMH,EAAQI,aAAa,mBAC1CC,EAAiB,CAACF,IAAgBrB,GAAIwB,OAAOC,SAASC,KAAK,KAGjE,OAFAR,EAAQS,aAAa,kBAAmBJ,GACxCrB,EAAWC,QAAUe,EACd,KAAM,IAAAU,EAKX,MAAML,EAAc,QAAAK,EAAGP,WAAH,IAAAO,OAAA,EAAGA,EAAgBC,QAAQ7B,EAAI,IAC5B,KAAnBuB,EACFL,EAAQY,gBAAgB,mBACfP,GACTL,EAAQS,aAAa,kBAAmBJ,QAK/C,CAACvB,EAAIS,iBAGNsB,EAAAC,cAACC,EAAD,CAAejC,GAAIA,EAAIE,WAAYA,gBACjC6B,EAAAC,cAACE,EAAUC,KAAXC,EAAA,CACEC,KAAK,QACLrC,GAAIA,GACAW,EAHN,CAIEE,IAAKC,EACLwB,YAAcC,IAAU,IAAAC,EACtB,QAAAA,EAAAjC,EAAM+B,mBAAN,IAAAE,GAAAA,EAAAC,KAAAlC,EAAoBgC,IAEfA,EAAMG,kBAAoBH,EAAMI,OAAS,GAAGJ,EAAMK,kBAEzDC,QAAUN,IAAU,IAAAO,EAElB,GADA,QAAAA,EAAAvC,EAAMsC,eAAN,IAAAC,GAAAA,EAAAL,KAAAlC,EAAgBgC,IACXrC,EAAWC,SAAWoC,EAAMG,iBAAkB,OACnD,MAAMK,EAAoB7C,EAAWC,QAAQ6C,SAAST,EAAMU,QAGtDC,GAAkC,IAApBX,EAAMY,WAMrBJ,GAAqBG,IACxBhD,EAAWC,QAAQiD,QACnBlD,EAAWC,QAAQkD,qCAY/B,MAAMC,gBAAmBpC,IACvB,MAAMqC,EAAUzD,EAAoB,kBAC9BI,WAAEA,GAAeqD,EAMvB,OAJAlD,EAAMY,WAAU,KACVC,IAAShB,EAAWC,QAAUe,KACjC,CAACA,EAAShB,IAENqD,EAAQvD,WAGjB,MAAMwD,KAAOpD","sources":["./packages/react/label/src/Label.tsx"],"sourcesContent":["import * as React from 'react';\nimport { createContext } from '@radix-ui/react-context';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { useId } from '@radix-ui/react-id';\n\nimport type * as Radix from '@radix-ui/react-primitive';\n\n/* -------------------------------------------------------------------------------------------------\n * Label\n * -----------------------------------------------------------------------------------------------*/\n\nconst NAME = 'Label';\n\ntype LabelContextValue = { id?: string; controlRef: React.MutableRefObject<HTMLElement | null> };\nconst [LabelProvider, useLabelContextImpl] = createContext<LabelContextValue>(NAME, {\n id: undefined,\n controlRef: { current: null },\n});\n\ntype LabelElement = React.ElementRef<typeof Primitive.span>;\ntype PrimitiveSpanProps = Radix.ComponentPropsWithoutRef<typeof Primitive.span>;\ninterface LabelProps extends PrimitiveSpanProps {\n htmlFor?: string;\n}\n\nconst Label = React.forwardRef<LabelElement, LabelProps>((props, forwardedRef) => {\n const { htmlFor, id: idProp, ...labelProps } = props;\n const controlRef = React.useRef<HTMLElement | null>(null);\n const ref = React.useRef<HTMLSpanElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const id = useId(idProp);\n\n React.useEffect(() => {\n if (htmlFor) {\n const element = document.getElementById(htmlFor);\n const label = ref.current;\n if (label && element) {\n const getAriaLabel = () => element.getAttribute('aria-labelledby');\n const ariaLabelledBy = [getAriaLabel(), id].filter(Boolean).join(' ');\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n controlRef.current = element;\n return () => {\n /**\n * We get the latest attribute value because at the time that this cleanup fires,\n * the values from the closure may have changed.\n */\n const ariaLabelledBy = getAriaLabel()?.replace(id, '');\n if (ariaLabelledBy === '') {\n element.removeAttribute('aria-labelledby');\n } else if (ariaLabelledBy) {\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n }\n };\n }\n }\n }, [id, htmlFor]);\n\n return (\n <LabelProvider id={id} controlRef={controlRef}>\n <Primitive.span\n role=\"label\"\n id={id}\n {...labelProps}\n ref={composedRefs}\n onMouseDown={(event) => {\n props.onMouseDown?.(event);\n // prevent text selection when double clicking label\n if (!event.defaultPrevented && event.detail > 1) event.preventDefault();\n }}\n onClick={(event) => {\n props.onClick?.(event);\n if (!controlRef.current || event.defaultPrevented) return;\n const isClickingControl = controlRef.current.contains(event.target as Node);\n // Ensure event was generated by a user action\n // https://developer.mozilla.org/en-US/docs/Web/API/Event/isTrusted\n const isUserClick = event.isTrusted === true;\n /**\n * When a label is wrapped around the control it labels, we trigger the appropriate events\n * on the control when the label is clicked. We do nothing if the user is already clicking the\n * control inside the label.\n */\n if (!isClickingControl && isUserClick) {\n controlRef.current.click();\n controlRef.current.focus();\n }\n }}\n />\n </LabelProvider>\n );\n});\n\nLabel.displayName = NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst useLabelContext = (element?: HTMLElement | null) => {\n const context = useLabelContextImpl('LabelConsumer');\n const { controlRef } = context;\n\n React.useEffect(() => {\n if (element) controlRef.current = element;\n }, [element, controlRef]);\n\n return context.id;\n};\n\nconst Root = Label;\n\nexport {\n Label,\n //\n Root,\n //\n useLabelContext,\n};\nexport type { LabelProps };\n"],"names":["LabelProvider","useLabelContextImpl","createContext","id","undefined","controlRef","current","Label","React","forwardRef","props","forwardedRef","htmlFor","idProp","labelProps","useRef","ref","composedRefs","useComposedRefs","useId","useEffect","element","document","getElementById","getAriaLabel","getAttribute","ariaLabelledBy","filter","Boolean","join","setAttribute","_getAriaLabel","replace","removeAttribute","_react","createElement","$b835b8b6a05acdec720aee4b37e4b65c$var$LabelProvider","Primitive","span","_babelRuntimeHelpersEsmExtends","role","onMouseDown","event","_props$onMouseDown","call","defaultPrevented","detail","preventDefault","onClick","_props$onClick","isClickingControl","contains","target","isUserClick","isTrusted","click","focus","useLabelContext","context","Root"],"version":3,"file":"index.module.js.map"}
1
+ {"mappings":"kSAYA,MAGOA,EAAeC,GAAuBC,EAHhC,QAGuE,CAClFC,QAAIC,EACJC,WAAY,CAAEC,QAAS,eASzB,MAAMC,mBAAQC,EAAMC,YAAqC,CAACC,EAAOC,KAC/D,MAAMC,QAAEA,EAAST,GAAIU,KAAWC,GAAeJ,EACzCL,EAAaG,EAAMO,OAA2B,MAC9CC,EAAMR,EAAMO,OAAwB,MACpCE,EAAeC,EAAgBP,EAAcK,GAC7Cb,EAAKgB,EAAMN,GA2BjB,OAzBAL,EAAMY,WAAU,KACd,GAAIR,EAAS,CACX,MAAMS,EAAUC,SAASC,eAAeX,GAExC,GADcI,EAAIV,SACLe,EAAS,CACpB,MAAMG,EAAe,IAAMH,EAAQI,aAAa,mBAC1CC,EAAiB,CAACvB,EAAIqB,KAAgBG,OAAOC,SAASC,KAAK,KAGjE,OAFAR,EAAQS,aAAa,kBAAmBJ,GACxCrB,EAAWC,QAAUe,EACd,KAAM,IAAAU,EAKX,MAAML,EAAc,QAAAK,EAAGP,WAAH,IAAAO,OAAA,EAAGA,EAAgBC,QAAQ7B,EAAI,IAC5B,KAAnBuB,EACFL,EAAQY,gBAAgB,mBACfP,GACTL,EAAQS,aAAa,kBAAmBJ,QAK/C,CAACvB,EAAIS,iBAGNsB,EAAAC,cAACC,EAAD,CAAejC,GAAIA,EAAIE,WAAYA,gBACjC6B,EAAAC,cAACE,EAAUC,KAAXC,EAAA,CACEC,KAAK,QACLrC,GAAIA,GACAW,EAHN,CAIEE,IAAKC,EACLwB,YAAcC,IAAU,IAAAC,EACtB,QAAAA,EAAAjC,EAAM+B,mBAAN,IAAAE,GAAAA,EAAAC,KAAAlC,EAAoBgC,IAEfA,EAAMG,kBAAoBH,EAAMI,OAAS,GAAGJ,EAAMK,kBAEzDC,QAAUN,IAAU,IAAAO,EAElB,GADA,QAAAA,EAAAvC,EAAMsC,eAAN,IAAAC,GAAAA,EAAAL,KAAAlC,EAAgBgC,IACXrC,EAAWC,SAAWoC,EAAMG,iBAAkB,OACnD,MAAMK,EAAoB7C,EAAWC,QAAQ6C,SAAST,EAAMU,QAGtDC,GAAkC,IAApBX,EAAMY,WAMrBJ,GAAqBG,IACxBhD,EAAWC,QAAQiD,QACnBlD,EAAWC,QAAQkD,qCAY/B,MAAMC,gBAAmBpC,IACvB,MAAMqC,EAAUzD,EAAoB,kBAC9BI,WAAEA,GAAeqD,EAMvB,OAJAlD,EAAMY,WAAU,KACVC,IAAShB,EAAWC,QAAUe,KACjC,CAACA,EAAShB,IAENqD,EAAQvD,WAGjB,MAAMwD,KAAOpD","sources":["./packages/react/label/src/Label.tsx"],"sourcesContent":["import * as React from 'react';\nimport { createContext } from '@radix-ui/react-context';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { useId } from '@radix-ui/react-id';\n\nimport type * as Radix from '@radix-ui/react-primitive';\n\n/* -------------------------------------------------------------------------------------------------\n * Label\n * -----------------------------------------------------------------------------------------------*/\n\nconst NAME = 'Label';\n\ntype LabelContextValue = { id?: string; controlRef: React.MutableRefObject<HTMLElement | null> };\nconst [LabelProvider, useLabelContextImpl] = createContext<LabelContextValue>(NAME, {\n id: undefined,\n controlRef: { current: null },\n});\n\ntype LabelElement = React.ElementRef<typeof Primitive.span>;\ntype PrimitiveSpanProps = Radix.ComponentPropsWithoutRef<typeof Primitive.span>;\ninterface LabelProps extends PrimitiveSpanProps {\n htmlFor?: string;\n}\n\nconst Label = React.forwardRef<LabelElement, LabelProps>((props, forwardedRef) => {\n const { htmlFor, id: idProp, ...labelProps } = props;\n const controlRef = React.useRef<HTMLElement | null>(null);\n const ref = React.useRef<HTMLSpanElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const id = useId(idProp);\n\n React.useEffect(() => {\n if (htmlFor) {\n const element = document.getElementById(htmlFor);\n const label = ref.current;\n if (label && element) {\n const getAriaLabel = () => element.getAttribute('aria-labelledby');\n const ariaLabelledBy = [id, getAriaLabel()].filter(Boolean).join(' ');\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n controlRef.current = element;\n return () => {\n /**\n * We get the latest attribute value because at the time that this cleanup fires,\n * the values from the closure may have changed.\n */\n const ariaLabelledBy = getAriaLabel()?.replace(id, '');\n if (ariaLabelledBy === '') {\n element.removeAttribute('aria-labelledby');\n } else if (ariaLabelledBy) {\n element.setAttribute('aria-labelledby', ariaLabelledBy);\n }\n };\n }\n }\n }, [id, htmlFor]);\n\n return (\n <LabelProvider id={id} controlRef={controlRef}>\n <Primitive.span\n role=\"label\"\n id={id}\n {...labelProps}\n ref={composedRefs}\n onMouseDown={(event) => {\n props.onMouseDown?.(event);\n // prevent text selection when double clicking label\n if (!event.defaultPrevented && event.detail > 1) event.preventDefault();\n }}\n onClick={(event) => {\n props.onClick?.(event);\n if (!controlRef.current || event.defaultPrevented) return;\n const isClickingControl = controlRef.current.contains(event.target as Node);\n // Ensure event was generated by a user action\n // https://developer.mozilla.org/en-US/docs/Web/API/Event/isTrusted\n const isUserClick = event.isTrusted === true;\n /**\n * When a label is wrapped around the control it labels, we trigger the appropriate events\n * on the control when the label is clicked. We do nothing if the user is already clicking the\n * control inside the label.\n */\n if (!isClickingControl && isUserClick) {\n controlRef.current.click();\n controlRef.current.focus();\n }\n }}\n />\n </LabelProvider>\n );\n});\n\nLabel.displayName = NAME;\n\n/* -----------------------------------------------------------------------------------------------*/\n\nconst useLabelContext = (element?: HTMLElement | null) => {\n const context = useLabelContextImpl('LabelConsumer');\n const { controlRef } = context;\n\n React.useEffect(() => {\n if (element) controlRef.current = element;\n }, [element, controlRef]);\n\n return context.id;\n};\n\nconst Root = Label;\n\nexport {\n Label,\n //\n Root,\n //\n useLabelContext,\n};\nexport type { LabelProps };\n"],"names":["LabelProvider","useLabelContextImpl","createContext","id","undefined","controlRef","current","Label","React","forwardRef","props","forwardedRef","htmlFor","idProp","labelProps","useRef","ref","composedRefs","useComposedRefs","useId","useEffect","element","document","getElementById","getAriaLabel","getAttribute","ariaLabelledBy","filter","Boolean","join","setAttribute","_getAriaLabel","replace","removeAttribute","_react","createElement","$b835b8b6a05acdec720aee4b37e4b65c$var$LabelProvider","Primitive","span","_babelRuntimeHelpersEsmExtends","role","onMouseDown","event","_props$onMouseDown","call","defaultPrevented","detail","preventDefault","onClick","_props$onClick","isClickingControl","contains","target","isUserClick","isTrusted","click","focus","useLabelContext","context","Root"],"version":3,"file":"index.module.js.map"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@radix-ui/react-label",
3
- "version": "0.1.5-rc.10",
3
+ "version": "0.1.5-rc.14",
4
4
  "license": "MIT",
5
5
  "source": "src/index.ts",
6
6
  "main": "dist/index.js",
@@ -19,8 +19,8 @@
19
19
  "@babel/runtime": "^7.13.10",
20
20
  "@radix-ui/react-compose-refs": "0.1.0",
21
21
  "@radix-ui/react-context": "0.1.1",
22
- "@radix-ui/react-id": "0.1.5-rc.10",
23
- "@radix-ui/react-primitive": "0.1.4-rc.10"
22
+ "@radix-ui/react-id": "0.1.5-rc.14",
23
+ "@radix-ui/react-primitive": "0.1.4-rc.14"
24
24
  },
25
25
  "peerDependencies": {
26
26
  "react": "^16.8 || ^17.0"