carbon-react
Version:
A library of reusable React components for easily building user interfaces.
2 lines (1 loc) • 2.38 kB
JavaScript
;Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),t=require("react"),r=require("../../__internal__/utils/helpers/tags/tags.js"),n=require("./icon-button.style.js"),o=require("../../__internal__/tooltip-provider/index.js"),l=require("../batch-selection/__internal__/batch-selection.context.js");function i(e){return e&&e.__esModule?e:{default:e}}function c(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function u(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){c(e,t,r[t])}))}return e}function a(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 s=i(t).default.forwardRef(((i,c)=>{var s,{"aria-label":b,onClick:f,children:p,disabled:d=!1}=i,y=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}(i,["aria-label","onClick","children","disabled"]);const{batchSelectionDisabled:O}=t.useContext(l.default),j=d||O,[g,v]=t.useState(),_=b||(null==g||null===(s=g.querySelector("[data-component='icon']"))||void 0===s?void 0:s.getAttribute("type"))||"",P=t.useCallback((e=>{v(e),c&&("object"==typeof c&&(c.current=e),"function"==typeof c&&c(e))}),[c]);var h;return e.jsx(n.default,a(u(a(u({p:0},y),{"aria-label":_,onClick:e=>{null==g||g.focus({preventScroll:!0}),null==f||f(e)},ref:P,disabled:j}),r.default(null!==(h=y["data-component"])&&void 0!==h?h:"icon-button",y)),{children:e.jsx(o.TooltipProvider,{disabled:j,focusable:!1,target:g,children:p})}))}));s.displayName="IconButton",exports.default=s;