TransBtn.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. import { createVNode as _createVNode } from "vue";
  2. import PropTypes from '../_util/vue-types';
  3. var TransBtn = function TransBtn(props, _ref) {
  4. var _slots$default;
  5. var slots = _ref.slots;
  6. var className = props.class,
  7. customizeIcon = props.customizeIcon,
  8. customizeIconProps = props.customizeIconProps,
  9. _onMousedown = props.onMousedown,
  10. onClick = props.onClick;
  11. var icon;
  12. if (typeof customizeIcon === 'function') {
  13. icon = customizeIcon(customizeIconProps);
  14. } else {
  15. icon = customizeIcon;
  16. }
  17. return _createVNode("span", {
  18. "class": className,
  19. "onMousedown": function onMousedown(event) {
  20. event.preventDefault();
  21. if (_onMousedown) {
  22. _onMousedown(event);
  23. }
  24. },
  25. "style": {
  26. userSelect: 'none',
  27. WebkitUserSelect: 'none'
  28. },
  29. "unselectable": "on",
  30. "onClick": onClick,
  31. "aria-hidden": true
  32. }, [icon !== undefined ? icon : _createVNode("span", {
  33. "class": className.split(/\s+/).map(function (cls) {
  34. return "".concat(cls, "-icon");
  35. })
  36. }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)])]);
  37. };
  38. TransBtn.inheritAttrs = false;
  39. TransBtn.displayName = 'TransBtn';
  40. TransBtn.props = {
  41. class: String,
  42. customizeIcon: PropTypes.any,
  43. customizeIconProps: PropTypes.any,
  44. onMousedown: Function,
  45. onClick: Function
  46. };
  47. export default TransBtn;