FloatButton.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.floatButtonPrefixCls = exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  10. var _tooltip = _interopRequireDefault(require("../tooltip"));
  11. var _badge = _interopRequireDefault(require("../badge"));
  12. var _FloatButtonContent = _interopRequireDefault(require("./FloatButtonContent"));
  13. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  14. var _context = require("./context");
  15. var _warning = _interopRequireDefault(require("../_util/warning"));
  16. var _propsUtil = require("../_util/props-util");
  17. var _interface = require("./interface");
  18. var _style = _interopRequireDefault(require("./style"));
  19. var __rest = void 0 && (void 0).__rest || function (s, e) {
  20. var t = {};
  21. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  22. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  23. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  24. }
  25. return t;
  26. };
  27. // import { useCompactItemContext } from '../space/Compact';
  28. // CSSINJS
  29. const floatButtonPrefixCls = exports.floatButtonPrefixCls = 'float-btn';
  30. const FloatButton = (0, _vue.defineComponent)({
  31. compatConfig: {
  32. MODE: 3
  33. },
  34. name: 'AFloatButton',
  35. inheritAttrs: false,
  36. props: (0, _propsUtil.initDefaultProps)((0, _interface.floatButtonProps)(), {
  37. type: 'default',
  38. shape: 'circle'
  39. }),
  40. setup(props, _ref) {
  41. let {
  42. attrs,
  43. slots
  44. } = _ref;
  45. const {
  46. prefixCls,
  47. direction
  48. } = (0, _useConfigInject.default)(floatButtonPrefixCls, props);
  49. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  50. const {
  51. shape: groupShape
  52. } = (0, _context.useInjectFloatButtonGroupContext)();
  53. const floatButtonRef = (0, _vue.ref)(null);
  54. const mergeShape = (0, _vue.computed)(() => {
  55. return (groupShape === null || groupShape === void 0 ? void 0 : groupShape.value) || props.shape;
  56. });
  57. return () => {
  58. var _a;
  59. const {
  60. prefixCls: customPrefixCls,
  61. type = 'default',
  62. shape = 'circle',
  63. description = (_a = slots.description) === null || _a === void 0 ? void 0 : _a.call(slots),
  64. tooltip,
  65. badge = {}
  66. } = props,
  67. restProps = __rest(props, ["prefixCls", "type", "shape", "description", "tooltip", "badge"]);
  68. const classString = (0, _classNames.default)(prefixCls.value, `${prefixCls.value}-${type}`, `${prefixCls.value}-${mergeShape.value}`, {
  69. [`${prefixCls.value}-rtl`]: direction.value === 'rtl'
  70. }, attrs.class, hashId.value);
  71. const buttonNode = (0, _vue.createVNode)(_tooltip.default, {
  72. "placement": "left"
  73. }, {
  74. title: slots.tooltip || tooltip ? () => slots.tooltip && slots.tooltip() || tooltip : undefined,
  75. default: () => (0, _vue.createVNode)(_badge.default, badge, {
  76. default: () => [(0, _vue.createVNode)("div", {
  77. "class": `${prefixCls.value}-body`
  78. }, [(0, _vue.createVNode)(_FloatButtonContent.default, {
  79. "prefixCls": prefixCls.value
  80. }, {
  81. icon: slots.icon,
  82. description: () => description
  83. })])]
  84. })
  85. });
  86. if (process.env.NODE_ENV !== 'production') {
  87. (0, _warning.default)(!(shape === 'circle' && description), 'FloatButton', 'supported only when `shape` is `square`. Due to narrow space for text, short sentence is recommended.');
  88. }
  89. return wrapSSR(props.href ? (0, _vue.createVNode)("a", (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  90. "ref": floatButtonRef
  91. }, attrs), restProps), {}, {
  92. "class": classString
  93. }), [buttonNode]) : (0, _vue.createVNode)("button", (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  94. "ref": floatButtonRef
  95. }, attrs), restProps), {}, {
  96. "class": classString,
  97. "type": "button"
  98. }), [buttonNode]));
  99. };
  100. }
  101. });
  102. var _default = exports.default = FloatButton;