@styleless-ui/react
Version:
Completely unstyled, headless and accessible React UI components.
1 lines • 4.47 kB
JavaScript
;var __assign=this&&this.__assign||function(){return __assign=Object.assign||function(e){for(var t,r=1,l=arguments.length;r<l;r++)for(var i in t=arguments[r])Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i]);return e},__assign.apply(this,arguments)},__createBinding=this&&this.__createBinding||(Object.create?function(e,t,r,l){void 0===l&&(l=r);var i=Object.getOwnPropertyDescriptor(t,r);i&&!("get"in i?!t.__esModule:i.writable||i.configurable)||(i={enumerable:!0,get:function(){return t[r]}}),Object.defineProperty(e,l,i)}:function(e,t,r,l){void 0===l&&(l=r),e[l]=t[r]}),__setModuleDefault=this&&this.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),__importStar=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var r in e)"default"!==r&&Object.prototype.hasOwnProperty.call(e,r)&&__createBinding(t,e,r);return __setModuleDefault(t,e),t},__rest=this&&this.__rest||function(e,t){var r={};for(var l in e)Object.prototype.hasOwnProperty.call(e,l)&&t.indexOf(l)<0&&(r[l]=e[l]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var i=0;for(l=Object.getOwnPropertySymbols(e);i<l.length;i++)t.indexOf(l[i])<0&&Object.prototype.propertyIsEnumerable.call(e,l[i])&&(r[l[i]]=e[l[i]])}return r},__importDefault=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0});var jsx_runtime_1=require("react/jsx-runtime"),React=__importStar(require("react")),utils_1=require("../utils"),context_1=__importDefault(require("./context")),Slots=__importStar(require("./slots")),getLabelInfo=function(e){var t={};if("string"==typeof e)t.visibleLabel=e;else if("screenReaderLabel"in e)t.srOnlyLabel=e.screenReaderLabel;else{if(!("labelledBy"in e))throw new Error(["[StylelessUI][ToggleGroup]: Invalid `label` property.","The `label` property must be either a `string` or in shape of `{ screenReaderLabel: string; } | { labelledBy: string; }`"].join("\n"));t.labelledBy=e.labelledBy}return t},ToggleGroupBase=function(e,t){var r=e.label,l=e.children,i=e.id,n=e.classes,a=e.defaultValue,o=e.value,s=e.multiple,u=void 0!==s&&s,c=e.keyboardActivationBehavior,d=e.onChange,f=__rest(e,["label","children","id","classes","defaultValue","value","multiple","keyboardActivationBehavior","onChange"]),_=React.useRef(null),b=(0,utils_1.useForkedRefs)(t,_),p=(0,utils_1.useDeterministicId)(i,"styleless-ui__toggle-group"),g="".concat(p,"__label"),v=getLabelInfo(r),h=(0,utils_1.useControlledProp)(o,a,u?[]:""),y=h[0],m=h[1];if(u&&!Array.isArray(y))throw new Error("[StylelessUI][ToggleGroup]: The `value` and `defaultValue` should be an empty array or array of strings when `multiple={true}.`");if(!u&&"string"!=typeof y)throw new Error("[StylelessUI][ToggleGroup]: The `value` and `defaultValue` should be string when `multiple={false}.`");var j=[];return React.useEffect((function(){var e,t;if(_.current){j.forEach((function(e){var t=e[0],r=e[1];if(r.current){var l=Array.isArray(y)?y.includes(t):y===t,i=r.current.hasAttribute("disabled");r.current.tabIndex=i?-1:l?0:-1}}));var r=j.filter((function(e){var t;e[0];return"0"!==(null===(t=e[1].current)||void 0===t?void 0:t.getAttribute("tabindex"))}));if(r.length===j.length){var l=null!==(e=j.find((function(e){var t;e[0];return!(null===(t=e[1].current)||void 0===t?void 0:t.hasAttribute("disabled"))})))&&void 0!==e?e:null;if(l){l[0];null===(t=l[1].current)||void 0===t||t.setAttribute("tabindex","0")}}}})),(0,jsx_runtime_1.jsx)("div",__assign({},f,{id:p,ref:b,className:null==n?void 0:n.root,"data-slot":Slots.Root},{children:(0,jsx_runtime_1.jsxs)(context_1.default.Provider,__assign({value:{multiple:u,value:y,toggles:j,keyboardActivationBehavior:null!=c?c:"manual",onChange:function(e,t){var r=u?e?y.concat(t):y.filter((function(e){return e!==t})):e?t:"";m(r),null==d||d(r)},registerToggle:function(e,t){j.some((function(t){return t[0]===e}))||j.push([e,t])}}},{children:[v.visibleLabel&&(0,jsx_runtime_1.jsx)("span",__assign({id:g,"data-slot":Slots.Label,className:null==n?void 0:n.label},{children:v.visibleLabel})),(0,jsx_runtime_1.jsx)("div",__assign({role:"group","data-slot":Slots.Group,className:null==n?void 0:n.group,"aria-label":v.srOnlyLabel,"aria-labelledby":v.visibleLabel?g:v.labelledBy},{children:l}))]}))}))},ToggleGroup=(0,utils_1.componentWithForwardedRef)(ToggleGroupBase);exports.default=ToggleGroup;