@fe6/water-pro
Version:
An enterprise-class UI design language and Vue-based implementation
84 lines (68 loc) • 2.62 kB
JavaScript
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;
;