TransBtn.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = void 0;
  7. var _vue = require("vue");
  8. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  9. const TransBtn = (props, _ref) => {
  10. let {
  11. slots
  12. } = _ref;
  13. var _a;
  14. const {
  15. class: className,
  16. customizeIcon,
  17. customizeIconProps,
  18. onMousedown,
  19. onClick
  20. } = props;
  21. let icon;
  22. if (typeof customizeIcon === 'function') {
  23. icon = customizeIcon(customizeIconProps);
  24. } else {
  25. icon = (0, _vue.isVNode)(customizeIcon) ? (0, _vue.cloneVNode)(customizeIcon) : customizeIcon;
  26. }
  27. return (0, _vue.createVNode)("span", {
  28. "class": className,
  29. "onMousedown": event => {
  30. event.preventDefault();
  31. if (onMousedown) {
  32. onMousedown(event);
  33. }
  34. },
  35. "style": {
  36. userSelect: 'none',
  37. WebkitUserSelect: 'none'
  38. },
  39. "unselectable": "on",
  40. "onClick": onClick,
  41. "aria-hidden": true
  42. }, [icon !== undefined ? icon : (0, _vue.createVNode)("span", {
  43. "class": className.split(/\s+/).map(cls => `${cls}-icon`)
  44. }, [(_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)])]);
  45. };
  46. TransBtn.inheritAttrs = false;
  47. TransBtn.displayName = 'TransBtn';
  48. TransBtn.props = {
  49. class: String,
  50. customizeIcon: _vueTypes.default.any,
  51. customizeIconProps: _vueTypes.default.any,
  52. onMousedown: Function,
  53. onClick: Function
  54. };
  55. var _default = exports.default = TransBtn;