payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
159 lines (158 loc) • 15.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reactrouterdom = require("react-router-dom");
const _Chevron = /*#__PURE__*/ _interop_require_default(require("../../icons/Chevron"));
const _Edit = /*#__PURE__*/ _interop_require_default(require("../../icons/Edit"));
const _Link = /*#__PURE__*/ _interop_require_default(require("../../icons/Link"));
const _Plus = /*#__PURE__*/ _interop_require_default(require("../../icons/Plus"));
const _Swap = /*#__PURE__*/ _interop_require_default(require("../../icons/Swap"));
const _X = /*#__PURE__*/ _interop_require_default(require("../../icons/X"));
const _Tooltip = /*#__PURE__*/ _interop_require_default(require("../Tooltip"));
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
function _getRequireWildcardCache(nodeInterop) {
if (typeof WeakMap !== "function") return null;
var cacheBabelInterop = new WeakMap();
var cacheNodeInterop = new WeakMap();
return (_getRequireWildcardCache = function(nodeInterop) {
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
})(nodeInterop);
}
function _interop_require_wildcard(obj, nodeInterop) {
if (!nodeInterop && obj && obj.__esModule) {
return obj;
}
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
return {
default: obj
};
}
var cache = _getRequireWildcardCache(nodeInterop);
if (cache && cache.has(obj)) {
return cache.get(obj);
}
var newObj = {
__proto__: null
};
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
for(var key in obj){
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
if (desc && (desc.get || desc.set)) {
Object.defineProperty(newObj, key, desc);
} else {
newObj[key] = obj[key];
}
}
}
newObj.default = obj;
if (cache) {
cache.set(obj, newObj);
}
return newObj;
}
const icons = {
chevron: _Chevron.default,
edit: _Edit.default,
link: _Link.default,
plus: _Plus.default,
swap: _Swap.default,
x: _X.default
};
const baseClass = 'btn';
const ButtonContents = ({ children, icon, showTooltip, tooltip })=>{
const BuiltInIcon = icons[icon];
return /*#__PURE__*/ _react.default.createElement(_react.Fragment, null, tooltip && /*#__PURE__*/ _react.default.createElement(_Tooltip.default, {
className: `${baseClass}__tooltip`,
show: showTooltip
}, tooltip), /*#__PURE__*/ _react.default.createElement("span", {
className: `${baseClass}__content`
}, children && /*#__PURE__*/ _react.default.createElement("span", {
className: `${baseClass}__label`
}, children), icon && /*#__PURE__*/ _react.default.createElement("span", {
className: `${baseClass}__icon`
}, /*#__PURE__*/ (0, _react.isValidElement)(icon) && icon, BuiltInIcon && /*#__PURE__*/ _react.default.createElement(BuiltInIcon, null))));
};
const Button = /*#__PURE__*/ (0, _react.forwardRef)((props, ref)=>{
const { id, 'aria-label': ariaLabel, buttonStyle = 'primary', children, className, disabled, el = 'button', icon, iconPosition = 'right', iconStyle = 'without-border', newTab, onClick, round, size = 'medium', to, tooltip, type = 'button', url } = props;
const [showTooltip, setShowTooltip] = _react.default.useState(false);
const classes = [
baseClass,
className && className,
buttonStyle && `${baseClass}--style-${buttonStyle}`,
icon && `${baseClass}--icon`,
iconStyle && `${baseClass}--icon-style-${iconStyle}`,
icon && !children && `${baseClass}--icon-only`,
disabled && `${baseClass}--disabled`,
round && `${baseClass}--round`,
size && `${baseClass}--size-${size}`,
iconPosition && `${baseClass}--icon-position-${iconPosition}`,
tooltip && `${baseClass}--has-tooltip`
].filter(Boolean).join(' ');
function handleClick(event) {
setShowTooltip(false);
if (type !== 'submit' && onClick) event.preventDefault();
if (onClick) onClick(event);
}
const buttonProps = {
id,
'aria-disabled': disabled,
'aria-label': ariaLabel,
className: classes,
disabled,
onClick: !disabled ? handleClick : undefined,
onMouseEnter: tooltip ? ()=>setShowTooltip(true) : undefined,
onMouseLeave: tooltip ? ()=>setShowTooltip(false) : undefined,
rel: newTab ? 'noopener noreferrer' : undefined,
target: newTab ? '_blank' : undefined,
type
};
switch(el){
case 'link':
return /*#__PURE__*/ _react.default.createElement(_reactrouterdom.Link, {
...buttonProps,
to: to || url
}, /*#__PURE__*/ _react.default.createElement(ButtonContents, {
icon: icon,
showTooltip: showTooltip,
tooltip: tooltip
}, children));
case 'anchor':
return /*#__PURE__*/ _react.default.createElement("a", {
...buttonProps,
href: url,
ref: ref
}, /*#__PURE__*/ _react.default.createElement(ButtonContents, {
icon: icon,
showTooltip: showTooltip,
tooltip: tooltip
}, children));
default:
const Tag = el // eslint-disable-line no-case-declarations
;
return /*#__PURE__*/ _react.default.createElement(Tag, {
ref: ref,
type: "submit",
...buttonProps
}, /*#__PURE__*/ _react.default.createElement(ButtonContents, {
icon: icon,
showTooltip: showTooltip,
tooltip: tooltip
}, children));
}
});
const _default = Button;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/Button/index.tsx"],"sourcesContent":["import React, { Fragment, forwardRef, isValidElement } from 'react'\nimport { Link } from 'react-router-dom'\n\nimport type { Props } from './types'\n\nimport chevron from '../../icons/Chevron'\nimport edit from '../../icons/Edit'\nimport linkIcon from '../../icons/Link'\nimport plus from '../../icons/Plus'\nimport swap from '../../icons/Swap'\nimport x from '../../icons/X'\nimport Tooltip from '../Tooltip'\nimport './index.scss'\n\nconst icons = {\n  chevron,\n  edit,\n  link: linkIcon,\n  plus,\n  swap,\n  x,\n}\n\nconst baseClass = 'btn'\n\nconst ButtonContents = ({ children, icon, showTooltip, tooltip }) => {\n  const BuiltInIcon = icons[icon]\n\n  return (\n    <Fragment>\n      {tooltip && (\n        <Tooltip className={`${baseClass}__tooltip`} show={showTooltip}>\n          {tooltip}\n        </Tooltip>\n      )}\n      <span className={`${baseClass}__content`}>\n        {children && <span className={`${baseClass}__label`}>{children}</span>}\n        {icon && (\n          <span className={`${baseClass}__icon`}>\n            {isValidElement(icon) && icon}\n            {BuiltInIcon && <BuiltInIcon />}\n          </span>\n        )}\n      </span>\n    </Fragment>\n  )\n}\n\nconst Button = forwardRef<HTMLAnchorElement | HTMLButtonElement, Props>((props, ref) => {\n  const {\n    id,\n    'aria-label': ariaLabel,\n    buttonStyle = 'primary',\n    children,\n    className,\n    disabled,\n    el = 'button',\n    icon,\n    iconPosition = 'right',\n    iconStyle = 'without-border',\n    newTab,\n    onClick,\n    round,\n    size = 'medium',\n    to,\n    tooltip,\n    type = 'button',\n    url,\n  } = props\n\n  const [showTooltip, setShowTooltip] = React.useState(false)\n\n  const classes = [\n    baseClass,\n    className && className,\n    buttonStyle && `${baseClass}--style-${buttonStyle}`,\n    icon && `${baseClass}--icon`,\n    iconStyle && `${baseClass}--icon-style-${iconStyle}`,\n    icon && !children && `${baseClass}--icon-only`,\n    disabled && `${baseClass}--disabled`,\n    round && `${baseClass}--round`,\n    size && `${baseClass}--size-${size}`,\n    iconPosition && `${baseClass}--icon-position-${iconPosition}`,\n    tooltip && `${baseClass}--has-tooltip`,\n  ]\n    .filter(Boolean)\n    .join(' ')\n\n  function handleClick(event) {\n    setShowTooltip(false)\n    if (type !== 'submit' && onClick) event.preventDefault()\n    if (onClick) onClick(event)\n  }\n\n  const buttonProps = {\n    id,\n    'aria-disabled': disabled,\n    'aria-label': ariaLabel,\n    className: classes,\n    disabled,\n    onClick: !disabled ? handleClick : undefined,\n    onMouseEnter: tooltip ? () => setShowTooltip(true) : undefined,\n    onMouseLeave: tooltip ? () => setShowTooltip(false) : undefined,\n    rel: newTab ? 'noopener noreferrer' : undefined,\n    target: newTab ? '_blank' : undefined,\n    type,\n  }\n\n  switch (el) {\n    case 'link':\n      return (\n        <Link {...buttonProps} to={to || url}>\n          <ButtonContents icon={icon} showTooltip={showTooltip} tooltip={tooltip}>\n            {children}\n          </ButtonContents>\n        </Link>\n      )\n\n    case 'anchor':\n      return (\n        <a {...buttonProps} href={url} ref={ref as React.LegacyRef<HTMLAnchorElement>}>\n          <ButtonContents icon={icon} showTooltip={showTooltip} tooltip={tooltip}>\n            {children}\n          </ButtonContents>\n        </a>\n      )\n\n    default:\n      const Tag = el // eslint-disable-line no-case-declarations\n\n      return (\n        <Tag ref={ref} type=\"submit\" {...buttonProps}>\n          <ButtonContents icon={icon} showTooltip={showTooltip} tooltip={tooltip}>\n            {children}\n          </ButtonContents>\n        </Tag>\n      )\n  }\n})\n\nexport default Button\n"],"names":["icons","chevron","edit","link","linkIcon","plus","swap","x","baseClass","ButtonContents","children","icon","showTooltip","tooltip","BuiltInIcon","Fragment","Tooltip","className","show","span","isValidElement","Button","forwardRef","props","ref","id","ariaLabel","buttonStyle","disabled","el","iconPosition","iconStyle","newTab","onClick","round","size","to","type","url","setShowTooltip","React","useState","classes","filter","Boolean","join","handleClick","event","preventDefault","buttonProps","undefined","onMouseEnter","onMouseLeave","rel","target","Link","a","href","Tag"],"mappings":";;;;+BA4IA;;;eAAA;;;+DA5I4D;gCACvC;gEAID;6DACH;6DACI;6DACJ;6DACA;0DACH;gEACM;QACb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEP,MAAMA,QAAQ;IACZC,SAAAA,gBAAO;IACPC,MAAAA,aAAI;IACJC,MAAMC,aAAQ;IACdC,MAAAA,aAAI;IACJC,MAAAA,aAAI;IACJC,GAAAA,UAAC;AACH;AAEA,MAAMC,YAAY;AAElB,MAAMC,iBAAiB,CAAC,EAAEC,QAAQ,EAAEC,IAAI,EAAEC,WAAW,EAAEC,OAAO,EAAE;IAC9D,MAAMC,cAAcd,KAAK,CAACW,KAAK;IAE/B,qBACE,6BAACI,eAAQ,QACNF,yBACC,6BAACG,gBAAO;QAACC,WAAW,CAAC,EAAET,UAAU,SAAS,CAAC;QAAEU,MAAMN;OAChDC,wBAGL,6BAACM;QAAKF,WAAW,CAAC,EAAET,UAAU,SAAS,CAAC;OACrCE,0BAAY,6BAACS;QAAKF,WAAW,CAAC,EAAET,UAAU,OAAO,CAAC;OAAGE,WACrDC,sBACC,6BAACQ;QAAKF,WAAW,CAAC,EAAET,UAAU,MAAM,CAAC;qBAClCY,IAAAA,qBAAc,EAACT,SAASA,MACxBG,6BAAe,6BAACA;AAM7B;AAEA,MAAMO,uBAASC,IAAAA,iBAAU,EAA+C,CAACC,OAAOC;IAC9E,MAAM,EACJC,EAAE,EACF,cAAcC,SAAS,EACvBC,cAAc,SAAS,EACvBjB,QAAQ,EACRO,SAAS,EACTW,QAAQ,EACRC,KAAK,QAAQ,EACblB,IAAI,EACJmB,eAAe,OAAO,EACtBC,YAAY,gBAAgB,EAC5BC,MAAM,EACNC,OAAO,EACPC,KAAK,EACLC,OAAO,QAAQ,EACfC,EAAE,EACFvB,OAAO,EACPwB,OAAO,QAAQ,EACfC,GAAG,EACJ,GAAGf;IAEJ,MAAM,CAACX,aAAa2B,eAAe,GAAGC,cAAK,CAACC,QAAQ,CAAC;IAErD,MAAMC,UAAU;QACdlC;QACAS,aAAaA;QACbU,eAAe,CAAC,EAAEnB,UAAU,QAAQ,EAAEmB,YAAY,CAAC;QACnDhB,QAAQ,CAAC,EAAEH,UAAU,MAAM,CAAC;QAC5BuB,aAAa,CAAC,EAAEvB,UAAU,aAAa,EAAEuB,UAAU,CAAC;QACpDpB,QAAQ,CAACD,YAAY,CAAC,EAAEF,UAAU,WAAW,CAAC;QAC9CoB,YAAY,CAAC,EAAEpB,UAAU,UAAU,CAAC;QACpC0B,SAAS,CAAC,EAAE1B,UAAU,OAAO,CAAC;QAC9B2B,QAAQ,CAAC,EAAE3B,UAAU,OAAO,EAAE2B,KAAK,CAAC;QACpCL,gBAAgB,CAAC,EAAEtB,UAAU,gBAAgB,EAAEsB,aAAa,CAAC;QAC7DjB,WAAW,CAAC,EAAEL,UAAU,aAAa,CAAC;KACvC,CACEmC,MAAM,CAACC,SACPC,IAAI,CAAC;IAER,SAASC,YAAYC,KAAK;QACxBR,eAAe;QACf,IAAIF,SAAS,YAAYJ,SAASc,MAAMC,cAAc;QACtD,IAAIf,SAASA,QAAQc;IACvB;IAEA,MAAME,cAAc;QAClBxB;QACA,iBAAiBG;QACjB,cAAcF;QACdT,WAAWyB;QACXd;QACAK,SAAS,CAACL,WAAWkB,cAAcI;QACnCC,cAActC,UAAU,IAAM0B,eAAe,QAAQW;QACrDE,cAAcvC,UAAU,IAAM0B,eAAe,SAASW;QACtDG,KAAKrB,SAAS,wBAAwBkB;QACtCI,QAAQtB,SAAS,WAAWkB;QAC5Bb;IACF;IAEA,OAAQR;QACN,KAAK;YACH,qBACE,6BAAC0B,oBAAI;gBAAE,GAAGN,WAAW;gBAAEb,IAAIA,MAAME;6BAC/B,6BAAC7B;gBAAeE,MAAMA;gBAAMC,aAAaA;gBAAaC,SAASA;eAC5DH;QAKT,KAAK;YACH,qBACE,6BAAC8C;gBAAG,GAAGP,WAAW;gBAAEQ,MAAMnB;gBAAKd,KAAKA;6BAClC,6BAACf;gBAAeE,MAAMA;gBAAMC,aAAaA;gBAAaC,SAASA;eAC5DH;QAKT;YACE,MAAMgD,MAAM7B,GAAG,2CAA2C;;YAE1D,qBACE,6BAAC6B;gBAAIlC,KAAKA;gBAAKa,MAAK;gBAAU,GAAGY,WAAW;6BAC1C,6BAACxC;gBAAeE,MAAMA;gBAAMC,aAAaA;gBAAaC,SAASA;eAC5DH;IAIX;AACF;MAEA,WAAeW"}