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