UNPKG

@fe6/water-pro

Version:

An enterprise-class UI design language and Vue-based implementation

84 lines (68 loc) 2.62 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _vue = require("vue"); var _iconsVue = require("@ant-design/icons-vue/lib/icons"); var _useConfigInject2 = _interopRequireDefault(require("../../../_util/hooks/useConfigInject")); var _vueTypes = _interopRequireDefault(require("../../../_util/vue-types")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } var _default = (0, _vue.defineComponent)({ name: 'ModalClose', components: { FullscreenExitOutlined: _iconsVue.FullscreenExitOutlined, FullscreenOutlined: _iconsVue.FullscreenOutlined, CloseOutlined: _iconsVue.CloseOutlined }, props: { canFullscreen: _vueTypes.default.bool.def(true), fullScreen: _vueTypes.default.bool, prefixCls: _vueTypes.default.string }, emits: ['cancel', 'fullscreen'], setup: function setup(props, _ref) { var emit = _ref.emit; var _useConfigInject = (0, _useConfigInject2.default)('modal-pro-close', props), prefixClsNew = _useConfigInject.prefixCls; var getClass = (0, _vue.computed)(function () { return [prefixClsNew, "".concat(prefixClsNew, "--custom"), _defineProperty({}, "".concat(prefixClsNew, "--can-full"), props.canFullscreen)]; }); function handleCancel() { emit('cancel'); } function handleFullScreen(e) { e === null || e === void 0 ? void 0 : e.stopPropagation(); e === null || e === void 0 ? void 0 : e.preventDefault(); emit('fullscreen'); } return { getClass: getClass, handleCancel: handleCancel, handleFullScreen: handleFullScreen }; }, render: function render() { var fullScreenNode = null; if (this.canFullscreen) { if (this.fullScreen) { fullScreenNode = (0, _vue.createVNode)(_iconsVue.FullscreenExitOutlined, { "role": "full", "onClick": this.handleFullScreen }, null); } else { fullScreenNode = (0, _vue.createVNode)(_iconsVue.FullscreenOutlined, { "role": "close", "onClick": this.handleFullScreen }, null); } } return (0, _vue.createVNode)("div", { "class": this.getClass }, [fullScreenNode, (0, _vue.createVNode)(_iconsVue.CloseOutlined, { "onClick": this.handleCancel }, null)]); } }); exports.default = _default;