UNPKG

beta-parity-react

Version:

Beta Parity React Components

1 lines 4.25 kB
"use strict";function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){return typeof o}:function(o){return o&&"function"==typeof Symbol&&o.constructor===Symbol&&o!==Symbol.prototype?"symbol":typeof o},_typeof(o)}Object.defineProperty(exports,"__esModule",{value:true});exports.Button=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));require("./index.css");require("./variables.css");var _Spinner=require("../Spinner");var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","children","size","color","kind","disabled","iconOnly","isPending","onClick"];function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{"default":obj}}function ownKeys(e,r){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);r&&(o=o.filter(function(r){return Object.getOwnPropertyDescriptor(e,r).enumerable})),t.push.apply(t,o)}return t}function _objectSpread(e){for(var r=1;r<arguments.length;r++){var t=null!=arguments[r]?arguments[r]:{};r%2?ownKeys(Object(t),!0).forEach(function(r){_defineProperty(e,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):ownKeys(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})}return e}function _defineProperty(obj,key,value){key=_toPropertyKey(key);if(key in obj){Object.defineProperty(obj,key,{value:value,enumerable:true,configurable:true,writable:true})}else{obj[key]=value}return obj}function _toPropertyKey(t){var i=_toPrimitive(t,"string");return"symbol"==_typeof(i)?i:i+""}function _toPrimitive(t,r){if("object"!=_typeof(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var i=e.call(t,r||"default");if("object"!=_typeof(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(t)}function _objectWithoutProperties(source,excluded){if(source==null)return{};var target=_objectWithoutPropertiesLoose(source,excluded);var key,i;if(Object.getOwnPropertySymbols){var sourceSymbolKeys=Object.getOwnPropertySymbols(source);for(i=0;i<sourceSymbolKeys.length;i++){key=sourceSymbolKeys[i];if(excluded.indexOf(key)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(source,key))continue;target[key]=source[key]}}return target}function _objectWithoutPropertiesLoose(source,excluded){if(source==null)return{};var target={};for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){if(excluded.indexOf(key)>=0)continue;target[key]=source[key]}}return target}var sizeMap={sm:"small",md:"medium",lg:"large"};var colorMap={accent:"accent",neutral:"neutral",adverse:"adverse"};var kindMap={solid:"solid",outlined:"outlined",ghost:"ghost",glass:"glass"};var Button=exports.Button=_react["default"].forwardRef(function(_ref,ref){var _ref$className=_ref.className,className=_ref$className===void 0?"":_ref$className,children=_ref.children,_ref$size=_ref.size,size=_ref$size===void 0?"md":_ref$size,_ref$color=_ref.color,color=_ref$color===void 0?"neutral":_ref$color,_ref$kind=_ref.kind,kind=_ref$kind===void 0?"solid":_ref$kind,_ref$disabled=_ref.disabled,disabled=_ref$disabled===void 0?false:_ref$disabled,_ref$iconOnly=_ref.iconOnly,iconOnly=_ref$iconOnly===void 0?false:_ref$iconOnly,_ref$isPending=_ref.isPending,isPending=_ref$isPending===void 0?false:_ref$isPending,onClick=_ref.onClick,props=_objectWithoutProperties(_ref,_excluded);var classes=(0,_classnames["default"])("btn",colorMap[color],kindMap[kind],sizeMap[size],className,{"icon-only":iconOnly,loading:isPending});var parsedChildren=_react["default"].Children.map(children,function(child){if(typeof child==="string"||typeof child==="number"){return(0,_jsxRuntime.jsx)("span",{className:"btn-text",children:child})}return child});return(0,_jsxRuntime.jsxs)("button",_objectSpread(_objectSpread({type:"button",className:classes,onClick:!disabled&&!isPending?onClick:undefined,ref:ref,disabled:disabled||isPending},props),{},{children:[isPending&&(0,_jsxRuntime.jsx)(_Spinner.Spinner,{variant:"sunburst",color:"neutral",size:"sm"}),parsedChildren]}))});Button.displayName="Button";