UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

159 lines (158 loc) • 15.5 kB
"use strict"; 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":"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"}