carbon-react
Version:
A library of reusable React components for easily building user interfaces.
2 lines (1 loc) • 2.24 kB
JavaScript
import{jsx as e,jsxs as t}from"react/jsx-runtime";import r from"react";import n from"../../../__internal__/utils/helpers/tags/tags.js";import o from"../../../__internal__/radio-button-mapper/radio-button-mapper.component.js";import{StyledTileSelectFieldset as l,StyledGroupDescription as i}from"../tile-select.style.js";import"../../../style/utils/filter-styled-system-padding-props.js";import c from"../../../style/utils/filter-styled-system-margin-props.js";function p(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function a(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){p(e,t,r[t])}))}return e}function s(e,t){return t=null!=t?t:{},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):function(e){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t.push.apply(t,r)}return t}(Object(t)).forEach((function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})),e}const u=p=>{var{children:u,name:m,legend:f,description:y,onChange:b,onBlur:O,value:d,multiSelect:g=!1}=p,j=function(e,t){if(null==e)return{};var r,n,o=function(e,t){if(null==e)return{};var r,n,o={},l=Object.keys(e);for(n=0;n<l.length;n++)r=l[n],t.indexOf(r)>=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);for(n=0;n<l.length;n++)r=l[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}(p,["children","name","legend","description","onChange","onBlur","value","multiSelect"]);let h;return h=g?u:e(o,{name:m,onBlur:O,onChange:b,value:d,"data-role":"tile-select-group-radio-button-mapper",children:r.Children.map(u,(e=>r.isValidElement(e)?r.cloneElement(e,{type:"radio"}):e))}),t(l,s(a(s(a({legend:f},n("tile-select-group",j)),{multiSelect:g}),c(j)),{children:[y&&e(i,{"data-element":"tile-select-group-description",children:y}),h]}))};export{u as TileSelectGroup,u as default};