carbon-react
Version:
A library of reusable React components for easily building user interfaces.
2 lines (1 loc) • 2.67 kB
JavaScript
;Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react/jsx-runtime"),t=require("react"),r=require("./flat-table-checkbox.style.js");require("../../checkbox/checkbox-group/checkbox-group.component.js");var n=require("../../checkbox/checkbox.component.js"),o=require("../../../__internal__/utils/helpers/events/events.js"),l=require("../../../__internal__/utils/helpers/tags/tags.js"),a=require("../../../__internal__/utils/helpers/guid/index.js"),c=require("../flat-table-row/__internal__/flat-table-row.context.js");function i(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function s(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){i(e,t,r[t])}))}return e}const u=i=>{var{as:u="td",checked:b,onChange:f,selectable:p=!0,onClick:y,ariaLabelledBy:d,id:h}=i,O=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,["as","checked","onChange","selectable","onClick","ariaLabelledBy","id"]);const j=t.useRef(null),g=t.useRef(h||a.default()),{leftPositions:k,rightPositions:x}=t.useContext(c.default),P=k[g.current],m=x[g.current],v=void 0!==P||void 0!==m,_="flat-table-checkbox-"+("td"===u?"cell":"header"),w=t.useCallback((e=>{e.stopPropagation(),null==y||y(e)}),[y]),C=t.useCallback((e=>{o.default.isDownKey(e)||o.default.isUpKey(e)||e.stopPropagation()}),[]);return e.jsx(r.default,(q=s({ref:j,makeCellSticky:v,className:v?"isSticky":void 0,leftPosition:P,rightPosition:m,as:u},l.default("flat-table-checkbox",s({"data-element":_},O))),S=null!=(S={id:g.current,children:p&&e.jsx(n.Checkbox,{checked:b,onChange:f,name:"flat-table-checkbox",mb:0,ariaLabelledBy:d,onClick:w,onKeyDown:C})})?S:{},Object.getOwnPropertyDescriptors?Object.defineProperties(q,Object.getOwnPropertyDescriptors(S)):function(e){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t.push.apply(t,r)}return t}(Object(S)).forEach((function(e){Object.defineProperty(q,e,Object.getOwnPropertyDescriptor(S,e))})),q));var q,S};u.displayName="FlatTableCheckbox",exports.FlatTableCheckbox=u,exports.default=u;