UNPKG

@fe6/water-pro

Version:

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

86 lines (75 loc) 2.52 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _vue = require("vue"); var _vueTypes = _interopRequireDefault(require("../../../_util/vue-types")); var _BaseMixin = _interopRequireDefault(require("../../../_util/BaseMixin")); var _propsUtil = require("../../../_util/props-util"); var _util = require("../util"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var DateInput = { name: 'DateInput', inheritAttrs: false, mixins: [_BaseMixin.default], props: { prefixCls: _vueTypes.default.string, format: _vueTypes.default.oneOfType([_vueTypes.default.string, _vueTypes.default.arrayOf(_vueTypes.default.string), _vueTypes.default.func]), locale: _vueTypes.default.object, selectedValue: _vueTypes.default.object, clearIcon: _vueTypes.default.any, showClear: _vueTypes.default.looseBool, multiplePanelHeaderRender: _vueTypes.default.func }, data: function data() { var _this = this; var selectedValue = this.selectedValue; return { str: selectedValue.map(function (sItem) { return (0, _util.formatDate)(sItem, _this.format); }) }; }, watch: { selectedValue: function selectedValue() { var _this2 = this; this.setState({ str: this.selectedValue.map(function (sItem) { return (0, _util.formatDate)(sItem, _this2.format); }) }); }, format: function format() { this.setState(); } }, methods: { onClear: function onClear() { this.setState({ str: '' }); this.__emit('clear', null); } }, render: function render() { var locale = this.locale, prefixCls = this.prefixCls, showClear = this.showClear, multiplePanelHeaderRender = this.multiplePanelHeaderRender; var clearIcon = (0, _propsUtil.getComponent)(this, 'clearIcon'); return (0, _vue.createVNode)("div", { "class": "".concat(prefixCls, "-input-wrap") }, [(0, _vue.createVNode)("div", { "class": "".concat(prefixCls, "-date-input-wrap") }, [multiplePanelHeaderRender(this.str, this.selectedValue)]), showClear ? (0, _vue.createVNode)("a", { "role": "button", "title": locale.clear, "onClick": this.onClear }, [clearIcon || (0, _vue.createVNode)("span", { "class": "".concat(prefixCls, "-clear-btn") }, null)]) : null]); } }; var _default = DateInput; exports.default = _default;