(window["webpackJsonp"] = window["webpackJsonp"] || []).push([ ["chunk-common"], { "0e09": function (e, t) { e.exports = ""; }, "0f2b": function (e, t, i) { e.exports = { layout: "VideoPlayBack_layout_3qFD7", videos: "VideoPlayBack_videos_27A1A", item: "VideoPlayBack_item_2CAwS", grid: "VideoPlayBack_grid_1mb-w", waiting: "VideoPlayBack_waiting_26xZ5", disabled: "VideoPlayBack_disabled_2fZxt", }; }, "10c1": function (e, t, i) {}, 2229: function (e, t, i) { "use strict"; i("28a5"), i("ac6a"); (function () { if (!window.addResizeListener) { var e = document.attachEvent, t = !1, i = (function () { var e = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || function (e) { return window.setTimeout(e, 20); }; return function (t) { return e(t); }; })(), s = (function () { var e = window.cancelAnimationFrame || window.mozCancelAnimationFrame || window.webkitCancelAnimationFrame || window.clearTimeout; return function (t) { return e(t); }; })(), n = !1, o = "", r = "animationstart", l = "Webkit Moz O ms".split(" "), a = "webkitAnimationStart animationstart oAnimationStart MSAnimationStart".split( " " ), h = "", c = document.createElement("fakeelement"); if ((void 0 !== c.style.animationName && (n = !0), !1 === n)) for (var d = 0; d < l.length; d++) if (void 0 !== c.style[l[d] + "AnimationName"]) { (h = l[d]), h + "Animation", (o = "-" + h.toLowerCase() + "-"), (r = a[d]), (n = !0); break; } var u = "resizeanim", p = "@" + o + "keyframes " + u + " { from { opacity: 0; } to { opacity: 0; } } ", f = o + "animation: 1ms " + u + "; "; (window.addResizeListener = function (t, i) { e ? t.attachEvent("onresize", i) : (t.__resizeTriggers__ || ("static" == getComputedStyle(t).position && (t.style.position = "relative"), _(), (t.__resizeLast__ = {}), (t.__resizeListeners__ = []), ((t.__resizeTriggers__ = document.createElement("div")).className = "resize-triggers"), (t.__resizeTriggers__.innerHTML = '
'), t.appendChild(t.__resizeTriggers__), m(t), t.addEventListener("scroll", v, !0), r && t.__resizeTriggers__.addEventListener(r, function (e) { e.animationName == u && m(t); })), t.__resizeListeners__.push(i)); }), (window.removeResizeListener = function (t, i) { e ? t.detachEvent("onresize", i) : (t.__resizeListeners__.splice( t.__resizeListeners__.indexOf(i), 1 ), t.__resizeListeners__.length || (t.removeEventListener("scroll", v), (t.__resizeTriggers__ = !t.removeChild( t.__resizeTriggers__ )))); }); } function m(e) { var t = e.__resizeTriggers__, i = t.firstElementChild, s = t.lastElementChild, n = i.firstElementChild; (s.scrollLeft = s.scrollWidth), (s.scrollTop = s.scrollHeight), (n.style.width = i.offsetWidth + 1 + "px"), (n.style.height = i.offsetHeight + 1 + "px"), (i.scrollLeft = i.scrollWidth), (i.scrollTop = i.scrollHeight); } function g(e) { return ( e.offsetWidth != e.__resizeLast__.width || e.offsetHeight != e.__resizeLast__.height ); } function v(e) { var t = this; m(this), this.__resizeRAF__ && s(this.__resizeRAF__), (this.__resizeRAF__ = i(function () { g(t) && ((t.__resizeLast__.width = t.offsetWidth), (t.__resizeLast__.height = t.offsetHeight), t.__resizeListeners__.forEach(function (i) { i.call(t, e); })); })); } function _() { if (!t) { var e = (p || "") + ".resize-triggers { " + (f || "") + 'visibility: hidden; opacity: 0; } .resize-triggers, .resize-triggers > div, .contract-trigger:before { content: " "; display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; } .resize-triggers > div { background: #eee; overflow: auto; } .contract-trigger:before { width: 200%; height: 200%; }', i = document.head || document.getElementsByTagName("head")[0], s = document.createElement("style"); (s.type = "text/css"), s.styleSheet ? (s.styleSheet.cssText = e) : s.appendChild(document.createTextNode(e)), i.appendChild(s), (t = !0); } } })(); }, 2707: function (e, t, i) { e.exports = { container: "CloudPanel_container_1vjMn", icon: "CloudPanel_icon_2hEIS", }; }, "299b": function (e, t, i) { "use strict"; var s = function () { var e = this, t = e.$createElement, i = e._self._c || t; return i( "div", { class: e.$style.layout }, [ e.toolbar ? i( "Toolbar", { ref: "toolbar", class: e.$style.toolbar, style: [ "top" == e.toolbar ? { top: "0" } : { bottom: "0" }, ], attrs: { mini: "" }, }, [ i( "Button", { attrs: { height: 30, borderColor: "#AEBAC5" }, on: { click: function (t) { return e._closeAll(); }, }, }, [e._v("全部关闭")] ), i("InputSelect", { attrs: { height: 30, borderColor: "#AEBAC5", showArrow: !0, options: [ { label: "清晰(主码流)", value: 0 }, { label: "流畅(子码流)", value: 1 }, ], }, on: { change: e._onStreamChg }, model: { value: e.stream, callback: function (t) { e.stream = t; }, expression: "stream", }, }), e.talks.show ? i("InputSelect", { attrs: { height: 30, borderColor: "#AEBAC5", showArrow: !0, options: e.talks.options, }, model: { value: e.talks.value, callback: function (t) { e.$set(e.talks, "value", t); }, expression: "talks.value", }, }) : e._e(), e.talks.show ? i( "Button", { attrs: { height: 30, borderColor: "#AEBAC5", disabled: e.talks.waiting || !e.socketIsOpen, icon: "el-icon-microphone", }, on: { click: function (t) { return e._toogleTalk(); }, }, }, [ e._v( e._s(e.talks.playing ? "关闭对讲" : "打开对讲") ), ] ) : e._e(), i( "template", { slot: "right" }, [ i( "Button", { ref: "rcBtn", staticStyle: { "min-width": "86px" }, attrs: { height: 30, borderColor: "#AEBAC5" }, on: { click: function (t) { return e._onRcBtnClick(); }, }, }, [ e._v( " " + e._s(e.row) + "行 × " + e._s(e.col) + "列 " ), ] ), i("InputSelect", { staticStyle: { "text-align": "center" }, attrs: { height: 30, showArrow: !0, borderColor: "#AEBAC5", options: [ { label: "满画面", value: 0 }, { label: " 2:1 显示", value: 2 }, { label: "16:9 显示", value: 16 / 9 }, { label: " 4:3 显示", value: 4 / 3 }, { label: " 1:1 显示", value: 1 }, { label: " 3:4 显示", value: 0.75 }, { label: "9:16 显示", value: 9 / 16 }, { label: " 1:2 显示", value: 0.5 }, ], }, on: { change: function (t) { return e._onResize(); }, }, model: { value: e.ratio, callback: function (t) { e.ratio = t; }, expression: "ratio", }, }), i("Button", { attrs: { height: 30, icon: "el-icon-full-screen", padding: "0 6px", borderColor: "#AEBAC5", }, on: { click: function (t) { return e._fullScreen(); }, }, }), ], 1 ), ], 2 ) : e._e(), i("div", { ref: "videos", class: e.$style.videos, style: [ !1 === e.toolbar ? { bottom: "0", top: "0" } : "top" == e.toolbar ? { bottom: "0", top: "38px" } : { top: "0", bottom: "38px" }, ], }), i("audio", { ref: "audio", staticStyle: { display: "none" }, attrs: { autoplay: "autoplay" }, }), e.showRcWindow ? i( "div", { ref: "rc", staticStyle: { position: "fixed", padding: "5px", border: "1px solid #AEBAC5", display: "flex", "background-color": "#fff", }, }, [ i("ButtonBar", { staticStyle: { width: "calc(50% - 2.5px)", "margin-right": "2.5px", }, attrs: { vertical: !0, height: 18, padding: "2px 5px", options: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10], }, on: { change: function (t) { (e.col = e.row), (e.count = e.row * e.col), e._regrid(); }, }, model: { value: e.row, callback: function (t) { e.row = t; }, expression: "row", }, }), i("ButtonBar", { staticStyle: { width: "calc(50% - 2.5px)", "margin-left": "2.5px", }, attrs: { vertical: !0, height: 18, padding: "2px 5px", options: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10], }, on: { change: function (t) { (e.col = e.col), (e.count = e.row * e.col), e._regrid(); }, }, model: { value: e.col, callback: function (t) { e.col = t; }, expression: "col", }, }), ], 1 ) : e._e(), ], 1 ); }, n = [], o = (i("6b54"), i("28a5"), i("3835")), r = (i("ac6a"), i("2b0e")), l = function () { var e = this, t = e.$createElement, i = e._self._c || t; return i( "div", { class: [ e.$style.toolbar, e.small && e.$style.toolbar_small, e.mini && e.$style.toolbar_mini, e.zero && e.$style.toolbar_zero, ], style: [ { backgroundColor: e.theme.bg_color }, e.border ? { borderColor: e.theme.border_color_dark } : { border: 0 }, ], }, [ e.$slots.default ? i( "div", { class: [ e.$style.left, e.small && e.$style.left_small, e.mini && e.$style.left_mini, e.zero && e.$style.left_zero, ], style: [ { width: e.$slots.right ? "" : "100%" }, e.leftStyle, ], }, [e._t("default")], 2 ) : e._e(), e.$slots.right && !e.$slots.default ? i("span", [e._v(" ")]) : e._e(), e.$slots.right ? i( "div", { class: [ e.$style.right, e.small && e.$style.right_small, e.mini && e.$style.right_mini, e.zero && e.$style.right_zero, ], style: e.rightStyle, }, [e._t("right")], 2 ) : e._e(), e.disabled ? i("div", { class: e.$style.disabled }) : e._e(), ] ); }, a = [], h = { name: "Toolbar", props: { border: { type: Boolean, default: !0 }, small: { type: Boolean, default: !1 }, mini: { type: Boolean, default: !1 }, zero: { type: Boolean, default: !1 }, leftStyle: { default: null }, rightStyle: { default: null }, disabled: Boolean, }, }, c = h, d = i("9535"), u = i("2877"); function p(e) { this["$style"] = d["default"].locals || d["default"]; } var f = Object(u["a"])(c, l, a, !1, p, null, null), m = f.exports, g = i("2a7d"), v = i("3d56"), _ = i("f4c2"), b = i("a852"), y = function () { var e = this, t = e.$createElement, i = e._self._c || t; return i( "div", { class: e.$style.container, style: [ e.backgroundImage, e.playing && e.reply && e.backgroundColor, ], on: { mouseenter: function (t) { e.hover = !0; }, mouseleave: function (t) { e.hover = !1; }, }, }, [ e.playing ? i( "div", { class: e.$style.bar, staticStyle: { top: "0", "border-top": "1px solid #000" }, }, [ i( "span", { staticStyle: { "flex-grow": "1", width: "1px", "margin-left": "6px", }, }, [e._v(e._s(e.title))] ), e.cloudable && e.cloud ? i("i", { directives: [ { name: "show", rawName: "v-show", value: e.hover, expression: "hover", }, ], staticClass: "el-icon-sunny", staticStyle: { "font-size": "18px", cursor: "pointer", position: "absolute", top: "0", right: "22px", padding: "4px", "background-color": "#202020", }, attrs: { title: "云台控制" }, on: { click: e.cloudClick }, }) : e._e(), e.closeable ? i("i", { directives: [ { name: "show", rawName: "v-show", value: e.hover, expression: "hover", }, ], staticClass: "el-icon-close", staticStyle: { "font-size": "18px", cursor: "pointer", position: "absolute", top: "0", right: "0", padding: "4px", "background-color": "#202020", }, attrs: { title: "关闭播放" }, on: { dblclick: function (t) { return t.stopPropagation(), e.close(!0); }, click: function (t) { return t.stopPropagation(), e.close(!0); }, }, }) : e._e(), ] ) : e._e(), i( "span", { class: e.reverse && e.$style.reverse, staticStyle: { display: "block", "margin-top": "26px", width: "100%", height: "calc(100% - 26px)", position: "relative", }, style: { rotate: e.rotate + "deg" }, }, [ i("video", { ref: "video", staticStyle: { position: "absolute", "object-fit": "fill", display: "none", }, attrs: { autoplay: "autoplay", muted: "" }, domProps: { muted: !0 }, }), ] ), e.tip ? i( "span", { staticStyle: { color: "#fff", position: "absolute", top: "calc(75% - 13px)", "text-align": "center", width: "100%", }, }, [e._v(e._s(e.tip))] ) : e._e(), e.record.ing ? i( "span", { staticStyle: { position: "absolute", right: "5px", bottom: "30px", padding: "2px", "background-color": "#000", color: "#f00", display: "inline-block", }, }, [e._v(e._s(e.record.time))] ) : e._e(), e.playing && !e.loading ? i( "div", { directives: [ { name: "show", rawName: "v-show", value: e.hover, expression: "hover", }, ], class: e.$style.bar, staticStyle: { bottom: "0", "background-color": "#303030", }, }, [ e.pauseable ? i("i", { class: [ e.pause ? "el-icon-video-play" : "el-icon-video-pause", ], staticStyle: { "font-size": "16px", cursor: "pointer", margin: "0 6px", }, attrs: { title: e.pause ? "恢复播放" : "暂停播放" }, on: { click: e.tooglePause }, }) : e._e(), i( "span", { staticStyle: { "flex-grow": "1", width: "1px", "text-align": "center", }, }, [ e._v( " " + e._s(parseInt(e.flow.kbs / 1024)) + "kb/s | " + e._s(parseInt(e.flow.total / 1024)) + "kb " ), ] ), e.voiceable ? i("i", { class: [ e.voice ? "el-icon-bell" : "el-icon-close-notification", ], staticStyle: { "font-size": "16px", cursor: "pointer", margin: "0 5px", }, on: { click: function (t) { return e.setVoice(!e.voice); }, }, }) : e._e(), e.snapshotable ? i("i", { staticClass: "el-icon-camera", staticStyle: { "font-size": "16px", cursor: "pointer", "margin-right": "5px", }, attrs: { title: "视频截图" }, on: { click: function (t) { return e.snapshot(); }, }, }) : e._e(), e.recordable ? i("i", { staticClass: "el-icon-video-camera", staticStyle: { "font-size": "16px", cursor: "pointer", "margin-right": "5px", }, attrs: { title: e.record.ing ? "停止录像" : "开始录像", }, on: { click: function (t) { return e.toogleRecord(); }, }, }) : e._e(), i("i", { staticClass: "el-icon-refresh", staticStyle: { "font-size": "16px", cursor: "pointer", "margin-right": "5px", }, attrs: { title: "镜像反转" }, on: { click: function (t) { e.reverse = !e.reverse; }, }, }), i("i", { staticClass: "el-icon-refresh-right", staticStyle: { "font-size": "16px", cursor: "pointer", "margin-right": "6px", }, attrs: { title: "旋转画面" }, on: { click: function (t) { e.rotate = (e.rotate + 180) % 360; }, }, }), ] ) : e._e(), e.loading ? i("i", { staticClass: "el-icon-loading", staticStyle: { color: "#ddd", "font-size": "40px", position: "absolute", left: "calc(50% - 20px)", top: "calc(50% - 10px)", }, }) : e._e(), e.border ? i("div", { class: e.$style.border_top }) : e._e(), e.border ? i("div", { class: e.$style.border_bottom }) : e._e(), e.border ? i("div", { class: e.$style.border_left }) : e._e(), e.border ? i("div", { class: e.$style.border_right }) : e._e(), ] ); }, x = [], w = function () { var e = this, t = e.$createElement, i = e._self._c || t; return i( "div", { class: e.$style.container }, [ i("Slider", { staticStyle: { "grid-column": "1/span 2" }, attrs: { min: 0, max: 255, tooltip: "速度{}", valueColor: "#fff", barColor: "#fff", }, model: { value: e.speed, callback: function (t) { e.speed = t; }, expression: "speed", }, }), i( "div", { staticStyle: { position: "relative", height: "65px", color: "#fff", "font-size": "30px", cursor: "move", "grid-column": "1/span 2", }, on: { mousedown: function (t) { return e.onDragStart(t); }, }, }, [ i("i", { staticClass: "el-icon-caret-top", class: e.$style.icon, staticStyle: { top: "-10px", left: "calc(50% - 15px)" }, attrs: { title: "镜头上移" }, on: { mousedown: function (e) { e.stopPropagation(); }, click: function (t) { return e.rotate(1); }, }, }), i("i", { staticClass: "el-icon-caret-bottom", class: e.$style.icon, staticStyle: { top: "39px", left: "calc(50% - 15px)" }, attrs: { title: "镜头下移" }, on: { mousedown: function (e) { e.stopPropagation(); }, click: function (t) { return e.rotate(2); }, }, }), i("i", { staticClass: "el-icon-caret-left", class: e.$style.icon, staticStyle: { top: "15px", left: "calc(50% - 40px)" }, attrs: { title: "镜头左移" }, on: { mousedown: function (e) { e.stopPropagation(); }, click: function (t) { return e.rotate(3); }, }, }), i("i", { staticClass: "el-icon-caret-right", class: e.$style.icon, staticStyle: { top: "15px", right: "calc(50% - 39px)" }, attrs: { title: "镜头右移" }, on: { mousedown: function (e) { e.stopPropagation(); }, click: function (t) { return e.rotate(4); }, }, }), i("i", { staticClass: "el-icon-circle-close", class: e.$style.icon, staticStyle: { top: "18px", left: "calc(50% - 12px)", "font-size": "25px", }, attrs: { title: "停止移动" }, on: { mousedown: function (e) { e.stopPropagation(); }, click: function (t) { return e.rotate(0); }, }, }), ] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.focus(1); }, }, }, [e._v(" 焦距变小 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.focus(0); }, }, }, [e._v(" 焦距变大 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.aperture(1); }, }, }, [e._v(" 光圈缩小 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.aperture(0); }, }, }, [e._v(" 光圈放大 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.zoom(1); }, }, }, [e._v(" 变倍调小 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.zoom(0); }, }, }, [e._v(" 变倍调大 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.light(1); }, }, }, [e._v(" 补光打开 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.light(0); }, }, }, [e._v(" 补光关闭 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.wiper(1); }, }, }, [e._v(" 雨刷打开 ")] ), i( "Button", { attrs: { border: !1, height: 24 }, on: { click: function (t) { return e.wiper(0); }, }, }, [e._v(" 雨刷关闭 ")] ), ], 1 ); }, S = [], E = i("89fb"), k = { components: { Button: g["a"], Slider: E["a"] }, data() { return { carId: null, channel: null, speed: 127 }; }, mounted() { document.addEventListener("mousedown", this.onMouseClick); }, methods: { rotate(e) { this._socket.send({ cmd: "cloud_ctr", type: "0", carId: this.carId, channel: this.channel, speed: this.speed, drct: e + "", }); }, focus(e) { this._socket.send({ cmd: "cloud_ctr", type: "1", carId: this.carId, channel: this.channel, action: e + "", }); }, aperture(e) { this._socket.send({ cmd: "cloud_ctr", type: "2", carId: this.carId, channel: this.channel, action: e + "", }); }, zoom(e) { this._socket.send({ cmd: "cloud_ctr", type: "5", carId: this.carId, channel: this.channel, action: e + "", }); }, light(e) { this._socket.send({ cmd: "cloud_ctr", type: "4", carId: this.carId, channel: this.channel, action: e + "", }); }, wiper(e) { this._socket.send({ cmd: "cloud_ctr", type: "3", carId: this.carId, channel: this.channel, action: e + "", }); }, onDragStart(e) { (this.divX = e.clientX - this.$el.offsetLeft), (this.divY = e.clientY - this.$el.offsetTop), document.addEventListener("mousemove", this.onDraging), document.addEventListener("mouseup", this.onDragEnd); }, onDraging(e) { (this.$el.style.left = e.clientX - this.divX + "px"), (this.$el.style.top = e.clientY - this.divY + "px"); }, onDragEnd() { document.removeEventListener("mousemove", this.onDraging), document.removeEventListener("mouseup", this.onDragEnd); }, onMouseClick(e) { this.$el.contains(e.target) || (document.removeEventListener("mousedown", this.onMouseClick), document.body.removeChild(this.$el), this.$destroy()); }, }, }, C = k, T = i("58a7"); function O(e) { this["$style"] = T["default"].locals || T["default"]; } var $ = Object(u["a"])(C, w, S, !1, O, null, null), R = $.exports, A = i("d0ee"), L = i("eb5b"), D = i("4a66"), I = i("7319"), M = { components: {}, props: { sessionId: String, user_pwd: String, uuid: String, videoIp: String, onClose: Function, onVoiceOpen: Function, openVideo: Function, openAudio: Function, closeAudio: Function, cloudable: { type: Boolean, default: !0 }, closeable: { type: Boolean, default: !0 }, pauseable: { type: Boolean, default: !0 }, voiceable: { type: Boolean, default: !0 }, snapshotable: { type: Boolean, default: !0 }, recordable: { type: Boolean, default: !0 }, }, _chn: null, _type: null, _stream: null, data() { return { border: !1, title: null, cloud: !1, hover: !1, playing: !1, loading: !1, reply: !1, pause: !1, voice: !1, tip: null, record: { ing: !1, time: null, second: 0, interval: null }, flow: { total: 0, kbs: 0 }, rotate: 0, reverse: !1, }; }, computed: { backgroundImage() { return null; }, backgroundColor() { return { backgroundColor: "#000", backgroundSize: "0" }; }, }, methods: { play(e, t, i, s) { (this._chn = e), (this._chn.player = this), (this._type = t), (this._stream = i), (this.playing = this.loading = !0), (this.$refs.video.style.display = ""), (this.reply = !1), (this.cloud = e.cloud), (this.tip = null), (this.flow.total = this.flow.kbs = 0), (this.title = e.title), (this._socket = s); let n = "/real_play/" + [ this.sessionId, this.user_pwd, this.uuid, "_" + this._chn.sim, this._type, this._chn.chn, this._stream, ].join("/"); this._player && this._player.destroy(), (this._player = this.openVideo(n, this.$refs.video)), this._player.on(flvjs.Events.METADATA_ARRIVED, () => { (this.loading = !1), (this.reply = !0), (this.tip = null); }); }, setVoice(e) { if (this.voice === e) return; if (((this.voice = e), !this.playing)) return; if ( (e && this.onVoiceOpen && this.onVoiceOpen(this), this._closeAudio(), !e) ) return; let t = () => ((65536 * (1 + Math.random())) | 0).toString(16).substring(1); this._audio_uuid = t() + t() + t() + t() + t() + t() + t() + t(); let i = "/listen_open/" + [ this.sessionId, this.user_pwd, this._audio_uuid, "_" + this._chn.sim, this._chn.chn, "1", ].join("/"); this.openAudio(i, !1); }, tooglePause() { this.playing && ((this.pause = !this.pause), this.pause ? this.$refs.video.pause() : this.$refs.video.play(), this._socket.send({ cmd: this.pause ? "real_pause" : "real_resume", uuid: this.uuid, carId: "_" + this._chn.sim, channel: this._chn.chn, stream: this._stream, })); }, snapshot() { this._player.snapshot( this.title + "(" + Object(A["f"])("YYYYMMDDHHNNSS") + ")" ), this.pause && this.$refs.video.pause(); }, toogleRecord() { if (this.record.ing) { (this.record.ing = !1), this.record.interval && (clearInterval(this.record.interval), (this.record.interval = null)); let e = (t) => { let i = t.downloadPort; this._socket.removeListener("cfg", e); let s = ("https:" == location.protocol ? "https:" : "http:") + "//" + this.videoIp + ":" + i + "/download/92&" + this.uuid + "/" + encodeURIComponent(this.title) + "(" + Object(A["f"])("YYYYMMDDHHNNSS") + ").flv"; window.open(s); }; this._socket.addListener("cfg", e), this._socket.send({ cmd: "cfg" }); } else this._socket.send({ cmd: "record_start", uuid: this.uuid }); }, cloudClick() { let e = Object(I["b"])(this.$el), t = e.left, i = e.top, s = D["a"].open(R, { carId: "_" + this._chn.sim, channel: this._chn.chn, }); (s._socket = this._socket), (s.$el.style.left = t + this.$el.clientWidth - s.$el.clientWidth - 2 + "px"), (s.$el.style.top = i + 26 + "px"); }, on_real_play(e) { let t = arguments.length > 1 && void 0 !== arguments[1] && arguments[1]; if (((this.reply = !0), 0 !== e.ret)) { this.loading = !1; let i = this.title + " - " + Object(L["a"])(e.ret); this.clear(), t ? b["a"].error(i) : (this.tip = i); } }, on_play_flow(e) { (this.flow.kbs = e.flow - this.flow.total), (this.flow.total = e.flow), e.flow > 0 && (this.reply = !0); }, on_record_start(e) { (this.record.second = 0), (this.record.time = "00:00:00"), (this.record.ing = !0), (this.record.interval = setInterval(() => { this.pause || ((this.record.second += 1), (this.record.time = Object(A["i"])(this.record.second))); }, 1e3)); }, on_tmn_close() { this.playing && (this.play(this._chn, this._type, this._stream, this._socket), (this.tip = "设备视频链接断开,重新播放...")); }, on_tmn_open() { this.playing && (this.tip = null); }, replay() { this.playing && this.play(this._chn, this._type, this._stream, this._socket); }, close() { let e = arguments.length > 0 && void 0 !== arguments[0] && arguments[0]; if (!this.playing) return (this.tip = null); this._socket.send({ cmd: "real_close", uuid: this.uuid, carId: "_" + this._chn.sim, channel: this._chn.chn, stream: this._stream, }), this._player && (this._player.destroy(), (this._player = null)), this._closeAudio(), this.clear(e); }, _closeAudio() { this._audio_uuid && (this.closeAudio(), this._socket.send({ cmd: "listen_close", uuid: this._audio_uuid, carId: "_" + this._chn.sim, channel: this._chn.chn, stream: "1", }), (this._audio_uuid = null)); }, clear() { let e = arguments.length > 0 && void 0 !== arguments[0] && arguments[0]; (this.playing = this.loading = this.reply = !1), (this.$refs.video.style.display = "none"), (this.title = null), (this.tip = null), (this._chn.player = null), this._chn && this.onClose && this.onClose(this._chn, this, e), (this._chn = null), (this.pause = !1), (this.voice = !1), (this.cloud = !1), (this.rotate = 0), (this.reverse = !1), (this.flow.total = this.flow.kbs = 0), this.record.ing && (clearInterval(this.record.interval), (this.record.ing = !1), (this.record.interval = null)); }, switchStream(e) { this.playing && ((this._stream = e), this._socket.send({ cmd: "real_switch_stream", uuid: this.uuid, carId: "_" + this._chn.sim, channel: this._chn.chn, stream: this._stream, })); }, resize(e, t, i, s) { this.$refs.video && (this.$refs.video.setAttribute("width", e + "px"), this.$refs.video.setAttribute("height", t + "px"), (this.$refs.video.style.left = i), (this.$refs.video.style.top = s), this._player && this._player.onResize()); }, }, }, P = M, N = i("f190"); function B(e) { this["$style"] = N["default"].locals || N["default"]; } var F = Object(u["a"])(P, y, x, !1, B, null, null), V = F.exports, z = i("360e"), j = i("a963"); function H(e, t, i) { if ( ((navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia), navigator.getUserMedia) ) return navigator.getUserMedia( { audio: !0 }, (i) => { t(W(i, e)); }, (s) => U(e, t, i, s.message || s.name) ); U(e, t, null, null); } function U(e, t, i, s) { let n = { mic_open: !1, ws_open: !1 }; (n.mic = new WebSocket("ws://localhost:3316")), (n.mic.binaryType = "arraybuffer"), (n.mic.onopen = () => { (n.mic_open = !0), (n.ws = new WebSocket(e)), (n.ws.binaryType = "arraybuffer"), (n.ws.onopen = () => (n.ws_open = !0)), (n.ws.onclose = () => (n.ws_open = !1)), t(n); }), (n.mic.onmessage = (e) => { n.ws_open && n.ws.send(e.data); }), (n.mic.onerror = () => !n.mic_open && (t(!1), s && i && i(s))), (n.close = () => { (n.ws_open = !1), n.mic && (n.mic.close(), (n.mic = null)), n.ws && (n.ws.close(), (n.ws = null)); }); } function W(e, t) { let i = {}; return ( (i.ws = new WebSocket(t)), (i.ws.binaryType = "arraybuffer"), (i.ws.onopen = () => { i.ws_open = !0; let t = new AudioContext(), s = t.createMediaStreamSource(e); (i.recorder = t.createScriptProcessor(0, 1, 1)), (i.recorder.onaudioprocess = (e) => { let s = e.inputBuffer.getChannelData(0); (s = waveResampler.resample(s, t.sampleRate, 8e3)), (s = G(s)), i.ws_open && i.ws.send(s); }), s.connect(i.recorder), i.recorder.connect(t.destination); }), (i.ws.onclose = () => (i.ws_open = !1)), (i.close = () => { (i.ws_open = !1), i.recorder && i.recorder.disconnect(), (i.recorder = null), i.ws.close(), (i.ws = null); }), i ); } function G(e) { let t = 0, i = new DataView(new ArrayBuffer(2 * e.length)); for (let s = 0; s < e.length; s++, t += 2) { let n = Math.max(-1, Math.min(1, e[s])); i.setInt16(t, n < 0 ? 32768 * n : 32767 * n, !0); } return new Blob([i]); } var Z = void 0; function Y(e) { function t(e, t, i) { for (var s = [], n = 0; n < e; n++) s.push( this.b({ u: t, s: i, Q: 0.5 / Math.sin((Math.PI / (2 * e)) * (n + 0.5)), }) ); for (this.a = [], e = 0; e < s.length; e++) this.a[e] = { A: s[e].c[0], B: s[e].c[1], C: s[e].c[2], v: s[e].i[0], w: s[e].i[1], k: s[e].k, z: [0, 0], }; } function i(e, t, i) { (i = (2 * Math.PI * i) / t), (t = 0), (this.a = []); for (var s = 0; s <= e; s++) 0 === s - e / 2 ? (this.a[s] = i) : ((this.a[s] = Math.sin(i * (s - e / 2)) / (s - e / 2)), (this.a[s] *= 0.54 - 0.46 * Math.cos((2 * Math.PI * s) / e))), (t += this.a[s]); for (i = 0; i <= e; i++) this.a[i] /= t; this.z = this.b(); } function s(e, t, i) { (this.G = e), (this.b = (e - 1) / t), (this.h = this.D), "point" === i.method ? (this.h = this.I) : "linear" === i.method ? (this.h = this.H) : "sinc" === i.method && (this.h = this.J), (this.K = 1 - Math.max(0, Math.min(1, i.tension || 0))), (this.l = i.sincFilterSize || 1), (this.F = o(i.sincWindow || n)); } function n(e) { return Math.exp(((-e / 2) * e) / 2); } function o(e) { return function (t) { return (0 === t ? 1 : Math.sin(Math.PI * t) / (Math.PI * t)) * e(t); }; } function r(e, t, i) { for (var s = 0, n = t.length; s < n; s++) t[s] = i.h(s, e); } (s.prototype.I = function (e, t) { return this.a(Math.round(this.b * e), t); }), (s.prototype.H = function (e, t) { e *= this.b; var i = Math.floor(e); return (e -= i), (1 - e) * this.a(i, t) + e * this.a(i + 1, t); }), (s.prototype.D = function (e, t) { e *= this.b; var i = Math.floor(e), s = [this.j(i, t), this.j(i + 1, t)], n = [this.a(i, t), this.a(i + 1, t)]; (e -= i), (i = e * e); var o = e * i; return ( (2 * o - 3 * i + 1) * n[0] + (o - 2 * i + e) * s[0] + (-2 * o + 3 * i) * n[1] + (o - i) * s[1] ); }), (s.prototype.J = function (e, t) { e *= this.b; var i = Math.floor(e), s = i + this.l, n = 0; for (i = i - this.l + 1; i <= s; i++) n += this.F(e - i) * this.a(i, t); return n; }), (s.prototype.j = function (e, t) { return (this.K * (this.a(e + 1, t) - this.a(e - 1, t))) / 2; }), (s.prototype.a = function (e, t) { return 0 <= e && e < this.G ? t[e] : 0; }), (i.prototype.filter = function (e) { this.z.g[this.z.m] = e; for (var t = (e = 0), i = this.z.g.length; t < i; t++) e += this.a[t] * this.z.g[(this.z.m + t) % this.z.g.length]; return (this.z.m = (this.z.m + 1) % this.z.g.length), e; }), (i.prototype.reset = function () { this.z = this.b(); }), (i.prototype.b = function () { for (var e = [], t = 0; t < this.a.length - 1; t++) e.push(0); return { g: e, m: 0 }; }), (t.prototype.filter = function (e) { for (var t = 0, i = this.a.length; t < i; t++) e = this.l(t, e); return e; }), (t.prototype.b = function (e) { var t = { z: [0, 0], i: [], c: [] }; return ( (e = this.j(e, t)), (t.k = 1), t.c.push((1 - e.o) / (2 * e.f)), t.c.push(2 * t.c[0]), t.c.push(t.c[0]), t ); }), (t.prototype.j = function (e, t) { var i = {}, s = (2 * Math.PI * e.s) / e.u; return ( (i.alpha = Math.sin(s) / (2 * e.Q)), (i.o = Math.cos(s)), (i.f = 1 + i.alpha), (t.f = i.f), t.i.push((-2 * i.o) / i.f), (t.k = 1), t.i.push((1 - i.alpha) / i.f), i ); }), (t.prototype.l = function (e, t) { var i = t * this.a[e].k - this.a[e].v * this.a[e].z[0] - this.a[e].w * this.a[e].z[1], s = this.a[e].A * i + this.a[e].B * this.a[e].z[0] + this.a[e].C * this.a[e].z[1]; return (this.a[e].z[1] = this.a[e].z[0]), (this.a[e].z[0] = i), s; }), (t.prototype.reset = function () { for (var e = 0; e < this.a.length; e++) this.a[e].z = [0, 0]; }); var l = { point: !1, linear: !1, cubic: !0, sinc: !0 }, a = { IIR: 16, FIR: 71 }, h = { IIR: t, FIR: i }; (e.resample = function (e, t, i, n) { n = void 0 === n ? {} : n; var o = new Float64Array(e.length * ((i - t) / t + 1)); n.method = n.method || "cubic"; var c = new s(e.length, o.length, { method: n.method, tension: n.tension || 0, sincFilterSize: n.sincFilterSize || 6, sincWindow: n.sincWindow || void 0, }); if ((void 0 === n.LPF && (n.LPF = l[n.method]), n.LPF)) { n.LPFType = n.LPFType || "IIR"; var d = h[n.LPFType]; if (i > t) { for ( t = new d(n.LPFOrder || a[n.LPFType], i, t / 2), i = 0, n = o.length; i < n; i++ ) o[i] = t.filter(c.h(i, e)); for (t.reset(), e = o.length - 1; 0 <= e; e--) o[e] = t.filter(o[e]); } else { for ( t = new d(n.LPFOrder || a[n.LPFType], t, i / 2), i = 0, n = e.length; i < n; i++ ) e[i] = t.filter(e[i]); for (t.reset(), i = e.length - 1; 0 <= i; i--) e[i] = t.filter(e[i]); r(e, o, c); } } else r(e, o, c); return o; }), Object.defineProperty(e, "__esModule", { value: !0 }); } "object" === typeof exports && "undefined" !== typeof e ? Y(exports) : "function" === typeof define && define.L ? define(["exports"], Y) : ((Z = Z || self), Y((Z.waveResampler = {}))); var q = { components: { Toolbar: m, Button: g["a"], ButtonBar: v["a"], InputSelect: _["a"], }, data() { return { stream: 1, ratio: 0, row: 3, col: 3, count: 9, talks: { options: null, value: null, show: !1, playing: !1, waiting: !1, }, auto_talks: !1, showRcWindow: !1, socketIsOpen: !1, toolbar: "top", }; }, created() { (this._PlayerClass = r["a"].extend(V)), (this.stream = j["a"].get("VRT_STREAM", 1)); }, watch: { socketIsOpen: function (e) { e && this._player_list.forEach((e) => e.replay()); }, }, mounted() { (this._sessionId = this._uuid()), (this._player_map = {}), (this._player_list = []), (this._cfg = {}), this._regrid(), window.addResizeListener(this.$refs.videos, this._onResize), window.onVideoRealPlayLoad && window.onVideoRealPlayLoad(flvjs.isSupported(), this); }, methods: { init(e) { (this._cfg = e), (e.user_pwd = encodeURI(e.user || e.userId || "")), e.pwd && (e.user_pwd += "*" + e.pwd), this._player_list.forEach( (t) => ((t.user_pwd = e.user_pwd), (t.videoIp = e.ip)) ), (this.toolbar = void 0 == e.toolbar ? this.toolbar : e.toolbar), (this._videoUrl = ("https:" == location.protocol ? "wss://" : "ws://") + e.ip + ":" + e.port); let t = 1, i = 1; if ( ((this._socket = new z["a"]( this._sessionId, this._videoUrl + "/video", () => { (this.socketIsOpen = !0), e.onServerOpen && e.onServerOpen(t++), 2 == t && this.auto_talks && this._toogleTalk(); }, () => { (this.socketIsOpen = !1), e.onServerClose && e.onServerClose(i++); } )), this._socket.connect(), this._socket.addListener("real_play", this._on_real_play), this._socket.addListener("play_flow", this._on_play_flow), this._socket.addListener("tmn_close", this._on_tmn_close), this._socket.addListener("tmn_open", this._on_tmn_open), this._socket.addListener("record_start", this._on_record_start), e.count > 0) ) { let t = 1, i = 1; while (t * i < e.count) t == i ? i++ : t++; this.regrid(t, i); } else e.row && e.col && this.regrid(e.row, e.col); this._setPlayTimeout(parseInt(e.timeout || 0)); }, regrid(e, t) { (this.row = e), (this.col = t), (this.count = e * t), this._regrid(); }, playVideo(e, t, i, s) { let n = arguments.length > 4 && void 0 !== arguments[4] && arguments[4]; for (let r, l = 0; l < this._player_list.length; l++) if ( ((r = this._player_list[l]), r.playing && r._chn.sim == t && r._chn.chn == i) ) return 0; let o = this._nextIdlePlayer(); return o ? ((this.stream = 0 === s || 1 === s || "0" === s || "1" === s ? parseInt(s) : this.stream), o.play( { sim: t, chn: i, title: e, cloud: n }, 0, this.stream, this._socket ), 1) : -1; }, closeVideo(e, t) { for (let i, s = 0; s < this._player_list.length; s++) if ( ((i = this._player_list[s]), i.playing && i._chn.sim == e && i._chn.chn == t) ) return i.close(); }, playListen(e, t, i, s) { this._closeAllAudio(), (this._listen = { sim: e, chn: t, uuid: this._uuid(), on_close: s, on_result: (e) => { if (this._listen.uuid == e.uuid) { if ( (this._socket.removeListener( "listen_open", this._listen.on_result ), 0 == e.ret) ) return i && i(1, this._listen.sim, this._listen.chn); this._closeAudio(), (this._listen = null), i && i( 0, this._listen.sim, this._listen.chn, Object(L["a"])(e.ret) ); } }, }), this._socket.addListener("listen_open", this._listen.on_result); let n = "/listen_open/" + [ this._sessionId, this._cfg.user_pwd, this._listen.uuid, "_" + e, t, "1", ].join("/"); this._openAudio(n, !0); }, closeListen() { this._listen && (this._socket.removeListener( "listen_open", this._listen.on_result ), this._socket.send({ cmd: "listen_close", uuid: this._listen.uuid, carId: "_" + this._listen.sim, channel: this._listen.chn, stream: "1", }), this._closeAudio(), this._listen.on_close && this._listen.on_close(this._listen.sim, this._listen.chn), (this._listen = null)); }, showTalks(e, t) { (this.talks.options = e), (this.talks.show = e && e.length > 0), (this.talks.value = this.talks.show ? e[0].value : null), (this.auto_talks = this.talks.show && t); }, _toogleTalk() { if (this.talks.playing) return this.closeTalk(); let e = this.talks.value.split("_"), t = Object(o["a"])(e, 2), i = t[0], s = t[1]; (this.talks.waiting = !0), this.playTalk(i, s, (e, t, i, s) => { if (((this.talks.waiting = !1), 0 == e)) return b["a"].warn(s); (this.talks.playing = !0), 2 == e && b["a"].warn("获取不到本地麦克风 " + (s || "")); }); }, playTalk(e, t, i, s) { this._closeAllAudio(), (this._talk = { sim: e, chn: t, uuid: this._uuid(), on_close: s, on_result: (e) => { if (this._talk.uuid == e.uuid) { if (0 == e.ret) return H( this._videoUrl + "/mic_data/" + this._talk.uuid, (e) => { (this._mic = e), i && i( e ? 1 : 2, this._talk.sim, this._talk.chn, "" ); }, (e) => i && i(2, this._talk.sim, this._talk.chn, e) ); this._socket.removeListener( "talk_open", this._talk.on_result ), this._closeAudio(), (this._talk = null), i && i( 0, this._talk.sim, this._talk.chn, Object(L["a"])(e.ret) ); } }, }), this._socket.addListener("talk_open", this._talk.on_result); let n = "/talk_open/" + [ this._sessionId, this._cfg.user_pwd, this._talk.uuid, "_" + e, t, "1", ].join("/"); this._openAudio(n, !0); }, closeTalk() { this._talk && (this._socket.removeListener("talk_open", this._talk.on_result), this._socket.send({ cmd: "talk_close", uuid: this._talk.uuid, carId: "_" + this._talk.sim, channel: this._talk.chn, stream: "1", }), this._closeAudio(), this._talk.on_close && this._talk.on_close(this._talk.sim, this._talk.chn), (this._talk = null), this._mic && (this._mic.close(), (this._mic = null)), this.talks.show && (this.talks.playing = this.talks.waiting = !1)); }, closeAll() { this._closeAll(), this.closeListen(), this.closeTalk(); }, destroy() { removeResizeListener(this.$refs.videos, this._onResize), this._mouseMove && (document.removeEventListener("mousemove", this._mouseMove), (this._mouseMove = null)), this._interval && (clearInterval(this._interval), (this._interval = null)), this.closeAll(), this._player_list.forEach((e) => e.$destroy()), (this._PlayerClass = null), (this._player_map = null), (this._player_list = null), (this._player = null), this._socket && (this._socket.destroy(), (this._socket = null)); }, _setPlayTimeout(e) { if (e <= 0) return; e *= 1e3; let t = new Date().getTime(), i = !1, s = !1; document.addEventListener( "mousemove", (this._mouseMove = () => (i = !0)) ), (this._interval = setInterval(() => { i ? ((t = new Date().getTime()), (i = s = !1)) : !s && new Date().getTime() - t > e && ((s = !0), this._closeAll() && b["a"].warn("您已长时间不操作系统,视频已经自动关闭")); }, 1e3)); }, _closeAllAudio() { this._player_list.forEach((e) => e.setVoice(!1)), this.closeListen(), this.closeTalk(); }, _on_real_play(e) { let t = this._player_map[e.uuid]; t && t.playing && t.on_real_play(e); }, _on_tmn_close(e) { let t = this._player_map[e.uuid]; t && t.playing && t.on_tmn_close(); }, _on_tmn_open(e) { let t = this._player_map[e.uuid]; t && t.playing && t.on_tmn_open(); }, _on_play_flow(e) { let t = this._player_map[e.uuid]; t && t.playing && t.on_play_flow(e); }, _on_record_start(e) { let t = this._player_map[e.uuid]; t && t.playing && t.on_record_start(e); }, _regrid() { if (0 != this.count) { for (let e = 0; e < this.count; e++) { let t = this._player_list.length > e ? this._player_list[e] : this._newPlayer(); t.$el.style.display = "flex"; } for (let e = this.count; e < this._player_list.length; e++) this._player_list[e].$el.style.display = "none"; (this._playerIsMax = !1), this._player && 1 != this.count && (this._player.border = !0), this._onResize(); } }, _newPlayer() { let e = this._uuid(), t = new this._PlayerClass({ propsData: { uuid: e, sessionId: this._sessionId, user_pwd: this._cfg.user_pwd, videoIp: this._cfg.ip, onClose: this._onPlayerClose, onVoiceOpen: this._onPlayerVoiceOpen, openVideo: this._openVideo, openAudio: this._openAudio, closeAudio: this._closeAudio, }, }); return ( t.$mount(), (t.$el.onclick = () => this._onPlayerClick(t)), (t.$el.ondblclick = () => this._onPlayerDbclick(t)), this.$refs.videos.appendChild(t.$el), this._player_list.push(t), (this._player_map[e] = t), t ); }, _openAudio(e, t) { !t && (this.closeListen(), this.closeTalk()); let i = this._videoUrl + e; (this._audio = flvjs.createPlayer( { type: "flv", isLive: !0, hasAudio: !0, hasVideo: !1, cors: !0, url: i, }, { enableStashBuffer: !1, fixAudioTimestampGap: !1 } )), this._audio.attachMediaElement(this.$refs.audio), this._audio.load(), this._audio.play(); }, _closeAudio() { this._audio && (this._audio.destroy(), (this._audio = null)); }, _openVideo(e, t) { let i = this._videoUrl + e, s = flvjs.createPlayer( { type: "flv", isLive: !0, hasAudio: !1, hasVideo: !0, cors: !0, url: i, }, { enableStashBuffer: !1, fixAudioTimestampGap: !1 } ); return s.attachMediaElement(t), s.load(), s.play(), s; }, _onResize() { if (0 == this.count) return; if (this._playerIsMax) { (this._player.$el.style.width = this.$refs.videos.clientWidth + "px"), (this._player.$el.style.height = this.$refs.videos.clientHeight + "px"); let e = this._getRatioAjust( this.$refs.videos.clientWidth, this.$refs.videos.clientHeight ), t = Object(o["a"])(e, 4), i = t[0], s = t[1], n = t[2], r = t[3]; return void this._player.resize(i, s, n, r); } let e = this.$refs.videos.clientWidth / this.col, t = this.$refs.videos.clientHeight / this.row, i = this._getRatioAjust(e, t), s = Object(o["a"])(i, 4), n = s[0], r = s[1], l = s[2], a = s[3]; (e = Math.ceil(e)), (t = Math.ceil(t)); for ( let o, h = 0, c = Math.min(this.count, this._player_list.length); h < c; h++ ) (o = this._player_list[h]), (o.$el.style.width = e + "px"), (o.$el.style.height = t + "px"), (o.$el.style.left = (h % this.col) * e + "px"), (o.$el.style.top = Math.floor(h / this.col) * t + "px"), o.resize(n, r, l, a); }, _onPlayerClick(e) { this._switchPlayer(e); }, _onPlayerDbclick(e) { if ( ((this._playerIsMax = !this._playerIsMax), !this._playerIsMax) ) return this._regrid(); this._player_list.forEach( (t) => t != e && (t.$el.style.display = "none") ), (e.$el.style.width = this.$refs.videos.clientWidth + "px"), (e.$el.style.height = this.$refs.videos.clientHeight + "px"), (e.$el.style.top = "0px"), (e.$el.style.left = "0px"), (e.border = !1); let t = this._getRatioAjust( this.$refs.videos.clientWidth, this.$refs.videos.clientHeight ), i = Object(o["a"])(t, 4), s = i[0], n = i[1], r = i[2], l = i[3]; e.resize(s, n, r, l); }, _switchPlayer(e) { return this._player == e ? e : (this._player && (this._player.border = !1), (this._player = e), 1 != this.count && (e.border = !0), e); }, _onPlayerClose(e) { let t = e.sim, i = e.chn; this._cfg.onVideoClose && this._cfg.onVideoClose(t, i); }, _onPlayerVoiceOpen(e) { this._player_list.forEach((t) => t != e && t.setVoice(!1)); }, _getRatioAjust(e, t) { if (((t -= 26), 0 == this.ratio)) return [e, t, "0px", "0px"]; let i = e / t; if (this.ratio == i) return [e, t, "0px", "0px"]; if (i > this.ratio) { i = t * this.ratio; let s = (e - i) / 2; return [i, t, s + "px", "0px"]; } { i = e / this.ratio; let s = (t - e / this.ratio) / 2; return [e, i, "0px", s + "px"]; } }, _onStreamChg() { j["a"].set("VRT_STREAM", this.stream), this._player_list.forEach((e) => e.switchStream(this.stream)); }, _onRcBtnClick() { this.showRcWindow || ((this.showRcWindow = !0), this.$nextTick(() => { let e = Object(I["b"])(this.$refs.rcBtn.$el), t = e.left, i = e.top; (this.$refs.rc.style.width = this.$refs.rcBtn.$el.clientWidth + 2 + "px"), (this.$refs.rc.style["z-index"] = window.$_theme.zindex()), (this.$refs.rc.style.left = t + "px"), "top" == this.toolbar ? (this.$refs.rc.style.top = i + this.$refs.rcBtn.$el.clientHeight + "px") : (this.$refs.rc.style.top = i - this.$refs.rc.clientHeight + "px"), document.addEventListener("click", this._hideRcWindow); })); }, _hideRcWindow(e) { this.$refs.rc.contains(e.target) || this.$refs.rcBtn.$el.contains(e.target) || ((this.showRcWindow = !1), document.removeEventListener("click", this._hideRcWindow)); }, _nextIdlePlayer() { let e = this._player ? this._player_list.indexOf(this._player) : 0; for (let t, i = e; i < this.count; i++) if (((t = this._player_list[i]), !t.playing)) return this._switchPlayer(t); e = Math.min(e, this.count); for (let t, i = 0; i < e; i++) if (((t = this._player_list[i]), !t.playing)) return this._switchPlayer(t); return null; }, _closeAll() { if (0 == this._player_list.length) return !1; let e = !1; return ( [...this._player_list].forEach((t) => { (e = e || t.playing), t.close(); }), this._switchPlayer(this._player_list[0]), e ); }, _fullScreen() { let e = this.$refs.videos, t = e.requestFullscreen || e.webkitRequestFullscreen || e.mozRequestFullScreen || e.msRequestFullscreen; t && t.call(e); }, _uuid() { let e = () => ((65536 * (1 + Math.random())) | 0).toString(16).substring(1); return e() + e() + e() + e() + e() + e() + e() + e(); }, }, }, X = q, K = (i("b9fe"), i("930c")); function J(e) { this["$style"] = K["default"].locals || K["default"]; } var Q = Object(u["a"])(X, s, n, !1, J, null, null); t["a"] = Q.exports; }, "2a7d": function (e, t, i) { "use strict"; var s = function () { var e = this, t = e.$createElement, i = e._self._c || t; return i( "button", { class: [ e.$style.btn, "transparent" == e.type && e.$style.transparent, ], style: [ "transparent" != e.type && e.buttonColor, e.buttonStyle, { borderRadius: e.radius }, ], attrs: { type: "button" }, on: { mouseenter: function (t) { !e.disabled_ && (e.hover = !0); }, mouseleave: function (t) { e.hover = !1; }, mousedown: function (t) { !e.disabled_ && (e.down = !0), e.$emit("mousedown", t); }, mouseup: function (t) { !e.disabled_ && (e.down = !1), e.$emit("mouseup", t); }, click: function (t) { !e.disabled_ && e.handleClick(t); }, }, }, [ e.icon_ ? i("i", { class: e.icon_, staticStyle: { "font-size": "16px" }, style: [e.istyle, e.iconStyle], }) : e._e(), e.$slots.default ? i( "span", { staticStyle: { display: "inline-block", "margin-top": "-1px", "vertical-align": "middle", }, style: e.slotStyle, }, [e._t("default")], 2 ) : e._e(), e.disabled_ ? i("div", { class: e.$style.disabled, style: [ e.border && { left: "-1px", top: "-1px", width: "calc(100% + 2px)", height: "calc(100% + 2px)", }, ], }) : e._e(), ] ); }, n = [], o = { name: "Button", props: { type: { type: String, default: "plain" }, customs: { type: Array, default: null }, border: { type: Boolean, default: !0 }, borderColor: { type: String, default: null }, height: { type: Number, default: $_theme.inputHeight }, padding: String, radius: { type: String, default: "0px" }, disabled: Boolean, icon: String, iconStyle: { default: null }, slotStyle: { default: null }, }, data() { return { hover: !1, down: !1, disabled_: this.disabled, icon_: this.icon, }; }, watch: { disabled: function (e) { (this.disabled_ = e), e && (this.hover = !1); }, icon: function (e) { this.icon_ = e; }, }, methods: { handleClick(e) { this.$emit("click", e); }, setIcon(e) { this.icon_ = e; }, setDisabled(e) { this.disabled_ = e; }, }, computed: { istyle() { return this.$slots.default ? { marginRight: "5px", verticalAlign: "middle" } : null; }, buttonStyle() { return { height: this.height + "px", padding: this.padding || "0 " + Math.max(this.height / 2 - 6, 0) + "px", borderWidth: this.border ? "1px" : "0", cursor: this.disabled ? "not-allowed" : "pointer", }; }, buttonColor() { return this[this.type][ this.down ? "down" : this.hover ? "hover" : "normal" ]; }, plain() { return { down: { backgroundColor: this.theme.bg_color, borderColor: this.borderColor || this.theme.color, color: this.theme.color, }, hover: { backgroundColor: "#fff", borderColor: this.borderColor || this.theme.border_color_dark, color: this.theme.color, }, normal: { backgroundColor: "#fff", borderColor: this.borderColor || this.theme.border_color_dark, color: this.disabled ? "#707070" : null, }, }; }, primary() { return { down: { color: "#fff", borderColor: this.theme.color, backgroundColor: this.theme.color, }, hover: { color: "#fff", borderColor: this.theme.rgba(this.theme.color, 0.1), backgroundColor: this.theme.rgba(this.theme.color, 0.8), }, normal: { color: "#fff", borderColor: this.theme.color, backgroundColor: this.theme.color, }, }; }, light() { return { down: { borderColor: this.borderColor || this.theme.border_color_light, color: this.theme.color, backgroundColor: this.theme.selected_color, }, hover: { borderColor: this.borderColor || this.theme.border_color_light, color: this.theme.color, backgroundColor: "#fff", }, normal: { borderColor: this.borderColor || this.theme.border_color_light, backgroundColor: this.theme.bg_color, }, }; }, custom() { return this.customs ? { down: { backgroundColor: this.customs[2][0], borderColor: this.customs[2][1], color: this.customs[2][2], }, hover: { backgroundColor: this.customs[1][0], borderColor: this.customs[1][1], color: this.customs[1][2], }, normal: { backgroundColor: this.customs[0][0], borderColor: this.customs[0][1], color: this.customs[0][2], }, } : {}; }, }, }, r = o, l = i("8f6b"), a = i("2877"); function h(e) { this["$style"] = l["default"].locals || l["default"]; } var c = Object(a["a"])(r, s, n, !1, h, null, null); t["a"] = c.exports; }, "2fbf": function (e, t, i) { "use strict"; var s = i("ce55"), n = i.n(s); t["default"] = n.a; }, "332c": function (e, t, i) { "use strict"; var s = i("bb81"), n = i.n(s); t["default"] = n.a; }, "360e": function (e, t, i) { "use strict"; i.d(t, "a", function () { return s; }); i("ac6a"); function s(e, t, i, s) { (this.onopen = i), (this.onclose = s), (this.sid = e), (this.url = t), (this.ws = null), (this.opened = !1), (this.stopped = !1), (this.listeners = {}); } s.prototype = { connect: function () { (this.stopped = !1), (this.ws = new WebSocket(this.url)), (this.ws.onopen = this._onopen.bind(this)), (this.ws.onmessage = this._onmessage.bind(this)), (this.ws.onclose = this._onclose.bind(this)); }, close: function () { (this.stopped = !0), (this.opened = !1), (this.listeners = {}), this.ws && 1 === this.ws.readyState && this.ws.close(); }, destroy: function () { this.close(), (this.ws = null), (this.onopen = null), (this.onclose = null), (this.listeners = null); }, send: function (e) { return ( !(!this.opened || !this.ws || 1 != this.ws.readyState) && (this.ws.send("string" === typeof e ? e : JSON.stringify(e)), !0) ); }, addListener: function (e, t) { (this.listeners[e] = this.listeners[e] || []), this.listeners[e].push(t); }, removeListener: function (e, t) { let i = this.listeners[e]; if (!i) return; let s = i.indexOf(t); -1 != s && (i.splice(s, 1), i.length || delete this.listeners[e]); }, _onopen: function () { if (this.stopped) return this.ws.close(); (this.opened = !0), (this.time = new Date().getTime()), this._keepalive(), this.onopen && this.onopen(); }, _onmessage: function (e) { (this.time = new Date().getTime()), (e = JSON.parse(e.data)); let t = this.listeners[e.cmd]; t && t.forEach((t) => { try { t(e); } catch (i) { console.log(i); } }); }, _onclose: function () { this.opened && (this.onclose && this.onclose(), (this.opened = !1)), this.keepaliveTimer && (clearTimeout(this.keepaliveTimer), (this.keepaliveTimer = !1)), !this.stopped && this.connect(); }, _keepalive: function () { if (this.opened) { if (new Date().getTime() - this.time > 6e4) return console.log("socket超时断开"), this.ws && this.ws.close(); this.send('{"cmd":"keep_alive","sid":"' + this.sid + '"}'), (this.keepaliveTimer = setTimeout( this._keepalive.bind(this), 1e4 )); } }, }; }, 3727: function (e, t, i) { e.exports = { checked: "InputRadio_checked_2uyhw", unchecked: "InputRadio_unchecked_3F-GA", container: "InputRadio_container_16315", border: "InputRadio_border_31Kcm", label: "InputRadio_label_34Ssu", radioGroup: "InputRadio_radioGroup_1VW9c", radioItem: "InputRadio_radioItem_pdDQ_", unit: "InputRadio_unit_2VcvA", required: "InputRadio_required_2bkNY", disabled: "InputRadio_disabled_yToEl", }; }, "3d56": function (e, t, i) { "use strict"; var s = function () { var e = this, t = e.$createElement, i = e._self._c || t; return i( "div", { class: e.$style.container, style: e.containerStyle }, [ e._l(e.options, function (t, s) { return i( "div", { key: e.getItemValue(t), class: [ e.$style.btnItem, "underline" == e.mode ? null : e.vertical ? e.$style.btnItem_v : e.$style.btnItem_h, ], style: e.getItemValue(t) === e.value ? [ e.checkedStyle, e.gapStyle, e.widthStyle, e.boxShadowStyle(s), e.buttonStyle, ] : [ e.uncheckedStyle, e.gapStyle, e.widthStyle, e.buttonStyle, ], on: { mouseenter: function (i) { e.mouseenter(e.getItemValue(t) !== e.value, i); }, mouseleave: function (i) { e.mouseleave(e.getItemValue(t) !== e.value, i); }, click: function (i) { e.handleClick(e.getItemValue(t)); }, }, }, [ e.iconField ? i("i", { class: t[e.iconField], staticStyle: { "font-size": "16px" }, }) : e._e(), e._v("\n " + e._s(e.getItemText(t)) + "\n "), e._t("default", null, { item: t }), ], 2 ); }), e.disabled ? i("div", { class: e.$style.disabled }) : e._e(), ], 2 ); }, n = [], o = { name: "ButtonBar", props: { value: [String, Number], options: Array, labelField: { type: String, default: "label" }, valueField: { type: String, default: "value" }, iconField: { type: String, default: null }, mode: { type: String, default: "button" }, gap: { type: Number, default: 0 }, widthIsSet: { type: Boolean, default: !0 }, vertical: { type: Boolean, default: !1 }, padding: { type: String, default: "0 10px" }, borderColor: { type: String, default: $_theme.border_color_dark }, disabled: Boolean, height: { type: Number, default: $_theme.inputHeight }, beforeChange: Function, buttonStyle: { default: null }, }, _single: null, data() { return { groupName: window.$_uuid("RadioGroup") }; }, created() { if ( ((this._single = !1), null != this.options && this.options.length) ) { let e = typeof this.options[0]; ("string" != e && "number" != e) || (this._single = !0); } }, methods: { getItemValue(e) { return this._single ? e : e[this.valueField]; }, getItemText(e) { return this._single ? e : e[this.labelField]; }, handleClick(e) { if ( this.value !== e && (!this.beforeChange || !1 !== this.beforeChange(e, this.value)) ) { let t = this.value; this.$emit("input", e), this.$emit("change", e, t); } this.$emit("click", e); }, mouseenter(e, t) { e && (t.target.style.color = this.theme.color); }, mouseleave(e, t) { e && (t.target.style.color = ""); }, boxShadowStyle(e) { return "underline" == this.mode ? null : { boxShadow: `${this.vertical || 0 == e ? "0" : "-1px"} ${ this.vertical && 0 != e ? "-1px" : "0" } 0 0 ${this.theme.color}`, }; }, }, computed: { containerStyle() { return this.vertical ? { flexFlow: "column" } : { height: this.height + "px", lineHeight: this.height + "px", }; }, checkedStyle() { return "underline" == this.mode ? { color: this.theme.color, borderBottomWidth: "2px", borderBottomStyle: "solid", borderBottomColor: this.theme.color, } : { backgroundColor: this.theme.color, borderColor: this.theme.color, color: "#fff", }; }, uncheckedStyle() { return "underline" == this.mode ? null : { backgroundColor: "#fff", borderColor: this.borderColor }; }, gapStyle() { return this.gap <= 0 ? { padding: this.padding } : { borderLeftWidth: "1px", marginRight: this.gap + "px", padding: this.padding, }; }, widthStyle() { return this.widthIsSet ? { width: "100%" } : null; }, }, }, r = o, l = i("5742"), a = i("2877"); function h(e) { this["$style"] = l["default"].locals || l["default"]; } var c = Object(a["a"])(r, s, n, !1, h, null, null); t["a"] = c.exports; }, "3e88": function (e, t, i) { "use strict"; var s = i("6eef"), n = i.n(s); n.a; }, "4a66": function (e, t, i) { "use strict"; var s = i("2b0e"), n = i("7319"); function o(e, t, i) { (t = t || document.body), "string" === typeof t && (t = document.getElementById(t) || document.body); let s = Object(n["b"])(t), o = s.left, r = s.top, l = t.offsetWidth, a = t.offsetHeight, h = e.$el.clientWidth, c = e.$el.clientHeight; if ( ((o = Math.max(0, o + (l - h) / 2)), (r = Math.max(0, r + (a - c) / 3)), (e.$el.style.top = r + "px"), (e.$el.style.left = o + "px"), (e.$el.style["z-index"] = window.$_theme.zindex()), i) ) for (let n in i) e.$el.style[n] = i[n]; } t["a"] = { open: function (e, t, i) { let n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : null, r = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : null, l = arguments.length > 5 ? arguments[5] : void 0, a = arguments.length > 6 ? arguments[6] : void 0, h = s["a"].extend(e), c = new h({ data: t || null, propsData: a || null }); n && n(c); let d = document.createElement("div"); return ( l ? l.appendChild(d) : document.body.appendChild(d), c.$mount(d), o(c, i, r), c ); }, position: (e, t, i) => { o(e, t, i); }, }; }, "4cda": function (e, t, i) { e.exports = { container: "Window_container_2MYCb", fullScreen: "Window_fullScreen_3nxbU", title: "Window_title_17nFY", closebtn: "Window_closebtn_3ravb", fullScreenbtn: "Window_fullScreenbtn_38xSC", header: "Window_header_1r3Ke", footer: "Window_footer_PRMYT", modal: "Window_modal_305nc", waiting: "Window_waiting_1ccAc", }; }, "4d00": function (e, t, i) { "use strict"; var s = i("b1b2"), n = i.n(s); t["default"] = n.a; }, "53b0": function (e, t, i) { "use strict"; i.d(t, "a", function () { return s; }), i.d(t, "b", function () { return n; }), i.d(t, "c", function () { return r; }); i("55dd"); function s(e, t, i) { if (!e) return null; for (let s = 0, n = e.length; s < n; s++) if (e[s][t] === i) return e[s]; return null; } function n(e) { let t = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : null, i = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2]; return e && 0 != e.length ? e.sort((e, s) => { return (i ? 1 : -1) * r(e, s, t); }) : e; } let o = { 零: 10, 一: 11, 二: 12, 三: 13, 四: 14, 五: 15, 六: 16, 七: 17, 八: 18, 九: 19, 十: 20, }; function r(e, t) { let i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : null; if (null === e || void 0 == e) return -1; if (null === t || void 0 == t) return 1; if (((e = i ? e[i] : e), (t = i ? t[i] : t), e == t)) return 0; if (null === e || void 0 == e) return -1; if (null === t || void 0 == t) return 1; let s = !isNaN(e), n = !isNaN(t); if (((e = String(e)), (t = String(t)), s || n)) return s && n ? e.length > t.length ? 1 : e.length < t.length ? -1 : Number(e) > Number(t) ? 1 : -1 : s ? -1 : 1; for ( let l, a, h, c, d = 0, u = Math.min(e.length, t.length); d < u; d++ ) if (((l = e.charAt(d)), (a = t.charAt(d)), l != a)) return ( (h = o[l] || Number(l)), (c = o[a] || Number(a)), isNaN(h) || isNaN(c) ? l.localeCompare(a, "zh") : h > c ? 1 : -1 ); let r = e.length - t.length; return 0 == r ? 0 : r > 0 ? 1 : -1; } }, "568c": function (e, t, i) { e.exports = { layout: "VideoRealPlay_layout_2h5tk", videos: "VideoRealPlay_videos_1frY1", toolbar: "VideoRealPlay_toolbar_1dwqf", }; }, 5742: function (e, t, i) { "use strict"; var s = i("e58f"), n = i.n(s); t["default"] = n.a; }, "58a7": function (e, t, i) { "use strict"; var s = i("2707"), n = i.n(s); t["default"] = n.a; }, 5916: function (e, t, i) { e.exports = { container: "RealVideoPlayer_container_3pUZp", bar: "RealVideoPlayer_bar_2UdJY", border_top: "RealVideoPlayer_border_top_1I_In", border_bottom: "RealVideoPlayer_border_bottom_2NaQf", border_left: "RealVideoPlayer_border_left_3HpXB", border_right: "RealVideoPlayer_border_right_3AwPj", reverse: "RealVideoPlayer_reverse_2VvbS", }; }, "63b4": function (e, t, i) { "use strict"; var s = i("9647"), n = i.n(s); t["default"] = n.a; }, "64fd": function (e, t, i) { "use strict"; var s = i("c695"), n = i.n(s); i("6b54"); const o = "vxe-icon--"; var r = { size: null, zIndex: 100, version: 0, emptyCell: " ", table: { fit: !0, showHeader: !0, delayHover: 250, showOverflow: "tooltip", showHeaderOverflow: "tooltip", highlightHoverRow: !0, highlightCurrentRow: !0, size: "mini", resizable: !0, stripe: !0, border: !0, checkboxConfig: { strict: !0 }, validConfig: { showMessage: !0, message: "default" }, sortConfig: { showIcon: !0 }, filterConfig: { showIcon: !0 }, treeConfig: { children: "children", hasChild: "hasChild", indent: 20, showIcon: !0, }, expandConfig: { showIcon: !0 }, editConfig: { showIcon: !0, showAsterisk: !0 }, importConfig: { modes: ["insert", "covering"] }, exportConfig: { modes: ["current", "selected"] }, printConfig: { modes: ["current", "selected"] }, mouseConfig: { extension: !0 }, areaConfig: { selectCellByHeader: !0 }, clipConfig: { isCopy: !0, isCut: !0, isPaste: !0 }, fnrConfig: { isFind: !0, isReplace: !0 }, scrollX: { enabled: !0, gt: 60 }, scrollY: { enabled: !0, gt: 100 }, }, export: { types: {} }, icon: { TABLE_SORT_ASC: o + "caret-top", TABLE_SORT_DESC: o + "caret-bottom", TABLE_FILTER_NONE: o + "funnel", TABLE_FILTER_MATCH: o + "funnel", TABLE_EDIT: o + "edit-outline", TABLE_HELP: o + "question", TABLE_TREE_LOADED: o + "refresh roll", TABLE_TREE_OPEN: o + "caret-right rotate90", TABLE_TREE_CLOSE: o + "caret-right", TABLE_EXPAND_LOADED: o + "refresh roll", TABLE_EXPAND_OPEN: o + "arrow-right rotate90", TABLE_EXPAND_CLOSE: o + "arrow-right", BUTTON_DROPDOWN: o + "arrow-bottom", BUTTON_LOADING: o + "refresh roll", SELECT_LOADED: o + "refresh roll", SELECT_OPEN: o + "caret-bottom rotate180", SELECT_CLOSE: o + "caret-bottom", PAGER_JUMP_PREV: o + "d-arrow-left", PAGER_JUMP_NEXT: o + "d-arrow-right", PAGER_PREV_PAGE: o + "arrow-left", PAGER_NEXT_PAGE: o + "arrow-right", PAGER_JUMP_MORE: o + "more", INPUT_CLEAR: o + "close", INPUT_PWD: o + "eye-slash", INPUT_SHOW_PWD: o + "eye", INPUT_PREV_NUM: o + "caret-top", INPUT_NEXT_NUM: o + "caret-bottom", INPUT_DATE: o + "calendar", INPUT_SEARCH: o + "search", MODAL_ZOOM_IN: o + "square", MODAL_ZOOM_OUT: o + "zoomout", MODAL_CLOSE: o + "close", MODAL_INFO: o + "info", MODAL_SUCCESS: o + "success", MODAL_WARNING: o + "warning", MODAL_ERROR: o + "error", MODAL_QUESTION: o + "question", MODAL_LOADING: o + "refresh roll", TOOLBAR_TOOLS_REFRESH: o + "refresh", TOOLBAR_TOOLS_REFRESH_LOADING: o + "refresh roll", TOOLBAR_TOOLS_IMPORT: o + "upload", TOOLBAR_TOOLS_EXPORT: o + "download", TOOLBAR_TOOLS_PRINT: o + "print", TOOLBAR_TOOLS_ZOOM_IN: o + "zoomin", TOOLBAR_TOOLS_ZOOM_OUT: o + "zoomout", TOOLBAR_TOOLS_CUSTOM: o + "menu", FORM_PREFIX: o + "question", FORM_SUFFIX: o + "question", FORM_FOLDING: o + "arrow-top rotate180", FORM_UNFOLDING: o + "arrow-top", }, grid: { size: "mini", formConfig: { enabled: !0 }, pagerConfig: { enabled: !0 }, toolbarConfig: { enabled: !0 }, proxyConfig: { enabled: !0, autoLoad: !0, message: !0, props: { list: null, result: "result", total: "page.total", message: "message", }, }, }, tooltip: { trigger: "hover", skin: "dark", leaveDelay: 300 }, pager: {}, form: { validConfig: { showMessage: !0, autoPos: !0 }, titleAsterisk: !0, }, input: { minDate: new Date(1900, 0, 1), maxDate: new Date(2100, 0, 1), startDay: 1, selectDay: 1, digits: 2, controls: !0, }, textarea: {}, select: { multiCharOverflow: 8 }, toolbar: {}, button: {}, radio: {}, checkbox: {}, switch: {}, modal: { top: 15, showHeader: !0, minWidth: 340, minHeight: 140, lockView: !0, mask: !0, duration: 3e3, marginSize: 0, dblclickZoom: !0, showTitleOverflow: !0, animat: !0, showClose: !0, storageKey: "VXE_MODAL_POSITION", }, list: { scrollY: { enabled: !0, gt: 100 } }, i18n: (e) => e, }; i("28a5"), i("a481"), i("ac6a"), i("d263"); class l { constructor() { this.store = {}; } mixin(e) { return Object.assign(this.store, e), l; } get(e) { return this.store[e]; } add(e, t) { return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && (n.a.eqNull(this.store[e]) || this.store[e] === t || g.warn("vxe.error.coverProp", [this._name, e])), (this.store[e] = t), l ); } delete(e) { return delete this.store[e], l; } } var a = l; const h = new a(); "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && Object.assign(h, { _name: "Formats" }); let c = 0, d = 1; class u { constructor(e, t) { let i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : {}, s = i.renderHeader, o = i.renderCell, r = i.renderFooter, l = i.renderData; const a = e.$xegrid, c = a ? a.proxyOpts : null, d = t.formatter, u = !n.a.isBoolean(t.visible) || t.visible; if ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV ) { const i = ["seq", "index", "checkbox", "radio", "expand", "html"]; if ( (t.type && -1 === i.indexOf(t.type) && g.warn("vxe.error.errProp", [`type=${t.type}`, i.join(", ")]), (n.a.isBoolean(t.cellRender) || (t.cellRender && !n.a.isObject(t.cellRender))) && g.warn("vxe.error.errProp", [ `column.cell-render=${t.cellRender}`, "column.cell-render={}", ]), (n.a.isBoolean(t.editRender) || (t.editRender && !n.a.isObject(t.editRender))) && g.warn("vxe.error.errProp", [ `column.edit-render=${t.editRender}`, "column.edit-render={}", ]), t.cellRender && t.editRender && g.warn("vxe.error.errConflicts", [ "column.cell-render", "column.edit-render", ]), "expand" === t.type && e.treeConfig && e.treeOpts.line && g.error("vxe.error.errConflicts", [ "tree-config.line", "column.type=expand", ]), t.remoteSort && g.warn("vxe.error.delProp", [ "column.remote-sort", "sort-config.remote", ]), t.sortMethod && g.warn("vxe.error.delProp", [ "column.sort-method", "sort-config.sortMethod", ]), d) ) if (n.a.isString(d)) { const e = h.get(d) || n.a[d]; n.a.isFunction(e) || g.error("vxe.error.notFunc", [d]); } else if (n.a.isArray(d)) { const e = h.get(d[0]) || n.a[d[0]]; n.a.isFunction(e) || g.error("vxe.error.notFunc", [d[0]]); } } Object.assign(this, { type: t.type, property: t.field, title: t.title, width: t.width, minWidth: t.minWidth, resizable: t.resizable, fixed: t.fixed, align: t.align, headerAlign: t.headerAlign, footerAlign: t.footerAlign, showOverflow: t.showOverflow, showHeaderOverflow: t.showHeaderOverflow, showFooterOverflow: t.showFooterOverflow, className: t.className, headerClassName: t.headerClassName, footerClassName: t.footerClassName, formatter: d, sortable: t.sortable, sortBy: t.sortBy, sortType: t.sortType, sortMethod: t.sortMethod, remoteSort: t.remoteSort, sortByFormatter: t.sortByFormatter, filters: g.getFilters(t.filters), filterMultiple: !n.a.isBoolean(t.filterMultiple) || t.filterMultiple, filterMethod: t.filterMethod, filterResetMethod: t.filterResetMethod, filterRecoverMethod: t.filterRecoverMethod, filterRender: t.filterRender, treeNode: t.treeNode, cellType: t.cellType, cellRender: t.cellRender, editRender: t.editRender, contentRender: t.contentRender, exportMethod: t.exportMethod, footerExportMethod: t.footerExportMethod, titleHelp: t.titleHelp, params: t.params, id: t.colId || n.a.uniqueId("col_"), parentId: null, visible: u, halfVisible: !1, defaultVisible: u, checked: !1, halfChecked: !1, disabled: !1, level: 1, rowSpan: 1, colSpan: 1, order: null, sortTime: 0, renderWidth: 0, renderHeight: 0, resizeWidth: 0, renderLeft: 0, renderArgs: [], model: {}, renderHeader: s || t.renderHeader, renderCell: o || t.renderCell, renderFooter: r || t.renderFooter, renderData: l, slots: t.slots, }), c && c.beforeColumn && c.beforeColumn({ $grid: a, column: this }); } getTitle() { return g.getFuncText( this.title || ("seq" === this.type || "index" === this.type ? r.i18n("vxe.table.seqTitle") : "") ); } getKey() { return this.property || (this.type ? `type=${this.type}` : null); } update(e, t) { "filters" !== e && ("field" === e ? (this.property = t) : (this[e] = t)); } } function p(e) { return e && !1 !== e.enabled; } function f(e) { return function (t, i) { const s = g.getLog(t, i); return console[e](s), s; }; } function m(e) { return "" === e || n.a.eqNull(e); } const g = { warn: f("warn"), error: f("error"), getLog(e, t) { return `[vxe-table] ${r.i18n(e, t)}`; }, getFuncText(e) { return n.a.isFunction(e) ? e() : r.translate ? r.translate(e) : e; }, nextZIndex() { return (d = r.zIndex + c++), d; }, getLastZIndex() { return d; }, getRowkey(e) { return e.rowId || "_XID"; }, getRowid(e, t) { const i = n.a.get(t, g.getRowkey(e)); return i ? encodeURIComponent(i) : ""; }, getColumnList(e) { const t = []; return ( e.forEach((e) => { t.push( ...(e.children && e.children.length ? g.getColumnList(e.children) : [e]) ); }), t ); }, getClass(e, t) { return e ? (n.a.isFunction(e) ? e(t) : e) : ""; }, getFilters(e) { return e && n.a.isArray(e) ? e.map((e) => { let t = e.label, i = e.value, s = e.data, n = e.resetValue, o = e.checked; return { label: t, value: i, data: s, resetValue: n, checked: !!o, _checked: !!o, }; }) : e; }, formatText(e, t) { return ( "" + ("" === e || null === e || void 0 === e ? t ? r.emptyCell : "" : e) ); }, getCellValue(e, t) { return n.a.get(e, t.property); }, setCellValue(e, t, i) { return n.a.set(e, t.property, i); }, isColumn(e) { return e instanceof u; }, getColumnConfig(e, t, i) { return g.isColumn(t) ? t : new u(e, t, i); }, assemColumn(e) { const t = e.$el, i = e.$xetable, s = e.$xecolumn, n = e.columnConfig, o = s ? s.columnConfig : null; (n.slots = e.$scopedSlots), o ? ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && ("vxe-table-column" === s.$options._componentTag ? g.error("vxe.error.groupTag", [ ``, ``, ]) : "vxe-column" === s.$options._componentTag && g.warn("vxe.error.groupTag", [ ``, ``, ])), o.children || (o.children = []), o.children.splice([].indexOf.call(s.$el.children, t), 0, n)) : i.staticColumns.splice( [].indexOf.call(i.$refs.hideColumn.children, t), 0, n ); }, destroyColumn(e) { const t = e.$xetable, i = e.columnConfig, s = n.a.findTree(t.staticColumns, (e) => e === i); s && s.items.splice(s.index, 1); }, hasChildrenList(e) { return e && e.children && e.children.length > 0; }, parseFile(e) { const t = e.name, i = n.a.lastIndexOf(t, "."), s = t.substring(i + 1, t.length), o = t.substring(0, i); return { filename: o, type: s }; }, isNumVal(e) { return !isNaN(parseFloat("" + e)); }, }; var v = g; i("4917"), i("3b2b"); const _ = v.getRowid, b = n.a.browse(), y = {}; function x(e) { return y[e] || (y[e] = new RegExp(`(?:^|\\s)${e}(?!\\S)`, "g")), y[e]; } function w(e, t, i) { if (e) { const s = e.parentNode; if ( ((i.top += e.offsetTop), (i.left += e.offsetLeft), s && s !== document.documentElement && s !== document.body && ((i.top -= s.scrollTop), (i.left -= s.scrollLeft)), (!t || (e !== t && e.offsetParent !== t)) && e.offsetParent) ) return w(e.offsetParent, t, i); } return i; } function S(e) { return e && /^\d+%$/.test(e); } function E(e, t) { return e && e.className && e.className.match && e.className.match(x(t)); } function k(e, t) { e && E(e, t) && (e.className = e.className.replace(x(t), "")); } function C() { const e = document.documentElement, t = document.body; return { scrollTop: e.scrollTop || t.scrollTop, scrollLeft: e.scrollLeft || t.scrollLeft, visibleHeight: e.clientHeight || t.clientHeight, visibleWidth: e.clientWidth || t.clientWidth, }; } function T(e) { return e ? e.offsetHeight : 0; } function O(e) { if (e) { const t = getComputedStyle(e), i = n.a.toNumber(t.paddingTop), s = n.a.toNumber(t.paddingBottom); return i + s; } return 0; } function $(e, t) { e && (e.scrollTop = t); } function R(e, t) { e && (e.scrollLeft = t); } const A = { browse: b, isPx(e) { return e && /^\d+(px)?$/.test(e); }, isScale: S, hasClass: E, removeClass: k, addClass(e, t) { e && !E(e, t) && (k(e, t), (e.className = `${e.className} ${t}`)); }, updateCellTitle(e, t) { const i = "html" === t.type ? e.innerText : e.textContent; e.getAttribute("title") !== i && e.setAttribute("title", i); }, rowToVisible(e, t) { const i = e.$refs.tableBody.$el, s = i.querySelector(`[rowid="${_(e, t)}"]`); if (s) { const t = i.clientHeight, n = i.scrollTop, o = s.offsetTop + (s.offsetParent ? s.offsetParent.offsetTop : 0), r = s.clientHeight; if (o < n || o > n + t) return e.scrollTo(null, o); if (o + r >= t + n) return e.scrollTo(null, n + r); } else if (e.scrollYLoad) return e.scrollTo( null, (e.afterFullData.indexOf(t) - 1) * e.scrollYStore.rowHeight ); return Promise.resolve(); }, colToVisible(e, t) { const i = e.$refs.tableBody.$el, s = i.querySelector(`.${t.id}`); if (s) { const t = i.clientWidth, n = i.scrollLeft, o = s.offsetLeft + (s.offsetParent ? s.offsetParent.offsetLeft : 0), r = s.clientWidth; if (o < n || o > n + t) return e.scrollTo(o); if (o + r >= t + n) return e.scrollTo(n + r); } else if (e.scrollXLoad) { const i = e.visibleColumn; let s = 0; for (let e = 0; e < i.length; e++) { if (i[e] === t) break; s += i[e].renderWidth; } return e.scrollTo(s); } return Promise.resolve(); }, getDomNode: C, getEventTargetNode(e, t, i, s) { let n, o = e.target; while (o && o.nodeType && o !== document) { if (i && E(o, i) && (!s || s(o))) n = o; else if (o === t) return { flag: !i || !!n, container: t, targetElem: n }; o = o.parentNode; } return { flag: !1 }; }, getOffsetPos(e, t) { return w(e, t, { left: 0, top: 0 }); }, getAbsolutePos(e) { const t = e.getBoundingClientRect(), i = t.top, s = t.left, n = C(), o = n.scrollTop, r = n.scrollLeft, l = n.visibleHeight, a = n.visibleWidth; return { boundingTop: i, top: o + i, boundingLeft: s, left: r + s, visibleHeight: l, visibleWidth: a, }; }, scrollToView(e) { const t = "scrollIntoViewIfNeeded", i = "scrollIntoView"; e && (e[t] ? e[t]() : e[i] && e[i]()); }, triggerEvent(e, t) { let i; "function" === typeof Event ? (i = new Event(t)) : ((i = document.createEvent("Event")), i.initEvent(t, !0, !0)), e.dispatchEvent(i); }, calcHeight(e, t) { const i = e[t]; let s = 0; if (i) if ("auto" === i) s = e.parentHeight; else { const t = e.getExcludeHeight(); (s = S(i) ? Math.floor(((n.a.toInteger(i) || 1) / 100) * e.parentHeight) : n.a.toNumber(i)), (s = Math.max(40, s - t)); } return s; }, }; const L = { F2: "F2", ESCAPE: "Escape", ENTER: "Enter", TAB: "Tab", DELETE: "Delete", BACKSPACE: "Backspace", SPACEBAR: " ", CONTEXT_MENU: "ContextMenu", ARROW_UP: "ArrowUp", ARROW_DOWN: "ArrowDown", ARROW_LEFT: "ArrowLeft", ARROW_RIGHT: "ArrowRight", PAGE_UP: "PageUp", PAGE_DOWN: "PageDown", }, D = (L.CONTEXT_MENU, L.DELETE, L.ARROW_UP, L.ARROW_DOWN, L.ARROW_LEFT, L.ARROW_RIGHT, b.firefox ? "DOMMouseScroll" : "mousewheel"), I = [], M = { on(e, t, i) { i && I.push({ comp: e, type: t, cb: i }); }, off(e, t) { n.a.remove(I, (i) => i.comp === e && i.type === t); }, trigger(e) { const t = e.type === D; I.forEach((i) => { let s = i.comp, n = i.type, o = i.cb; e.cancelBubble || ((n === e.type || (t && "mousewheel" === n)) && o.call(s, e)); }); }, eqKeypad(e, t) { const i = e.key; return t.toLowerCase() === i.toLowerCase(); }, }; b.isDoc && (b.msie || (document.addEventListener("copy", M.trigger, !1), document.addEventListener("cut", M.trigger, !1), document.addEventListener("paste", M.trigger, !1)), document.addEventListener("keydown", M.trigger, !1), document.addEventListener("contextmenu", M.trigger, !1), window.addEventListener("mousedown", M.trigger, !1), window.addEventListener("blur", M.trigger, !1), window.addEventListener("resize", M.trigger, !1), window.addEventListener( D, n.a.throttle(M.trigger, 100, { leading: !0, trailing: !1 }), !1 )); let P; const N = [], B = 500; function F() { N.length && (N.forEach((e) => { e.tarList.forEach((t) => { const i = t.target, s = t.width, n = t.heighe, o = i.clientWidth, r = i.clientHeight, l = o && s !== o, a = r && n !== r; (l || a) && ((t.width = o), (t.heighe = r), setTimeout(e.callback)); }); }), V()); } function V() { clearTimeout(P), (P = setTimeout(F, r.resizeInterval || B)); } class z { constructor(e) { (this.tarList = []), (this.callback = e); } observe(e) { e && (this.tarList.some((t) => t.target === e) || this.tarList.push({ target: e, width: e.clientWidth, heighe: e.clientHeight, }), N.length || V(), N.some((e) => e === this) || N.push(this)); } unobserve(e) { n.a.remove(N, (t) => t.tarList.some((t) => t.target === e)); } disconnect() { n.a.remove(N, (e) => e === this); } } function j(e) { return window.ResizeObserver ? new window.ResizeObserver(e) : new z(e); } function H(e) { return n.a.toString(e).replace("_", "").toLowerCase(); } const U = "created,mounted,activated,beforeDestroy,destroyed,event.clearActived,event.clearFilter,event.clearAreas,event.showMenu,event.keydown,event.export,event.import" .split(",") .map(H), W = {}, G = { mixin(e) { return n.a.each(e, (e, t) => G.add(t, e)), G; }, get(e) { return W[H(e)] || []; }, add(e, t) { if ( ((e = H(e)), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && -1 === U.indexOf(e) && g.warn("vxe.error.errProp", [`Interceptor.${e}`, U.join("|")]), t && U.indexOf(e) > -1) ) { let i = W[e]; i || (i = W[e] = []), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && i.indexOf(t) > -1 && g.warn("vxe.error.coverProp", ["Interceptor", e]), i.push(t); } return G; }, delete(e, t) { const i = W[H(e)]; return i && n.a.remove(i, (e) => e === t), G; }, }, Z = { transfer: !0 }, Y = "value"; function q(e) { return null === e || void 0 === e || "" === e; } function X(e) { switch (e.name) { case "input": case "textarea": case "$input": case "$textarea": return "input"; } return "change"; } function K(e, t) { return e && t.valueFormat ? n.a.toStringDate(e, t.valueFormat) : e; } function J(e, t, i) { const s = t.dateConfig, o = void 0 === s ? {} : s; return n.a.toDateString(K(e, t), o.labelFormat || i); } function Q(e, t) { return J(e, t, r.i18n(`vxe.input.date.labelFormat.${t.type}`)); } function ee(e) { let t = e.name; return `vxe-${t.replace("$", "")}`; } function te(e, t, i) { const s = e.$panel; s.changeOption({}, t, i); } function ie(e) { let t = e.name, i = e.attrs; return "input" === t && (i = Object.assign({ type: "text" }, i)), i; } function se(e) { const t = e.name, i = e.immediate, s = e.props; if (!i) { if ("$input" === t) { const e = s || {}, t = e.type; return !( !t || "text" === t || "number" === t || "integer" === t || "float" === t ); } return "input" !== t && "textarea" !== t && "$textarea" !== t; } return i; } function ne(e, t) { return "cell" === t.$type || se(e); } function oe(e, t, i, s) { const o = t.$table.vSize; return n.a.assign( { immediate: se(e) }, o ? { size: o } : {}, Z, s, e.props, { [Y]: i } ); } function re(e, t, i, s) { const o = t.$table.vSize; return n.a.assign(o ? { size: o } : {}, Z, s, e.props, { [Y]: i }); } function le(e, t, i, s) { const o = t.$form.vSize; return n.a.assign(o ? { size: o } : {}, Z, s, e.props, { [Y]: i }); } function ae(e, t, i, s) { const n = t.placeholder; return [ e( "span", { class: "vxe-cell--label" }, n && q(s) ? [ e( "span", { class: "vxe-cell--placeholder" }, g.formatText(g.getFuncText(n), 1) ), ] : g.formatText(s, 1) ), ]; } function he(e, t) { const i = e.nativeEvents, s = {}; return ( n.a.objectEach(i, (e, i) => { s[i] = function () { for ( var i = arguments.length, s = new Array(i), n = 0; n < i; n++ ) s[n] = arguments[n]; e(t, ...s); }; }), s ); } function ce(e, t, i, s) { const o = e.name, r = e.events, l = "input", a = X(e), h = a === l, c = {}; return ( n.a.objectEach(r, (e, i) => { c[i] = function () { for ( var i = arguments.length, s = new Array(i), n = 0; n < i; n++ ) s[n] = arguments[n]; e(t, ...s); }; }), i && (c[l] = function (e) { i("$input" === o || "$textarea" === o ? e.value : e), r && r[l] && r[l](t, e), h && s && s(e); }), !h && s && (c[a] = function () { for ( var e = arguments.length, i = new Array(e), n = 0; n < e; n++ ) i[n] = arguments[n]; s(...i), r && r[a] && r[a](t, ...i); }), c ); } function de(e, t) { const i = t.$table, s = t.row, n = t.column, o = e.name, r = n.model, l = ne(e, t); return ce( e, t, (e) => { l ? g.setCellValue(s, n, e) : ((r.update = !0), (r.value = e)); }, (e) => { l || ("$input" !== o && "$textarea" !== o) ? i.updateStatus(t) : i.updateStatus(t, e.value); } ); } function ue(e, t, i) { return ce( e, t, (e) => { i.data = e; }, () => { te(t, !n.a.eqNull(i.data), i); } ); } function pe(e, t) { const i = t.$form, s = t.data, o = t.property; return ce( e, t, (e) => { n.a.set(s, o, e); }, () => { i.updateStatus(t); } ); } function fe(e, t) { const i = t.$table, s = t.row, n = t.column, o = n.model; return ce( e, t, (i) => { const r = i.target.value; ne(e, t) ? g.setCellValue(s, n, r) : ((o.update = !0), (o.value = r)); }, (e) => { const s = e.target.value; i.updateStatus(t, s); } ); } function me(e, t, i) { return ce( e, t, (e) => { i.data = e.target.value; }, () => { te(t, !n.a.eqNull(i.data), i); } ); } function ge(e, t) { const i = t.$form, s = t.data, o = t.property; return ce( e, t, (e) => { const t = e.target.value; n.a.set(s, o, t); }, () => { i.updateStatus(t); } ); } function ve(e, t, i) { const s = i.row, n = i.column, o = t.name, r = ie(t), l = ne(t, i) ? g.getCellValue(s, n) : n.model.value; return [ e(o, { class: `vxe-default-${o}`, attrs: r, domProps: { value: l }, on: fe(t, i), }), ]; } function _e(e, t, i) { const s = i.row, n = i.column, o = g.getCellValue(s, n); return [ e(ee(t), { props: oe(t, i, o), on: de(t, i), nativeOn: he(t, i) }), ]; } function be(e, t, i) { return [ e("vxe-button", { props: oe(t, i), on: ce(t, i), nativeOn: he(t, i), }), ]; } function ye(e, t, i) { return t.children.map((t) => be(e, t, i)[0]); } function xe(e, t, i, s) { const n = t.optionGroups, o = t.optionGroupProps, r = void 0 === o ? {} : o, l = r.options || "options", a = r.label || "label"; return n.map((n, o) => { return e( "optgroup", { key: o, domProps: { label: n[a] } }, s(e, n[l], t, i) ); }); } function we(e, t, i, s) { const n = i.optionProps, o = void 0 === n ? {} : n, r = s.row, l = s.column, a = o.label || "label", h = o.value || "value", c = o.disabled || "disabled", d = ne(i, s) ? g.getCellValue(r, l) : l.model.value; return t.map((t, i) => { return e( "option", { key: i, attrs: { value: t[h], disabled: t[c] }, domProps: { selected: t[h] == d }, }, t[a] ); }); } function Se(e, t, i) { const s = i.column, n = t.name, o = ie(t); return s.filters.map((s, r) => { return e(n, { key: r, class: `vxe-default-${n}`, attrs: o, domProps: { value: s.data }, on: me(t, i, s), }); }); } function Ee(e, t, i) { const s = i.column; return s.filters.map((s, n) => { const o = s.data; return e(ee(t), { key: n, props: re(t, t, o), on: ue(t, i, s) }); }); } function ke(e) { let t = e.option, i = e.row, s = e.column; const o = t.data, r = n.a.get(i, s.property); return r == o; } function Ce(e, t, i) { return [ e( "select", { class: "vxe-default-select", attrs: ie(t), on: fe(t, i) }, t.optionGroups ? xe(e, t, i, we) : we(e, t.options, t, i) ), ]; } function Te(e, t, i) { const s = i.row, n = i.column, o = t.options, r = t.optionProps, l = t.optionGroups, a = t.optionGroupProps, h = g.getCellValue(s, n); return [ e(ee(t), { props: oe(t, i, h, { options: o, optionProps: r, optionGroups: l, optionGroupProps: a, }), on: de(t, i), }), ]; } function Oe(e, t) { let i = t.row, s = t.column; const o = e.props, r = void 0 === o ? {} : o, l = e.options, a = e.optionGroups, h = e.optionProps, c = void 0 === h ? {} : h, d = e.optionGroupProps, u = void 0 === d ? {} : d, p = n.a.get(i, s.property); let f; const m = c.label || "label", g = c.value || "value"; return q(p) ? null : n.a .map( r.multiple ? p : [p], a ? (e) => { const t = u.options || "options"; for (let i = 0; i < a.length; i++) if (((f = n.a.find(a[i][t], (t) => t[g] == e)), f)) break; return f ? f[m] : e; } : (e) => { return (f = n.a.find(l, (t) => t[g] == e)), f ? f[m] : e; } ) .join(", "); } function $e(e, t, i) { const s = i.data, o = i.property, r = t.name, l = ie(t), a = n.a.get(s, o); return [ e(r, { class: `vxe-default-${r}`, attrs: l, domProps: !l || "input" !== r || ("submit" !== l.type && "reset" !== l.type) ? { value: a } : null, on: ge(t, i), }), ]; } function Re(e, t, i) { const s = i.data, o = i.property, r = n.a.get(s, o); return [ e(ee(t), { props: le(t, i, r), on: pe(t, i), nativeOn: he(t, i) }), ]; } function Ae(e, t, i) { return [ e("vxe-button", { props: le(t, i), on: ce(t, i), nativeOn: he(t, i), }), ]; } function Le(e, t, i) { return t.children.map((t) => Ae(e, t, i)[0]); } function De(e, t, i, s) { const o = s.data, r = s.property, l = i.optionProps, a = void 0 === l ? {} : l, h = a.label || "label", c = a.value || "value", d = a.disabled || "disabled", u = n.a.get(o, r); return t.map((t, i) => { return e( "option", { key: i, attrs: { value: t[c], disabled: t[d] }, domProps: { selected: t[c] == u }, }, t[h] ); }); } function Ie(e) { const t = e.row, i = e.column, s = e.options; return s.original ? g.getCellValue(t, i) : Oe(i.editRender || i.cellRender, e); } function Me(e, t, i) { const s = t.options, o = t.optionProps, r = void 0 === o ? {} : o, l = i.data, a = i.property, h = r.label || "label", c = r.value || "value", d = r.disabled || "disabled", u = n.a.get(l, a), p = ee(t); return [ e( `${p}-group`, { props: le(t, i, u), on: pe(t, i), nativeOn: he(t, i) }, s.map((t, i) => { return e(p, { key: i, props: { label: t[c], content: t[h], disabled: t[d] }, }); }) ), ]; } const Pe = { input: { autofocus: "input", renderEdit: ve, renderDefault: ve, renderFilter: Se, filterMethod: ke, renderItemContent: $e, }, textarea: { autofocus: "textarea", renderEdit: ve, renderItemContent: $e, }, select: { renderEdit: Ce, renderDefault: Ce, renderCell(e, t, i) { return ae(e, t, i, Oe(t, i)); }, renderFilter(e, t, i) { const s = i.column; return s.filters.map((s, n) => { return e( "select", { key: n, class: "vxe-default-select", attrs: ie(t), on: me(t, i, s), }, t.optionGroups ? xe(e, t, i, we) : we(e, t.options, t, i) ); }); }, filterMethod: ke, renderItemContent(e, t, i) { return [ e( "select", { class: "vxe-default-select", attrs: ie(t), on: ge(t, i) }, t.optionGroups ? xe(e, t, i, De) : De(e, t.options, t, i) ), ]; }, cellExportMethod: Ie, }, $input: { autofocus: ".vxe-input--inner", renderEdit: _e, renderCell(e, t, i) { const s = t.props, o = void 0 === s ? {} : s, l = i.row, a = i.column, h = o.digits || r.input.digits; let c = n.a.get(l, a.property); if (c) switch (o.type) { case "date": case "week": case "month": case "year": c = Q(c, o); break; case "float": c = n.a.toFixed(n.a.floor(c, h), h); break; } return ae(e, t, i, c); }, renderDefault: _e, renderFilter: Ee, filterMethod: ke, renderItemContent: Re, }, $textarea: { autofocus: ".vxe-textarea--inner", renderItemContent: Re, }, $button: { renderDefault: be, renderItemContent: Ae }, $buttons: { renderDefault: ye, renderItemContent: Le }, $select: { autofocus: ".vxe-input--inner", renderEdit: Te, renderDefault: Te, renderCell(e, t, i) { return ae(e, t, i, Oe(t, i)); }, renderFilter(e, t, i) { const s = i.column, n = t.options, o = t.optionProps, r = t.optionGroups, l = t.optionGroupProps, a = he(t, i); return s.filters.map((s, h) => { const c = s.data; return e(ee(t), { key: h, props: re(t, i, c, { options: n, optionProps: o, optionGroups: r, optionGroupProps: l, }), on: ue(t, i, s), nativeOn: a, }); }); }, filterMethod: ke, renderItemContent(e, t, i) { const s = i.data, o = i.property, r = t.options, l = t.optionProps, a = t.optionGroups, h = t.optionGroupProps, c = n.a.get(s, o); return [ e(ee(t), { props: le(t, i, c, { options: r, optionProps: l, optionGroups: a, optionGroupProps: h, }), on: pe(t, i), nativeOn: he(t, i), }), ]; }, cellExportMethod: Ie, }, $radio: { autofocus: ".vxe-radio--input", renderItemContent: Me }, $checkbox: { autofocus: ".vxe-checkbox--input", renderItemContent: Me, }, $switch: { autofocus: ".vxe-switch--button", renderEdit: _e, renderDefault: _e, renderItemContent: Re, }, }, Ne = { mixin(e) { return n.a.each(e, (e, t) => Ne.add(t, e)), Ne; }, get(e) { return Pe[e] || null; }, add(e, t) { if (e && t) { const i = Pe[e]; i ? ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && n.a.each(t, (t, s) => { n.a.eqNull(i[s]) || i[s] === t || g.warn("vxe.error.coverProp", [`Renderer.${e}`, s]); }), Object.assign(i, t)) : (Pe[e] = t); } return Ne; }, delete(e) { return delete Pe[e], Ne; }, }, Be = new a(); "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && Object.assign(Be, { _name: "Commands" }); const Fe = new a(); function Ve(e) { return n.a.merge(r, e); } "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && Object.assign(Fe, { _name: "Menus" }); const ze = []; function je(e, t) { return ( e && e.install && -1 === ze.indexOf(e) && (e.install(Xe, t), ze.push(e)), Xe ); } function He(e) { "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && Xe.Table && g.error("vxe.error.useErr", [e]), (Xe[`_${e}`] = 1); } function Ue(e, t) { const i = []; return ( n.a.objectEach(e, (e, s) => { (0 !== e && e !== t) || i.push(s); }), i ); } class We { get zIndex() { return g.getLastZIndex(); } get nextZIndex() { return g.nextZIndex(); } get exportTypes() { return Ue(r.export.types, 1); } get importTypes() { return Ue(r.export.types, 2); } } const Ge = new We(); function Ze(e, t) { return r.i18n(e, t); } function Ye(e, t) { return e ? n.a.toString(r.translate ? r.translate(e, t) : e) : ""; } const qe = "v3", Xe = { v: qe, reg: He, use: je, setup: Ve, interceptor: G, renderer: Ne, commands: Be, formats: h, menus: Fe, config: Ge, t: Ze, _t: Ye, }; var Ke = Xe; const Je = { install() {} }; const Qe = { mini: 3, small: 2, medium: 1 }; function et(e) { if (e) { const t = getComputedStyle(e), i = n.a.toNumber(t.paddingLeft), s = n.a.toNumber(t.paddingRight); return i + s; } return 0; } function tt(e) { if (e) { const t = getComputedStyle(e), i = n.a.toNumber(t.marginLeft), s = n.a.toNumber(t.marginRight); return e.offsetWidth + i + s; } return 0; } function it(e, t) { return t ? (n.a.isString(t) ? e.getColumnByField(t) : t) : null; } function st(e, t) { return e.querySelector(".vxe-cell" + t); } function nt(e) { const t = e.$table, i = e.column, s = e.cell, o = t.showHeaderOverflow, r = t.resizableOpts, l = r.minWidth; if (l) { const t = n.a.isFunction(l) ? l(e) : l; if ("auto" !== t) return Math.max(1, n.a.toNumber(t)); } const a = i.showHeaderOverflow, h = i.minWidth, c = n.a.isUndefined(a) || n.a.isNull(a) ? o : a, d = "ellipsis" === c, u = "title" === c, p = !0 === c || "tooltip" === c, f = u || p || d, m = n.a.floor( 1.6 * (n.a.toNumber(getComputedStyle(s).fontSize) || 14) ), g = et(s) + et(st(s, "")); let v = m + g; if (f) { const e = et(st(s, "--title>.vxe-cell--checkbox")), t = tt(st(s, ">.vxe-cell--required-icon")), i = tt(st(s, ">.vxe-cell--edit-icon")), n = tt(st(s, ">.vxe-cell-help-icon")), o = tt(st(s, ">.vxe-cell--sort")), r = tt(st(s, ">.vxe-cell--filter")); v += e + t + i + n + r + o; } if (h) { const e = t.$refs.tableBody, i = e ? e.$el : null; if (i) { if (A.isScale(h)) { const e = i.clientWidth - 1, t = e / 100; return Math.max(v, Math.floor(n.a.toInteger(h) * t)); } if (A.isPx(h)) return Math.max(v, n.a.toInteger(h)); } } return v; } function ot(e, t) { const i = t.$table, s = e[i.treeOpts.children]; let n = 1; if (i.isTreeExpandByRow(e)) for (let o = 0; o < s.length; o++) n += ot(s[o], t); return n; } function rt(e) { return Qe[e.vSize] || 0; } function lt(e, t) { const i = e.$table, s = e.$rowIndex; let n = 1; return ( s && (n = ot(t[s - 1], e)), i.rowHeight * n - (s ? 1 : 12 - rt(i)) ); } function at(e, t, i) { for (let s = 0; s < e.length; s++) { const n = e[s], o = n.row, r = n.col, l = n.rowspan, a = n.colspan; if (r > -1 && o > -1 && l && a) { if (o === t && r === i) return { rowspan: l, colspan: a }; if (t >= o && t < o + l && i >= r && i < r + a) return { rowspan: 0, colspan: 0 }; } } } function ht(e) { return ( (e.initStatus = !1), e.clearSort(), e.clearCurrentRow(), e.clearCurrentColumn(), e.clearRadioRow(), e.clearRadioReserve(), e.clearCheckboxRow(), e.clearCheckboxReserve(), e.clearRowExpand(), e.clearTreeExpand(), e.clearTreeExpandReserve(), e.clearActived && Ke._edit && e.clearActived(), e.clearSelected && (e.keyboardConfig || e.mouseConfig) && e.clearSelected(), e.clearCellAreas && e.mouseConfig && (e.clearCellAreas(), e.clearCopyCellArea()), e.clearScroll() ); } function ct(e) { return e.clearFilter && Ke._filter && e.clearFilter(), ht(e); } const dt = "body"; function ut(e) { return ( e._isResize || (e.lastScrollTime && Date.now() < e.lastScrollTime + e.delayHover) ); } function pt(e, t, i, s, n, o) { const r = o.column, l = i.treeOpts, a = i.treeConfig, h = r.slots, c = r.treeNode; return h && h.line ? i.callSlot(h.line, o, e) : a && c && l.line ? [ e("div", { class: "vxe-tree--line-wrapper" }, [ e("div", { class: "vxe-tree--line", style: { height: `${lt(o, n)}px`, left: `${s * l.indent + (s ? 2 - rt(i) : 0) + 16}px`, }, }), ]), ] : []; } function ft(e, t, i, s, o, r, l, a, h, c, d, u, f, m, v, _) { const b = i.$listeners, y = i.afterFullData, x = i.tableData, w = i.height, S = i.columnKey, E = i.overflowX, k = i.scrollXLoad, C = i.scrollYLoad, T = i.highlightCurrentRow, O = i.showOverflow, $ = i.isAllOverflow, R = i.align, L = i.currentColumn, D = i.cellClassName, I = i.cellStyle, M = i.mergeList, P = i.spanMethod, N = i.radioOpts, B = i.checkboxOpts, F = i.expandOpts, V = i.treeOpts, z = i.tooltipOpts, j = i.mouseConfig, H = i.editConfig, U = i.editOpts, W = i.editRules, G = i.validOpts, Z = i.editStore, Y = i.validStore, q = i.tooltipConfig, X = f.type, K = f.cellRender, J = f.editRender, Q = f.align, ee = f.showOverflow, te = f.className, ie = f.treeNode, se = Z.actived, ne = z.showAll || z.enabled, oe = i.getColumnIndex(f), re = i.getVTColumnIndex(f), le = p(J); let ae = l ? f.fixed !== l : f.fixed && E; const he = n.a.isUndefined(ee) || n.a.isNull(ee) ? O : ee; let ce = "ellipsis" === he; const de = "title" === he, ue = !0 === he || "tooltip" === he; let pe, fe = de || ue || ce; const me = {}, ge = Q || R, ve = Y.row === h && Y.column === f, _e = W && G.showMessage && ("default" === G.message ? w || x.length > 1 : "inline" === G.message), be = { colid: f.id }, ye = b["cell-mouseenter"], xe = b["cell-mouseleave"], we = J && H && "dblclick" === U.trigger, Se = { $table: i, $seq: s, seq: o, rowid: r, row: h, rowIndex: c, $rowIndex: d, _rowIndex: u, column: f, columnIndex: oe, $columnIndex: m, _columnIndex: re, fixed: l, type: dt, isHidden: ae, level: a, visibleData: y, data: x, items: _, }; if ( ((!k && !C) || fe || (ce = fe = !0), (de || ue || ne || ye || q) && (me.mouseenter = (e) => { ut(i) || (de ? A.updateCellTitle(e.currentTarget, f) : (ue || ne) && i.triggerBodyTooltipEvent(e, Se), ye && i.emitEvent( "cell-mouseenter", Object.assign({ cell: e.currentTarget }, Se), e )); }), (ue || ne || xe || q) && (me.mouseleave = (e) => { ut(i) || ((ue || ne) && i.handleTargetLeaveEvent(e), xe && i.emitEvent( "cell-mouseleave", Object.assign({ cell: e.currentTarget }, Se), e )); }), (B.range || j) && (me.mousedown = (e) => { i.triggerCellMousedownEvent(e, Se); }), (T || b["cell-click"] || (J && H) || "row" === F.trigger || "cell" === F.trigger || "row" === N.trigger || ("radio" === f.type && "cell" === N.trigger) || "row" === B.trigger || ("checkbox" === f.type && "cell" === B.trigger) || "row" === V.trigger || (f.treeNode && "cell" === V.trigger)) && (me.click = (e) => { i.triggerCellClickEvent(e, Se); }), (we || b["cell-dblclick"]) && (me.dblclick = (e) => { i.triggerCellDblclickEvent(e, Se); }), M.length) ) { const e = at(M, u, re); if (e) { const t = e.rowspan, i = e.colspan; if (!t || !i) return null; t > 1 && (be.rowspan = t), i > 1 && (be.colspan = i); } } else if (P) { const e = P(Se) || {}, t = e.rowspan, i = void 0 === t ? 1 : t, s = e.colspan, n = void 0 === s ? 1 : s; if (!i || !n) return null; i > 1 && (be.rowspan = i), n > 1 && (be.colspan = n); } ae && M && (be.colspan > 1 || be.rowspan > 1) && (ae = !1), !ae && H && (J || K) && (U.showStatus || U.showUpdateStatus) && (pe = i.isUpdateByRow(h, f.property)); const Ee = []; return ( ae && (O ? $ : O) ? Ee.push( e("div", { class: [ "vxe-cell", { "c--title": de, "c--tooltip": ue, "c--ellipsis": ce }, ], }) ) : (Ee.push( ...pt(e, t, i, a, _, Se), e( "div", { class: [ "vxe-cell", { "c--title": de, "c--tooltip": ue, "c--ellipsis": ce }, ], attrs: { title: de ? i.getCellLabel(h, f) : null }, }, f.renderCell(e, Se) ) ), _e && ve && Ee.push( e( "div", { class: "vxe-cell--valid", style: Y.rule && Y.rule.maxWidth ? { width: `${Y.rule.maxWidth}px` } : null, }, [e("span", { class: "vxe-cell--valid-msg" }, Y.content)] ) )), e( "td", { class: [ "vxe-body--column", f.id, { [`col--${ge}`]: ge, [`col--${X}`]: X, "col--last": m === v.length - 1, "col--tree-node": ie, "col--edit": le, "col--ellipsis": fe, "fixed--hidden": ae, "col--dirty": pe, "col--actived": H && le && se.row === h && (se.column === f || "row" === U.mode), "col--valid-error": ve, "col--current": L === f, }, g.getClass(te, Se), g.getClass(D, Se), ], key: S ? f.id : m, attrs: be, style: I ? (n.a.isFunction(I) ? I(Se) : I) : null, on: me, }, Ee ) ); } function mt(e, t, i, s, o, r, l, a) { const h = i.stripe, c = i.rowKey, d = i.highlightHoverRow, u = i.rowClassName, p = i.rowStyle, f = i.editConfig, m = i.showOverflow, v = i.treeConfig, _ = i.treeOpts, b = i.editOpts, y = i.treeExpandeds, x = i.scrollYLoad, w = i.scrollYStore, S = i.editStore, E = i.rowExpandeds, k = i.radioOpts, C = i.checkboxOpts, T = i.expandColumn, O = i.hasFixedColumn, $ = []; return ( l.forEach((R, A) => { const L = {}; let D = A, I = D + 1; x && (I += w.startIndex); const M = i.getVTRowIndex(R); (D = i.getRowIndex(R)), d && ((L.mouseenter = (e) => { ut(i) || i.triggerHoverEvent(e, { row: R, rowIndex: D }); }), (L.mouseleave = () => { ut(i) || i.clearHoverRow(); })); const P = g.getRowid(i, R), N = { $table: i, $seq: s, seq: I, rowid: P, fixed: r, type: dt, level: o, row: R, rowIndex: D, $rowIndex: A, }; let B = !1; if ( (f && (B = S.insertList.indexOf(R) > -1), $.push( e( "tr", { class: [ "vxe-body--row", { "row--stripe": h && (i.getVTRowIndex(R) + 1) % 2 === 0, "is--new": B, "row--new": B && (b.showStatus || b.showInsertStatus), "row--radio": k.highlight && i.selectRow === R, "row--checked": C.highlight && i.isCheckedByCheckboxRow(R), }, u ? (n.a.isFunction(u) ? u(N) : u) : "", ], attrs: { rowid: P }, style: p ? (n.a.isFunction(p) ? p(N) : p) : null, key: c || v ? P : A, on: L, }, a.map((n, h) => { return ft(e, t, i, s, I, P, r, o, R, D, A, M, n, h, a, l); }) ) ), T && E.length && E.indexOf(R) > -1) ) { let t; v && (t = { paddingLeft: `${o * _.indent + 30}px` }); const l = T.showOverflow, h = n.a.isUndefined(l) || n.a.isNull(l) ? m : l, c = { $table: i, $seq: s, seq: I, column: T, fixed: r, type: dt, level: o, row: R, rowIndex: D, $rowIndex: A, }; $.push( e( "tr", { class: "vxe-body--expanded-row", key: `expand_${P}`, style: p ? (n.a.isFunction(p) ? p(c) : p) : null, on: L, }, [ e( "td", { class: [ "vxe-body--expanded-column", { "fixed--hidden": r && !O, "col--ellipsis": h }, ], attrs: { colspan: a.length }, }, [ e( "div", { class: "vxe-body--expanded-cell", style: t }, [T.renderData(e, c)] ), ] ), ] ) ); } if (v && y.length) { const n = R[_.children]; n && n.length && y.indexOf(R) > -1 && $.push( ...mt(e, t, i, s ? `${s}.${I}` : `${I}`, o + 1, r, n, a) ); } }), $ ); } let gt; function vt(e, t, i) { (t || i) && (t && ((t.onscroll = null), (t.scrollTop = e)), i && ((i.onscroll = null), (i.scrollTop = e)), clearTimeout(gt), (gt = setTimeout(function () { t && (t.onscroll = t._onscroll), i && (i.onscroll = i._onscroll); }, 300))); } var _t = { name: "VxeTableBody", props: { tableData: Array, tableColumn: Array, fixedColumn: Array, size: String, fixedType: String, }, data() { return { wheelTime: null, wheelYSize: 0, wheelYInterval: 0, wheelYTotal: 0, }; }, mounted() { const e = this.$parent, t = this.$el, i = this.$refs, s = this.fixedType, n = e.elemStore, o = `${s || "main"}-body-`; (n[`${o}wrapper`] = t), (n[`${o}table`] = i.table), (n[`${o}colgroup`] = i.colgroup), (n[`${o}list`] = i.tbody), (n[`${o}xSpace`] = i.xSpace), (n[`${o}ySpace`] = i.ySpace), (n[`${o}emptyBlock`] = i.emptyBlock), (this.$el.onscroll = this.scrollEvent), (this.$el._onscroll = this.scrollEvent); }, beforeDestroy() { clearTimeout(this.wheelTime), (this.$el._onscroll = null), (this.$el.onscroll = null); }, render(e) { const t = this._e, i = this.$parent, s = this.fixedColumn, n = this.fixedType; let o, l = i.$scopedSlots, a = i.tId, h = i.tableData, c = i.tableColumn, d = i.showOverflow, u = i.keyboardConfig, p = i.keyboardOpts, f = i.mergeList, m = i.spanMethod, g = i.scrollXLoad, v = i.scrollYLoad, _ = i.isAllOverflow, b = i.emptyOpts, y = i.mouseConfig, x = i.mouseOpts, w = i.sYOpts; if ( (n && (f.length || m || (u && p.isMerge) || !(g || v || (d ? _ : d)) || (c = s)), l.empty) ) o = l.empty.call(this, { $table: i }, e); else { const t = b.name ? Ke.renderer.get(b.name) : null, s = t ? t.renderEmpty : null; o = s ? s.call(this, e, b, { $table: i }) : i.emptyText || r.i18n("vxe.table.emptyText"); } return e( "div", { class: [ "vxe-table--body-wrapper", n ? `fixed-${n}--wrapper` : "body--wrapper", ], attrs: { xid: a }, on: v && "wheel" === w.mode ? { wheel: this.wheelEvent } : {}, }, [ n ? t() : e("div", { class: "vxe-body--x-space", ref: "xSpace" }), e("div", { class: "vxe-body--y-space", ref: "ySpace" }), e( "table", { class: "vxe-table--body", attrs: { xid: a, cellspacing: 0, cellpadding: 0, border: 0, }, ref: "table", }, [ e( "colgroup", { ref: "colgroup" }, c.map((t, i) => { return e("col", { attrs: { name: t.id }, key: i }); }) ), e( "tbody", { ref: "tbody" }, mt(e, this, i, "", 0, n, h, c) ), ] ), e("div", { class: "vxe-table--checkbox-range" }), y && x.area ? e("div", { class: "vxe-table--cell-area" }, [ e( "span", { class: "vxe-table--cell-main-area" }, x.extension ? [ e("span", { class: "vxe-table--cell-main-area-btn", on: { mousedown(e) { i.triggerCellExtendMousedownEvent(e, { $table: i, fixed: n, type: dt, }); }, }, }), ] : null ), e("span", { class: "vxe-table--cell-copy-area" }), e("span", { class: "vxe-table--cell-extend-area" }), e("span", { class: "vxe-table--cell-multi-area" }), e("span", { class: "vxe-table--cell-active-area" }), ]) : null, n ? null : e( "div", { class: "vxe-table--empty-block", ref: "emptyBlock" }, [e("div", { class: "vxe-table--empty-content" }, o)] ), ] ); }, methods: { scrollEvent(e) { const t = this.$el, i = this.$parent, s = this.fixedType, n = i.$refs, o = i.highlightHoverRow, r = i.scrollXLoad, l = i.scrollYLoad, a = i.lastScrollTop, h = i.lastScrollLeft, c = n.tableHeader, d = n.tableBody, u = n.leftBody, p = n.rightBody, f = n.tableFooter, m = n.validTip, g = c ? c.$el : null, v = f ? f.$el : null, _ = d.$el, b = u ? u.$el : null, y = p ? p.$el : null; let x = t.scrollTop; const w = _.scrollLeft, S = w !== h, E = x !== a; (i.lastScrollTop = x), (i.lastScrollLeft = w), (i.lastScrollTime = Date.now()), o && i.clearHoverRow(), b && "left" === s ? ((x = b.scrollTop), vt(x, _, y)) : y && "right" === s ? ((x = y.scrollTop), vt(x, _, b)) : (S && (g && (g.scrollLeft = _.scrollLeft), v && (v.scrollLeft = _.scrollLeft)), (b || y) && (i.checkScrolling(), E && vt(x, b, y))), r && S && i.triggerScrollXEvent(e), l && E && i.triggerScrollYEvent(e), S && m && m.visible && m.updatePlacement(), i.emitEvent( "scroll", { type: dt, fixed: s, scrollTop: x, scrollLeft: w, isX: S, isY: E, }, e ); }, handleWheel(e, t, i, s, n) { const o = this.$parent, r = o.$refs, l = r.tableBody, a = r.leftBody, h = r.rightBody, c = l.$el, d = a ? a.$el : null, u = h ? h.$el : null, p = this.isPrevWheelTop === t ? Math.max(0, this.wheelYSize - this.wheelYTotal) : 0; (this.isPrevWheelTop = t), (this.wheelYSize = Math.abs(t ? i - p : i + p)), (this.wheelYInterval = 0), (this.wheelYTotal = 0), clearTimeout(this.wheelTime); const f = () => { let i = this.fixedType, r = this.wheelYTotal, l = this.wheelYSize, a = this.wheelYInterval; if (r < l) { (a = Math.max(5, Math.floor(1.5 * a))), (r += a), r > l && (a -= r - l); const h = c.scrollTop, p = c.clientHeight, m = c.scrollHeight, g = h + a * (t ? -1 : 1); (c.scrollTop = g), d && (d.scrollTop = g), u && (u.scrollTop = g), (t ? g < m - p : g >= 0) && (this.wheelTime = setTimeout(f, 10)), (this.wheelYTotal = r), (this.wheelYInterval = a), o.emitEvent( "scroll", { type: dt, fixed: i, scrollTop: c.scrollTop, scrollLeft: c.scrollLeft, isX: s, isY: n, }, e ); } }; f(); }, wheelEvent(e) { const t = e.deltaY, i = e.deltaX, s = this.$el, n = this.$parent, o = n.$refs, r = n.highlightHoverRow, l = n.scrollYLoad, a = n.lastScrollTop, h = n.lastScrollLeft, c = o.tableBody, d = c.$el, u = b.firefox ? 40 * t : t, p = b.firefox ? 40 * i : i, f = u < 0; if ( f ? s.scrollTop <= 0 : s.scrollTop >= s.scrollHeight - s.clientHeight ) return; const m = s.scrollTop + u, g = d.scrollLeft + p, v = g !== h, _ = m !== a; _ && (e.preventDefault(), (n.lastScrollTop = m), (n.lastScrollLeft = g), (n.lastScrollTime = Date.now()), r && n.clearHoverRow(), this.handleWheel(e, f, u, v, _), l && n.triggerScrollYEvent(e)); }, }, }, bt = { computed: { vSize() { const e = this.$parent, t = this.size; return t || (e && (e.size || e.vSize)); }, }, }, yt = (i("55dd"), i("ade3")); function xt(e, t) { var i = Object.keys(e); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); t && (s = s.filter(function (t) { return Object.getOwnPropertyDescriptor(e, t).enumerable; })), i.push.apply(i, s); } return i; } function wt(e) { for (var t = 1; t < arguments.length; t++) { var i = null != arguments[t] ? arguments[t] : {}; t % 2 ? xt(i, !0).forEach(function (t) { Object(yt["a"])(e, t, i[t]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(i)) : xt(i).forEach(function (t) { Object.defineProperty( e, t, Object.getOwnPropertyDescriptor(i, t) ); }); } return e; } function St(e, t) { const i = t.$table, s = t.column, n = s.titleHelp; return n ? [ e("i", { class: ["vxe-cell-help-icon", n.icon || r.icon.TABLE_HELP], on: { mouseenter(e) { i.triggerHeaderHelpEvent(e, t); }, mouseleave(e) { i.handleTargetLeaveEvent(e); }, }, }), ] : []; } function Et(e, t, i) { const s = t.$table, o = t.column, r = o.type, l = o.showHeaderOverflow, a = s.showHeaderOverflow, h = s.tooltipOpts, c = h.showAll || h.enabled, d = n.a.isUndefined(l) || n.a.isNull(l) ? a : l, u = "title" === d, p = !0 === d || "tooltip" === d, f = {}; return ( (u || p || c) && (f.mouseenter = (e) => { s._isResize || (u ? A.updateCellTitle(e.currentTarget, o) : (p || c) && s.triggerHeaderTooltipEvent(e, t)); }), (p || c) && (f.mouseleave = (e) => { s._isResize || ((p || c) && s.handleTargetLeaveEvent(e)); }), [ "html" === r && n.a.isString(i) ? e("span", { class: "vxe-cell--title", domProps: { innerHTML: i }, on: f, }) : e("span", { class: "vxe-cell--title", on: f }, i), ] ); } function kt(e, t) { const i = t.$table, s = t.column, n = t._columnIndex, o = t.items, r = s.slots, l = s.editRender, a = s.cellRender, h = l || a; if (r && r.footer) return i.callSlot(r.footer, t, e); if (h) { const s = Ke.renderer.get(h.name); if (s && s.renderFooter) return s.renderFooter.call(i, e, h, t); } return [g.formatText(o[n], 1)]; } function Ct(e) { const t = e.$table, i = e.row, s = e.column; return g.formatText(t.getCellLabel(i, s), 1); } const Tt = { createColumn(e, t) { const i = t.type, s = t.sortable, n = t.remoteSort, o = t.filters, r = t.editRender, l = t.treeNode, a = e.editConfig, h = e.editOpts, c = e.checkboxOpts, d = { renderHeader: this.renderDefaultHeader, renderCell: l ? this.renderTreeCell : this.renderDefaultCell, renderFooter: this.renderDefaultFooter, }; switch (i) { case "index": case "seq": (d.renderHeader = this.renderIndexHeader), (d.renderCell = l ? this.renderTreeIndexCell : this.renderIndexCell); break; case "radio": (d.renderHeader = this.renderRadioHeader), (d.renderCell = l ? this.renderTreeRadioCell : this.renderRadioCell); break; case "checkbox": (d.renderHeader = this.renderSelectionHeader), (d.renderCell = c.checkField ? l ? this.renderTreeSelectionCellByProp : this.renderSelectionCellByProp : l ? this.renderTreeSelectionCell : this.renderSelectionCell); break; case "expand": (d.renderCell = this.renderExpandCell), (d.renderData = this.renderExpandData); break; case "html": (d.renderCell = l ? this.renderTreeHTMLCell : this.renderHTMLCell), o && (s || n) ? (d.renderHeader = this.renderSortAndFilterHeader) : s || n ? (d.renderHeader = this.renderSortHeader) : o && (d.renderHeader = this.renderFilterHeader); break; default: a && r ? ((d.renderHeader = this.renderEditHeader), (d.renderCell = "cell" === h.mode ? l ? this.renderTreeCellEdit : this.renderCellEdit : l ? this.renderTreeRowEdit : this.renderRowEdit)) : o && (s || n) ? (d.renderHeader = this.renderSortAndFilterHeader) : s || n ? (d.renderHeader = this.renderSortHeader) : o && (d.renderHeader = this.renderFilterHeader); } return g.getColumnConfig(e, t, d); }, renderHeaderTitle(e, t) { const i = t.$table, s = t.column, n = s.slots, o = s.editRender, r = s.cellRender, l = o || r; if (n && n.header) return Et(e, t, i.callSlot(n.header, t, e)); if (l) { const s = Ke.renderer.get(l.name); if (s && s.renderHeader) return Et(e, t, s.renderHeader.call(i, e, l, t)); } return Et(e, t, g.formatText(s.getTitle(), 1)); }, renderDefaultHeader(e, t) { return St(e, t).concat(Tt.renderHeaderTitle(e, t)); }, renderDefaultCell(e, t) { const i = t.$table, s = t.row, n = t.column, o = n.slots, r = n.editRender, l = n.cellRender, a = r || l; if (o && o.default) return i.callSlot(o.default, t, e); if (a) { const s = r ? "renderCell" : "renderDefault", n = Ke.renderer.get(a.name); if (n && n[s]) return n[s].call( i, e, a, Object.assign({ $type: r ? "edit" : "cell" }, t) ); } const h = i.getCellLabel(s, n), c = r ? r.placeholder : ""; return [ e( "span", { class: "vxe-cell--label" }, r && m(h) ? [ e( "span", { class: "vxe-cell--placeholder" }, g.formatText(g.getFuncText(c), 1) ), ] : g.formatText(h, 1) ), ]; }, renderTreeCell(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderDefaultCell.call(this, e, t)); }, renderDefaultFooter(e, t) { return [e("span", { class: "vxe-cell--item" }, kt(e, t))]; }, renderTreeIcon(e, t, i) { const s = t.$table, n = t.isHidden, o = s.treeOpts, l = s.treeExpandeds, a = s.treeLazyLoadeds, h = t.row, c = t.column, d = t.level, u = c.slots, p = o.children, f = o.hasChild, m = o.indent, g = o.lazy, v = o.trigger, _ = o.iconLoaded, b = o.showIcon, y = o.iconOpen, x = o.iconClose, w = h[p]; let S = !1, E = !1, k = !1; const C = {}; return u && u.icon ? s.callSlot(u.icon, t, e, i) : (n || ((E = l.indexOf(h) > -1), g && ((k = a.indexOf(h) > -1), (S = h[f]))), (v && "default" !== v) || (C.click = (e) => s.triggerTreeExpandEvent(e, t)), [ e( "div", { class: ["vxe-cell--tree-node", { "is--active": E }], style: { paddingLeft: `${d * m}px` }, }, [ b && ((w && w.length) || S) ? [ e("div", { class: "vxe-tree--btn-wrapper", on: C }, [ e("i", { class: [ "vxe-tree--node-btn", k ? _ || r.icon.TABLE_TREE_LOADED : E ? y || r.icon.TABLE_TREE_OPEN : x || r.icon.TABLE_TREE_CLOSE, ], }), ]), ] : null, e("div", { class: "vxe-tree-cell" }, i), ] ), ]); }, renderIndexHeader(e, t) { const i = t.$table, s = t.column, n = s.slots; return Et( e, t, n && n.header ? i.callSlot(n.header, t, e) : g.formatText(s.getTitle(), 1) ); }, renderIndexCell(e, t) { const i = t.$table, s = t.column, n = i.seqOpts, o = s.slots; if (o && o.default) return i.callSlot(o.default, t, e); const r = t.$seq, l = t.seq, a = t.level, h = n.seqMethod; return [ g.formatText(h ? h(t) : a ? `${r}.${l}` : n.startIndex + l, 1), ]; }, renderTreeIndexCell(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderIndexCell(e, t)); }, renderRadioHeader(e, t) { const i = t.$table, s = t.column, n = s.slots, o = n ? n.header : null, r = n ? n.title : null; return Et( e, t, o ? i.callSlot(o, t, e) : [ e( "span", { class: "vxe-radio--label" }, r ? i.callSlot(r, t, e) : g.formatText(s.getTitle(), 1) ), ] ); }, renderRadioCell(e, t) { const i = t.$table, s = t.column, o = t.isHidden, r = i.radioOpts, l = i.selectRow, a = s.slots, h = r.labelField, c = r.checkMethod, d = t.row, u = a ? a.default : null, p = a ? a.radio : null, f = d === l; let m, g = !!c; o || ((m = { click(e) { g || i.triggerRadioRowEvent(e, t); }, }), c && (g = !c({ row: d }))); const v = wt({}, t, { checked: f, disabled: g }); return p ? i.callSlot(p, v, e) : [ e( "span", { class: [ "vxe-cell--radio", { "is--checked": f, "is--disabled": g }, ], on: m, }, [ e("span", { class: "vxe-radio--icon vxe-radio--checked-icon", }), e("span", { class: "vxe-radio--icon vxe-radio--unchecked-icon", }), ].concat( u || h ? [ e( "span", { class: "vxe-radio--label" }, u ? i.callSlot(u, v, e) : n.a.get(d, h) ), ] : [] ) ), ]; }, renderTreeRadioCell(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderRadioCell(e, t)); }, renderSelectionHeader(e, t) { const i = t.$table, s = t.column, n = t.isHidden, o = i.isIndeterminate, l = i.isAllCheckboxDisabled, a = s.slots, h = a ? a.header : null, c = a ? a.title : null, d = i.checkboxOpts, u = s.getTitle(); let p, f = !1; n || ((f = !l && i.isAllSelected), (p = { click(e) { l || i.triggerCheckAllEvent(e, !f); }, })); const m = wt({}, t, { checked: f, disabled: l, indeterminate: o }); return h ? Et(e, m, i.callSlot(h, m, e)) : (d.checkStrictly ? d.showHeader : !1 !== d.showHeader) ? Et(e, m, [ e( "span", { class: [ "vxe-cell--checkbox", { "is--checked": f, "is--disabled": l, "is--indeterminate": o, }, ], attrs: { title: r.i18n("vxe.table.allTitle") }, on: p, }, [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color }, }), ].concat( c || u ? [ e( "span", { class: "vxe-checkbox--label" }, c ? i.callSlot(c, m, e) : u ), ] : [] ) ), ]) : Et(e, m, [ e( "span", { class: "vxe-checkbox--label" }, c ? i.callSlot(c, m, e) : u ), ]); }, renderSelectionCell(e, t) { const i = t.$table, s = t.row, o = t.column, r = t.isHidden, l = i.treeConfig, a = i.treeIndeterminates, h = i.checkboxOpts, c = h.labelField, d = h.checkMethod, u = o.slots, p = u ? u.default : null, f = u ? u.checkbox : null; let m, g = !1, v = !1, _ = !!d; r || ((v = i.selection.indexOf(s) > -1), (m = { click(e) { _ || i.triggerCheckRowEvent(e, t, !v); }, }), d && (_ = !d({ row: s })), l && (g = a.indexOf(s) > -1)); const b = wt({}, t, { checked: v, disabled: _, indeterminate: g }); return f ? i.callSlot(f, b, e) : [ e( "span", { class: [ "vxe-cell--checkbox", { "is--checked": v, "is--disabled": _, "is--indeterminate": g, }, ], on: m, }, [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color }, }), ].concat( p || c ? [ e( "span", { class: "vxe-checkbox--label" }, p ? i.callSlot(p, b, e) : n.a.get(s, c) ), ] : [] ) ), ]; }, renderTreeSelectionCell(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderSelectionCell(e, t)); }, renderSelectionCellByProp(e, t) { const i = t.$table, s = t.row, o = t.column, r = t.isHidden, l = i.treeConfig, a = i.treeIndeterminates, h = i.checkboxOpts, c = h.labelField, d = h.checkField, u = h.halfField, p = h.checkMethod, f = o.slots, m = f ? f.default : null, g = f ? f.checkbox : null; let v, _ = !1, b = !1, y = !!p; r || ((b = n.a.get(s, d)), (v = { click(e) { y || i.triggerCheckRowEvent(e, t, !b); }, }), p && (y = !p({ row: s })), l && (_ = a.indexOf(s) > -1)); const x = wt({}, t, { checked: b, disabled: y, indeterminate: _ }); return g ? i.callSlot(g, x, e) : [ e( "span", { class: [ "vxe-cell--checkbox", { "is--checked": b, "is--disabled": y, "is--indeterminate": u && !b ? s[u] : _, }, ], on: v, }, [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color }, }), ].concat( m || c ? [ e( "span", { class: "vxe-checkbox--label" }, m ? i.callSlot(m, x, e) : n.a.get(s, c) ), ] : [] ) ), ]; }, renderTreeSelectionCellByProp(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderSelectionCellByProp(e, t)); }, renderExpandCell(e, t) { const i = t.$table, s = t.isHidden, o = t.row, l = t.column, a = i.expandOpts, h = i.rowExpandeds, c = i.expandLazyLoadeds, d = a.lazy, u = a.labelField, p = a.iconLoaded, f = a.showIcon, m = a.iconOpen, g = a.iconClose, v = a.visibleMethod, _ = l.slots, b = _ ? _.default : null; let y = !1, x = !1; return _ && _.icon ? i.callSlot(_.icon, t, e) : (s || ((y = h.indexOf(t.row) > -1), d && (x = c.indexOf(o) > -1)), [ !f || (v && !v(t)) ? null : e( "span", { class: ["vxe-table--expanded", { "is--active": y }], on: { click(e) { i.triggerRowExpandEvent(e, t); }, }, }, [ e("i", { class: [ "vxe-table--expand-btn", x ? p || r.icon.TABLE_EXPAND_LOADED : y ? m || r.icon.TABLE_EXPAND_OPEN : g || r.icon.TABLE_EXPAND_CLOSE, ], }), ] ), b || u ? e( "span", { class: "vxe-table--expand-label" }, b ? i.callSlot(b, t, e) : n.a.get(o, u) ) : null, ]); }, renderExpandData(e, t) { const i = t.$table, s = t.column, n = s.slots, o = s.contentRender; if (n && n.content) return i.callSlot(n.content, t, e); if (o) { const s = Ke.renderer.get(o.name); if (s && s.renderExpand) return s.renderExpand.call(i, e, o, t); } return []; }, renderHTMLCell(e, t) { const i = t.$table, s = t.column, n = s.slots; return n && n.default ? i.callSlot(n.default, t, e) : [ e("span", { class: "vxe-cell--html", domProps: { innerHTML: Ct(t) }, }), ]; }, renderTreeHTMLCell(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderHTMLCell(e, t)); }, renderSortAndFilterHeader(e, t) { return Tt.renderDefaultHeader(e, t) .concat(Tt.renderSortIcon(e, t)) .concat(Tt.renderFilterIcon(e, t)); }, renderSortHeader(e, t) { return Tt.renderDefaultHeader(e, t).concat(Tt.renderSortIcon(e, t)); }, renderSortIcon(e, t) { const i = t.$table, s = t.column, n = i.sortOpts, o = n.showIcon, l = n.iconAsc, a = n.iconDesc; return o ? [ e( "span", { class: "vxe-cell--sort", style: { visibility: "asc" === s.order || "desc" === s.order ? "visible" : "", }, }, [ e("i", { class: [ "vxe-sort--asc-btn", l || r.icon.TABLE_SORT_ASC, { "sort--active": "asc" === s.order }, ], attrs: { title: r.i18n("vxe.table.sortAsc") }, on: { click(e) { i.triggerSortEvent(e, s, "asc"); }, }, }), e("i", { class: [ "vxe-sort--desc-btn", a || r.icon.TABLE_SORT_DESC, { "sort--active": "desc" === s.order }, ], attrs: { title: r.i18n("vxe.table.sortDesc") }, on: { click(e) { i.triggerSortEvent(e, s, "desc"); }, }, }), ] ), ] : []; }, renderFilterHeader(e, t) { return Tt.renderDefaultHeader(e, t).concat(Tt.renderFilterIcon(e, t)); }, renderFilterIcon(e, t) { const i = t.$table, s = t.column, n = t.hasFilter, o = i.filterStore, l = i.filterOpts, a = l.showIcon, h = l.iconNone, c = l.iconMatch; return a ? [ e( "span", { class: [ "vxe-cell--filter", { "is--active": o.visible && o.column === s }, ], }, [ e("i", { class: [ "vxe-filter--btn", n ? c || r.icon.TABLE_FILTER_MATCH : h || r.icon.TABLE_FILTER_NONE, ], attrs: { title: r.i18n("vxe.table.filter") }, on: { click(e) { i.triggerFilterEvent(e, t.column, t); }, }, }), ] ), ] : []; }, renderEditHeader(e, t) { const i = t.$table, s = t.column, o = i.editRules, l = i.editOpts, a = s.sortable, h = s.remoteSort, c = s.filters, d = s.editRender; let u; if (o) { const e = n.a.get(o, t.column.property); e && (u = e.some((e) => e.required)); } return [ u && l.showAsterisk ? e("i", { class: "vxe-cell--required-icon" }) : null, p(d) && l.showIcon ? e("i", { class: ["vxe-cell--edit-icon", l.icon || r.icon.TABLE_EDIT], }) : null, ] .concat(Tt.renderDefaultHeader(e, t)) .concat(a || h ? Tt.renderSortIcon(e, t) : []) .concat(c ? Tt.renderFilterIcon(e, t) : []); }, renderRowEdit(e, t) { const i = t.$table, s = t.column, n = s.editRender, o = i.editStore.actived; return Tt.runRenderer(e, t, this, p(n) && o && o.row === t.row); }, renderTreeRowEdit(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderRowEdit(e, t)); }, renderCellEdit(e, t) { const i = t.$table, s = t.column, n = s.editRender, o = i.editStore.actived; return Tt.runRenderer( e, t, this, p(n) && o && o.row === t.row && o.column === t.column ); }, renderTreeCellEdit(e, t) { return Tt.renderTreeIcon(e, t, Tt.renderCellEdit(e, t)); }, runRenderer(e, t, i, s) { const n = t.$table, o = t.column, r = o.slots, l = o.editRender, a = o.formatter, h = Ke.renderer.get(l.name); return s ? r && r.edit ? n.callSlot(r.edit, t, e) : h && h.renderEdit ? h.renderEdit.call(n, e, l, Object.assign({ $type: "edit" }, t)) : [] : r && r.default ? n.callSlot(r.default, t, e) : a ? [e("span", { class: "vxe-cell--label" }, [Ct(t)])] : Tt.renderDefaultCell.call(i, e, t); }, }; var Ot = Tt, $t = i("53b0"); const Rt = g.getRowid, At = g.getRowkey, Lt = g.setCellValue, Dt = g.hasChildrenList, It = g.getColumnList, Mt = A.calcHeight, Pt = A.hasClass, Nt = A.addClass, Bt = A.removeClass, Ft = A.getEventTargetNode, Vt = b["-webkit"] && !b.edge, zt = b.msie ? 80 : 20, jt = "VXE_TABLE_CUSTOM_COLUMN_WIDTH", Ht = "VXE_TABLE_CUSTOM_COLUMN_VISIBLE"; function Ut() { return n.a.uniqueId("row_"); } function Wt(e, t, i) { const s = n.a.get(e, i), o = n.a.get(t, i); return ( !(!m(s) || !m(o)) || (n.a.isString(s) || n.a.isNumber(s) ? s == o : n.a.isEqual(s, o)) ); } function Gt(e, t) { const i = e.sortOpts.orders, s = t.order || null, n = i.indexOf(s) + 1; return i[n < i.length ? n : 0]; } function Zt(e) { const t = r.version, i = n.a.toStringJSON(localStorage.getItem(e)); return i && i._v === t ? i : { _v: t }; } function Yt(e, t) { const i = e.fullAllDataRowMap; return t.filter((e) => i.has(e)); } function qt(e, t) { const i = e.fullDataRowIdData, s = []; return ( n.a.each(t, (e, t) => { i[t] && -1 === s.indexOf(i[t].row) && s.push(i[t].row); }), s ); } function Xt(e, t, i) { return e.clearScroll().then(() => { if (t || i) return ( (e.lastScrollLeft = 0), (e.lastScrollTop = 0), e.scrollTo(t, i) ); }); } function Kt(e) { const t = e.$refs, i = e.visibleColumn, s = t.tableBody, n = s ? s.$el : null; if (n) { const e = n.scrollLeft, t = n.clientWidth, s = e + t; let o = -1, r = 0, l = 0; for (let n = 0, a = i.length; n < a; n++) if ( ((r += i[n].renderWidth), -1 === o && e < r && (o = n), o >= 0 && (l++, r > s)) ) break; return { toVisibleIndex: Math.max(0, o), visibleSize: Math.max(8, l), }; } return { toVisibleIndex: 0, visibleSize: 8 }; } function Jt(e) { const t = e.$refs, i = e.vSize, s = e.rowHeightMaps, n = e.params, o = t.tableHeader, r = t.tableBody, l = r ? r.$el : null; if (l) { const e = o ? o.$el : null; let t = n ? n.rowHeight : 0; if (!t) { let i; (i = l.querySelector("tr")), !i && e && (i = e.querySelector("tr")), i && (t = i.clientHeight); } t || (t = s[i || "default"]); const r = Math.max(8, Math.ceil(l.clientHeight / t) + 2); return { rowHeight: t, visibleSize: r }; } return { rowHeight: 0, visibleSize: 8 }; } function Qt(e, t, i) { for (let s = 0, n = e.length; s < n; s++) { const n = e[s], o = t.startIndex, r = t.endIndex, l = n[i], a = n[i + "span"], h = l + a; l < o && o < h && (t.startIndex = l), l < r && r < h && (t.endIndex = h), (t.startIndex === o && t.endIndex === r) || (s = -1); } } function ei(e, t, i, s) { if (t) { const o = e.treeConfig, r = e.visibleColumn; if (o) throw new Error( g.getLog("vxe.error.noTree", ["merge-footer-items"]) ); n.a.isArray(t) || (t = [t]), t.forEach((e) => { let t = e.row, o = e.col, l = e.rowspan, a = e.colspan; if ( (s && n.a.isNumber(t) && (t = s[t]), n.a.isNumber(o) && (o = r[o]), (s ? t : n.a.isNumber(t)) && o && (l || a) && ((l = n.a.toNumber(l) || 1), (a = n.a.toNumber(a) || 1), l > 1 || a > 1)) ) { const e = n.a.findIndexOf( i, (e) => e._row === t && e._col === o ), h = i[e]; if (h) (h.rowspan = l), (h.colspan = a), (h._rowspan = l), (h._colspan = a); else { const e = s ? s.indexOf(t) : t, n = r.indexOf(o); i.push({ row: e, col: n, rowspan: l, colspan: a, _row: t, _col: o, _rowspan: l, _colspan: a, }); } } }); } } function ti(e, t, i, s) { const o = []; if (t) { const r = e.treeConfig, l = e.visibleColumn; if (r) throw new Error(g.getLog("vxe.error.noTree", ["merge-cells"])); n.a.isArray(t) || (t = [t]), t.forEach((e) => { let t = e.row, r = e.col; s && n.a.isNumber(t) && (t = s[t]), n.a.isNumber(r) && (r = l[r]); const a = n.a.findIndexOf(i, (e) => e._row === t && e._col === r); if (a > -1) { const e = i.splice(a, 1); o.push(e[0]); } }); } return o; } function ii(e) { e.tableFullColumn.forEach((e) => { e.order = null; }); } function si(e, t) { const i = t.sortBy, s = t.sortType; return (o) => { let r; return ( (r = i ? n.a.isFunction(i) ? i({ row: o, column: t }) : n.a.get(o, i) : e.getCellLabel(o, t)), s && "auto" !== s ? "number" === s ? n.a.toNumber(r) : "string" === s ? n.a.toString(r) : r : isNaN(r) ? r : n.a.toNumber(r) ); }; } const ni = { callSlot(e, t, i, s) { if (e) { const o = this.$xegrid; if (o) return o.callSlot(e, t, i, s); if (n.a.isFunction(e)) return e.call(this, t, i, s); } return []; }, getParentElem() { const e = this.$el, t = this.$xegrid; return t ? t.$el.parentNode : e.parentNode; }, getParentHeight() { const e = this.$el, t = this.$xegrid, i = this.height, s = e.parentNode, o = "auto" === i ? O(s) : 0; return Math.floor( t ? t.getParentHeight() : n.a.toNumber(getComputedStyle(s).height) - o ); }, getExcludeHeight() { const e = this.$xegrid; return e ? e.getExcludeHeight() : 0; }, clearAll() { return ct(this); }, syncData() { return this.$nextTick().then(() => { return ( (this.tableData = []), this.$nextTick().then(() => this.loadTableData(this.tableFullData) ) ); }); }, updateData() { return this.handleTableData(!0) .then(this.updateFooter) .then(this.recalculate); }, handleTableData(e) { const t = this.scrollYLoad, i = this.scrollYStore, s = e ? this.updateAfterFullData() : this.afterFullData; return ( (this.tableData = t ? s.slice(i.startIndex, i.endIndex) : s.slice(0)), this.$nextTick() ); }, loadTableData(e) { const t = this.keepSource, i = this.treeConfig, s = this.editStore, o = this.sYOpts, r = this.scrollYStore, l = this.scrollXStore, a = this.lastScrollLeft, h = this.lastScrollTop, c = this.scrollYLoad, d = e ? e.slice(0) : [], u = !i && o.enabled && o.gt > -1 && o.gt < d.length; return ( (r.startIndex = 0), (r.endIndex = 1), (l.startIndex = 0), (l.endIndex = 1), (s.insertList = []), (s.removeList = []), (this.tableFullData = d), this.updateCache(!0), (this.tableSynchData = e), t && (this.tableSourceData = n.a.clone(d, !0)), (this.scrollYLoad = u), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && u && (this.height || this.maxHeight || g.error("vxe.error.reqProp", [ "table.height | table.max-height | table.scroll-y={enabled: false}", ]), this.showOverflow || g.warn("vxe.error.reqProp", ["table.show-overflow"]), this.spanMethod && g.warn("vxe.error.scrollErrProp", ["table.span-method"])), this.clearCellAreas && this.mouseConfig && (this.clearCellAreas(), this.clearCopyCellArea()), this.clearMergeCells(), this.clearMergeFooterItems(), this.handleTableData(!0), this.updateFooter(), this.$nextTick() .then(() => { this.updateHeight(), this.updateStyle(); }) .then(() => { this.computeScrollLoad(); }) .then(() => { return ( u && (r.endIndex = r.visibleSize), this.handleReserveStatus(), this.checkSelectionStatus(), new Promise((e) => { this.$nextTick() .then(() => this.recalculate()) .then(() => { c === u ? Xt(this, a, h).then(e) : setTimeout(() => Xt(this, a, h).then(e)); }); }) ); }) ); }, loadData(e) { const t = this.inited, i = this.initStatus; return this.loadTableData(e).then(() => { return ( (this.inited = !0), (this.initStatus = !0), i || this.handleLoadDefaults(), t || this.handleInitDefaults(), this.recalculate() ); }); }, reloadData(e) { const t = this.inited; return this.clearAll() .then(() => { return ( (this.inited = !0), (this.initStatus = !0), this.loadTableData(e) ); }) .then(() => { return ( this.handleLoadDefaults(), t || this.handleInitDefaults(), this.recalculate() ); }); }, reloadRow(e, t, i) { const s = this.keepSource, o = this.tableSourceData, r = this.tableData; if (s) { const s = this.getRowIndex(e), l = o[s]; l && e && (i ? n.a.set(l, i, n.a.get(t || e, i)) : t ? ((o[s] = t), n.a.clear(e, void 0), Object.assign(e, this.defineField(Object.assign({}, t))), this.updateCache(!0)) : n.a.destructuring(l, n.a.clone(e, !0))), (this.tableData = r.slice(0)); } else "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.reqProp", ["keep-source"]); return this.$nextTick(); }, loadColumn(e) { const t = n.a.mapTree(e, (e) => Ot.createColumn(this, e), { children: "children", }); return this.handleColumn(t), this.$nextTick(); }, reloadColumn(e) { return this.clearAll().then(() => { return this.loadColumn(e); }); }, handleColumn(e) { this.collectColumn = e; const t = It(e); (this.tableFullColumn = t), this.cacheColumnMap(), this.restoreCustomStorage(), this.parseColumns().then(() => { this.scrollXLoad && this.loadScrollXData(!0); }), this.clearMergeCells(), this.clearMergeFooterItems(), this.handleTableData(!0), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && (this.scrollXLoad || this.scrollYLoad) && this.expandColumn && g.warn("vxe.error.scrollErrProp", ["column.type=expand"]), this.$nextTick(() => { this.$toolbar && this.$toolbar.syncUpdate({ collectColumn: e, $table: this }); }); }, updateCache(e) { const t = this.treeConfig, i = this.treeOpts, s = this.tableFullData, o = this.fullDataRowMap, r = this.fullAllDataRowMap; let l = this.fullDataRowIdData, a = this.fullAllDataRowIdData; const h = At(this), c = t && i.lazy, d = (s, d, u, p, f) => { let m = Rt(this, s); m || ((m = Ut()), n.a.set(s, h, m)), c && s[i.hasChild] && n.a.isUndefined(s[i.children]) && (s[i.children] = null); const g = { row: s, rowid: m, index: t && f ? -1 : d, items: u, parent: f, }; e && ((l[m] = g), o.set(s, g)), (a[m] = g), r.set(s, g); }; e && ((l = this.fullDataRowIdData = {}), o.clear()), (a = this.fullAllDataRowIdData = {}), r.clear(), t ? n.a.eachTree(s, d, i) : s.forEach(d); }, loadChildren(e, t) { return this.createData(t).then((t) => { const i = this.keepSource, s = this.tableSourceData, o = this.treeOpts, r = this.fullDataRowIdData, l = this.fullDataRowMap, a = this.fullAllDataRowMap, h = this.fullAllDataRowIdData, c = o.children; if (i) { const i = Rt(this, e), r = n.a.findTree(s, (e) => i === Rt(this, e), o); r && (r.item[c] = n.a.clone(t, !0)); } return ( n.a.eachTree( t, (e, t, i, s, n) => { const o = Rt(this, e), c = { row: e, rowid: o, index: -1, items: i, parent: n }; (r[o] = c), l.set(e, c), (h[o] = c), a.set(e, c); }, o ), (e[c] = t), t ); }); }, cacheColumnMap() { const e = this.tableFullColumn, t = this.collectColumn, i = this.fullColumnMap, s = this.showOverflow, o = (this.fullColumnIdData = {}), r = (this.fullColumnFieldData = {}), l = t.some(Dt); let a, h, c, d, u, p = !!s; const f = (e, t, s, n, l) => { const f = e.id, m = e.property, v = e.fixed, _ = e.type, b = e.treeNode, y = { column: e, colid: f, index: t, items: s, parent: l }; m && ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && r[m] && g.warn("vxe.error.colRepet", ["field", m]), (r[m] = y)), !u && v && (u = v), b ? ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && h && g.warn("vxe.error.colRepet", ["tree-node", b]), h || (h = e)) : "expand" === _ && ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && a && g.warn("vxe.error.colRepet", ["type", _]), a || (a = e)), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && ("checkbox" === _ ? (c && g.warn("vxe.error.colRepet", ["type", _]), c || (c = e)) : "radio" === _ && (d && g.warn("vxe.error.colRepet", ["type", _]), d || (d = e))), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && (this.showOverflow && !1 === e.showOverflow && g.warn("vxe.error.errConflicts", [ `table.show-overflow=${this.showOverflow}`, `column.show-overflow=${e.showOverflow}`, ]), this.showHeaderOverflow && !1 === e.showHeaderOverflow && g.warn("vxe.error.errConflicts", [ `table.show-header-overflow=${this.showHeaderOverflow}`, `column.show-header-overflow=${e.showHeaderOverflow}`, ]), this.showFooterOverflow && !1 === e.showFooterOverflow && g.warn("vxe.error.errConflicts", [ `table.show-footer-overflow=${this.showFooterOverflow}`, `column.show-footer-overflow=${e.showFooterOverflow}`, ])), p && !1 === e.showOverflow && (p = !1), o[f] && g.error("vxe.error.colRepet", ["colId", f]), (o[f] = y), i.set(e, y); }; i.clear(), l ? n.a.eachTree(t, (e, t, i, s, n, o) => { (e.level = o.length), f(e, t, i, s, n); }) : e.forEach(f), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && a && this.mouseOpts.area && g.error("vxe.error.errConflicts", [ "mouse-config.area", "column.type=expand", ]), (this.isGroup = l), (this.treeNodeColumn = h), (this.expandColumn = a), (this.isAllOverflow = p); }, getRowNode(e) { if (e) { const t = this.fullAllDataRowIdData, i = e.getAttribute("rowid"), s = t[i]; if (s) return { rowid: s.rowid, item: s.row, index: s.index, items: s.items, parent: s.parent, }; } return null; }, getColumnNode(e) { if (e) { const t = this.fullColumnIdData, i = e.getAttribute("colid"), s = t[i]; if (s) return { colid: s.colid, item: s.column, index: s.index, items: s.items, parent: s.parent, }; } return null; }, getRowIndex(e) { return this.fullDataRowMap.has(e) ? this.fullDataRowMap.get(e).index : -1; }, getVTRowIndex(e) { return this.afterFullData.indexOf(e); }, _getRowIndex(e) { return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delFunc", ["_getRowIndex", "getVTRowIndex"]), this.getVTRowIndex(e) ); }, getVMRowIndex(e) { return this.tableData.indexOf(e); }, $getRowIndex(e) { return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delFunc", ["$getRowIndex", "getVMRowIndex"]), this.getVMRowIndex(e) ); }, getColumnIndex(e) { return this.fullColumnMap.has(e) ? this.fullColumnMap.get(e).index : -1; }, getVTColumnIndex(e) { return this.visibleColumn.indexOf(e); }, _getColumnIndex(e) { return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delFunc", [ "_getColumnIndex", "getVTColumnIndex", ]), this.getVTColumnIndex(e) ); }, getVMColumnIndex(e) { return this.tableColumn.indexOf(e); }, $getColumnIndex(e) { return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delFunc", [ "$getColumnIndex", "getVMColumnIndex", ]), this.getVMColumnIndex(e) ); }, isSeqColumn(e) { return e && ("seq" === e.type || "index" === e.type); }, defineField(e) { const t = this.radioOpts, i = this.checkboxOpts, s = this.treeConfig, o = this.treeOpts, r = this.expandOpts, l = At(this); this.visibleColumn.forEach((t) => { let i = t.property, s = t.editRender; i && !n.a.has(e, i) && n.a.set( e, i, s && !n.a.isUndefined(s.defaultValue) ? s.defaultValue : null ); }); const a = [t.labelField, i.checkField, i.labelField, r.labelField]; return ( a.forEach((t) => { t && !n.a.get(e, t) && n.a.set(e, t, null); }), s && o.lazy && n.a.isUndefined(e[o.children]) && (e[o.children] = null), n.a.get(e, l) || n.a.set(e, l, Ut()), e ); }, createData(e) { const t = this.treeConfig, i = this.treeOpts, s = (e) => this.defineField(Object.assign({}, e)), o = t ? n.a.mapTree(e, s, i) : e.map(s); return this.$nextTick().then(() => o); }, createRow(e) { const t = n.a.isArray(e); return ( t || (e = [e]), this.$nextTick().then(() => this.createData(e).then((e) => (t ? e : e[0])) ) ); }, revertData(e, t) { const i = this.keepSource, s = this.tableSourceData, o = this.treeConfig; if (!i) return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.reqProp", ["keep-source"]), this.$nextTick() ); let r = e; return ( e ? n.a.isArray(e) || (r = [e]) : (r = n.a.toArray(this.getUpdateRecords())), r.length && r.forEach((e) => { if (!this.isInsertByRow(e)) { const i = this.getRowIndex(e); if (o && -1 === i) throw new Error( g.getLog("vxe.error.noTree", ["revertData"]) ); const r = s[i]; r && e && (t ? n.a.set(e, t, n.a.clone(n.a.get(r, t), !0)) : n.a.destructuring(e, n.a.clone(r, !0))); } }), e ? this.$nextTick() : this.reloadData(s) ); }, clearData(e, t) { const i = this.tableFullData, s = this.visibleColumn; return ( arguments.length ? e && !n.a.isArray(e) && (e = [e]) : (e = i), t ? e.forEach((e) => n.a.set(e, t, null)) : e.forEach((e) => { s.forEach((t) => { t.property && Lt(e, t, null); }); }), this.$nextTick() ); }, isInsertByRow(e) { return this.editStore.insertList.indexOf(e) > -1; }, isUpdateByRow(e, t) { const i = this.visibleColumn, s = this.keepSource, o = this.treeConfig, r = this.treeOpts, l = this.tableSourceData, a = this.fullDataRowIdData; if (s) { let s, h; const c = Rt(this, e); if (!a[c]) return !1; if (o) { const t = r.children, i = n.a.findTree(l, (e) => c === Rt(this, e), r); (e = Object.assign({}, e, { [t]: null })), i && (s = Object.assign({}, i.item, { [t]: null })); } else { const e = a[c].index; s = l[e]; } if (s) { if (arguments.length > 1) return !Wt(s, e, t); for (let t = 0, n = i.length; t < n; t++) if (((h = i[t].property), h && !Wt(s, e, h))) return !0; } } return !1; }, getColumns(e) { const t = this.visibleColumn; return n.a.isUndefined(e) ? t.slice(0) : t[e]; }, getColumnById(e) { const t = this.fullColumnIdData; return t[e] ? t[e].column : null; }, getColumnByField(e) { const t = this.fullColumnFieldData; return t[e] ? t[e].column : null; }, getTableColumn() { return { collectColumn: this.collectColumn.slice(0), fullColumn: this.tableFullColumn.slice(0), visibleColumn: this.visibleColumn.slice(0), tableColumn: this.tableColumn.slice(0), }; }, getData(e) { const t = this.data || this.tableSynchData; return n.a.isUndefined(e) ? t.slice(0) : t[e]; }, getCheckboxRecords() { const e = this.tableFullData, t = this.treeConfig, i = this.treeOpts, s = this.checkboxOpts, o = s.checkField; let r = []; if (o) r = t ? n.a.filterTree(e, (e) => n.a.get(e, o), i) : e.filter((e) => n.a.get(e, o)); else { const s = this.selection; r = t ? n.a.filterTree(e, (e) => s.indexOf(e) > -1, i) : e.filter((e) => s.indexOf(e) > -1); } return r; }, updateAfterFullData() { const e = this.tableFullColumn, t = this.tableFullData, i = this.filterOpts, s = this.sortOpts, o = i.remote, r = i.filterMethod, l = s.remote, a = s.sortMethod, h = s.multiple; let c = t.slice(0); const d = [], u = []; e.forEach((e) => { const t = e.sortable, i = e.order, s = e.filters; if (!o && s && s.length) { const t = [], i = []; s.forEach((e) => { e.checked && (i.push(e), t.push(e.value)); }), i.length && d.push({ column: e, valueList: t, itemList: i }); } !l && t && i && u.push({ column: e, property: e.property, order: i }); }), d.length && (c = c.filter((e) => { return d.every((t) => { let i = t.column, s = t.valueList, l = t.itemList; if (s.length && !o) { const t = i.filterMethod, o = i.filterRender, a = o ? Ke.renderer.get(o.name) : null, h = a && a.renderFilter ? a.filterMethod : null, c = g.getCellValue(e, i); return t ? l.some((s) => t({ value: s.value, option: s, cellValue: c, row: e, column: i, $table: this, }) ) : h ? l.some((t) => h({ value: t.value, option: t, cellValue: c, row: e, column: i, $table: this, }) ) : r ? r({ options: l, values: s, cellValue: c, row: e, column: i, }) : s.indexOf(n.a.get(e, i.property)) > -1; } return !0; }); })); const p = u[0]; if (!l && p) if (a) { const e = a({ data: c, column: p.column, property: p.property, order: p.order, sortList: u, $table: this, }); c = n.a.isArray(e) ? e : c; } else if (h) c = n.a.orderBy( c, u.map((e) => { let t = e.column, i = e.order; return [si(this, t), i]; }) ); else { let e = p.column, t = null; if (e.sortMethod) t = c.sort(e.sortMethod); else if (e.sortBy) t = Object($t["b"])(c, e.sortBy, !0); else if (e.formatter && e.sortByFormatter) { let i = { $table: this, column: e }; t = c.sort((t, s) => { return ( (i.row = t), (t = this.getCellLabel(t, e, i)), (i.row = s), (s = this.getCellLabel(s, e, i)), Object($t["c"])(t, s) ); }); } else t = e.property ? Object($t["b"])(c, e.property, !0) : c; c = "desc" === e.order ? t.reverse() : t; } return (this.afterFullData = c), c; }, getRowById(e) { const t = this.fullDataRowIdData; return t[e] ? t[e].row : null; }, getRowid(e) { const t = this.fullAllDataRowMap; return t.has(e) ? t.get(e).rowid : null; }, getTableData() { const e = this.tableFullData, t = this.afterFullData, i = this.tableData, s = this.footerTableData; return { fullData: e.slice(0), visibleData: t.slice(0), tableData: i.slice(0), footerData: s.slice(0), }; }, handleLoadDefaults() { this.checkboxConfig && this.handleDefaultSelectionChecked(), this.radioConfig && this.handleDefaultRadioChecked(), this.expandConfig && this.handleDefaultRowExpand(), this.treeConfig && this.handleDefaultTreeExpand(), this.mergeCells && this.handleDefaultMergeCells(), this.mergeFooterItems && this.handleDefaultMergeFooterItems(), this.$nextTick(() => setTimeout(this.recalculate)); }, handleInitDefaults() { const e = this.sortConfig; e && this.handleDefaultSort(); }, hideColumn(e) { const t = it(this, e); return t && (t.visible = !1), this.handleCustom(); }, showColumn(e) { const t = it(this, e); return t && (t.visible = !0), this.handleCustom(); }, resetColumn(e) { const t = this.customOpts, i = t.checkMethod, s = Object.assign({ visible: !0, resizable: !0 === e }, e); return ( this.tableFullColumn.forEach((e) => { s.resizable && (e.resizeWidth = 0), (i && !i({ column: e })) || (e.visible = e.defaultVisible); }), s.resizable && this.saveCustomResizable(!0), this.handleCustom() ); }, handleCustom() { return ( this.saveCustomVisible(), this.analyColumnWidth(), this.refreshColumn() ); }, restoreCustomStorage() { const e = this.id, t = this.collectColumn, i = this.customConfig, s = this.customOpts, o = s.storage, r = !0 === s.storage, l = r || (o && o.resizable), a = r || (o && o.visible); if (i && (l || a)) { const i = {}; if (!e) return void g.error("vxe.error.reqProp", ["id"]); if (l) { const t = Zt(jt)[e]; t && n.a.each(t, (e, t) => { i[t] = { field: t, resizeWidth: e }; }); } if (a) { const t = Zt(Ht)[e]; if (t) { const e = t.split("|"), s = e[0] ? e[0].split(",") : [], n = e[1] ? e[1].split(",") : []; s.forEach((e) => { i[e] ? (i[e].visible = !1) : (i[e] = { field: e, visible: !1 }); }), n.forEach((e) => { i[e] ? (i[e].visible = !0) : (i[e] = { field: e, visible: !0 }); }); } } const s = {}; n.a.eachTree(t, (e) => { const t = e.getKey(); t && (s[t] = e); }), n.a.each(i, (e, t) => { let i = e.visible, o = e.resizeWidth; const r = s[t]; r && (n.a.isNumber(o) && (r.resizeWidth = o), n.a.isBoolean(i) && (r.visible = i)); }); } }, saveCustomVisible() { const e = this.id, t = this.collectColumn, i = this.customConfig, s = this.customOpts, o = s.checkMethod, r = s.storage, l = !0 === s.storage, a = l || (r && r.visible); if (i && a) { const i = Zt(Ht), s = [], r = []; if (!e) return void g.error("vxe.error.reqProp", ["id"]); n.a.eachTree(t, (e) => { if (!o || o({ column: e })) if (!e.visible && e.defaultVisible) { const t = e.getKey(); t && s.push(t); } else if (e.visible && !e.defaultVisible) { const t = e.getKey(); t && r.push(t); } }), (i[e] = [s.join(",")] .concat(r.length ? [r.join(",")] : []) .join("|") || void 0), localStorage.setItem(Ht, n.a.toJSONString(i)); } }, saveCustomResizable(e) { const t = this.id, i = this.collectColumn, s = this.customConfig, o = this.customOpts, r = o.storage, l = !0 === o.storage, a = l || (r && r.resizable); if (s && a) { const s = Zt(jt); let o; if (!t) return void g.error("vxe.error.reqProp", ["id"]); e || ((o = n.a.isPlainObject(s[t]) ? s[t] : {}), n.a.eachTree(i, (e) => { if (e.resizeWidth) { const t = e.getKey(); t && (o[t] = e.renderWidth); } })), (s[t] = n.a.isEmpty(o) ? void 0 : o), localStorage.setItem(jt, n.a.toJSONString(s)); } }, refreshColumn() { return this.parseColumns() .then(() => { return this.refreshScroll(); }) .then(() => { return this.recalculate(); }); }, parseColumns() { const e = [], t = [], i = [], s = this.collectColumn, o = this.tableFullColumn, r = this.isGroup, l = this.columnStore, a = this.sXOpts, h = this.scrollXStore; if (r) { const o = [], r = [], l = []; n.a.eachTree(s, (s, o, r, l, a) => { const h = Dt(s); a && a.fixed && (s.fixed = a.fixed), a && s.fixed !== a.fixed && g.error("vxe.error.groupFixed"), h ? (s.visible = !!n.a.findTree(s.children, (e) => Dt(e) ? null : e.visible )) : s.visible && ("left" === s.fixed ? e.push(s) : "right" === s.fixed ? i.push(s) : t.push(s)); }), s.forEach((e) => { e.visible && ("left" === e.fixed ? o.push(e) : "right" === e.fixed ? l.push(e) : r.push(e)); }), (this.tableGroupColumn = o.concat(r).concat(l)); } else o.forEach((s) => { s.visible && ("left" === s.fixed ? e.push(s) : "right" === s.fixed ? i.push(s) : t.push(s)); }); const c = e.concat(t).concat(i); let d = a.enabled && a.gt > -1 && a.gt < o.length; if ( ((this.hasFixedColumn = e.length > 0 || i.length > 0), Object.assign(l, { leftList: e, centerList: t, rightList: i }), d && r && ((d = !1), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.scrollXNotGroup")), d) ) { "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && (this.showHeader && !this.showHeaderOverflow && g.warn("vxe.error.reqProp", ["show-header-overflow"]), this.showFooter && !this.showFooterOverflow && g.warn("vxe.error.reqProp", ["show-footer-overflow"]), this.spanMethod && g.warn("vxe.error.scrollErrProp", ["span-method"]), this.footerSpanMethod && g.warn("vxe.error.scrollErrProp", ["footer-span-method"])); const e = Kt(this), t = e.visibleSize; (h.startIndex = 0), (h.endIndex = t), (h.visibleSize = t); } return ( (c.length === this.visibleColumn.length && this.visibleColumn.every((e, t) => e === c[t])) || (this.clearMergeCells(), this.clearMergeFooterItems()), (this.scrollXLoad = d), (this.visibleColumn = c), this.handleTableColumn(), this.updateFooter() .then(() => { return this.recalculate(); }) .then(() => { return this.updateCellAreas(), this.recalculate(); }) ); }, analyColumnWidth() { const e = this.columnOpts, t = e.width, i = e.minWidth, s = [], n = [], o = [], r = [], l = [], a = []; this.tableFullColumn.forEach((e) => { t && !e.width && (e.width = t), i && !e.minWidth && (e.minWidth = i), e.visible && (e.resizeWidth ? s.push(e) : A.isPx(e.width) ? n.push(e) : A.isScale(e.width) ? r.push(e) : A.isPx(e.minWidth) ? o.push(e) : A.isScale(e.minWidth) ? l.push(e) : a.push(e)); }), Object.assign(this.columnStore, { resizeList: s, pxList: n, pxMinList: o, scaleList: r, scaleMinList: l, autoList: a, }); }, refreshScroll() { const e = this.lastScrollLeft, t = this.lastScrollTop, i = this.$refs, s = i.tableBody, n = i.leftBody, o = i.rightBody, r = i.tableFooter, l = s ? s.$el : null, a = n ? n.$el : null, h = o ? o.$el : null, c = r ? r.$el : null; if (e || t) return Xt(this, e, t); $(l, t), $(a, t), $(h, t), R(c, e); }, recalculate(e) { const t = this.$refs, i = t.tableBody, s = t.tableHeader, n = t.tableFooter, o = i ? i.$el : null, r = s ? s.$el : null, l = n ? n.$el : null; return o && (this.autoCellWidth(r, o, l), !0 === e) ? this.computeScrollLoad().then(() => { return this.autoCellWidth(r, o, l), this.computeScrollLoad(); }) : this.computeScrollLoad(); }, autoCellWidth(e, t, i) { let s = 0; const n = 40, o = t.clientWidth - 1; let r = o, l = r / 100; const a = this.fit, h = this.columnStore, c = h.resizeList, d = h.pxMinList, u = h.pxList, p = h.scaleList, f = h.scaleMinList, m = h.autoList; if ( (d.forEach((e) => { const t = parseInt(e.minWidth); (s += t), (e.renderWidth = t); }), f.forEach((e) => { const t = Math.floor(parseInt(e.minWidth) * l); (s += t), (e.renderWidth = t); }), p.forEach((e) => { const t = Math.floor(parseInt(e.width) * l); (s += t), (e.renderWidth = t); }), u.forEach((e) => { const t = parseInt(e.width); (s += t), (e.renderWidth = t); }), c.forEach((e) => { const t = parseInt(e.resizeWidth); (s += t), (e.renderWidth = t); }), (r -= s), (l = r > 0 ? Math.floor(r / (f.length + d.length + m.length)) : 0), a ? r > 0 && f.concat(d).forEach((e) => { (s += l), (e.renderWidth += l); }) : (l = n), m.forEach((e) => { const t = Math.max(l, n); (e.renderWidth = t), (s += t); }), a) ) { const e = p.concat(f).concat(d).concat(m); let t = e.length - 1; if (t > 0) { let i = o - s; if (i > 0) { while (i > 0 && t >= 0) i--, e[t--].renderWidth++; s = o; } } } const g = t.offsetHeight, v = t.scrollHeight > t.clientHeight; if ( ((this.scrollbarWidth = v ? t.offsetWidth - t.clientWidth : 0), (this.overflowY = v), (this.tableWidth = s), (this.tableHeight = g), e ? ((this.headerHeight = e.clientHeight), this.$nextTick(() => { e && t && e.scrollLeft !== t.scrollLeft && (e.scrollLeft = t.scrollLeft); })) : (this.headerHeight = 0), i) ) { const e = i.offsetHeight; (this.scrollbarHeight = Math.max(e - i.clientHeight, 0)), (this.overflowX = s > i.clientWidth), (this.footerHeight = e); } else (this.footerHeight = 0), (this.scrollbarHeight = Math.max(g - t.clientHeight, 0)), (this.overflowX = s > o); this.updateHeight(), (this.parentHeight = Math.max( this.headerHeight + this.footerHeight + 20, this.getParentHeight() )), this.overflowX && this.checkScrolling(); }, updateHeight() { (this.customHeight = Mt(this, "height")), (this.customMaxHeight = Mt(this, "maxHeight")); }, updateStyle() { let e = this.$refs, t = this.isGroup, i = this.fullColumnIdData, s = this.tableColumn, o = this.customHeight, r = (this.customMaxHeight, this.border), l = this.headerHeight, a = this.showFooter, h = this.showOverflow, c = this.showHeaderOverflow, d = this.showFooterOverflow, u = this.footerHeight, p = this.tableHeight, f = this.tableWidth, m = this.scrollbarHeight, g = this.scrollbarWidth, v = this.scrollXLoad, _ = this.scrollYLoad, y = this.cellOffsetWidth, x = this.columnStore, w = this.elemStore, S = this.editStore, E = this.currentRow, k = this.mouseConfig, C = this.keyboardConfig, T = this.keyboardOpts, O = this.spanMethod, $ = this.mergeList, R = this.mergeFooterList, A = this.footerSpanMethod, L = this.isAllOverflow; const D = ["main", "left", "right"], I = e.emptyPlaceholder; w["main-body-wrapper"]; let M = Math.max(32, l); return ( I && ((I.style.top = `${M}px`), (I.style.height = "calc(100% - " + M + "px)")), o > 0 && a && (o += m), D.forEach((l, a) => { const S = a > 0 ? l : "", E = ["header", "body", "footer"], k = x[`${S}List`], D = e[`${S}Container`]; E.forEach((e) => { const a = w[`${l}-${e}-wrapper`], E = w[`${l}-${e}-table`]; if ("header" === e) { let i = f, o = !1; t || (S && (v || c) && (o = !0)), o && (s = k), (o || v) && (i = s.reduce((e, t) => e + t.renderWidth, 0)), E && ((E.style.width = i ? `${i + g + 1}px` : ""), b.msie && n.a.arrayEach( E.querySelectorAll(".vxe-resizable"), (e) => { e.style.height = `${e.parentNode.offsetHeight}px`; } )); const a = w[`${l}-${e}-repair`]; a && (a.style.width = `${f}px`); const h = w[`${l}-${e}-list`]; t && h && n.a.arrayEach(h.querySelectorAll(".col--group"), (e) => { const t = this.getColumnNode(e); if (t) { const i = t.item, s = i.showHeaderOverflow, o = n.a.isBoolean(s) ? s : c, l = "ellipsis" === o, a = "title" === o, h = !0 === o || "tooltip" === o, d = a || h || l; let u = 0, p = 0; d && n.a.eachTree(i.children, (e) => { (e.children && i.children.length) || p++, (u += e.renderWidth); }), (e.style.width = d ? `${u - p - (r ? 2 : 0)}px` : ""); } }); } else if ("body" === e) { const t = w[`${l}-${e}-emptyBlock`]; if ( (a && (a.style.height = "calc(100% - " + M + "px)"), D) ) { const e = "right" === S, t = x[`${S}List`]; a && (a.style.top = `${M}px`), (D.style.height = "calc(100% - 11px)"), (D.style.width = `${t.reduce( (e, t) => e + t.renderWidth, e ? g : 0 )}px`); } let i = f, n = !1; S && ($.length || O || (C && T.isMerge) || !(v || _ || (h ? L : h)) || (n = !0)), n && (s = k), (n || v) && (i = s.reduce((e, t) => e + t.renderWidth, 0)), E && ((E.style.width = i ? `${i + 1}px` : ""), (E.style.paddingRight = g && S && (b["-moz"] || b.safari) ? `${g}px` : "")), t && (t.style.width = i ? `${i}px` : ""); } else if ("footer" === e) { let e = f, t = !1; S && ((R.length && A) || (!v && !d) || (t = !0)), t && (s = k), (t || v) && (e = s.reduce((e, t) => e + t.renderWidth, 0)), a && (D && (a.style.top = `${o > 0 ? o - u : p + M}px`), (a.style.marginTop = `${-m}px`)), E && (E.style.width = e ? `${e + g + 1}px` : ""); } const I = w[`${l}-${e}-colgroup`]; I && n.a.arrayEach(I.children, (t) => { const s = t.getAttribute("name"); if ( ("col_gutter" === s && (t.style.width = `${g}px`), i[s]) ) { const o = i[s].column, r = o.showHeaderOverflow, a = o.showFooterOverflow, u = o.showOverflow; let p; (t.style.width = `${o.renderWidth}px`), (p = "header" === e ? n.a.isUndefined(r) || n.a.isNull(r) ? c : r : "footer" === e ? n.a.isUndefined(a) || n.a.isNull(a) ? d : a : n.a.isUndefined(u) || n.a.isNull(u) ? h : u); const f = "ellipsis" === p, m = "title" === p, g = !0 === p || "tooltip" === p; let b = m || g || f; const x = w[`${l}-${e}-list`]; "header" === e || "footer" === e ? v && !b && (b = !0) : (!v && !_) || b || (b = !0), x && n.a.arrayEach( x.querySelectorAll(`.${o.id}`), (e) => { const t = parseInt( e.getAttribute("colspan") || 1 ), i = e.querySelector(".vxe-cell"); let s = o.renderWidth; if (i) { if (t > 1) { const e = this.getColumnIndex(o); for (let i = 1; i < t; i++) { const t = this.getColumns(e + i); t && (s += t.renderWidth); } } let e = y * t > 2 ? y * t : 0; i.style.width = b ? `${s - e}px` : ""; } } ); } }); }); }), E && this.setCurrentRow(E), k && k.selected && S.selected.row && S.selected.column && this.addColSdCls(), this.$nextTick() ); }, checkScrolling() { const e = this.$refs, t = e.tableBody, i = e.leftContainer, s = e.rightContainer, n = t ? t.$el : null; n && (i && A[n.scrollLeft > 0 ? "addClass" : "removeClass"]( i, "scrolling--middle" ), s && A[ n.clientWidth < n.scrollWidth - Math.ceil(n.scrollLeft) ? "addClass" : "removeClass" ](s, "scrolling--middle")); }, preventEvent(e, t, i, s, n) { const o = Ke.interceptor.get(t); let r; return ( o.some( (t) => !1 === t( Object.assign( { $grid: this.$xegrid, $table: this, $event: e }, i ) ) ) || (s && (r = s())), n && n(), r ); }, handleGlobalMousedownEvent(e) { const t = this.$el, i = this.$refs, s = this.$xegrid, n = this.$toolbar, o = this.mouseConfig, r = this.editStore, l = this.ctxMenuStore, a = this.editOpts, h = this.filterStore, c = this.getRowNode, d = r.actived, u = i.ctxWrapper, p = i.filterWrapper, f = i.validTip; if ( (p && (Ft(e, t, "vxe-cell--filter").flag || Ft(e, p.$el).flag || Ft(e, document.body, "vxe-table--ignore-clear").flag || this.preventEvent( e, "event.clearFilter", h.args, this.closeFilter )), d.row) ) { if (!1 !== a.autoClear) { const i = d.args.cell; (i && Ft(e, i).flag) || (f && Ft(e, f.$el).flag) || ((!this.lastCallTime || this.lastCallTime + 50 < Date.now()) && (Ft(e, document.body, "vxe-table--ignore-clear").flag || this.preventEvent(e, "event.clearActived", d.args, () => { let i; if ("row" === a.mode) { const s = Ft(e, t, "vxe-body--row"); i = !!s.flag && c(s.targetElem).item !== d.args.row; } else i = !Ft(e, t, "col--edit").flag; if ( (i || (i = Ft(e, t, "vxe-header--row").flag), i || (i = Ft(e, t, "vxe-footer--row").flag), !i && this.height && !this.overflowY) ) { const t = e.target; Pt(t, "vxe-table--body-wrapper") && (i = e.offsetY < t.clientHeight); } (!i && Ft(e, t).flag) || setTimeout(() => this.clearActived(e)); }))); } } else o && (Ft(e, t).flag || (s && Ft(e, s.$el).flag) || (u && Ft(e, u.$el).flag) || (n && Ft(e, n.$el).flag) || (this.clearSelected(), Ft(e, document.body, "vxe-table--ignore-areas-clear").flag || this.preventEvent(e, "event.clearAreas", {}, () => { this.clearCellAreas(), this.clearCopyCellArea(); }))); l.visible && u && !Ft(e, u.$el).flag && this.closeMenu(), (this.isActivated = Ft(e, (s || this).$el).flag); }, handleGlobalBlurEvent() { this.closeFilter(), this.closeMenu(); }, handleGlobalMousewheelEvent() { this.closeTooltip(), this.closeMenu(); }, keydownEvent(e) { const t = this.filterStore, i = this.ctxMenuStore, s = this.editStore, n = this.keyboardConfig, o = this.mouseConfig, r = this.mouseOpts, l = s.actived, a = e.keyCode, h = 27 === a; h && this.preventEvent(e, "event.keydown", null, () => { if (n && o && r.area && this.handleKeyboardEvent) this.handleKeyboardEvent(e); else if ( (l.row || t.visible || i.visible) && (e.stopPropagation(), this.closeFilter(), this.closeMenu(), l.row) ) { const t = l.args; this.clearActived(e), o && r.selected && this.$nextTick(() => this.handleSelected(t, e)); } this.emitEvent("keydown", {}, e); }); }, handleGlobalKeydownEvent(e) { this.isActivated && this.preventEvent(e, "event.keydown", null, () => { const t = this.filterStore, i = this.isCtxMenu, s = this.ctxMenuStore, o = this.editStore, r = this.editOpts, l = this.editConfig, a = this.mouseConfig, h = this.mouseOpts, c = this.keyboardConfig, d = this.keyboardOpts, u = this.treeConfig, f = this.treeOpts, m = this.highlightCurrentRow, g = this.currentRow, v = this.bodyCtxMenu, _ = o.selected, b = o.actived, y = e.keyCode, x = 8 === y, w = 9 === y, S = 13 === y, E = 27 === y, k = 32 === y, C = 37 === y, T = 38 === y, O = 39 === y, $ = 40 === y, R = 46 === y, A = 113 === y, L = 93 === y, D = e.metaKey, I = e.ctrlKey, M = e.shiftKey, P = e.altKey, N = C || T || O || $, B = i && s.visible && (S || k || N), F = l && b.column && b.row; let V; if (t.visible) E && this.closeFilter(); else { if (B) e.preventDefault(), s.showChild && Dt(s.selected) ? this.moveCtxMenu( e, y, s, "selectChild", 37, !1, s.selected.children ) : this.moveCtxMenu( e, y, s, "selected", 39, !0, this.ctxMenuList ); else if (c && a && h.area && this.handleKeyboardEvent) this.handleKeyboardEvent(e); else if ( c && k && d.isChecked && _.row && _.column && ("checkbox" === _.column.type || "radio" === _.column.type) ) e.preventDefault(), "checkbox" === _.column.type ? this.handleToggleCheckRowEvent(e, _.args) : this.triggerRadioRowEvent(e, _.args); else if (A) F || (_.row && _.column && (e.stopPropagation(), e.preventDefault(), this.handleActived(_.args, e))); else if (L) (this._keyCtx = _.row && _.column && v.length), clearTimeout(this.keyCtxTimeout), (this.keyCtxTimeout = setTimeout(() => { this._keyCtx = !1; }, 1e3)); else if ( S && !P && c && d.isEnter && (_.row || b.row || (u && m && g)) ) { if (I) b.row && ((V = b.args), this.clearActived(e), a && h.selected && this.$nextTick(() => this.handleSelected(V, e))); else if (_.row || b.row) { const t = _.row ? _.args : b.args; M ? d.enterToTab ? this.moveTabSelected(t, M, e) : this.moveSelected(t, C, !0, O, !1, e) : d.enterToTab ? this.moveTabSelected(t, M, e) : this.moveSelected(t, C, !1, O, !0, e); } else if (u && m && g) { const t = g[f.children]; if (t && t.length) { e.preventDefault(); const i = t[0]; (V = { $table: this, row: i }), this.setTreeExpand(g, !0) .then(() => this.scrollToRow(i)) .then(() => this.triggerCurrentRowEvent(e, V)); } } } else if (N && c && d.isArrow) F || (_.row && _.column ? this.moveSelected(_.args, C, T, O, $, e) : (T || $) && m && this.moveCurrentRow(T, $, e)); else if (w && c && d.isTab) _.row || _.column ? this.moveTabSelected(_.args, M, e) : (b.row || b.column) && this.moveTabSelected(b.args, M, e); else if (c && (R || (u && m && g ? x && d.isArrow : x))) { if (!F) { const t = d.delMethod, i = d.backMethod; if (d.isDel && (_.row || _.column)) t ? t({ row: _.row, rowIndex: this.getRowIndex(_.row), column: _.column, columnIndex: this.getColumnIndex(_.column), $table: this, }) : Lt(_.row, _.column, null), x ? i ? i({ row: _.row, rowIndex: this.getRowIndex(_.row), column: _.column, columnIndex: this.getColumnIndex(_.column), $table: this, }) : this.handleActived(_.args, e) : R && this.updateFooter(); else if (x && d.isArrow && u && m && g) { const t = n.a.findTree( this.afterFullData, (e) => e === g, f ), i = t.parent; i && (e.preventDefault(), (V = { $table: this, row: i }), this.setTreeExpand(i, !1) .then(() => this.scrollToRow(i)) .then(() => this.triggerCurrentRowEvent(e, V))); } } } else if ( c && d.isEdit && !I && !D && (k || (y >= 48 && y <= 57) || (y >= 65 && y <= 90) || (y >= 96 && y <= 111) || (y >= 186 && y <= 192) || (y >= 219 && y <= 222)) ) { const t = d.editMethod; _.column && _.row && p(_.column.editRender) && ((r.activeMethod && !r.activeMethod(_.args)) || (t ? t({ row: _.row, rowIndex: this.getRowIndex(_.row), column: _.column, columnIndex: this.getColumnIndex(_.column), $table: this, }) : (Lt(_.row, _.column, null), this.handleActived(_.args, e)))); } this.emitEvent("keydown", {}, e); } }); }, handleGlobalPasteEvent(e) { const t = this.isActivated, i = this.keyboardConfig, s = this.keyboardOpts, n = this.mouseConfig, o = this.mouseOpts, r = this.editStore, l = this.filterStore, a = r.actived; t && !l.visible && (a.row || a.column || (i && s.isClip && n && o.area && this.handlePasteCellAreaEvent && this.handlePasteCellAreaEvent(e)), this.emitEvent("paste", {}, e)); }, handleGlobalCopyEvent(e) { const t = this.isActivated, i = this.keyboardConfig, s = this.keyboardOpts, n = this.mouseConfig, o = this.mouseOpts, r = this.editStore, l = this.filterStore, a = r.actived; t && !l.visible && (a.row || a.column || (i && s.isClip && n && o.area && this.handleCopyCellAreaEvent && this.handleCopyCellAreaEvent(e)), this.emitEvent("copy", {}, e)); }, handleGlobalCutEvent(e) { const t = this.isActivated, i = this.keyboardConfig, s = this.keyboardOpts, n = this.mouseConfig, o = this.mouseOpts, r = this.editStore, l = this.filterStore, a = r.actived; t && !l.visible && (a.row || a.column || (i && s.isClip && n && o.area && this.handleCutCellAreaEvent && this.handleCutCellAreaEvent(e)), this.emitEvent("cut", {}, e)); }, handleGlobalResizeEvent() { this.closeMenu(), this.updateCellAreas(), this.recalculate(!0); }, handleTooltipLeaveMethod() { const e = this.tooltipOpts; return ( setTimeout(() => { this.tooltipActive || this.closeTooltip(); }, e.leaveDelay), !1 ); }, handleTargetEnterEvent() { clearTimeout(this.tooltipTimeout), (this.tooltipActive = !0), this.closeTooltip(); }, handleTargetLeaveEvent() { const e = this.tooltipOpts; (this.tooltipActive = !1), e.enterable ? (this.tooltipTimeout = setTimeout(() => { const e = this.$refs.tooltip; e && !e.isHover && this.closeTooltip(); }, e.leaveDelay)) : this.closeTooltip(); }, triggerHeaderHelpEvent(e, t) { const i = t.column, s = i.titleHelp; if (s.message) { const t = this.$refs, i = this.tooltipStore, n = t.tooltip, o = g.getFuncText(s.message); this.handleTargetEnterEvent(), (i.visible = !0), n && n.open(e.currentTarget, o); } }, triggerHeaderTooltipEvent(e, t) { const i = this.tooltipStore, s = t.column, n = e.currentTarget; this.handleTargetEnterEvent(), (i.column === s && i.visible) || this.handleTooltip(e, n, n, null, t); }, triggerBodyTooltipEvent(e, t) { const i = this.editConfig, s = this.editOpts, n = this.editStore, o = this.tooltipStore, r = n.actived, l = t.row, a = t.column, h = e.currentTarget; if ( (this.handleTargetEnterEvent(), (!i || !( ("row" === s.mode && r.row === l) || (r.row === l && r.column === a) )) && (o.column !== a || o.row !== l || !o.visible)) ) { let i, s; a.treeNode ? ((i = h.querySelector(".vxe-tree-cell")), "html" === a.type && (s = h.querySelector(".vxe-cell--html"))) : (s = h.querySelector( "html" === a.type ? ".vxe-cell--html" : ".vxe-cell--label" )), this.handleTooltip(e, h, i || h.children[0], s, t); } }, triggerFooterTooltipEvent(e, t) { const i = t.column, s = this.tooltipStore, n = e.currentTarget; this.handleTargetEnterEvent(), (s.column === i && s.visible) || this.handleTooltip( e, n, n.querySelector(".vxe-cell--item") || n.children[0], null, t ); }, handleTooltip(e, t, i, s, o) { o.cell = t; const r = this.$refs, l = this.tooltipOpts, a = this.tooltipStore, h = o.column, c = o.row, d = l.showAll, u = l.enabled, p = l.contentMethod, f = r.tooltip, m = p ? p(o) : null, v = p && !n.a.eqNull(m), _ = v ? m : ("html" === h.type ? i.innerText : i.textContent).trim(), b = i.scrollWidth > i.clientWidth; return ( _ && (d || u || v || b) && (Object.assign(a, { row: c, column: h, visible: !0 }), f && f.open(b ? i : s || i, g.formatText(_))), this.$nextTick() ); }, openTooltip(e, t) { const i = this.$refs, s = i.commTip; return s ? s.open(e, t) : this.$nextTick(); }, closeTooltip() { const e = this.$refs, t = this.tooltipStore, i = e.tooltip, s = e.commTip; return ( t.visible && (Object.assign(t, { row: null, column: null, content: null, visible: !1, }), i && i.close()), s && s.close(), this.$nextTick() ); }, isAllCheckboxChecked() { return this.isAllSelected; }, isCheckboxIndeterminate() { return !this.isAllSelected && this.isIndeterminate; }, getCheckboxIndeterminateRecords() { const e = this.treeConfig, t = this.treeIndeterminates; return e ? t.slice(0) : []; }, handleDefaultSelectionChecked() { const e = this.fullDataRowIdData, t = this.checkboxOpts, i = t.checkAll, s = t.checkRowKeys; if (i) this.setAllCheckboxRow(!0); else if (s) { const t = []; s.forEach((i) => { e[i] && t.push(e[i].row); }), this.setCheckboxRow(t, !0); } }, setCheckboxRow(e, t) { return ( e && !n.a.isArray(e) && (e = [e]), e.forEach((e) => this.handleSelectRow({ row: e }, !!t)), this.$nextTick() ); }, isCheckedByCheckboxRow(e) { const t = this.checkboxOpts.checkField; return t ? n.a.get(e, t) : this.selection.indexOf(e) > -1; }, handleSelectRow(e, t) { let i = e.row; const s = this.selection, o = this.afterFullData, r = this.treeConfig, l = this.treeOpts, a = this.treeIndeterminates, h = this.checkboxOpts, c = h.checkField, d = h.checkStrictly, u = h.checkMethod; if (c) if (r && !d) { -1 === t ? (-1 === a.indexOf(i) && a.push(i), n.a.set(i, c, !1)) : n.a.eachTree( [i], (e) => { (i !== e && u && !u({ row: e })) || (n.a.set(e, c, t), n.a.remove(a, (t) => t === e), this.handleCheckboxReserveRow(i, t)); }, l ); const e = n.a.findTree(o, (e) => e === i, l); if (e && e.parent) { let i; const s = u ? e.items.filter((e) => u({ row: e })) : e.items, o = n.a.find(e.items, (e) => a.indexOf(e) > -1); if (o) i = -1; else { const o = e.items.filter((e) => n.a.get(e, c)); i = o.filter((e) => s.indexOf(e) > -1).length === s.length || (!(!o.length && -1 !== t) && -1); } return this.handleSelectRow({ row: e.parent }, i); } } else (u && !u({ row: i })) || (n.a.set(i, c, t), this.handleCheckboxReserveRow(i, t)); else if (r && !d) { -1 === t ? (-1 === a.indexOf(i) && a.push(i), n.a.remove(s, (e) => e === i)) : n.a.eachTree( [i], (e) => { (i !== e && u && !u({ row: e })) || (t ? s.push(e) : n.a.remove(s, (t) => t === e), n.a.remove(a, (t) => t === e), this.handleCheckboxReserveRow(i, t)); }, l ); const e = n.a.findTree(o, (e) => e === i, l); if (e && e.parent) { let i; const o = u ? e.items.filter((e) => u({ row: e })) : e.items, r = n.a.find(e.items, (e) => a.indexOf(e) > -1); if (r) i = -1; else { const n = e.items.filter((e) => s.indexOf(e) > -1); i = n.filter((e) => o.indexOf(e) > -1).length === o.length || (!(!n.length && -1 !== t) && -1); } return this.handleSelectRow({ row: e.parent }, i); } } else (u && !u({ row: i })) || (t ? -1 === s.indexOf(i) && s.push(i) : n.a.remove(s, (e) => e === i), this.handleCheckboxReserveRow(i, t)); this.checkSelectionStatus(); }, handleToggleCheckRowEvent(e, t) { const i = this.selection, s = this.checkboxOpts, o = s.checkField, r = t.row, l = o ? !n.a.get(r, o) : -1 === i.indexOf(r); e ? this.triggerCheckRowEvent(e, t, l) : this.handleSelectRow(t, l); }, triggerCheckRowEvent(e, t, i) { const s = this.checkboxOpts.checkMethod; (s && !s({ row: t.row })) || (this.handleSelectRow(t, i), this.emitEvent( "checkbox-change", Object.assign( { records: this.getCheckboxRecords(), reserves: this.getCheckboxReserveRecords(), indeterminates: this.getCheckboxIndeterminateRecords(), checked: i, }, t ), e )); }, toggleCheckboxRow(e) { return ( this.handleToggleCheckRowEvent(null, { row: e }), this.$nextTick() ); }, setAllCheckboxRow(e) { const t = this.afterFullData, i = this.treeConfig, s = this.treeOpts, o = this.selection, r = this.checkboxReserveRowMap, l = this.checkboxOpts, a = l.checkField, h = l.reserve, c = l.checkStrictly, d = l.checkMethod; let u = []; const p = i ? [] : o.filter((e) => -1 === t.indexOf(e)); if (c) this.isAllSelected = e; else { if (a) { const o = (t) => { (d && !d({ row: t })) || (e && u.push(t), n.a.set(t, a, e)); }; i ? n.a.eachTree(t, o, s) : t.forEach(o); } else i ? e ? n.a.eachTree( t, (e) => { (d && !d({ row: e })) || u.push(e); }, s ) : d && n.a.eachTree( t, (e) => { !d({ row: e }) && o.indexOf(e) > -1 && u.push(e); }, s ) : e ? (u = d ? t.filter((e) => o.indexOf(e) > -1 || d({ row: e })) : t.slice(0)) : d && (u = t.filter((e) => d({ row: e }) ? 0 : o.indexOf(e) > -1 )); h && (e ? u.forEach((e) => { r[Rt(this, e)] = e; }) : t.forEach((e) => this.handleCheckboxReserveRow(e, !1))), (this.selection = a ? [] : p.concat(u)); } (this.treeIndeterminates = []), this.checkSelectionStatus(); }, checkSelectionStatus() { const e = this.afterFullData, t = this.selection, i = this.treeIndeterminates, s = this.checkboxOpts, o = this.treeConfig, r = s.checkField, l = s.halfField, a = s.checkStrictly, h = s.checkMethod; if (!a) { let s = !1, a = !1; r ? ((s = e.length && e.every( h ? (e) => !h({ row: e }) || n.a.get(e, r) : (e) => n.a.get(e, r) )), (a = o ? l ? !s && e.some( (e) => n.a.get(e, r) || n.a.get(e, l) || i.indexOf(e) > -1 ) : !s && e.some((e) => n.a.get(e, r) || i.indexOf(e) > -1) : l ? !s && e.some((e) => n.a.get(e, r) || n.a.get(e, l)) : !s && e.some((e) => n.a.get(e, r)))) : ((s = e.length && e.every( h ? (e) => !h({ row: e }) || t.indexOf(e) > -1 : (e) => t.indexOf(e) > -1 )), (a = o ? !s && e.some((e) => i.indexOf(e) > -1 || t.indexOf(e) > -1) : !s && e.some((e) => t.indexOf(e) > -1))), (this.isAllSelected = s), (this.isIndeterminate = a); } }, handleReserveStatus() { const e = this.expandColumn, t = this.treeOpts, i = this.treeConfig, s = this.fullDataRowIdData, n = this.fullAllDataRowMap, o = this.currentRow, r = this.selectRow, l = this.radioReserveRow, a = this.radioOpts, h = this.checkboxOpts, c = this.selection, d = this.rowExpandeds, u = this.treeExpandeds, p = this.expandOpts; if ((r && !n.has(r) && (this.selectRow = null), a.reserve && l)) { const e = Rt(this, l); s[e] && this.setRadioRow(s[e].row); } (this.selection = Yt(this, c)), h.reserve && this.setCheckboxRow(qt(this, this.checkboxReserveRowMap), !0), o && !n.has(o) && (this.currentRow = null), (this.rowExpandeds = e ? Yt(this, d) : []), e && p.reserve && this.setRowExpand(qt(this, this.rowExpandedReserveRowMap), !0), (this.treeExpandeds = i ? Yt(this, u) : []), i && t.reserve && this.setTreeExpand( qt(this, this.treeExpandedReserveRowMap), !0 ); }, getRadioReserveRecord() { const e = this.fullDataRowIdData, t = this.radioReserveRow, i = this.radioOpts; return i.reserve && t && !e[Rt(this, t)] ? t : null; }, clearRadioReserve() { return (this.radioReserveRow = null), this.$nextTick(); }, handleRadioReserveRow(e) { const t = this.radioOpts; t.reserve && (this.radioReserveRow = e); }, getCheckboxReserveRecords() { const e = this.fullDataRowIdData, t = this.checkboxReserveRowMap, i = this.checkboxOpts, s = []; return ( i.reserve && n.a.each(t, (t, i) => { t && !e[i] && s.push(t); }), s ); }, clearCheckboxReserve() { return (this.checkboxReserveRowMap = {}), this.$nextTick(); }, handleCheckboxReserveRow(e, t) { const i = this.checkboxReserveRowMap, s = this.checkboxOpts; if (s.reserve) { const s = Rt(this, e); t ? (i[s] = e) : i[s] && delete i[s]; } }, triggerCheckAllEvent(e, t) { this.setAllCheckboxRow(t), this.emitEvent( "checkbox-all", { records: this.getCheckboxRecords(), reserves: this.getCheckboxReserveRecords(), indeterminates: this.getCheckboxIndeterminateRecords(), checked: t, }, e ); }, toggleAllCheckboxRow() { return ( this.triggerCheckAllEvent(null, !this.isAllSelected), this.$nextTick() ); }, clearCheckboxRow() { const e = this.tableFullData, t = this.treeConfig, i = this.treeOpts, s = this.checkboxOpts, o = s.checkField, r = s.reserve; return ( o && (t ? n.a.eachTree(e, (e) => n.a.set(e, o, !1), i) : e.forEach((e) => n.a.set(e, o, !1))), r && e.forEach((e) => this.handleCheckboxReserveRow(e, !1)), (this.isAllSelected = !1), (this.isIndeterminate = !1), (this.selection = []), (this.treeIndeterminates = []), this.$nextTick() ); }, handleDefaultRadioChecked() { const e = this.radioOpts, t = this.fullDataRowIdData, i = e.checkRowKey, s = e.reserve; if (i && (t[i] && this.setRadioRow(t[i].row), s)) { const e = At(this); this.radioReserveRow = { [e]: i }; } }, triggerRadioRowEvent(e, t) { const i = this.selectRow !== t.row; this.setRadioRow(t.row), i && this.emitEvent("radio-change", t, e); }, triggerCurrentRowEvent(e, t) { const i = this.currentRow !== t.row; this.setCurrentRow(t.row), i && this.emitEvent("current-change", t, e); }, setCurrentRow(e) { const t = this.$el; return ( this.clearCurrentRow(), this.clearCurrentColumn(), (this.currentRow = e), this.highlightCurrentRow && t && n.a.arrayEach( t.querySelectorAll(`[rowid="${Rt(this, e)}"]`), (e) => { Nt(e, "row--current"), (e.style["background-color"] = $_theme.selected_color); } ), this.$nextTick() ); }, isCheckedByRadioRow(e) { return this.selectRow === e; }, setRadioRow(e) { const t = this.radioOpts, i = t.checkMethod; return ( !e || (i && !i({ row: e })) || ((this.selectRow = e), this.handleRadioReserveRow(e)), this.$nextTick() ); }, clearCurrentRow() { const e = this.$el; return ( (this.currentRow = null), (this.hoverRow = null), e && n.a.arrayEach(e.querySelectorAll(".row--current"), (e) => { Bt(e, "row--current"), (e.style["background-color"] = ""); }), this.$nextTick() ); }, clearRadioRow() { return (this.selectRow = null), this.$nextTick(); }, getCurrentRecord() { return this.highlightCurrentRow ? this.currentRow : null; }, getRadioRecord() { return this.selectRow; }, triggerHoverEvent(e, t) { let i = t.row; this.setHoverRow(i); }, setHoverRow(e) { const t = this.$el, i = Rt(this, e); this.clearHoverRow(), t && n.a.arrayEach(t.querySelectorAll(`[rowid="${i}"]`), (e) => Nt(e, "row--hover") ), (this.hoverRow = e); }, clearHoverRow() { const e = this.$el; e && n.a.arrayEach( e.querySelectorAll(".vxe-body--row.row--hover"), (e) => Bt(e, "row--hover") ), (this.hoverRow = null); }, triggerHeaderCellClickEvent(e, t) { const i = this._lastResizeTime, s = this.sortOpts, n = t.column, o = e.currentTarget, r = i && i > Date.now() - 300, l = Ft(e, o, "vxe-cell--sort").flag, a = Ft(e, o, "vxe-cell--filter").flag; return ( "cell" !== s.trigger || r || l || a || this.triggerSortEvent(e, n, Gt(this, n)), this.emitEvent( "header-cell-click", Object.assign( { triggerResizable: r, triggerSort: l, triggerFilter: a, cell: o, }, t ), e ), this.highlightCurrentColumn ? this.setCurrentColumn(n) : this.$nextTick() ); }, triggerHeaderCellDblclickEvent(e, t) { this.emitEvent( "header-cell-dblclick", Object.assign({ cell: e.currentTarget }, t), e ); }, getCurrentColumn() { return this.highlightCurrentColumn ? this.currentColumn : null; }, setCurrentColumn(e) { const t = it(this, e); return ( t && (this.clearCurrentRow(), this.clearCurrentColumn(), (this.currentColumn = t)), this.$nextTick() ); }, clearCurrentColumn() { return (this.currentColumn = null), this.$nextTick(); }, checkValidate(e) { return Ke._valid ? this.triggerValidate(e) : this.$nextTick(); }, handleChangeCell(e, t) { this.checkValidate("blur") .catch((e) => e) .then(() => { this.handleActived(t, e) .then(() => this.checkValidate("change")) .catch((e) => e); }); }, triggerCellClickEvent(e, t) { const i = this.highlightCurrentRow, s = this.editStore, n = this.radioOpts, o = this.expandOpts, r = this.treeOpts, l = this.editConfig, a = this.editOpts, h = this.checkboxOpts, c = s.actived, d = t, u = d.row, p = d.column, f = p.type, m = p.treeNode, g = "radio" === f, v = "checkbox" === f, _ = "expand" === f, b = e.currentTarget, y = g && Ft(e, b, "vxe-cell--radio").flag, x = v && Ft(e, b, "vxe-cell--checkbox").flag, w = m && Ft(e, b, "vxe-tree--btn-wrapper").flag, S = _ && Ft(e, b, "vxe-table--expanded").flag; (t = Object.assign( { cell: b, triggerRadio: y, triggerCheckbox: x, triggerTreeNode: w, triggerExpandNode: S, }, t )), x || y || (!S && ("row" === o.trigger || (_ && "cell" === o.trigger)) && this.triggerRowExpandEvent(e, t), ("row" === r.trigger || (m && "cell" === r.trigger)) && this.triggerTreeExpandEvent(e, t)), w || (S || (i && (x || y || this.triggerCurrentRowEvent(e, t)), !y && ("row" === n.trigger || (g && "cell" === n.trigger)) && this.triggerRadioRowEvent(e, t), !x && ("row" === h.trigger || (v && "cell" === h.trigger)) && this.handleToggleCheckRowEvent(e, t)), l && ("manual" === a.trigger ? c.args && c.row === u && p !== c.column && this.handleChangeCell(e, t) : (c.args && u === c.row && p === c.column) || ("click" === a.trigger ? this.handleChangeCell(e, t) : "dblclick" === a.trigger && "row" === a.mode && c.row === u && this.handleChangeCell(e, t)))), this.emitEvent("cell-click", t, e); }, triggerCellDblclickEvent(e, t) { const i = this.editStore, s = this.editConfig, n = this.editOpts, o = i.actived, r = e.currentTarget; (t.cell = r), s && "dblclick" === n.trigger && ((o.args && e.currentTarget === o.args.cell) || ("row" === n.mode ? this.checkValidate("blur") .catch((e) => e) .then(() => { this.handleActived(t, e) .then(() => this.checkValidate("change")) .catch((e) => e); }) : "cell" === n.mode && this.handleActived(t, e) .then(() => this.checkValidate("change")) .catch((e) => e))), this.emitEvent("cell-dblclick", t, e); }, handleDefaultSort() { const e = this.sortConfig, t = this.sortOpts; let i = t.defaultSort; i && (n.a.isArray(i) || (i = [i]), i.length && ((e.multiple ? i : i.slice(0, 1)).forEach((e) => { const t = e.field, i = e.order; if (t && i) { const e = this.getColumnByField(t); e && e.sortable && ((e.order = i), (e.sortTime = Date.now())); } }), t.remote || this.handleTableData(!0).then(this.updateStyle))); }, triggerSortEvent(e, t, i) { const s = this.sortOpts, n = t.property; if (t.sortable || t.remoteSort) { let o = this.currentRow; o && this.clearCurrentRow(), i && t.order !== i ? this.sort({ field: t, order: i }) : this.clearSort(s.multiple ? t : null); const r = { column: t, property: n, order: t.order, sortList: this.getSortColumns(), }; o && this.$nextTick(() => this.setCurrentRow(o)), this.emitEvent("sort-change", r, e); } }, sort(e, t) { const i = this.sortOpts, s = i.multiple, o = i.remote, r = i.orders; if ( (e && n.a.isString(e) && (e = [{ field: e, order: t }]), n.a.isArray(e) || (e = [e]), e.length) ) { let t; return ( s || ii(this), (s ? e : [e[0]]).forEach((e) => { let i = e.field, s = e.order, o = i; n.a.isString(i) && (o = this.getColumnByField(i)), o && (o.sortable || o.remoteSort) && (t || (t = o), -1 === r.indexOf(s) && (s = Gt(this, o)), o.order !== s && (o.order = s)); }), (!o || (t && t.remoteSort)) && this.handleTableData(!0), this.$nextTick().then(this.updateStyle) ); } return this.$nextTick(); }, clearSort(e) { const t = this.sortOpts; if (e) { const t = it(this, e); t && (t.order = null); } else ii(this); return t.remote ? this.$nextTick() : this.handleTableData(!0); }, getSortColumn() { return ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delFunc", [ "getSortColumn", "getSortColumns", ]), n.a.find( this.tableFullColumn, (e) => (e.sortable || e.remoteSort) && e.order ) ); }, isSort(e) { if (e) { const t = it(this, e); return t && t.sortable && !!t.order; } return this.getSortColumns().length > 0; }, getSortColumns() { const e = []; return ( this.tableFullColumn.forEach((t) => { const i = t.order; (t.sortable || t.remoteSort) && i && e.push({ column: t, property: t.property, order: i }); }), e ); }, closeFilter() { return ( Object.assign(this.filterStore, { isAllSelected: !1, isIndeterminate: !1, options: [], visible: !1, }), this.$nextTick() ); }, isFilter(e) { const t = it(this, e); return t ? t.filters && t.filters.some((e) => e.checked) : this.getCheckedFilters().length > 0; }, isRowExpandLoaded(e) { const t = this.fullAllDataRowMap.get(e); return t && t.expandLoaded; }, clearRowExpandLoaded(e) { const t = this.expandOpts, i = this.expandLazyLoadeds, s = this.fullAllDataRowMap, o = t.lazy, r = s.get(e); return ( o && r && ((r.expandLoaded = !1), n.a.remove(i, (t) => e === t)), this.$nextTick() ); }, reloadExpandContent(e) { const t = this.expandOpts, i = this.expandLazyLoadeds, s = t.lazy; return ( s && -1 === i.indexOf(e) && this.clearRowExpandLoaded(e).then(() => this.handleAsyncRowExpand(e) ), this.$nextTick() ); }, triggerRowExpandEvent(e, t) { const i = this.expandOpts, s = this.expandLazyLoadeds, n = this.expandColumn, o = t.row, r = i.lazy; if (!r || -1 === s.indexOf(o)) { const t = !this.isExpandByRow(o), i = this.getColumnIndex(n), s = this.getVMColumnIndex(n); this.setRowExpand(o, t), this.emitEvent( "toggle-row-expand", { expanded: t, column: n, columnIndex: i, $columnIndex: s, row: o, rowIndex: this.getRowIndex(o), $rowIndex: this.getVMRowIndex(o), }, e ); } }, toggleRowExpand(e) { return this.setRowExpand(e, !this.isExpandByRow(e)); }, handleDefaultRowExpand() { const e = this.expandOpts, t = this.fullDataRowIdData, i = e.expandAll, s = e.expandRowKeys; if (i) this.setAllRowExpand(!0); else if (s) { const e = []; s.forEach((i) => { t[i] && e.push(t[i].row); }), this.setRowExpand(e, !0); } }, setAllRowExpand(e) { return this.setRowExpand( this.expandOpts.lazy ? this.tableData : this.tableFullData, e ); }, handleAsyncRowExpand(e) { const t = this.fullAllDataRowMap.get(e); return new Promise((i) => { this.expandLazyLoadeds.push(e), this.expandOpts .loadMethod({ $table: this, row: e, rowIndex: this.getRowIndex(e), $rowIndex: this.getVMRowIndex(e), }) .catch((e) => e) .then(() => { (t.expandLoaded = !0), n.a.remove(this.expandLazyLoadeds, (t) => t === e), this.rowExpandeds.push(e), i(this.$nextTick().then(this.recalculate)); }); }); }, setRowExpand(e, t) { const i = this.fullAllDataRowMap, s = this.expandLazyLoadeds, o = this.expandOpts, r = this.expandColumn; let l = this.rowExpandeds; const a = o.reserve, h = o.lazy, c = o.accordion, d = o.toggleMethod, u = [], p = this.getColumnIndex(r), f = this.getVMColumnIndex(r); if (e) { n.a.isArray(e) || (e = [e]), c && ((l = []), (e = e.slice(e.length - 1, e.length))); const o = d ? e.filter((e) => d({ expanded: t, column: r, columnIndex: p, $columnIndex: f, row: e, rowIndex: this.getRowIndex(e), $rowIndex: this.getVMRowIndex(e), }) ) : e; t ? o.forEach((e) => { if (-1 === l.indexOf(e)) { const t = i.get(e), n = h && !t.expandLoaded && -1 === s.indexOf(e); n ? u.push(this.handleAsyncRowExpand(e)) : l.push(e); } }) : n.a.remove(l, (e) => o.indexOf(e) > -1), a && o.forEach((e) => this.handleRowExpandReserve(e, t)); } return ( (this.rowExpandeds = l), Promise.all(u).then(this.recalculate) ); }, isExpandByRow(e) { return this.rowExpandeds.indexOf(e) > -1; }, clearRowExpand() { const e = this.expandOpts, t = this.rowExpandeds, i = this.tableFullData, s = e.reserve, n = t.length; return ( (this.rowExpandeds = []), s && i.forEach((e) => this.handleRowExpandReserve(e, !1)), this.$nextTick().then(() => { n && this.recalculate(); }) ); }, clearRowExpandReserve() { return (this.rowExpandedReserveRowMap = {}), this.$nextTick(); }, handleRowExpandReserve(e, t) { const i = this.rowExpandedReserveRowMap, s = this.expandOpts; if (s.reserve) { const s = Rt(this, e); t ? (i[s] = e) : i[s] && delete i[s]; } }, getRowExpandRecords() { return this.rowExpandeds.slice(0); }, getTreeExpandRecords() { return this.treeExpandeds.slice(0); }, getTreeStatus() { return this.treeConfig ? { config: this.treeOpts, rowExpandeds: this.getTreeExpandRecords(), } : null; }, isTreeExpandLoaded(e) { const t = this.fullAllDataRowMap.get(e); return t && t.treeLoaded; }, clearTreeExpandLoaded(e) { const t = this.treeOpts, i = this.treeExpandeds, s = this.fullAllDataRowMap, o = t.lazy, r = s.get(e); return ( o && r && ((r.treeLoaded = !1), n.a.remove(i, (t) => e === t)), this.$nextTick() ); }, reloadTreeChilds(e) { const t = this.treeOpts, i = this.treeLazyLoadeds, s = t.lazy, n = t.hasChild; return ( s && e[n] && -1 === i.indexOf(e) && this.clearTreeExpandLoaded(e).then(() => this.handleAsyncTreeExpandChilds(e) ), this.$nextTick() ); }, triggerTreeExpandEvent(e, t) { const i = this.treeOpts, s = this.treeLazyLoadeds, n = t.row, o = t.column, r = i.lazy; if (!r || -1 === s.indexOf(n)) { const t = !this.isTreeExpandByRow(n), i = this.getColumnIndex(o), s = this.getVMColumnIndex(o); this.setTreeExpand(n, t), this.emitEvent( "toggle-tree-expand", { expanded: t, column: o, columnIndex: i, $columnIndex: s, row: n, }, e ); } }, toggleTreeExpand(e) { return this.setTreeExpand(e, !this.isTreeExpandByRow(e)); }, handleDefaultTreeExpand() { const e = this.treeConfig, t = this.treeOpts, i = this.tableFullData; if (e) { const e = t.expandAll, s = t.expandRowKeys; if (e) this.setAllTreeExpand(!0); else if (s) { const e = [], o = At(this); s.forEach((s) => { const r = n.a.findTree(i, (e) => s === n.a.get(e, o), t); r && e.push(r.item); }), this.setTreeExpand(e, !0); } } }, handleAsyncTreeExpandChilds(e) { const t = this.fullAllDataRowMap, i = this.treeExpandeds, s = this.treeOpts, o = this.treeLazyLoadeds, r = this.checkboxOpts, l = s.loadMethod, a = r.checkStrictly, h = t.get(e); return new Promise((t) => { o.push(e), l({ $table: this, row: e }) .catch(() => []) .then((s) => { (h.treeLoaded = !0), n.a.remove(o, (t) => t === e), n.a.isArray(s) || (s = []), s && this.loadChildren(e, s).then((t) => { t.length && -1 === i.indexOf(e) && i.push(e), !a && this.isCheckedByCheckboxRow(e) && this.setCheckboxRow(t, !0); }), t(this.$nextTick().then(this.recalculate)); }); }); }, setAllTreeExpand(e) { const t = this.tableFullData, i = this.treeOpts, s = i.lazy, o = i.children, r = []; return ( n.a.eachTree( t, (e) => { const t = e[o]; (s || (t && t.length)) && r.push(e); }, i ), this.setTreeExpand(r, e) ); }, setTreeExpand(e, t) { const i = this.fullAllDataRowMap, s = this.tableFullData, o = this.treeExpandeds, r = this.treeOpts, l = this.treeLazyLoadeds, a = this.treeNodeColumn, h = r.reserve, c = r.lazy, d = r.hasChild, u = r.children, p = r.accordion, f = r.toggleMethod, m = [], g = this.getColumnIndex(a), v = this.getVMColumnIndex(a); if (e && (n.a.isArray(e) || (e = [e]), e.length)) { let _ = f ? e.filter((e) => f({ expanded: t, column: a, columnIndex: g, $columnIndex: v, row: e, }) ) : e; if (p) { _ = _.length ? [_[_.length - 1]] : []; const e = n.a.findTree(s, (e) => e === _[0], r); e && n.a.remove(o, (t) => e.items.indexOf(t) > -1); } return ( t ? _.forEach((e) => { if (-1 === o.indexOf(e)) { const t = i.get(e), s = c && e[d] && !t.treeLoaded && -1 === l.indexOf(e); s ? m.push(this.handleAsyncTreeExpandChilds(e)) : e[u] && e[u].length && o.push(e); } }) : n.a.remove(o, (e) => _.indexOf(e) > -1), h && _.forEach((e) => this.handleTreeExpandReserve(e, t)), Promise.all(m).then(this.recalculate) ); } return this.$nextTick(); }, isTreeExpandByRow(e) { return this.treeExpandeds.indexOf(e) > -1; }, clearTreeExpand() { const e = this.treeOpts, t = this.treeExpandeds, i = this.tableFullData, s = e.reserve, o = t.length; return ( (this.treeExpandeds = []), s && n.a.eachTree(i, (e) => this.handleTreeExpandReserve(e, !1), e), this.$nextTick().then(() => { o && this.recalculate(); }) ); }, clearTreeExpandReserve() { return (this.treeExpandedReserveRowMap = {}), this.$nextTick(); }, handleTreeExpandReserve(e, t) { const i = this.treeExpandedReserveRowMap, s = this.treeOpts; if (s.reserve) { const s = Rt(this, e); t ? (i[s] = e) : i[s] && delete i[s]; } }, getScroll() { const e = this.$refs, t = this.scrollXLoad, i = this.scrollYLoad, s = e.tableBody.$el; return { virtualX: t, virtualY: i, scrollTop: s.scrollTop, scrollLeft: s.scrollLeft, }; }, triggerScrollXEvent() { this.loadScrollXData(); }, loadScrollXData() { const e = this.mergeList, t = this.mergeFooterList, i = this.scrollXStore, s = i.startIndex, n = i.endIndex, o = i.offsetSize, r = Kt(this), l = r.toVisibleIndex, a = r.visibleSize, h = { startIndex: Math.max(0, l - 1 - o), endIndex: l + a + o }; Qt(e.concat(t), h, "col"); const c = h.startIndex, d = h.endIndex; (l <= s || l >= n - a - 1) && ((s === c && n === d) || ((i.startIndex = c), (i.endIndex = d), this.updateScrollXData())), this.closeTooltip(); }, triggerScrollYEvent(e) { let t = this.currentRow; t && this.clearCurrentRow(); const i = this.scrollYStore, s = i.adaptive, n = i.offsetSize, o = i.visibleSize; Vt && s && 2 * n + o <= 40 ? this.loadScrollYData(e) : this.debounceScrollY(e), t && this.$nextTick(() => this.setCurrentRow(t)); }, debounceScrollY: n.a.debounce( function (e) { this.loadScrollYData(e); }, zt, { leading: !1, trailing: !0 } ), loadScrollYData(e) { const t = this.mergeList, i = this.scrollYStore, s = i.startIndex, n = i.endIndex, o = i.visibleSize, r = i.offsetSize, l = i.rowHeight, a = e.currentTarget || e.target, h = a.scrollTop, c = Math.floor(h / l), d = { startIndex: Math.max(0, c - 1 - r), endIndex: c + o + r }; Qt(t, d, "row"); const u = d.startIndex, p = d.endIndex; (c <= s || c >= n - o - 1) && ((s === u && n === p) || ((i.startIndex = u), (i.endIndex = p), this.updateScrollYData())); }, computeScrollLoad() { return this.$nextTick().then(() => { const e = this.sYOpts, t = this.sXOpts, i = this.scrollXLoad, s = this.scrollYLoad, o = this.scrollXStore, r = this.scrollYStore; if (i) { const e = Kt(this), i = e.visibleSize, s = t.oSize ? n.a.toNumber(t.oSize) : b.msie ? 10 : b.edge ? 5 : 0; (o.offsetSize = s), (o.visibleSize = i), (o.endIndex = Math.max( o.startIndex + o.visibleSize + s, o.endIndex )), this.updateScrollXData(); } else this.updateScrollXSpace(); const l = Jt(this), a = l.rowHeight, h = l.visibleSize; if (((r.rowHeight = a), s)) { const t = e.oSize ? n.a.toNumber(e.oSize) : b.msie ? 20 : b.edge ? 10 : 0; (r.offsetSize = t), (r.visibleSize = h), (r.endIndex = Math.max(r.startIndex + h + t, r.endIndex)), this.updateScrollYData(); } else this.updateScrollYSpace(); (this.rowHeight = a), this.$nextTick(this.updateStyle); }); }, handleTableColumn() { const e = this.scrollXLoad, t = this.visibleColumn, i = this.scrollXStore; this.tableColumn = e ? t.slice(i.startIndex, i.endIndex) : t.slice(0); }, updateScrollXData() { this.handleTableColumn(), this.updateScrollXSpace(); }, updateScrollXSpace() { const e = this.$refs, t = this.elemStore, i = this.visibleColumn, s = this.scrollXStore, n = this.scrollXLoad, o = this.tableWidth, r = this.scrollbarWidth, l = e.tableHeader, a = e.tableBody, h = e.tableFooter, c = a ? a.$el : null; if (c) { const e = l ? l.$el : null, a = h ? h.$el : null, d = e ? e.querySelector(".vxe-table--header") : null, u = c.querySelector(".vxe-table--body"), p = a ? a.querySelector(".vxe-table--footer") : null, f = i .slice(0, s.startIndex) .reduce((e, t) => e + t.renderWidth, 0); let m = ""; n && (m = `${f}px`), d && (d.style.marginLeft = m), (u.style.marginLeft = m), p && (p.style.marginLeft = m); const g = ["main"]; g.forEach((e) => { const i = ["header", "body", "footer"]; i.forEach((i) => { const s = t[`${e}-${i}-xSpace`]; s && (s.style.width = n ? `${o + ("header" === i ? r : 0)}px` : ""); }); }), this.$nextTick(this.updateStyle); } }, updateScrollYData() { this.handleTableData(), this.updateScrollYSpace(); }, updateScrollYSpace() { const e = this.elemStore, t = this.scrollYStore, i = this.scrollYLoad, s = this.afterFullData, n = t.startIndex, o = t.rowHeight, r = s.length * o, l = Math.max(0, n * o), a = ["main", "left", "right"]; let h = "", c = ""; i && ((h = `${l}px`), (c = `${r}px`)), a.forEach((t) => { const i = ["header", "body", "footer"], s = e[`${t}-body-table`]; s && (s.style.marginTop = h), i.forEach((i) => { const s = e[`${t}-${i}-ySpace`]; s && (s.style.height = c); }); }), this.$nextTick(this.updateStyle); }, scrollTo(e, t) { const i = this.$refs, s = i.tableBody, o = i.rightBody, r = i.tableFooter, l = s ? s.$el : null, a = o ? o.$el : null, h = r ? r.$el : null; return ( n.a.isNumber(e) && R(h || l, e), n.a.isNumber(t) && $(a || l, t), this.scrollXLoad || this.scrollYLoad ? new Promise((e) => setTimeout(() => e(this.$nextTick()), 50)) : this.$nextTick() ); }, scrollToRow(e, t) { const i = []; return ( e && (this.treeConfig && this.scrollToTreeRow(e), i.push(A.rowToVisible(this, e))), t && i.push(this.scrollToColumn(t)), Promise.all(i) ); }, scrollToColumn(e) { const t = it(this, e); return t && this.fullColumnMap.has(t) ? A.colToVisible(this, t) : this.$nextTick(); }, scrollToTreeRow(e) { const t = this.tableFullData, i = this.treeConfig, s = this.treeOpts; if (i) { const i = n.a.findTree(t, (t) => t === e, s); if (i) { const e = i.nodes; e.forEach((t, i) => { i < e.length - 1 && !this.isTreeExpandByRow(t) && this.setTreeExpand(t, !0); }); } } return this.$nextTick(); }, clearScroll() { const e = this.$refs, t = e.tableBody, i = e.rightBody, s = e.tableFooter, n = t ? t.$el : null, o = i ? i.$el : null, r = s ? s.$el : null; return ( o && (o.scrollTop = 0), r && (r.scrollLeft = 0), n && ((n.scrollTop = 0), (n.scrollLeft = 0)), this.$nextTick() ); }, updateFooter() { const e = this.showFooter, t = this.visibleColumn, i = this.footerMethod; return ( e && i && (this.footerTableData = t.length ? i({ columns: t, data: this.afterFullData, $table: this, $grid: this.$xegrid, }) : []), this.$nextTick() ); }, updateStatus(e, t) { const i = !n.a.isUndefined(t); return this.$nextTick().then(() => { const s = this.$refs, n = this.editRules, o = this.validStore; if (e && s.tableBody && n) { const s = e.row, n = e.column, r = "change"; if (this.hasCellRules(r, s, n)) { const e = this.getCell(s, n); if (e) return this.validCellRules(r, s, n, t) .then(() => { i && o.visible && Lt(s, n, t), this.clearValidate(); }) .catch((o) => { let r = o.rule; i && Lt(s, n, t), this.showValidTooltip({ rule: r, row: s, column: n, cell: e, }); }); } } }); }, handleDefaultMergeCells() { this.setMergeCells(this.mergeCells); }, setMergeCells(e) { return ( this.spanMethod && g.error("vxe.error.errConflicts", [ "merge-cells", "span-method", ]), ei(this, e, this.mergeList, this.afterFullData), this.$nextTick().then(() => this.updateCellAreas()) ); }, removeMergeCells(e) { this.spanMethod && g.error("vxe.error.errConflicts", ["merge-cells", "span-method"]); const t = ti(this, e, this.mergeList, this.afterFullData); return this.$nextTick().then(() => { return this.updateCellAreas(), t; }); }, getMergeCells() { return this.mergeList.slice(0); }, clearMergeCells() { return (this.mergeList = []), this.$nextTick(); }, handleDefaultMergeFooterItems() { this.setMergeFooterItems(this.mergeFooterItems); }, setMergeFooterItems(e) { return ( this.footerSpanMethod && g.error("vxe.error.errConflicts", [ "merge-footer-items", "footer-span-method", ]), ei(this, e, this.mergeFooterList, null), this.$nextTick().then(() => this.updateCellAreas()) ); }, removeMergeFooterItems(e) { this.footerSpanMethod && g.error("vxe.error.errConflicts", [ "merge-footer-items", "footer-span-method", ]); const t = ti(this, e, this.mergeFooterList, null); return this.$nextTick().then(() => { return this.updateCellAreas(), t; }); }, getMergeFooterItems() { return this.mergeFooterList.slice(0); }, clearMergeFooterItems() { return (this.mergeFooterList = []), this.$nextTick(); }, updateZindex() { this.zIndex ? (this.tZindex = this.zIndex) : this.tZindex < g.getLastZIndex() && (this.tZindex = g.nextZIndex()); }, updateCellAreas() { this.mouseConfig && this.mouseOpts.area && this.handleUpdateCellAreas && this.handleUpdateCellAreas(); }, emitEvent(e, t, i) { this.$emit( e, Object.assign({ $table: this, $grid: this.$xegrid, $event: i }, t) ); }, focus() { return (this.isActivated = !0), this.$nextTick(); }, blur() { return (this.isActivated = !1), this.$nextTick(); }, connect(e) { return ( e && e.syncUpdate ? (e.syncUpdate({ collectColumn: this.collectColumn, $table: this, }), (this.$toolbar = e)) : g.error("vxe.error.barUnableLink"), this.$nextTick() ); }, getCell(e, t) { const i = this.$refs, s = Rt(this, e), n = i[`${t.fixed || "table"}Body`] || i.tableBody; return n && n.$el ? n.$el.querySelector(`.vxe-body--row[rowid="${s}"] .${t.id}`) : null; }, getCellLabel(e, t) { const i = t.formatter, s = g.getCellValue(e, t); let o = s; if (i) { let r, l; const a = this.fullAllDataRowMap, c = t.id, d = a.has(e); if ( d && ((r = a.get(e)), (l = r.formatData), l || (l = a.get(e).formatData = {}), r && l[c] && l[c].value === s) ) return l[c].label; const u = { cellValue: s, row: e, rowIndex: this.getRowIndex(e), column: t, columnIndex: this.getColumnIndex(t), }; if (n.a.isString(i)) { const e = h.get(i); o = e ? e(u) : ""; } else if (n.a.isArray(i)) { const e = h.get(i[0]); o = e ? e(u, ...i.slice(1)) : ""; } else o = i(u); l && (l[c] = { value: s, label: o }); } return o; }, }, oi = "setFilter,clearFilter,getCheckedFilters,closeMenu,setActiveCellArea,getActiveCellArea,getCellAreas,clearCellAreas,copyCellArea,cutCellArea,pasteCellArea,getCopyCellArea,clearCopyCellArea,setCellAreas,openFind,openReplace,getSelectedCell,clearSelected,insert,insertAt,remove,removeCheckboxRow,removeRadioRow,removeCurrentRow,getRecordset,getInsertRecords,getRemoveRecords,getUpdateRecords,clearActived,getActiveRecord,isActiveByRow,setActiveRow,setActiveCell,setSelectCell,clearValidate,fullValidate,validate,openExport,openPrint,exportData,openImport,importData,saveFile,readFile,importByFile,print".split( "," ); oi.forEach((e) => { ni[e] = function () { return this[`_${e}`] ? this[`_${e}`](...arguments) : null; }; }); var ri = ni; function li(e, t, i) { const s = t._e, n = t.tableData, o = t.tableColumn, r = t.tableGroupColumn, l = t.vSize, a = t.showHeader, h = t.showFooter, c = t.columnStore, d = t.footerTableData, u = c[`${i}List`]; return e( "div", { class: `vxe-table--fixed-${i}-wrapper`, ref: `${i}Container` }, [ a ? e("vxe-table-header", { props: { fixedType: i, tableData: n, tableColumn: o, tableGroupColumn: r, size: l, fixedColumn: u, }, ref: `${i}Header`, }) : s(), e("vxe-table-body", { props: { fixedType: i, tableData: n, tableColumn: o, fixedColumn: u, size: l, }, ref: `${i}Body`, }), h ? e("vxe-table-footer", { props: { footerTableData: d, tableColumn: o, fixedColumn: u, fixedType: i, size: l, }, ref: `${i}Footer`, }) : s(), ] ); } function ai(e, t) { const i = t.$scopedSlots, s = t.emptyOpts; let n = ""; const o = { $table: t }; if (i.empty) n = i.empty.call(t, o, e); else { const i = s.name ? Ke.renderer.get(s.name) : null, l = i ? i.renderEmpty : null; n = l ? l.call(t, e, s, o) : g.getFuncText(t.emptyText) || r.i18n("vxe.table.emptyText"); } return n; } function hi(e) { const t = e.$el; t && t.clientWidth && t.clientHeight && e.recalculate(); } var ci = { name: "VxeTable", mixins: [bt], props: { id: String, data: Array, height: [Number, String], maxHeight: [Number, String], resizable: { type: Boolean, default: () => r.table.resizable }, stripe: { type: Boolean, default: () => r.table.stripe }, border: { type: [Boolean, String], default: () => r.table.border }, round: { type: Boolean, default: () => r.table.round }, size: { type: String, default: () => r.table.size || r.size }, fit: { type: Boolean, default: () => r.table.fit }, loading: Boolean, align: { type: String, default: () => r.table.align }, headerAlign: { type: String, default: () => r.table.headerAlign }, footerAlign: { type: String, default: () => r.table.footerAlign }, showHeader: { type: Boolean, default: () => r.table.showHeader }, highlightCurrentRow: { type: Boolean, default: () => r.table.highlightCurrentRow, }, highlightHoverRow: { type: Boolean, default: () => r.table.highlightHoverRow, }, highlightCurrentColumn: { type: Boolean, default: () => r.table.highlightCurrentColumn, }, highlightHoverColumn: { type: Boolean, default: () => r.table.highlightHoverColumn, }, highlightCell: Boolean, showFooter: Boolean, footerMethod: { type: Function, default: r.table.footerMethod }, rowClassName: [String, Function], cellClassName: [String, Function], headerRowClassName: [String, Function], headerCellClassName: [String, Function], footerRowClassName: [String, Function], footerCellClassName: [String, Function], cellStyle: [Object, Function], headerCellStyle: [Object, Function], footerCellStyle: [Object, Function], rowStyle: [Object, Function], headerRowStyle: [Object, Function], footerRowStyle: [Object, Function], mergeCells: Array, mergeFooterItems: Array, spanMethod: Function, footerSpanMethod: Function, showOverflow: { type: [Boolean, String], default: () => r.table.showOverflow, }, showHeaderOverflow: { type: [Boolean, String], default: () => r.table.showHeaderOverflow, }, showFooterOverflow: { type: [Boolean, String], default: () => r.table.showFooterOverflow, }, columnKey: Boolean, rowKey: Boolean, rowId: { type: String, default: () => r.table.rowId }, zIndex: Number, emptyText: { type: String, default: () => r.table.emptyText }, keepSource: { type: Boolean, default: () => r.table.keepSource }, autoResize: { type: Boolean, default: () => r.table.autoResize }, syncResize: [Boolean, String, Number], columnConfig: Object, resizableConfig: Object, seqConfig: Object, sortConfig: Object, filterConfig: Object, radioConfig: Object, checkboxConfig: Object, tooltipConfig: Object, exportConfig: [Boolean, Object], importConfig: [Boolean, Object], printConfig: Object, expandConfig: Object, treeConfig: [Boolean, Object], menuConfig: [Boolean, Object], contextMenu: [Boolean, Object], mouseConfig: Object, areaConfig: Object, keyboardConfig: Object, clipConfig: Object, fnrConfig: Object, editConfig: [Boolean, Object], validConfig: Object, editRules: Object, emptyRender: [Boolean, Object], customConfig: [Boolean, Object], scrollX: Object, scrollY: Object, animat: { type: Boolean, default: () => r.table.animat }, delayHover: { type: Number, default: () => r.table.delayHover }, params: Object, }, components: { VxeTableBody: _t }, provide() { return { $xetable: this, xecolgroup: null }; }, inject: { $xegrid: { default: null } }, data() { return { tId: `${n.a.uniqueId()}`, staticColumns: [], tableGroupColumn: [], tableColumn: [], tableData: [], scrollXLoad: !1, scrollYLoad: !1, overflowY: !0, overflowX: !1, scrollbarWidth: 0, scrollbarHeight: 0, rowHeight: 0, parentHeight: 0, isGroup: !1, isAllOverflow: !1, isAllSelected: !1, isIndeterminate: !1, selection: [], currentRow: null, currentColumn: null, selectRow: null, footerTableData: [], expandColumn: null, hasFixedColumn: !1, treeNodeColumn: null, rowExpandeds: [], expandLazyLoadeds: [], treeExpandeds: [], treeLazyLoadeds: [], treeIndeterminates: [], mergeList: [], mergeFooterList: [], initStore: { filter: !1, import: !1, export: !1 }, filterStore: { isAllSelected: !1, isIndeterminate: !1, style: null, options: [], column: null, multiple: !1, visible: !1, maxHeight: null, }, columnStore: { leftList: [], centerList: [], rightList: [], resizeList: [], pxList: [], pxMinList: [], scaleList: [], scaleMinList: [], autoList: [], }, ctxMenuStore: { selected: null, visible: !1, showChild: !1, selectChild: null, list: [], style: null, }, editStore: { indexs: { columns: [] }, titles: { columns: [] }, selected: { row: null, column: null }, copyed: { cut: !1, rows: [], columns: [] }, actived: { row: null, column: null }, insertList: [], removeList: [], }, validStore: { visible: !1, row: null, column: null, content: "", rule: null, isArrow: !1, }, importStore: { inited: !1, file: null, type: "", modeList: [], typeList: [], filename: "", visible: !1, }, importParams: { mode: "", types: null, message: !0 }, exportStore: { inited: !1, name: "", modeList: [], typeList: [], columns: [], isPrint: !1, hasFooter: !1, hasTree: !1, hasMerge: !1, hasColgroup: !1, visible: !1, }, exportParams: { filename: "", sheetName: "", mode: "", type: "", isColgroup: !1, isMerge: !1, isAllExpand: !1, useStyle: !1, original: !1, message: !0, isHeader: !1, isFooter: !1, }, }; }, computed: { validOpts() { return Object.assign( { message: "default" }, r.table.validConfig, this.validConfig ); }, sXOpts() { return Object.assign({}, r.table.scrollX, this.scrollX); }, sYOpts() { return Object.assign({}, r.table.scrollY, this.scrollY); }, rowHeightMaps() { return { default: 48, medium: 44, small: 40, mini: 36 }; }, columnOpts() { return Object.assign({}, this.columnConfig); }, resizableOpts() { return Object.assign( {}, r.table.resizableConfig, this.resizableConfig ); }, seqOpts() { return Object.assign( { startIndex: 0 }, r.table.seqConfig, this.seqConfig ); }, radioOpts() { return Object.assign({}, r.table.radioConfig, this.radioConfig); }, checkboxOpts() { return Object.assign( {}, r.table.checkboxConfig, this.checkboxConfig ); }, tooltipOpts() { const e = Object.assign( { leaveDelay: 300 }, r.table.tooltipConfig, this.tooltipConfig ); return ( e.enterable && (e.leaveMethod = this.handleTooltipLeaveMethod), e ); }, validTipOpts() { return Object.assign({ isArrow: !1 }, this.tooltipOpts); }, editOpts() { return Object.assign({}, r.table.editConfig, this.editConfig); }, sortOpts() { return Object.assign( { orders: ["asc", "desc", null] }, r.table.sortConfig, this.sortConfig ); }, filterOpts() { return Object.assign({}, r.table.filterConfig, this.filterConfig); }, mouseOpts() { return Object.assign({}, r.table.mouseConfig, this.mouseConfig); }, areaOpts() { return Object.assign({}, r.table.areaConfig, this.areaConfig); }, keyboardOpts() { return Object.assign( {}, r.table.keyboardConfig, this.keyboardConfig ); }, clipOpts() { return Object.assign({}, r.table.clipConfig, this.clipConfig); }, fnrOpts() { return Object.assign({}, r.table.fnrConfig, this.fnrConfig); }, hasTip() { return Ke._tooltip; }, headerCtxMenu() { const e = this.ctxMenuOpts.header; return e && e.options ? e.options : []; }, bodyCtxMenu() { const e = this.ctxMenuOpts.body; return e && e.options ? e.options : []; }, footerCtxMenu() { const e = this.ctxMenuOpts.footer; return e && e.options ? e.options : []; }, isCtxMenu() { return !( (!this.contextMenu && !this.menuConfig) || !p(this.ctxMenuOpts) || !( this.headerCtxMenu.length || this.bodyCtxMenu.length || this.footerCtxMenu.length ) ); }, ctxMenuOpts() { return Object.assign( {}, r.table.menuConfig, this.contextMenu, this.menuConfig ); }, ctxMenuList() { const e = []; return ( this.ctxMenuStore.list.forEach((t) => { t.forEach((t) => { e.push(t); }); }), e ); }, exportOpts() { return Object.assign({}, r.table.exportConfig, this.exportConfig); }, importOpts() { return Object.assign({}, r.table.importConfig, this.importConfig); }, printOpts() { return Object.assign({}, r.table.printConfig, this.printConfig); }, expandOpts() { return Object.assign({}, r.table.expandConfig, this.expandConfig); }, treeOpts() { return Object.assign({}, r.table.treeConfig, this.treeConfig); }, emptyOpts() { return Object.assign({}, r.table.emptyRender, this.emptyRender); }, cellOffsetWidth() { return this.border ? Math.max( 2, Math.ceil(this.scrollbarWidth / this.tableColumn.length) ) : 1; }, customOpts() { return Object.assign({}, r.table.customConfig, this.customConfig); }, tableBorder() { const e = this.border; return !0 === e ? "full" : e || "default"; }, isAllCheckboxDisabled() { const e = this.tableFullData, t = this.tableData, i = (this.treeConfig, this.checkboxOpts), s = i.strict, n = i.checkMethod; return ( !!s && ((!t.length && !e.length) || (!!n && e.every((e) => !n({ row: e })))) ); }, }, watch: { data(e) { const t = this.inited, i = this.initStatus; this.loadTableData(e).then(() => { (this.inited = !0), (this.initStatus = !0), i || this.handleLoadDefaults(), t || this.handleInitDefaults(), (this.scrollXLoad || this.scrollYLoad) && this.expandColumn && g.warn("vxe.error.scrollErrProp", ["column.type=expand"]), this.recalculate(); }); }, staticColumns(e) { this.handleColumn(e); }, tableColumn() { this.analyColumnWidth(); }, showHeader() { this.$nextTick(() => { this.recalculate(!0).then(() => this.refreshScroll()); }); }, showFooter() { this.$nextTick(() => { this.recalculate(!0).then(() => this.refreshScroll()); }); }, height() { this.$nextTick(() => this.recalculate(!0)); }, maxHeight() { this.$nextTick(() => this.recalculate(!0)); }, syncResize(e) { e && (hi(this), this.$nextTick(() => { hi(this), setTimeout(() => hi(this)); })); }, mergeCells(e) { this.clearMergeCells(), this.setMergeCells(e); }, mergeFooterItems(e) { this.clearMergeFooterItems(), this.setMergeFooterItems(e); }, }, created() { const e = Object.assign(this, { tZindex: 0, elemStore: {}, scrollXStore: {}, scrollYStore: {}, tooltipStore: {}, tableWidth: 0, tableHeight: 0, headerHeight: 0, footerHeight: 0, lastScrollLeft: 0, lastScrollTop: 0, radioReserveRow: null, checkboxReserveRowMap: {}, rowExpandedReserveRowMap: {}, treeExpandedReserveRowMap: {}, tableFullData: [], afterFullData: [], collectColumn: [], tableFullColumn: [], visibleColumn: [], fullAllDataRowMap: new Map(), fullAllDataRowIdData: {}, fullDataRowMap: new Map(), fullDataRowIdData: {}, fullColumnMap: new Map(), fullColumnIdData: {}, fullColumnFieldData: {}, }), t = e.scrollXStore, i = e.sYOpts, s = e.scrollYStore, o = e.data, r = e.editOpts, l = e.treeOpts, a = e.treeConfig, h = e.showOverflow; if ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV ) { !this.rowId && (this.checkboxOpts.reserve || this.checkboxOpts.checkRowKeys || this.radioOpts.reserve || this.radioOpts.checkRowKey || this.expandOpts.expandRowKeys || this.treeOpts.expandRowKeys) && g.warn("vxe.error.reqProp", ["row-id"]), this.editConfig && r.showStatus && !this.keepSource && g.warn("vxe.error.reqProp", ["keep-source"]), !a || !l.line || (this.rowKey && h) || g.warn("vxe.error.reqProp", ["row-key | show-overflow"]), this.showFooter && !this.footerMethod && g.warn("vxe.error.reqProp", ["footer-method"]), a && this.stripe && g.warn("vxe.error.noTree", ["stripe"]), this.tooltipOpts.enabled && g.warn("vxe.error.delProp", [ "tooltip-config.enabled", "tooltip-config.showAll", ]); const e = this.exportConfig, t = this.exportOpts, i = this.importConfig, s = this.importOpts; i && s.types && !s.importMethod && !n.a.includeArrays(Ke.config.importTypes, s.types) && g.warn("vxe.error.errProp", [ `export-config.types=${s.types.join(",")}`, s.types .filter((e) => n.a.includes(Ke.config.importTypes, e)) .join(",") || Ke.config.importTypes.join(","), ]), e && t.types && !t.exportMethod && !n.a.includeArrays(Ke.config.exportTypes, t.types) && g.warn("vxe.error.errProp", [ `export-config.types=${t.types.join(",")}`, t.types .filter((e) => n.a.includes(Ke.config.exportTypes, e)) .join(",") || Ke.config.exportTypes.join(","), ]); } if ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV ) { const e = this.customOpts; if ( (!this.id && this.customConfig && (!0 === e.storage || (e.storage && e.storage.resizable) || (e.storage && e.storage.visible)) && g.error("vxe.error.reqProp", ["id"]), this.treeConfig && this.checkboxOpts.range && g.error("vxe.error.noTree", ["checkbox-config.range"]), !this.handleUpdateCellAreas && (this.clipConfig && g.warn("vxe.error.notProp", ["clip-config"]), this.fnrConfig && g.warn("vxe.error.notProp", ["fnr-config"]), this.mouseOpts.area)) ) return void g.error("vxe.error.notProp", ["mouse-config.area"]); this.mouseOpts.area && this.mouseOpts.selected && g.warn("vxe.error.errConflicts", [ "mouse-config.area", "mouse-config.selected", ]), this.mouseOpts.area && this.checkboxOpts.range && g.warn("vxe.error.errConflicts", [ "mouse-config.area", "checkbox-config.range", ]), this.treeConfig && this.mouseOpts.area && g.error("vxe.error.noTree", ["mouse-config.area"]); } "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && (this.contextMenu && (g.warn("vxe.error.delProp", ["context-menu", "menu-config"]), n.a.isObject(this.contextMenu) || g.warn("vxe.error.errProp", [ `table.context-menu=${this.contextMenu}`, "table.context-menu={}", ])), this.menuConfig && !n.a.isObject(this.menuConfig) && g.warn("vxe.error.errProp", [ `table.menu-config=${this.menuConfig}`, "table.menu-config={}", ]), this.exportConfig && !n.a.isObject(this.exportConfig) && g.warn("vxe.error.errProp", [ `table.export-config=${this.exportConfig}`, "table.export-config={}", ]), this.importConfig && !n.a.isObject(this.importConfig) && g.warn("vxe.error.errProp", [ `table.import-config=${this.importConfig}`, "table.import-config={}", ]), this.printConfig && !n.a.isObject(this.printConfig) && g.warn("vxe.error.errProp", [ `table.print-config=${this.printConfig}`, "table.print-config={}", ]), this.treeConfig && !n.a.isObject(this.treeConfig) && g.warn("vxe.error.errProp", [ `table.tree-config=${this.treeConfig}`, "table.tree-config={}", ]), this.customConfig && !n.a.isObject(this.customConfig) && g.warn("vxe.error.errProp", [ `table.custom-config=${this.customConfig}`, "table.custom-config={}", ]), this.editConfig && !n.a.isObject(this.editConfig) && g.warn("vxe.error.errProp", [ `table.edit-config=${this.editConfig}`, "table.edit-config={}", ]), this.emptyRender && !n.a.isObject(this.emptyRender) && g.warn("vxe.error.errProp", [ `table.empty-render=${this.emptyRender}`, "table.empty-render={}", ])), "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && (this.editConfig && !this._insert && g.error("vxe.error.reqModule", ["Edit"]), this.editRules && !this._validate && g.error("vxe.error.reqModule", ["Validator"]), (this.checkboxOpts.range || this.keyboardConfig || this.mouseConfig) && !this.triggerCellMousedownEvent && g.error("vxe.error.reqModule", ["Keyboard"]), (this.printConfig || this.importConfig || this.exportConfig) && !this._exportData && g.error("vxe.error.reqModule", ["Export"])), Object.assign(s, { startIndex: 0, endIndex: 0, visibleSize: 0, adaptive: !1 !== i.adaptive, }), Object.assign(t, { startIndex: 0, endIndex: 0, visibleSize: 0 }), this.loadTableData(o).then(() => { o && o.length && ((this.inited = !0), (this.initStatus = !0), this.handleLoadDefaults(), this.handleInitDefaults()), this.updateStyle(); }), M.on(this, "paste", this.handleGlobalPasteEvent), M.on(this, "copy", this.handleGlobalCopyEvent), M.on(this, "cut", this.handleGlobalCutEvent), M.on(this, "mousedown", this.handleGlobalMousedownEvent), M.on(this, "blur", this.handleGlobalBlurEvent), M.on(this, "mousewheel", this.handleGlobalMousewheelEvent), M.on(this, "keydown", this.handleGlobalKeydownEvent), M.on(this, "resize", this.handleGlobalResizeEvent), M.on(this, "contextmenu", this.handleGlobalContextmenuEvent), this.preventEvent(null, "created"); }, mounted() { if ( "development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV ) { const e = this.$listeners; !this.menuConfig && (e["menu-click"] || e["cell-menu"] || e["header-cell-menu"] || e["footer-cell-menu"]) && g.warn("vxe.error.reqProp", ["menu-config"]), this.tooltipConfig || (!e["cell-mouseenter"] && !e["cell-mouseleave"]) || g.warn("vxe.error.reqProp", ["tooltip-config"]); } if (this.autoResize) { const e = j(() => this.recalculate(!0)); e.observe(this.$el), e.observe(this.getParentElem()), (this.$resize = e); } this.preventEvent(null, "mounted"); }, activated() { this.recalculate().then(() => this.refreshScroll()), this.preventEvent(null, "activated"); }, deactivated() { this.preventEvent(null, "deactivated"); }, beforeDestroy() { this.$resize && this.$resize.disconnect(), this.closeFilter(), this.closeMenu(), this.preventEvent(null, "beforeDestroy"); }, destroyed() { M.off(this, "paste"), M.off(this, "copy"), M.off(this, "cut"), M.off(this, "mousedown"), M.off(this, "blur"), M.off(this, "mousewheel"), M.off(this, "keydown"), M.off(this, "resize"), M.off(this, "contextmenu"), this.preventEvent(null, "destroyed"); }, render(e) { const t = this._e, i = this.tId, s = this.tableData, n = this.tableColumn, o = this.tableGroupColumn, r = this.isGroup, l = this.loading, a = this.stripe, h = this.showHeader, c = this.height, d = this.tableBorder, u = this.treeOpts, p = this.treeConfig, f = this.mouseConfig, m = this.mouseOpts, g = this.vSize, v = this.validOpts, _ = this.showFooter, b = this.overflowX, y = this.overflowY, x = this.scrollXLoad, w = this.scrollYLoad, S = this.scrollbarHeight, E = this.highlightCell, k = this.highlightHoverRow, C = this.highlightHoverColumn, T = this.editConfig, O = this.validTipOpts, $ = this.tooltipOpts, R = this.initStore, A = this.columnStore, L = this.filterStore, D = this.ctxMenuStore, I = this.ctxMenuOpts, M = this.footerTableData, P = this.hasTip, N = A.leftList, B = A.rightList; return e( "div", { class: [ "vxe-table", "vxe-table--render-default", `tid_${i}`, g ? `size--${g}` : "", `border--${d}`, { "vxe-editable": !!T, "cell--highlight": E, "cell--selected": f && m.selected, "cell--area": f && m.area, "row--highlight": k, "column--highlight": C, "is--header": h, "is--footer": _, "is--group": r, "is--tree-line": p && u.line, "is--fixed-left": N.length, "is--fixed-right": B.length, "is--animat": !!this.animat, "is--round": this.round, "is--stripe": !p && a, "is--loading": l, "is--empty": !l && !s.length, "is--scroll-y": y, "is--scroll-x": b, "is--virtual-x": x, "is--virtual-y": w, }, ], on: { keydown: this.keydownEvent }, }, [ e( "div", { class: "vxe-table-slots", ref: "hideColumn" }, this.$slots.default ), e("div", { class: "vxe-table--render-wrapper" }, [ e("div", { class: "vxe-table--main-wrapper" }, [ h ? e("vxe-table-header", { ref: "tableHeader", props: { tableData: s, tableColumn: n, tableGroupColumn: o, size: g, }, }) : t(), e("vxe-table-body", { ref: "tableBody", props: { tableData: s, tableColumn: n, size: g }, }), _ ? e("vxe-table-footer", { ref: "tableFooter", props: { footerTableData: M, tableColumn: n, size: g }, }) : t(), ]), e("div", { class: "vxe-table--fixed-wrapper" }, [ N && N.length && b ? li(e, this, "left") : t(), B && B.length && b ? li(e, this, "right") : t(), ]), ]), e( "div", { ref: "emptyPlaceholder", class: "vxe-table--empty-placeholder", }, [e("div", { class: "vxe-table--empty-content" }, ai(e, this))] ), e("div", { class: "vxe-table--border-line", style: { display: "none" }, }), e("div", { class: "vxe-table--resizable-bar", style: b ? { "padding-bottom": `${S}px` } : null, ref: "resizeBar", }), e( "div", { class: [ "vxe-table--loading vxe-loading", { "is--visible": l }, ], }, [e("div", { class: "vxe-loading--spinner" })] ), R.filter ? e("vxe-table-filter", { ref: "filterWrapper", props: { filterStore: L }, }) : t(), R.import && this.importConfig ? e("vxe-import-panel", { props: { defaultOptions: this.importParams, storeData: this.importStore, }, }) : t(), R.export && (this.exportConfig || this.printConfig) ? e("vxe-export-panel", { props: { defaultOptions: this.exportParams, storeData: this.exportStore, }, }) : t(), D.visible && this.isCtxMenu ? e("vxe-table-context-menu", { ref: "ctxWrapper", props: { ctxMenuStore: D, ctxMenuOpts: I }, }) : t(), P ? e("vxe-tooltip", { ref: "commTip", props: { isArrow: !1, enterable: !1 }, }) : t(), P ? e("vxe-tooltip", { ref: "tooltip", props: $ }) : t(), P && this.editRules && v.showMessage && ("default" === v.message ? !c : "tooltip" === v.message) ? e("vxe-tooltip", { ref: "validTip", class: "vxe-table--valid-error", props: "tooltip" === v.message || 1 === s.length ? O : null, }) : t(), ] ); }, methods: ri, }; const di = Object.assign(ci, { install(e) { "undefined" !== typeof window && window.VXETableMixin && (ci.mixins.push(window.VXETableMixin), delete window.VXETableMixin), (Ke.Vue = e), (Ke.Table = ci), (Ke.TableComponent = ci), e.prototype.$vxe ? ((e.prototype.$vxe.t = Ke.t), (e.prototype.$vxe._t = Ke._t)) : (e.prototype.$vxe = { t: Ke.t, _t: Ke._t }), e.component(ci.name, ci), e.component(_t.name, _t); }, }); var ui = di, pi = { name: "VxeTableFilter", props: { filterStore: Object }, computed: { hasCheckOption() { const e = this.filterStore; return e && e.options.some((e) => e.checked); }, }, render(e) { const t = this.$parent, i = this.filterStore, s = i.column, n = s ? s.filterRender : null, o = n ? Ke.renderer.get(n.name) : null; return e( "div", { class: [ "vxe-table--filter-wrapper", "filter--prevent-default", o && o.className ? o.className : "", { "is--animat": t.animat, "is--multiple": i.multiple, "filter--active": i.visible, }, ], style: i.style, }, i.visible ? this.renderOptions(e, n, o).concat(this.renderFooter(e)) : [] ); }, methods: { renderOptions(e, t, i) { const s = this.$parent, n = this.filterStore, o = n.args, l = n.column, a = n.multiple, h = n.maxHeight, c = l.slots; return c && c.filter ? [ e( "div", { class: "vxe-table--filter-template" }, s.callSlot( c.filter, Object.assign({ $panel: this, context: this }, o), e ) ), ] : i && i.renderFilter ? [ e( "div", { class: "vxe-table--filter-template" }, i.renderFilter.call( s, e, t, Object.assign({ $panel: this, context: this }, o) ) ), ] : [ e("ul", { class: "vxe-table--filter-header" }, [ e( "li", { class: [ "vxe-table--filter-option", { "is--checked": a ? n.isAllSelected : !n.options.some((e) => e._checked), "is--indeterminate": a && n.isIndeterminate, }, ], attrs: { title: r.i18n( a ? "vxe.table.allTitle" : "vxe.table.allFilter" ), }, on: { click: (e) => { this.changeAllOption(e, !n.isAllSelected); }, }, }, (a ? [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color }, }), ] : [] ).concat([ e( "span", { class: "vxe-checkbox--label" }, r.i18n("vxe.table.allFilter") ), ]) ), ]), e( "ul", { class: "vxe-table--filter-body", style: h ? { maxHeight: `${h}px` } : {}, }, n.options.map((t) => { return e( "li", { class: [ "vxe-table--filter-option", { "is--checked": t._checked }, ], attrs: { title: t.label }, on: { click: (e) => { this.changeOption(e, !t._checked, t); }, }, }, (a ? [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color }, }), ] : [] ).concat([ e( "span", { class: "vxe-checkbox--label" }, g.formatText(t.label, 1) ), ]) ); }) ), ]; }, renderFooter(e) { const t = this.hasCheckOption, i = this.filterStore, s = i.column, o = i.multiple, l = s.filterRender, a = l ? Ke.renderer.get(l.name) : null, h = !t && !i.isAllSelected && !i.isIndeterminate; return !o || (a && (n.a.isBoolean(a.showFilterFooter) ? !1 === a.showFilterFooter : !1 === a.isFooter)) ? [] : [ e("div", { class: "vxe-table--filter-footer" }, [ e( "button", { class: { "is--disabled": h }, attrs: { disabled: h }, on: { click: this.confirmFilter }, }, r.i18n("vxe.table.confirmFilter") ), e( "button", { on: { click: this.resetFilter } }, r.i18n("vxe.table.resetFilter") ), ]), ]; }, filterCheckAllEvent(e, t) { const i = this.filterStore; i.options.forEach((e) => { (e._checked = t), (e.checked = t); }), (i.isAllSelected = t), (i.isIndeterminate = !1); }, changeRadioOption(e, t, i) { const s = this.$parent, n = this.filterStore; n.options.forEach((e) => { e._checked = !1; }), (i._checked = t), s.checkFilterOptions(), this.confirmFilter(e); }, changeMultipleOption(e, t, i) { const s = this.$parent; (i._checked = t), s.checkFilterOptions(); }, changeAllOption(e, t) { this.filterStore.multiple ? this.filterCheckAllEvent(e, t) : this.resetFilter(e); }, changeOption(e, t, i) { this.filterStore.multiple ? this.changeMultipleOption(e, t, i) : this.changeRadioOption(e, t, i); }, confirmFilter(e) { const t = this.$parent, i = this.filterStore; i.options.forEach((e) => { e.checked = e._checked; }), t.confirmFilterEvent(e); }, resetFilter(e) { const t = this.$parent; t.resetFilterEvent(e); }, }, }, fi = { methods: { _setFilter(e, t) { const i = it(this, e); return ( i && i.filters && t && (i.filters = g.getFilters(t)), this.$nextTick() ); }, checkFilterOptions() { const e = this.filterStore; (e.isAllSelected = e.options.every((e) => e._checked)), (e.isIndeterminate = !e.isAllSelected && e.options.some((e) => e._checked)); }, triggerFilterEvent(e, t, i) { const s = this.filterStore; if (s.column === t && s.visible) s.visible = !1; else { const n = e.target, o = e.pageX, r = t.filters, l = t.filterMultiple, a = t.filterRender, h = a ? Ke.renderer.get(a.name) : null, c = t.filterRecoverMethod || (h ? h.filterRecoverMethod : null), d = A.getDomNode(), u = d.visibleWidth; Object.assign(s, { args: i, multiple: l, options: r, column: t, style: null, visible: !0, }), s.options.forEach((e) => { const i = e._checked, s = e.checked; (e._checked = s), s || i === s || (c && c({ option: e, column: t, $table: this })); }), this.checkFilterOptions(), (this.initStore.filter = !0), this.$nextTick(() => { const e = this.$refs, i = e.tableBody.$el, r = e.filterWrapper.$el; let l = 0, a = 0, h = null, c = null; r && ((l = r.offsetWidth), (a = r.offsetHeight), (h = r.querySelector(".vxe-table--filter-header")), (c = r.querySelector(".vxe-table--filter-footer"))); const d = l / 2, p = 10, f = i.clientWidth - l - p; let m, g; const v = { top: `${ n.offsetTop + n.offsetParent.offsetTop + n.offsetHeight + 8 }px`, }; let _ = null; if ( (a >= i.clientHeight && (_ = i.clientHeight - (c ? c.offsetHeight : 0) - (h ? h.offsetHeight : 0)), "left" === t.fixed ? (m = n.offsetLeft + n.offsetParent.offsetLeft - d) : "right" === t.fixed ? (g = n.offsetParent.offsetWidth - n.offsetLeft + (n.offsetParent.offsetParent.offsetWidth - n.offsetParent.offsetLeft) - t.renderWidth - d) : (m = n.offsetLeft + n.offsetParent.offsetLeft - d - i.scrollLeft), m) ) { const e = o + l - d + p - u; e > 0 && (m -= e), (v.left = `${Math.min(f, Math.max(p, m))}px`); } else if (g) { const e = o + l - d + p - u; e > 0 && (g += e), (v.right = `${Math.max(p, g)}px`); } (s.style = v), (s.maxHeight = _); }); } }, _getCheckedFilters() { const e = this.tableFullColumn, t = []; return ( e.filter((e) => { const i = e.property, s = e.filters, n = [], o = []; s && s.length && (s.forEach((e) => { e.checked && (n.push(e.value), o.push(e.data)); }), n.length && t.push({ column: e, property: i, values: n, datas: o })); }), t ); }, confirmFilterEvent(e) { const t = this.filterStore, i = this.filterOpts, s = this.scrollXLoad, n = this.scrollYLoad, o = t.column, r = o.property, l = [], a = []; o.filters.forEach((e) => { e.checked && (l.push(e.value), a.push(e.data)); }), (t.visible = !1); const h = this.getCheckedFilters(); i.remote || (this.handleTableData(!0), this.checkSelectionStatus()), this.emitEvent( "filter-change", { column: o, property: r, values: l, datas: a, filters: h, filterList: h, }, e ), this.updateFooter(), (s || n) && (this.clearScroll(), n && this.updateScrollYSpace()), this.closeFilter(), this.$nextTick(() => { this.recalculate(), this.updateCellAreas(); }); }, handleClearFilter(e) { if (e) { const t = e.filters, i = e.filterRender; if (t) { const s = i ? Ke.renderer.get(i.name) : null, o = e.filterResetMethod || (s ? s.filterResetMethod : null); t.forEach((e) => { (e._checked = !1), (e.checked = !1), o || (e.data = n.a.clone(e.resetValue, !0)); }), o && o({ options: t, column: e, $table: this }); } } }, resetFilterEvent(e) { this.handleClearFilter(this.filterStore.column), this.confirmFilterEvent(e); }, _clearFilter(e) { const t = this.filterStore; let i; return ( e ? ((i = it(this, e)), i && this.handleClearFilter(i)) : this.visibleColumn.forEach(this.handleClearFilter), (e && i === t.column) || Object.assign(t, { isAllSelected: !1, isIndeterminate: !1, style: null, options: [], column: null, multiple: !1, visible: !1, }), this.updateData() ); }, }, }; const mi = { Panel: pi, install(e) { Ke.reg("filter"), ui.mixins.push(fi), e.component(pi.name, pi); }, }; var gi = { name: "VxeTableContextMenu", props: { ctxMenuStore: Object, ctxMenuOpts: Object }, mounted() { document.body.appendChild(this.$el); }, beforeDestroy() { const e = this.$el; e.parentNode && e.parentNode.removeChild(e); }, render(e) { const t = this.$parent, i = this._e, s = this.ctxMenuOpts, n = this.ctxMenuStore; return e( "div", { class: ["vxe-table--context-menu-wrapper", s.className], style: n.style, }, n.list.map((s, o) => { return s.every((e) => !1 === e.visible) ? i() : e( "ul", { class: "vxe-context-menu--option-wrapper", key: o }, s.map((i, s) => { const r = i.children && i.children.length; return !1 === i.visible ? null : e( "li", { class: [ i.className, { "link--disabled": i.disabled, "link--active": i === n.selected, }, ], key: `${o}_${s}`, }, [ e( "a", { class: "vxe-context-menu--link", on: { click(e) { t.ctxMenuLinkEvent(e, i); }, mouseover(e) { t.ctxMenuMouseoverEvent(e, i); }, mouseout(e) { t.ctxMenuMouseoutEvent(e, i); }, }, }, [ e("i", { class: [ "vxe-context-menu--link-prefix", i.prefixIcon, ], }), e( "span", { class: "vxe-context-menu--link-content", }, g.getFuncText(i.name) ), e("i", { class: [ "vxe-context-menu--link-suffix", r ? i.suffixIcon || "suffix--haschild" : i.suffixIcon, ], }), ] ), r ? e( "ul", { class: [ "vxe-table--context-menu-clild-wrapper", { "is--show": i === n.selected && n.showChild, }, ], }, i.children.map((r, l) => { return !1 === r.visible ? null : e( "li", { class: [ r.className, { "link--disabled": r.disabled, "link--active": r === n.selectChild, }, ], key: `${o}_${s}_${l}`, }, [ e( "a", { class: "vxe-context-menu--link", on: { click(e) { t.ctxMenuLinkEvent( e, r ); }, mouseover(e) { t.ctxMenuMouseoverEvent( e, i, r ); }, mouseout(e) { t.ctxMenuMouseoutEvent( e, i, r ); }, }, }, [ e("i", { class: [ "vxe-context-menu--link-prefix", r.prefixIcon, ], }), e( "span", { class: "vxe-context-menu--link-content", }, g.getFuncText(r.name) ), ] ), ] ); }) ) : null, ] ); }) ); }) ); }, }, vi = { methods: { _closeMenu() { return ( Object.assign(this.ctxMenuStore, { visible: !1, selected: null, selectChild: null, showChild: !1, }), this.$nextTick() ); }, moveCtxMenu(e, t, i, s, o, r, l) { let a; const h = n.a.findIndexOf(l, (e) => i[s] === e); if (t === o) r && g.hasChildrenList(i.selected) ? (i.showChild = !0) : ((i.showChild = !1), (i.selectChild = null)); else if (38 === t) { for (let e = h - 1; e >= 0; e--) if (!1 !== l[e].visible) { a = l[e]; break; } i[s] = a || l[l.length - 1]; } else if (40 === t) { for (let e = h + 1; e < l.length; e++) if (!1 !== l[e].visible) { a = l[e]; break; } i[s] = a || l[0]; } else !i[s] || (13 !== t && 32 !== t) || this.ctxMenuLinkEvent(e, i[s]); }, handleGlobalContextmenuEvent(e) { const t = this.$refs, i = this.tId, s = this.editStore, n = this.menuConfig, o = this.contextMenu, r = this.ctxMenuStore, l = this.ctxMenuOpts, a = this.mouseConfig, h = this.mouseOpts, c = s.selected, d = ["header", "body", "footer"]; if (n || o) { if ( r.visible && t.ctxWrapper && A.getEventTargetNode(e, t.ctxWrapper.$el).flag ) return void e.preventDefault(); if (this._keyCtx) { const t = "body", i = { type: t, $grid: this.$xegrid, $table: this, keyboard: !0, columns: this.visibleColumn.slice(0), $event: e, }; if (a && h.area) { const s = this.getActiveCellArea(); if (s && s.row && s.column) return ( (i.row = s.row), (i.column = s.column), void this.openContextMenu(e, t, i) ); } else if (a && h.selected && c.row && c.column) return ( (i.row = c.row), (i.column = c.column), void this.openContextMenu(e, t, i) ); } for (let t = 0; t < d.length; t++) { const s = d[t], n = A.getEventTargetNode( e, this.$el, `vxe-${s}--column`, (e) => { return ( e.parentNode.parentNode.parentNode.getAttribute( "xid" ) === i ); } ), o = { type: s, $grid: this.$xegrid, $table: this, columns: this.visibleColumn.slice(0), $event: e, }; if (n.flag) { const t = n.targetElem, i = this.getColumnNode(t).item; let r = `${s}-`; if ( (Object.assign(o, { column: i, columnIndex: this.getColumnIndex(i), cell: t, }), "body" === s) ) { const e = this.getRowNode(t.parentNode).item; (r = ""), (o.row = e), (o.rowIndex = this.getRowIndex(e)); } return ( this.openContextMenu(e, s, o), void (this.$listeners[`${r}cell-context-menu`] ? ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delEvent", [ `${r}cell-context-menu`, `${r}cell-menu`, ]), this.emitEvent(`${r}cell-context-menu`, o, e)) : this.emitEvent(`${r}cell-menu`, o, e)) ); } if ( A.getEventTargetNode( e, this.$el, `vxe-table--${s}-wrapper`, (e) => e.getAttribute("xid") === i ).flag ) return void ("cell" === l.trigger ? e.preventDefault() : this.openContextMenu(e, s, o)); } } t.filterWrapper && !A.getEventTargetNode(e, t.filterWrapper.$el).flag && this.closeFilter(), this.closeMenu(); }, openContextMenu(e, t, i) { const s = this.isCtxMenu, n = this.ctxMenuStore, o = this.ctxMenuOpts, r = o[t], l = o.visibleMethod; if (r) { const t = r.options, o = r.disabled; o ? e.preventDefault() : s && t && t.length && ((i.options = t), this.preventEvent(e, "event.showMenu", i, () => { if (!l || l(i)) { e.preventDefault(), this.updateZindex(); const s = A.getDomNode(), o = s.scrollTop, r = s.scrollLeft, l = s.visibleHeight, a = s.visibleWidth; let h = e.clientY + o, c = e.clientX + r; const d = () => { Object.assign(n, { args: i, visible: !0, list: t, selected: null, selectChild: null, showChild: !1, style: { zIndex: this.tZindex, top: `${h}px`, left: `${c}px`, }, }), this.$nextTick(() => { const e = this.$refs.ctxWrapper.$el, t = e.clientHeight, i = e.clientWidth, s = A.getAbsolutePos(e), d = s.boundingTop, u = s.boundingLeft, p = d + t - l, f = u + i - a; p > -10 && (n.style.top = `${Math.max( o + 2, h - t - 2 )}px`), f > -10 && (n.style.left = `${Math.max( r + 2, c - i - 2 )}px`); }); }, u = i.keyboard, p = i.row, f = i.column; u && p && f ? this.scrollToRow(p, f).then(() => { const e = this.getCell(p, f), t = A.getAbsolutePos(e), i = t.boundingTop, s = t.boundingLeft; (h = i + o + Math.floor(e.offsetHeight / 2)), (c = s + r + Math.floor(e.offsetWidth / 2)), d(); }) : d(); } else this.closeMenu(); })); } this.closeFilter(); }, ctxMenuMouseoverEvent(e, t, i) { const s = e.currentTarget, n = this.ctxMenuStore; e.preventDefault(), e.stopPropagation(), (n.selected = t), (n.selectChild = i), i || ((n.showChild = g.hasChildrenList(t)), n.showChild && this.$nextTick(() => { const e = s.nextElementSibling; if (e) { const t = A.getAbsolutePos(s), i = t.boundingTop, n = t.boundingLeft, o = t.visibleHeight, r = t.visibleWidth, l = i + s.offsetHeight, a = n + s.offsetWidth; let h = "", c = ""; a + e.offsetWidth > r - 10 && ((h = "auto"), (c = `${s.offsetWidth}px`)); let d = "", u = ""; l + e.offsetHeight > o - 10 && ((d = "auto"), (u = "0")), (e.style.left = h), (e.style.right = c), (e.style.top = d), (e.style.bottom = u); } })); }, ctxMenuMouseoutEvent(e, t) { const i = this.ctxMenuStore; t.children || (i.selected = null), (i.selectChild = null); }, ctxMenuLinkEvent(e, t) { if ( !t.disabled && (t.code || !t.children || !t.children.length) ) { const i = Ke.menus.get(t.code), s = Object.assign( { menu: t, $grid: this.$xegrid, $table: this, $event: e }, this.ctxMenuStore.args ); i && i.call(this, s, e), this.$listeners["context-menu-click"] ? ("development" === Object({ NODE_ENV: "production", BASE_URL: "" }) .VUE_APP_VXE_TABLE_ENV && g.warn("vxe.error.delEvent", [ "context-menu-click", "menu-click", ]), this.emitEvent("context-menu-click", s, e)) : this.emitEvent("menu-click", s, e), this.closeMenu(); } }, }, }; const _i = { Panel: gi, install(e) { Ke.reg("menu"), ui.mixins.push(vi), e.component(gi.name, gi); }, }; var bi = { methods: { _insert(e) { return this.insertAt(e); }, _insertAt(e, t) { const i = this.mergeList, s = this.afterFullData, o = this.editStore, r = this.sYOpts, l = this.scrollYLoad, a = this.tableFullData, h = this.treeConfig; n.a.isArray(e) || (e = [e]); const c = e.map((e) => this.defineField(Object.assign({}, e))); if (t) if (-1 === t) s.push(...c), a.push(...c), i.forEach((e) => { const t = e.row, i = e.rowspan; t + i > s.length && (e.rowspan = i + c.length); }); else { if (h) throw new Error(g.getLog("vxe.error.noTree", ["insert"])); const e = s.indexOf(t); if (-1 === e) throw new Error(g.error("vxe.error.unableInsert")); s.splice(e, 0, ...c), a.splice(a.indexOf(t), 0, ...c), i.forEach((t) => { const i = t.row, s = t.rowspan; i > e ? (t.row = i + c.length) : i + s > e && (t.rowspan = s + c.length); }); } else s.unshift(...c), a.unshift(...c), i.forEach((e) => { const t = e.row; t > 0 && (e.row = t + c.length); }); return ( o.insertList.unshift(...c), (this.scrollYLoad = !h && r.gt > -1 && r.gt < a.length), this.handleTableData(), this.updateFooter(), this.updateCache(), this.checkSelectionStatus(), l && this.updateScrollYSpace(), this.$nextTick() .then(() => { return this.updateCellAreas(), this.recalculate(); }) .then(() => { return { row: c.length ? c[c.length - 1] : null, rows: c }; }) ); }, _remove(e) { const t = this.afterFullData, i = this.tableFullData, s = this.treeConfig, o = this.mergeList, r = this.editStore, l = this.checkboxOpts, a = this.selection, h = this.isInsertByRow, c = this.sYOpts, d = this.scrollYLoad, u = r.actived, p = r.removeList, f = r.insertList, m = l.checkField; let g = []; return ( e ? n.a.isArray(e) || (e = [e]) : (e = i), e.forEach((e) => { h(e) || p.push(e); }), m || e.forEach((e) => { const t = a.indexOf(e); t > -1 && a.splice(t, 1); }), i === e ? ((e = g = i.slice(0)), (this.tableFullData = []), (this.afterFullData = []), this.clearMergeCells()) : e.forEach((e) => { const s = i.indexOf(e); if (s > -1) { const e = i.splice(s, 1); g.push(e[0]); } const n = t.indexOf(e); n > -1 && (o.forEach((e) => { const t = e.row, i = e.rowspan; t > n ? (e.row = t - 1) : t + i > n && (e.rowspan = i - 1); }), t.splice(n, 1)); }), u.row && e.indexOf(u.row) > -1 && this.clearActived(), e.forEach((e) => { const t = f.indexOf(e); t > -1 && f.splice(t, 1); }), (this.scrollYLoad = !s && c.gt > -1 && c.gt < i.length), this.handleTableData(), this.updateFooter(), this.updateCache(), this.checkSelectionStatus(), d && this.updateScrollYSpace(), this.$nextTick() .then(() => { return this.updateCellAreas(), this.recalculate(); }) .then(() => { return { row: g.length ? g[g.length - 1] : null, rows: g }; }) ); }, _removeCheckboxRow() { return this.remove(this.getCheckboxRecords()).then((e) => { return this.clearCheckboxRow(), e; }); }, _removeRadioRow() { const e = this.getRadioRecord(); return this.remove(e || []).then((e) => { return this.clearRadioRow(), e; }); }, _removeCurrentRow() { const e = this.getCurrentRecord(); return this.remove(e || []).then((e) => { return this.clearCurrentRow(), e; }); }, _getRecordset() { return { insertRecords: this.getInsertRecords(), removeRecords: this.getRemoveRecords(), updateRecords: this.getUpdateRecords(), }; }, _getInsertRecords() { const e = this.editStore.insertList, t = []; return ( e.length && this.tableFullData.forEach((i) => { e.indexOf(i) > -1 && t.push(i); }), t ); }, _getRemoveRecords() { return this.editStore.removeList; }, _getUpdateRecords() { const e = this.keepSource, t = this.tableFullData, i = this.isUpdateByRow, s = this.treeConfig, o = this.treeOpts, r = this.editStore; if (e) { const e = r.actived, l = e.row, a = e.column; return ( (l || a) && this._syncActivedCell(), s ? n.a.filterTree(t, (e) => i(e), o) : t.filter((e) => i(e)) ); } return []; }, handleActived(e, t) { const i = this.editStore, s = this.editOpts, n = this.tableColumn, o = this.mouseConfig, r = s.mode, l = s.activeMethod, a = i.actived, h = e.row, c = e.column, d = c.editRender, u = (e.cell = e.cell || this.getCell(h, c)); if (p(d) && u) { if (a.row !== h || ("cell" === r && a.column !== c)) { let i = "edit-disabled"; (l && !l(e)) || (o && (this.clearSelected(t), this.clearCellAreas(t), this.clearCopyCellArea(t)), this.closeTooltip(), this.clearActived(t), (i = "edit-actived"), (c.renderHeight = u.offsetHeight), (a.args = e), (a.row = h), (a.column = c), "row" === r ? n.forEach((e) => this._getColumnModel(h, e)) : this._getColumnModel(h, c), this.$nextTick(() => { this.handleFocus(e, t); })), this.emitEvent( i, { row: h, rowIndex: this.getRowIndex(h), $rowIndex: this.getVMRowIndex(h), column: c, columnIndex: this.getColumnIndex(c), $columnIndex: this.getVMColumnIndex(c), }, t ); } else { const i = a.column; if ( (o && (this.clearSelected(t), this.clearCellAreas(t), this.clearCopyCellArea(t)), i !== c) ) { const e = i.model; e.update && g.setCellValue(h, i, e.value), this.clearValidate(); } (c.renderHeight = u.offsetHeight), (a.args = e), (a.column = c), setTimeout(() => { this.handleFocus(e, t); }); } this.focus(); } return this.$nextTick(); }, _getColumnModel(e, t) { const i = t.model, s = t.editRender; s && ((i.value = g.getCellValue(e, t)), (i.update = !1)); }, _setColumnModel(e, t) { const i = t.model, s = t.editRender; s && i.update && (g.setCellValue(e, t, i.value), (i.update = !1), (i.value = null)); }, _syncActivedCell() { const e = this.tableColumn, t = this.editStore, i = this.editOpts, s = t.actived, n = s.row, o = s.column; (n || o) && ("row" === i.mode ? e.forEach((e) => this._setColumnModel(n, e)) : this._setColumnModel(n, o)); }, _clearActived(e) { const t = this.editStore, i = t.actived, s = i.row, n = i.column; return ( (s || n) && (this._syncActivedCell(), (i.args = null), (i.row = null), (i.column = null), this.updateFooter(), this.emitEvent( "edit-closed", { row: s, rowIndex: this.getRowIndex(s), $rowIndex: this.getVMRowIndex(s), column: n, columnIndex: this.getColumnIndex(n), $columnIndex: this.getVMColumnIndex(n), }, e )), (Ke._valid ? this.clearValidate() : this.$nextTick()).then( this.recalculate ) ); }, _getActiveRecord() { const e = this.$el, t = this.editStore, i = this.afterFullData, s = t.actived, n = s.args, o = s.row; return n && i.indexOf(o) > -1 && e.querySelectorAll(".vxe-body--column.col--actived").length ? Object.assign({}, n) : null; }, _isActiveByRow(e) { return this.editStore.actived.row === e; }, handleFocus(e) { const t = e.row, i = e.column, s = e.cell, n = i.editRender; if (p(n)) { const e = Ke.renderer.get(n.name), o = n.autofocus, r = n.autoselect; let l; if ( (o && (l = s.querySelector(o)), !l && e && e.autofocus && (l = s.querySelector(e.autofocus)), l) ) { if ((l.focus(), r)) l.select(); else if (b.msie) { const e = l.createTextRange(); e.collapse(!1), e.select(); } } else this.scrollToRow(t, i); } }, _setActiveRow(e) { return this.setActiveCell( e, n.a.find(this.visibleColumn, (e) => p(e.editRender)) ); }, _setActiveCell(e, t) { const i = n.a.isString(t) ? this.getColumnByField(t) : t; return e && i && p(i.editRender) ? this.scrollToRow(e, !0).then(() => { const t = this.getCell(e, i); t && (this.handleActived({ row: e, rowIndex: this.getRowIndex(e), column: i, columnIndex: this.getColumnIndex(i), cell: t, $table: this, }), (this.lastCallTime = Date.now())); }) : this.$nextTick(); }, _setSelectCell(e, t) { const i = this.tableData, s = this.editOpts, o = this.visibleColumn, r = n.a.isString(t) ? this.getColumnByField(t) : t; if (e && r && "manual" !== s.trigger) { const t = i.indexOf(e); if (t > -1) { const i = this.getCell(e, r), s = { row: e, rowIndex: t, column: r, columnIndex: o.indexOf(r), cell: i, }; this.handleSelected(s, {}); } } return this.$nextTick(); }, handleSelected(e, t) { const i = this.mouseConfig, s = this.mouseOpts, n = this.editOpts, o = this.editStore, r = o.actived, l = o.selected, a = e.row, h = e.column, c = i && s.selected, d = () => { return ( !c || (l.row === a && l.column === h) || ((r.row !== a || ("cell" === n.mode && r.column !== h)) && (this.clearActived(t), this.clearSelected(t), this.clearCellAreas(t), this.clearCopyCellArea(t), (l.args = e), (l.row = a), (l.column = h), c && this.addColSdCls(), this.focus(), t && this.emitEvent("cell-selected", e, t))), this.$nextTick() ); }; return d(); }, _getSelectedCell() { const e = this.editStore.selected, t = e.args, i = e.column; return t && i ? Object.assign({}, t) : null; }, _clearSelected() { const e = this.editStore.selected; return ( (e.row = null), (e.column = null), this.reColTitleSdCls(), this.reColSdCls(), this.$nextTick() ); }, reColTitleSdCls() { const e = this.elemStore["main-header-list"]; e && n.a.arrayEach(e.querySelectorAll(".col--title-selected"), (e) => A.removeClass(e, "col--title-selected") ); }, reColSdCls() { const e = this.$el.querySelector(".col--selected"); e && A.removeClass(e, "col--selected"); }, addColSdCls() { const e = this.editStore.selected, t = e.row, i = e.column; if ((this.reColSdCls(), t && i)) { const e = this.getCell(t, i); e && A.addClass(e, "col--selected"); } }, }, }; const yi = { install() { Ke.reg("edit"), ui.mixins.push(bi); }, }; var xi = i("3835"); const wi = [], Si = []; var Ei = { name: "VxeModal", mixins: [bt], props: { value: Boolean, id: String, type: { type: String, default: "modal" }, loading: { type: Boolean, default: null }, status: String, iconStatus: String, className: String, top: { type: [Number, String], default: () => r.modal.top }, position: [String, Object], title: String, duration: { type: [Number, String], default: () => r.modal.duration }, message: [String, Function], content: [String, Function], cancelButtonText: { type: String, default: () => r.modal.cancelButtonText, }, confirmButtonText: { type: String, default: () => r.modal.confirmButtonText, }, lockView: { type: Boolean, default: () => r.modal.lockView }, lockScroll: Boolean, mask: { type: Boolean, default: () => r.modal.mask }, maskClosable: { type: Boolean, default: () => r.modal.maskClosable }, escClosable: { type: Boolean, default: () => r.modal.escClosable }, resize: { type: Boolean, default: () => r.modal.resize }, showHeader: { type: Boolean, default: () => r.modal.showHeader }, showFooter: { type: Boolean, default: () => r.modal.showFooter }, showZoom: { type: Boolean, default: null }, showClose: { type: Boolean, default: () => r.modal.showClose }, dblclickZoom: { type: Boolean, default: () => r.modal.dblclickZoom }, width: [Number, String], height: [Number, String], minWidth: { type: [Number, String], default: () => r.modal.minWidth }, minHeight: { type: [Number, String], default: () => r.modal.minHeight, }, zIndex: Number, marginSize: { type: [Number, String], default: r.modal.marginSize }, fullscreen: Boolean, remember: { type: Boolean, default: () => r.modal.remember }, destroyOnClose: { type: Boolean, default: () => r.modal.destroyOnClose, }, showTitleOverflow: { type: Boolean, default: () => r.modal.showTitleOverflow, }, transfer: { type: Boolean, default: () => r.modal.transfer }, storage: { type: Boolean, default: () => r.modal.storage }, storageKey: { type: String, default: () => r.modal.storageKey }, animat: { type: Boolean, default: () => r.modal.animat }, size: { type: String, default: () => r.modal.size || r.size }, beforeHideMethod: { type: Function, default: () => r.modal.beforeHideMethod, }, slots: Object, events: Object, }, data() { return { inited: !1, visible: !1, contentVisible: !1, modalTop: 0, modalZindex: 0, zoomLocat: null, firstOpen: !1, }; }, computed: { isMsg() { return "message" === this.type; }, }, watch: { width() { this.recalculate(); }, height() { this.recalculate(); }, value(e) { this[e ? "open" : "close"]("model"); }, }, created() { this.storage && !this.id && g.error("vxe.error.reqProp", ["modal.id"]); }, mounted() { const e = this.$listeners, t = this.events, i = void 0 === t ? {} : t; this.value && this.open(), this.recalculate(), this.escClosable && M.on(this, "keydown", this.handleGlobalKeydownEvent); const s = "inserted", n = { type: s, $modal: this, $event: { type: s } }; e.inserted ? this.$emit("inserted", n) : i.inserted && i.inserted.call(this, n); }, beforeDestroy() { const e = this.$el; M.off(this, "keydown"), this.removeMsgQueue(), e.parentNode === document.body && e.parentNode.removeChild(e); }, render(e) { const t = this._e, i = this.$scopedSlots, s = this.slots, n = void 0 === s ? {} : s, o = this.inited, l = this.vSize, a = this.className, h = this.type, c = this.resize, d = this.showClose, u = this.showZoom, p = this.animat, f = this.loading, m = this.status, v = this.iconStatus, _ = this.showFooter, b = this.zoomLocat, y = this.modalTop, x = this.dblclickZoom, w = this.contentVisible, S = this.visible, E = this.title, k = this.lockScroll, C = this.lockView, T = this.mask, O = this.isMsg, $ = this.showTitleOverflow, R = this.destroyOnClose, A = this.content || this.message, L = i.default || n.default, D = i.footer || n.footer, I = i.header || n.header, M = i.title || n.title, P = { mousedown: this.mousedownEvent }; return ( u && x && "modal" === h && (P.dblclick = this.toggleZoomEvent), e( "div", { class: [ "vxe-modal--wrapper", `type--${h}`, a || "", { [`size--${l}`]: l, [`status--${m}`]: m, "is--animat": p, "lock--scroll": k, "lock--view": C, "is--resize": c, "is--mask": T, "is--maximize": b, "is--visible": w, "is--active": S, "is--loading": f, }, ], style: { zIndex: this.modalZindex, top: y ? `${y}px` : null }, on: { click: this.selfClickEvent }, }, [ e( "div", { class: "vxe-modal--box", on: { mousedown: this.boxMousedownEvent }, ref: "modalBox", }, [ this.showHeader ? e( "div", { class: [ "vxe-modal--header", !O && $ ? "is--ellipsis" : "", ], on: P, }, I ? !o || (R && !S) ? [] : I.call(this, { $modal: this }, e) : [ M ? M.call(this, { $modal: this }, e) : e( "span", { class: "vxe-modal--title" }, E ? g.getFuncText(E) : r.i18n("vxe.alert.title") ), u ? e("i", { class: [ "vxe-modal--zoom-btn", "trigger--btn", b ? r.icon.MODAL_ZOOM_OUT : r.icon.MODAL_ZOOM_IN, ], attrs: { title: r.i18n( `vxe.modal.zoom${b ? "Out" : "In"}` ), }, on: { click: this.toggleZoomEvent }, }) : t(), d ? e("i", { class: [ "vxe-modal--close-btn", "trigger--btn", r.icon.MODAL_CLOSE, ], attrs: { title: r.i18n("vxe.modal.close"), }, on: { click: this.closeEvent }, }) : t(), ] ) : null, e("div", { class: "vxe-modal--body" }, [ m ? e("div", { class: "vxe-modal--status-wrapper" }, [ e("i", { class: [ "vxe-modal--status-icon", v || r.icon[`MODAL_${m}`.toLocaleUpperCase()], ], }), ]) : null, e( "div", { class: "vxe-modal--content" }, L ? !o || (R && !S) ? [] : L.call(this, { $modal: this }, e) : g.getFuncText(A) ), O ? null : e( "div", { class: ["vxe-loading", { "is--visible": f }] }, [e("div", { class: "vxe-loading--spinner" })] ), ]), _ ? e( "div", { class: "vxe-modal--footer" }, D ? !o || (R && !S) ? [] : D.call(this, { $modal: this }, e) : [ "confirm" === h ? e( "vxe-button", { ref: "cancelBtn", on: { click: this.cancelEvent }, }, this.cancelButtonText || r.i18n("vxe.button.cancel") ) : null, e( "vxe-button", { ref: "confirmBtn", props: { status: "primary" }, on: { click: this.confirmEvent }, }, this.confirmButtonText || r.i18n("vxe.button.confirm") ), ] ) : null, !O && c ? e( "span", { class: "vxe-modal--resize" }, [ "wl", "wr", "swst", "sest", "st", "swlb", "selb", "sb", ].map((t) => { return e("span", { class: `${t}-resize`, attrs: { type: t }, on: { mousedown: this.dragEvent }, }); }) ) : null, ] ), ] ) ); }, methods: { recalculate() { const e = this.width, t = this.height, i = this.getBox(); return ( (i.style.width = e ? (isNaN(e) ? e : `${e}px`) : null), (i.style.height = t ? (isNaN(t) ? t : `${t}px`) : null), this.$nextTick() ); }, selfClickEvent(e) { if (this.maskClosable && e.target === this.$el) { const e = "mask"; this.close(e); } }, updateZindex() { const e = this.zIndex, t = this.modalZindex; e ? (this.modalZindex = e) : t < g.getLastZIndex() && (this.modalZindex = g.nextZIndex()); }, closeEvent(e) { const t = "close"; this.$emit(t, { type: t, $modal: this, $event: e }), this.close(t); }, confirmEvent(e) { const t = "confirm"; this.$emit(t, { type: t, $modal: this, $event: e }), this.close(t); }, cancelEvent(e) { const t = "cancel"; this.$emit(t, { type: t, $modal: this, $event: e }), this.close(t); }, open() { const e = this.$refs, t = this.events, i = void 0 === t ? {} : t, s = this.inited, o = this.duration, r = this.visible, l = this.isMsg, a = this.remember, h = this.showFooter; s || ((this.inited = !0), this.transfer && document.body.appendChild(this.$el)), r || (a || this.recalculate(), (this.visible = !0), (this.contentVisible = !1), this.updateZindex(), wi.push(this), setTimeout(() => { (this.contentVisible = !0), this.$nextTick(() => { if (h) { const t = e.confirmBtn || e.cancelBtn; t && t.focus(); } const t = "", s = { type: t, $modal: this }; i.show ? i.show.call(this, s) : (this.$emit("input", !0), this.$emit("show", s)); }); }, 10), l ? (this.addMsgQueue(), -1 !== o && setTimeout(() => this.close("close"), n.a.toNumber(o))) : this.$nextTick(() => { const e = this.firstOpen, t = this.fullscreen; (a && e) || this.updatePosition().then(() => { setTimeout(() => this.updatePosition(), 20); }), e || ((this.firstOpen = !0), this.hasPosStorage() ? this.restorePosStorage() : t && this.$nextTick(() => this.maximize())); })); }, addMsgQueue() { -1 === Si.indexOf(this) && Si.push(this), this.updateStyle(); }, removeMsgQueue() { Si.indexOf(this) > -1 && n.a.remove(Si, (e) => e === this), this.updateStyle(); }, updateStyle() { this.$nextTick(() => { let e = 0; Si.forEach((t) => { (e += n.a.toNumber(t.top)), (t.modalTop = e), (e += t.$refs.modalBox.clientHeight); }); }); }, updatePosition() { return this.$nextTick().then(() => { const e = this.marginSize, t = this.position, i = this.getBox(), s = document.documentElement.clientWidth || document.body.clientWidth, n = document.documentElement.clientHeight || document.body.clientHeight, o = "center" === t, r = o ? { top: t, left: t } : Object.assign({}, t), l = r.top, a = r.left, h = o || "center" === l, c = o || "center" === a; let d = "", u = ""; (u = a && !c ? isNaN(a) ? a : `${a}px` : `${Math.max(e, s / 2 - i.offsetWidth / 2)}px`), (d = l && !h ? isNaN(l) ? l : `${l}px` : `${Math.max(e, n / 2 - i.offsetHeight / 2)}px`), (i.style.top = d), (i.style.left = u); }); }, close(e) { const t = this.events, i = void 0 === t ? {} : t, s = this.remember, o = this.visible, r = this.isMsg, l = this.beforeHideMethod, a = { type: e, $modal: this }; o && Promise.resolve(l ? l(a) : null) .then((e) => { n.a.isError(e) || (r && this.removeMsgQueue(), (this.contentVisible = !1), s || (this.zoomLocat = null), n.a.remove(wi, (e) => e === this), this.$emit("before-hide", a), setTimeout(() => { (this.visible = !1), i.hide ? i.hide.call(this, a) : (this.$emit("input", !1), this.$emit("hide", a)); }, 200)); }) .catch((e) => e); }, handleGlobalKeydownEvent(e) { const t = 27 === e.keyCode; if (t) { const e = n.a.max(wi, (e) => e.modalZindex); e && setTimeout(() => { e === this && e.escClosable && this.close("exit"); }, 10); } }, getBox() { return this.$refs.modalBox; }, isMaximized() { return !!this.zoomLocat; }, maximize() { return this.$nextTick().then(() => { if (!this.zoomLocat) { const e = this.marginSize, t = this.getBox(), i = A.getDomNode(), s = i.visibleHeight, n = i.visibleWidth; (this.zoomLocat = { top: t.offsetTop, left: t.offsetLeft, width: t.offsetWidth + (t.style.width ? 0 : 1), height: t.offsetHeight + (t.style.height ? 0 : 1), }), Object.assign(t.style, { top: `${e}px`, left: `${e}px`, width: `${n - 2 * e}px`, height: `${s - 2 * e}px`, }), this.savePosStorage(); } }); }, revert() { return this.$nextTick().then(() => { const e = this.zoomLocat; if (e) { const t = this.getBox(); (this.zoomLocat = null), Object.assign(t.style, { top: `${e.top}px`, left: `${e.left}px`, width: `${e.width}px`, height: `${e.height}px`, }), this.savePosStorage(); } }); }, zoom() { return this[this.zoomLocat ? "revert" : "maximize"]().then(() => this.isMaximized() ); }, toggleZoomEvent(e) { const t = this.$listeners, i = this.zoomLocat, s = this.events, n = void 0 === s ? {} : s, o = { type: i ? "revert" : "max", $modal: this, $event: e }; return this.zoom().then(() => { t.zoom ? this.$emit("zoom", o) : n.zoom && n.zoom.call(this, o); }); }, getPosition() { if (!this.isMsg) { const e = this.getBox(); if (e) return { top: e.offsetTop, left: e.offsetLeft }; } return null; }, setPosition(e, t) { if (!this.isMsg) { const i = this.getBox(); n.a.isNumber(e) && (i.style.top = `${e}px`), n.a.isNumber(t) && (i.style.left = `${t}px`); } return this.$nextTick(); }, boxMousedownEvent() { const e = this.modalZindex; wi.some((t) => t.visible && t.modalZindex > e) && this.updateZindex(); }, mousedownEvent(e) { const t = this.remember, i = this.storage, s = this.marginSize, n = this.zoomLocat, o = this.getBox(); if ( !n && 0 === e.button && !A.getEventTargetNode(e, o, "trigger--btn").flag ) { e.preventDefault(); const n = document.onmousemove, r = document.onmouseup, l = e.clientX - o.offsetLeft, a = e.clientY - o.offsetTop, h = A.getDomNode(), c = h.visibleHeight, d = h.visibleWidth; (document.onmousemove = (e) => { e.preventDefault(); const t = o.offsetWidth, i = o.offsetHeight, n = s, r = d - t - s - 1, h = s, u = c - i - s - 1; let p = e.clientX - l, f = e.clientY - a; p > r && (p = r), p < n && (p = n), f > u && (f = u), f < h && (f = h), (o.style.left = `${p}px`), (o.style.top = `${f}px`); }), (document.onmouseup = () => { (document.onmousemove = n), (document.onmouseup = r), t && i && this.$nextTick(() => { this.savePosStorage(); }); }); } }, dragEvent(e) { e.preventDefault(); const t = this.$listeners, i = this.marginSize, s = this.events, o = void 0 === s ? {} : s, r = this.remember, l = this.storage, a = A.getDomNode(), h = a.visibleHeight, c = a.visibleWidth, d = e.target.getAttribute("type"), u = n.a.toNumber(this.minWidth), p = n.a.toNumber(this.minHeight), f = c, m = h, g = this.getBox(), v = document.onmousemove, _ = document.onmouseup, b = g.clientWidth, y = g.clientHeight, x = e.clientX, w = e.clientY, S = g.offsetTop, E = g.offsetLeft, k = { type: "resize", $modal: this }; (document.onmousemove = (e) => { let s, n, a, v; switch ((e.preventDefault(), d)) { case "wl": (s = x - e.clientX), (a = s + b), E - s > i && a > u && ((g.style.width = `${a < f ? a : f}px`), (g.style.left = `${E - s}px`)); break; case "swst": (s = x - e.clientX), (n = w - e.clientY), (a = s + b), (v = n + y), E - s > i && a > u && ((g.style.width = `${a < f ? a : f}px`), (g.style.left = `${E - s}px`)), S - n > i && v > p && ((g.style.height = `${v < m ? v : m}px`), (g.style.top = `${S - n}px`)); break; case "swlb": (s = x - e.clientX), (n = e.clientY - w), (a = s + b), (v = n + y), E - s > i && a > u && ((g.style.width = `${a < f ? a : f}px`), (g.style.left = `${E - s}px`)), S + v + i < h && v > p && (g.style.height = `${v < m ? v : m}px`); break; case "st": (n = w - e.clientY), (v = y + n), S - n > i && v > p && ((g.style.height = `${v < m ? v : m}px`), (g.style.top = `${S - n}px`)); break; case "wr": (s = e.clientX - x), (a = s + b), E + a + i < c && a > u && (g.style.width = `${a < f ? a : f}px`); break; case "sest": (s = e.clientX - x), (n = w - e.clientY), (a = s + b), (v = n + y), E + a + i < c && a > u && (g.style.width = `${a < f ? a : f}px`), S - n > i && v > p && ((g.style.height = `${v < m ? v : m}px`), (g.style.top = `${S - n}px`)); break; case "selb": (s = e.clientX - x), (n = e.clientY - w), (a = s + b), (v = n + y), E + a + i < c && a > u && (g.style.width = `${a < f ? a : f}px`), S + v + i < h && v > p && (g.style.height = `${v < m ? v : m}px`); break; case "sb": (n = e.clientY - w), (v = n + y), S + v + i < h && v > p && (g.style.height = `${v < m ? v : m}px`); break; } (g.className = g.className.replace(/\s?is--drag/, "") + " is--drag"), r && l && this.savePosStorage(), t.zoom ? this.$emit("zoom", k) : o.zoom && o.zoom.call(this, k); }), (document.onmouseup = () => { (this.zoomLocat = null), (document.onmousemove = v), (document.onmouseup = _), setTimeout(() => { g.className = g.className.replace(/\s?is--drag/, ""); }, 50); }); }, getStorageMap(e) { const t = r.version, i = n.a.toStringJSON(localStorage.getItem(e)); return i && i._v === t ? i : { _v: t }; }, hasPosStorage() { const e = this.id, t = this.remember, i = this.storage, s = this.storageKey; return !!(t && i && this.getStorageMap(s)[e]); }, restorePosStorage() { const e = this.id, t = this.remember, i = this.storage, s = this.storageKey; if (t && i) { const t = this.getStorageMap(s)[e]; if (t) { const e = this.getBox(), i = t.split(","), s = Object(xi["a"])(i, 8), n = s[0], o = s[1], r = s[2], l = s[3], a = s[4], h = s[5], c = s[6], d = s[7]; n && (e.style.left = `${n}px`), o && (e.style.top = `${o}px`), r && (e.style.width = `${r}px`), l && (e.style.height = `${l}px`), a && h && (this.zoomLocat = { left: a, top: h, width: c, height: d }); } } }, savePosStorage() { const e = this.id, t = this.remember, i = this.storage, s = this.storageKey, o = this.zoomLocat; if (t && i) { const t = this.getBox(), i = this.getStorageMap(s); (i[e] = [t.style.left, t.style.top, t.style.width, t.style.height] .concat(o ? [o.left, o.top, o.width, o.height] : []) .map((e) => (e ? n.a.toNumber(e) : "")) .join(",")), localStorage.setItem(s, n.a.toJSONString(i)); } }, }, }; function ki(e, t) { var i = Object.keys(e); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); t && (s = s.filter(function (t) { return Object.getOwnPropertyDescriptor(e, t).enumerable; })), i.push.apply(i, s); } return i; } function Ci(e) { for (var t = 1; t < arguments.length; t++) { var i = null != arguments[t] ? arguments[t] : {}; t % 2 ? ki(i, !0).forEach(function (t) { Object(yt["a"])(e, t, i[t]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(i)) : ki(i).forEach(function (t) { Object.defineProperty( e, t, Object.getOwnPropertyDescriptor(i, t) ); }); } return e; } const Ti = 20, Oi = 20, $i = 8; function Ri(e) { if (e) { const t = new Date(); let i, s, o; if (n.a.isDate(e)) (i = e.getHours()), (s = e.getMinutes()), (o = e.getSeconds()); else { e = n.a.toString(e); const t = e.match(/^(\d{1,2})(:(\d{1,2}))?(:(\d{1,2}))?/); t && ((i = t[1]), (s = t[3]), (o = t[5])); } return ( t.setHours(i || 0), t.setMinutes(s || 0), t.setSeconds(o || 0), t ); } return new Date(""); } function Ai(e) { const t = e.getMonth(); return t < 3 ? 1 : t < 6 ? 2 : t < 9 ? 3 : 4; } function Li(e, t) { const i = e.type, s = e.exponential, o = e.digitsValue, r = e.inpMaxlength, l = "float" === i ? n.a.toFixed(n.a.floor(t, o), o) : n.a.toString(t); return !s || (t !== l && n.a.toString(t).toLowerCase() !== n.a.toNumber(l).toExponential()) ? l.slice(0, r) : t; } function Di(e, t, i, s) { const o = t.festivalMethod; if (o) { const r = o( Ci( { $input: t, type: t.datePanelType, viewType: t.datePanelType }, i ) ), l = r ? (n.a.isString(r) ? { label: r } : r) : {}, a = l.extra ? n.a.isString(l.extra) ? { label: l.extra } : l.extra : null, h = [ e( "span", { class: ["vxe-input--date-label", { "is-notice": l.notice }] }, a && a.label ? [ e("span", s), e( "span", { class: [ "vxe-input--date-label--extra", a.important ? "is-important" : "", a.className, ], style: a.style, }, n.a.toString(a.label) ), ] : s ), ], c = l.label; if (c) { const t = n.a.toString(c).split(","); h.push( e( "span", { class: [ "vxe-input--date-festival", l.important ? "is-important" : "", l.className, ], style: l.style, }, [ t.length > 1 ? e( "span", { class: [ "vxe-input--date-festival--overlap", `overlap--${t.length}`, ], }, t.map((t) => e("span", t.substring(0, 3))) ) : e( "span", { class: "vxe-input--date-festival--label" }, t[0].substring(0, 3) ), ] ) ); } return h; } return s; } function Ii(e, t) { const i = e.disabledMethod; return ( i && i({ $input: e, type: e.datePanelType, viewType: e.datePanelType, date: t.date, }) ); } function Mi(e, t) { const i = t.datePanelType, s = t.dateValue, o = t.datePanelValue, r = t.dateHeaders, l = t.dayDatas, a = "yyyy-MM-dd"; return [ e( "table", { class: `vxe-input--date-${i}-view`, attrs: { cellspacing: 0, cellpadding: 0, border: 0 }, }, [ e("thead", [ e( "tr", r.map((t) => { return e("th", t.label); }) ), ]), e( "tbody", l.map((i) => { return e( "tr", i.map((i) => { return e( "td", { class: { "is--prev": i.isPrev, "is--current": i.isCurrent, "is--now": i.isNow, "is--next": i.isNext, "is--disabled": Ii(t, i), "is--selected": n.a.isDateSame(s, i.date, a), "is--hover": n.a.isDateSame(o, i.date, a), }, on: { click: () => t.dateSelectEvent(i), mouseenter: () => t.dateMouseenterEvent(i), }, }, Di(e, t, i, i.label) ); }) ); }) ), ] ), ]; } function Pi(e, t) { const i = t.datePanelType, s = t.dateValue, o = t.datePanelValue, r = t.weekHeaders, l = t.weekDates, a = "yyyyMMdd"; return [ e( "table", { class: `vxe-input--date-${i}-view`, attrs: { cellspacing: 0, cellpadding: 0, border: 0 }, }, [ e("thead", [ e( "tr", r.map((t) => { return e("th", t.label); }) ), ]), e( "tbody", l.map((i) => { const r = i.some((e) => n.a.isDateSame(s, e.date, a)), l = i.some((e) => n.a.isDateSame(o, e.date, a)); return e( "tr", i.map((i) => { return e( "td", { class: { "is--prev": i.isPrev, "is--current": i.isCurrent, "is--now": i.isNow, "is--next": i.isNext, "is--disabled": Ii(t, i), "is--selected": r, "is--hover": l, }, on: { click: () => t.dateSelectEvent(i), mouseenter: () => t.dateMouseenterEvent(i), }, }, Di(e, t, i, i.label) ); }) ); }) ), ] ), ]; } function Ni(e, t) { const i = t.dateValue, s = t.datePanelType, o = t.monthDatas, l = t.datePanelValue, a = "yyyyMM"; return [ e( "table", { class: `vxe-input--date-${s}-view`, attrs: { cellspacing: 0, cellpadding: 0, border: 0 }, }, [ e( "tbody", o.map((s) => { return e( "tr", s.map((s) => { return e( "td", { class: { "is--prev": s.isPrev, "is--current": s.isCurrent, "is--now": s.isNow, "is--next": s.isNext, "is--disabled": Ii(t, s), "is--selected": n.a.isDateSame(i, s.date, a), "is--hover": n.a.isDateSame(l, s.date, a), }, on: { click: () => t.dateSelectEvent(s), mouseenter: () => t.dateMouseenterEvent(s), }, }, Di(e, t, s, r.i18n(`vxe.input.date.months.m${s.month}`)) ); }) ); }) ), ] ), ]; } function Bi(e, t) { const i = t.dateValue, s = t.datePanelType, o = t.quarterDatas, l = t.datePanelValue, a = "yyyyq"; return [ e( "table", { class: `vxe-input--date-${s}-view`, attrs: { cellspacing: 0, cellpadding: 0, border: 0 }, }, [ e( "tbody", o.map((s) => { return e( "tr", s.map((s) => { return e( "td", { class: { "is--prev": s.isPrev, "is--current": s.isCurrent, "is--now": s.isNow, "is--next": s.isNext, "is--disabled": Ii(t, s), "is--selected": n.a.isDateSame(i, s.date, a), "is--hover": n.a.isDateSame(l, s.date, a), }, on: { click: () => t.dateSelectEvent(s), mouseenter: () => t.dateMouseenterEvent(s), }, }, Di( e, t, s, r.i18n(`vxe.input.date.quarters.q${s.quarter}`) ) ); }) ); }) ), ] ), ]; } function Fi(e, t) { const i = t.dateValue, s = t.datePanelType, o = t.yearDatas, r = t.datePanelValue, l = "yyyy"; return [ e( "table", { class: `vxe-input--date-${s}-view`, attrs: { cellspacing: 0, cellpadding: 0, border: 0 }, }, [ e( "tbody", o.map((s) => { return e( "tr", s.map((s) => { return e( "td", { class: { "is--disabled": Ii(t, s), "is--current": s.isCurrent, "is--now": s.isNow, "is--selected": n.a.isDateSame(i, s.date, l), "is--hover": n.a.isDateSame(r, s.date, l), }, on: { click: () => t.dateSelectEvent(s), mouseenter: () => t.dateMouseenterEvent(s), }, }, Di(e, t, s, s.year) ); }) ); }) ), ] ), ]; } function Vi(e, t) { const i = t.datePanelType; switch (i) { case "week": return Pi(e, t); case "month": return Ni(e, t); case "quarter": return Bi(e, t); case "year": return Fi(e, t); } return Mi(e, t); } function zi(e, t) { const i = t.datePanelType, s = t.selectDatePanelLabel, n = t.isDisabledPrevDateBtn, o = t.isDisabledNextDateBtn; return [ e("div", { class: "vxe-input--date-picker-header" }, [ e("div", { class: "vxe-input--date-picker-type-wrapper" }, [ e( "span", "year" === i ? { class: "vxe-input--date-picker-label" } : { class: "vxe-input--date-picker-btn", on: { click: t.dateToggleTypeEvent }, }, s ), ]), e("div", { class: "vxe-input--date-picker-btn-wrapper" }, [ e( "span", { class: [ "vxe-input--date-picker-btn vxe-input--date-picker-prev-btn", { "is--disabled": n }, ], on: { click: t.datePrevEvent }, }, [e("i", { class: "vxe-icon--caret-left" })] ), e( "span", { class: "vxe-input--date-picker-btn vxe-input--date-picker-current-btn", on: { click: t.dateTodayMonthEvent }, }, [e("i", { class: "vxe-icon--dot" })] ), e( "span", { class: [ "vxe-input--date-picker-btn vxe-input--date-picker-next-btn", { "is--disabled": o }, ], on: { click: t.dateNextEvent }, }, [e("i", { class: "vxe-icon--caret-right" })] ), ]), ]), e("div", { class: "vxe-input--date-picker-body" }, Vi(e, t)), ]; } function ji(e, t) { const i = t.dateTimeLabel, s = t.datetimePanelValue, n = t.hourList, o = t.minuteList, l = t.secondList; return [ e("div", { class: "vxe-input--time-picker-header" }, [ e("span", { class: "vxe-input--time-picker-title" }, i), e( "button", { class: "vxe-input--time-picker-confirm", attrs: { type: "button" }, on: { click: t.dateConfirmEvent }, }, r.i18n("vxe.button.confirm") ), ]), e("div", { ref: "timeBody", class: "vxe-input--time-picker-body" }, [ e( "ul", { class: "vxe-input--time-picker-hour-list" }, n.map((i, n) => { return e( "li", { key: n, class: { "is--selected": s && s.getHours() === i.value }, on: { click: (e) => t.dateHourEvent(e, i) }, }, i.label ); }) ), e( "ul", { class: "vxe-input--time-picker-minute-list" }, o.map((i, n) => { return e( "li", { key: n, class: { "is--selected": s && s.getMinutes() === i.value }, on: { click: (e) => t.dateMinuteEvent(e, i) }, }, i.label ); }) ), e( "ul", { class: "vxe-input--time-picker-second-list" }, l.map((i, n) => { return e( "li", { key: n, class: { "is--selected": s && s.getSeconds() === i.value }, on: { click: (e) => t.dateSecondEvent(e, i) }, }, i.label ); }) ), ]), ]; } function Hi(e, t) { const i = t.type, s = t.vSize, n = t.isDatePickerType, o = t.transfer, r = t.animatVisible, l = t.visiblePanel, a = t.panelPlacement, h = t.panelStyle, c = []; return n ? ("datetime" === i ? c.push( e("div", { class: "vxe-input--panel-layout-wrapper" }, [ e( "div", { class: "vxe-input--panel-left-wrapper" }, zi(e, t) ), e( "div", { class: "vxe-input--panel-right-wrapper" }, ji(e, t) ), ]) ) : "time" === i ? c.push( e("div", { class: "vxe-input--panel-wrapper" }, ji(e, t)) ) : c.push( e("div", { class: "vxe-input--panel-wrapper" }, zi(e, t)) ), e( "div", { ref: "panel", class: [ "vxe-table--ignore-clear vxe-input--panel", `type--${i}`, { [`size--${s}`]: s, "is--transfer": o, "animat--leave": r, "animat--enter": l, }, ], attrs: { placement: a }, style: h, }, c )) : null; } function Ui(e, t) { return e("span", { class: "vxe-input--number-suffix" }, [ e( "span", { class: "vxe-input--number-prev is--prev", on: { mousedown: t.numberMousedownEvent, mouseup: t.numberStopDown, mouseleave: t.numberStopDown, }, }, [ e("i", { class: ["vxe-input--number-prev-icon", r.icon.INPUT_PREV_NUM], }), ] ), e( "span", { class: "vxe-input--number-next is--next", on: { mousedown: t.numberMousedownEvent, mouseup: t.numberStopDown, mouseleave: t.numberStopDown, }, }, [ e("i", { class: ["vxe-input--number-next-icon", r.icon.INPUT_NEXT_NUM], }), ] ), ]); } function Wi(e, t) { return e( "span", { class: "vxe-input--date-picker-suffix", on: { click: t.datePickerOpenEvent }, }, [ e("i", { class: ["vxe-input--date-picker-icon", r.icon.INPUT_DATE], }), ] ); } function Gi(e, t) { return e( "span", { class: "vxe-input--search-suffix", on: { click: t.searchEvent } }, [e("i", { class: ["vxe-input--search-icon", r.icon.INPUT_SEARCH] })] ); } function Zi(e, t) { const i = t.showPwd; return e( "span", { class: "vxe-input--password-suffix", on: { click: t.passwordToggleEvent }, }, [ e("i", { class: [ "vxe-input--password-icon", i ? r.icon.INPUT_SHOW_PWD : r.icon.INPUT_PWD, ], }), ] ); } function Yi(e, t) { const i = t.$scopedSlots, s = t.prefixIcon, n = []; return ( i.prefix ? n.push( e( "span", { class: "vxe-input--prefix-icon" }, i.prefix.call(this, {}, e) ) ) : s && n.push(e("i", { class: ["vxe-input--prefix-icon", s] })), n.length ? e( "span", { class: "vxe-input--prefix", on: { click: t.clickPrefixEvent }, }, n ) : null ); } function qi(e, t) { const i = t.$scopedSlots, s = t.inputValue, o = t.isClearable, l = t.disabled, a = t.suffixIcon, h = []; return ( i.suffix ? h.push( e( "span", { class: "vxe-input--suffix-icon" }, i.suffix.call(this, {}, e) ) ) : a && h.push(e("i", { class: ["vxe-input--suffix-icon", a] })), o && h.push( e("i", { class: ["vxe-input--clear-icon", r.icon.INPUT_CLEAR] }) ), h.length ? e( "span", { class: [ "vxe-input--suffix", { "is--clear": o && !l && !("" === s || n.a.eqNull(s)) }, ], on: { click: t.clickSuffixEvent }, }, h ) : null ); } function Xi(e, t) { const i = t.controls, s = t.isPawdType, n = t.isNumType, o = t.isDatePickerType, r = t.isSearch; let l; return ( s ? (l = Zi(e, t)) : n ? i && (l = Ui(e, t)) : o ? (l = Wi(e, t)) : r && (l = Gi(e, t)), l ? e("span", { class: "vxe-input--extra-suffix" }, [l]) : null ); } var Ki = { name: "VxeInput", mixins: [bt], model: { prop: "value", event: "modelValue" }, props: { value: [String, Number, Date], immediate: { type: Boolean, default: !0 }, name: String, type: { type: String, default: "text" }, clearable: { type: Boolean, default: () => r.input.clearable }, readonly: Boolean, disabled: Boolean, placeholder: String, maxlength: [String, Number], autocomplete: { type: String, default: "off" }, align: String, form: String, className: String, size: { type: String, default: () => r.input.size || r.size }, min: { type: [String, Number], default: null }, max: { type: [String, Number], default: null }, step: [String, Number], exponential: { type: Boolean, default: () => r.input.exponential }, controls: { type: Boolean, default: () => r.input.controls }, digits: { type: [String, Number], default: () => r.input.digits }, dateConfig: Object, minDate: { type: [String, Number, Date], default: () => r.input.minDate, }, maxDate: { type: [String, Number, Date], default: () => r.input.maxDate, }, startWeek: Number, startDay: { type: [String, Number], default: () => r.input.startDay, }, labelFormat: { type: String, default: () => r.input.labelFormat }, valueFormat: { type: String, default: () => r.input.valueFormat }, editable: { type: Boolean, default: !0 }, festivalMethod: { type: Function, default: () => r.input.festivalMethod, }, disabledMethod: { type: Function, default: () => r.input.disabledMethod, }, selectDay: { type: Number, default: () => r.input.selectDay }, prefixIcon: String, suffixIcon: String, placement: String, transfer: { type: Boolean, default: () => r.input.transfer }, }, data() { return { panelIndex: 0, showPwd: !1, visiblePanel: !1, animatVisible: !1, panelStyle: null, panelPlacement: null, isActivated: !1, inputValue: this.value, datetimePanelValue: null, datePanelValue: null, datePanelLabel: "", datePanelType: "day", selectMonth: null, currentDate: null, }; }, computed: { isNumType() { return ["number", "integer", "float"].indexOf(this.type) > -1; }, isDatePickerType() { return ( this.hasTime || ["date", "week", "month", "quarter", "year"].indexOf( this.type ) > -1 ); }, hasTime() { const e = this.type; return "time" === e || "datetime" === e; }, isPawdType() { return "password" === this.type; }, isSearch() { return "search" === this.type; }, stepValue() { const e = this.type, t = this.step; return "integer" === e ? n.a.toInteger(t) || 1 : "float" === e ? n.a.toNumber(t) || 1 / Math.pow(10, this.digitsValue) : n.a.toNumber(t) || 1; }, digitsValue() { return n.a.toInteger(this.digits) || 1; }, isClearable() { return ( this.clearable && (this.isPawdType || this.isNumType || this.isDatePickerType || "text" === this.type || "search" === this.type) ); }, isDisabledPrevDateBtn() { const e = this.selectMonth, t = this.dateMinTime; return !!e && e <= t; }, isDisabledNextDateBtn() { const e = this.selectMonth, t = this.dateMaxTime; return !!e && e >= t; }, dateMinTime() { return this.minDate ? n.a.toStringDate(this.minDate) : null; }, dateMaxTime() { return this.maxDate ? n.a.toStringDate(this.maxDate) : null; }, dateValue() { const e = this.value, t = this.isDatePickerType, i = this.type, s = this.dateValueFormat; let o = null; if (e && t) { let t; (t = "time" === i ? Ri(e) : n.a.toStringDate(e, s)), n.a.isValidDate(t) && (o = t); } return o; }, dateTimeLabel() { const e = this.datetimePanelValue; return e ? n.a.toDateString(e, "HH:mm:ss") : ""; }, hmsTime() { const e = this.dateValue; return e && this.hasTime ? 1e3 * (3600 * e.getHours() + 60 * e.getMinutes() + e.getSeconds()) : 0; }, dateLabelFormat() { return this.isDatePickerType ? this.labelFormat || r.i18n(`vxe.input.date.labelFormat.${this.type}`) : null; }, dateValueFormat() { const e = this.type; return "time" === e ? "HH:mm:ss" : this.valueFormat || ("datetime" === e ? "yyyy-MM-dd HH:mm:ss" : "yyyy-MM-dd"); }, selectDatePanelLabel() { if (this.isDatePickerType) { const e = this.datePanelType, t = this.selectMonth, i = this.yearList; let s, n = ""; return ( t && ((n = t.getFullYear()), (s = t.getMonth() + 1)), "quarter" === e ? r.i18n("vxe.input.date.quarterLabel", [n]) : "month" === e ? r.i18n("vxe.input.date.monthLabel", [n]) : "year" === e ? i.length ? `${i[0].year} - ${i[i.length - 1].year}` : "" : r.i18n("vxe.input.date.dayLabel", [ n, s ? r.i18n(`vxe.input.date.m${s}`) : "-", ]) ); } return ""; }, weekDatas() { const e = []; if (this.isDatePickerType) { const t = this.startDay, i = this.startWeek; let s = n.a.toNumber( n.a.isNumber(t) || n.a.isString(t) ? t : i ); e.push(s); for (let n = 0; n < 6; n++) s >= 6 ? (s = 0) : s++, e.push(s); } return e; }, dateHeaders() { return this.isDatePickerType ? this.weekDatas.map((e) => { return { value: e, label: r.i18n(`vxe.input.date.weeks.w${e}`), }; }) : []; }, weekHeaders() { return this.isDatePickerType ? [{ label: r.i18n("vxe.input.date.weeks.w") }].concat( this.dateHeaders ) : []; }, yearList() { const e = this.selectMonth, t = this.currentDate, i = []; if (e && t) { const s = t.getFullYear(), o = new Date( ("" + e.getFullYear()).replace(/\d{1}$/, "0"), 0, 1 ); for (let e = -10; e < Ti - 10; e++) { const t = n.a.getWhatYear(o, e, "first"), r = t.getFullYear(); i.push({ date: t, isCurrent: !0, isNow: s === r, year: r }); } } return i; }, yearDatas() { return n.a.chunk(this.yearList, 4); }, quarterList() { const e = this.selectMonth, t = this.currentDate, i = []; if (e && t) { const s = t.getFullYear(), o = Ai(t), r = n.a.getWhatYear(e, 0, "first"), l = r.getFullYear(); for (let e = -2; e < $i - 2; e++) { const t = n.a.getWhatQuarter(r, e), a = t.getFullYear(), h = Ai(t), c = a < l; i.push({ date: t, isPrev: c, isCurrent: a === l, isNow: a === s && h === o, isNext: !c && a > l, quarter: h, }); } } return i; }, quarterDatas() { return n.a.chunk(this.quarterList, 2); }, monthList() { const e = this.selectMonth, t = this.currentDate, i = []; if (e && t) { const s = t.getFullYear(), o = t.getMonth(), r = n.a.getWhatYear(e, 0, "first").getFullYear(); for (let t = -4; t < Oi - 4; t++) { const l = n.a.getWhatYear(e, 0, t), a = l.getFullYear(), h = l.getMonth(), c = a < r; i.push({ date: l, isPrev: c, isCurrent: a === r, isNow: a === s && h === o, isNext: !c && a > r, month: h, }); } } return i; }, monthDatas() { return n.a.chunk(this.monthList, 4); }, dayList() { const e = this.weekDatas, t = this.selectMonth, i = this.currentDate, s = this.hmsTime, o = []; if (t && i) { const r = i.getFullYear(), l = i.getMonth(), a = i.getDate(), h = t.getFullYear(), c = t.getMonth(), d = t.getDay(), u = -e.indexOf(d), p = new Date(n.a.getWhatDay(t, u).getTime() + s); for (let e = 0; e < 42; e++) { const i = n.a.getWhatDay(p, e), s = i.getFullYear(), d = i.getMonth(), u = i.getDate(), f = i < t; o.push({ date: i, isPrev: f, isCurrent: s === h && d === c, isNow: s === r && d === l && u === a, isNext: !f && c !== d, label: u, }); } } return o; }, dayDatas() { return n.a.chunk(this.dayList, 7); }, weekDates() { return this.dayDatas.map((e) => { const t = e[0], i = { date: t.date, isWeekNumber: !0, isPrev: !1, isCurrent: !1, isNow: !1, isNext: !1, label: n.a.getYearWeek(t.date), }; return [i].concat(e); }); }, hourList() { const e = []; if (this.hasTime) for (let t = 0; t < 24; t++) e.push({ value: t, label: ("" + t).padStart(2, 0) }); return e; }, minuteList() { const e = []; if (this.hasTime) for (let t = 0; t < 60; t++) e.push({ value: t, label: ("" + t).padStart(2, 0) }); return e; }, secondList() { return this.minuteList; }, inpImmediate() { const e = this.type, t = this.immediate; return ( t || !( "text" === e || "number" === e || "integer" === e || "float" === e ) ); }, inpPlaceholder() { const e = this.placeholder; return e ? g.getFuncText(e) : ""; }, inputType() { const e = this.isDatePickerType, t = this.isNumType, i = this.isPawdType, s = this.type, n = this.showPwd; return e || t || (i && n) || "number" === s ? "text" : s; }, inpMaxlength() { const e = this.isNumType, t = this.maxlength; return e && !n.a.toNumber(t) ? 16 : t; }, inpReadonly() { const e = this.type, t = this.readonly, i = this.editable; return t || !i || "week" === e || "quarter" === e; }, }, watch: { value(e) { (this.inputValue = e), this.changeValue(); }, dateLabelFormat() { this.dateParseValue(this.datePanelValue), (this.inputValue = this.datePanelLabel); }, }, created() { this.initValue(), M.on(this, "mousewheel", this.handleGlobalMousewheelEvent), M.on(this, "mousedown", this.handleGlobalMousedownEvent), M.on(this, "keydown", this.handleGlobalKeydownEvent), M.on(this, "blur", this.handleGlobalBlurEvent); }, mounted() { this.dateConfig && g.warn("vxe.error.removeProp", ["date-config"]), this.isDatePickerType && this.transfer && document.body.appendChild(this.$refs.panel); }, beforeDestroy() { const e = this.$refs.panel; e && e.parentNode && e.parentNode.removeChild(e); }, destroyed() { this.numberStopDown(), M.off(this, "mousewheel"), M.off(this, "mousedown"), M.off(this, "keydown"), M.off(this, "blur"); }, render(e) { const t = this.name, i = this.form, s = this.inputType, n = this.inpPlaceholder, o = this.inpMaxlength, r = this.inpReadonly, l = this.className, a = this.controls, h = this.inputValue, c = this.isDatePickerType, d = this.visiblePanel, u = this.isActivated, p = this.vSize, f = this.type, m = this.align, g = this.readonly, v = this.disabled, _ = this.autocomplete, b = [], y = Yi(e, this), x = qi(e, this); return ( y && b.push(y), b.push( e("input", { ref: "input", class: "vxe-input--inner", domProps: { value: h }, attrs: { name: t, form: i, type: s, placeholder: n, maxlength: o, readonly: r, disabled: v, autocomplete: _, }, on: { keydown: this.keydownEvent, keyup: this.triggerEvent, wheel: this.wheelEvent, click: this.clickEvent, input: this.inputEvent, change: this.changeEvent, focus: this.focusEvent, blur: this.blurEvent, }, }) ), x && b.push(x), b.push(Xi(e, this)), c && b.push(Hi(e, this)), e( "div", { class: [ "vxe-input", `type--${f}`, l, { [`size--${p}`]: p, [`is--${m}`]: m, "is--controls": a, "is--prefix": !!y, "is--suffix": !!x, "is--readonly": g, "is--visivle": d, "is--disabled": v, "is--active": u, }, ], }, b ) ); }, methods: { focus() { return ( (this.isActivated = !0), this.$refs.input.focus(), this.$nextTick() ); }, blur() { return ( this.$refs.input.blur(), (this.isActivated = !1), this.$nextTick() ); }, triggerEvent(e) { const t = this.$refs, i = this.inputValue; this.$emit(e.type, { $panel: t.panel, value: i, $event: e }); }, emitModel(e, t) { (this.inputValue = e), this.$emit("modelValue", e), this.$emit("input", { value: e, $event: t }), n.a.toString(this.value) !== e && this.$emit("change", { value: e, $event: t }); }, emitInputEvent(e, t) { const i = this.inpImmediate, s = this.isDatePickerType; (this.inputValue = e), s || (i ? this.emitModel(e, t) : this.$emit("input", { value: e, $event: t })); }, inputEvent(e) { const t = e.target.value; this.emitInputEvent(t, e); }, changeEvent(e) { const t = this.inpImmediate; t || this.triggerEvent(e); }, focusEvent(e) { (this.isActivated = !0), this.triggerEvent(e); }, blurEvent(e) { const t = this.inputValue, i = this.inpImmediate, s = t; i || this.emitModel(s, e), this.afterCheckValue(), this.visiblePanel || (this.isActivated = !1), this.$emit("blur", { value: s, $event: e }); }, keydownEvent(e) { const t = this.exponential, i = this.controls, s = this.isNumType; if (s) { const s = e.ctrlKey, n = e.shiftKey, o = e.altKey, r = e.keyCode; s || n || o || !( 32 === r || ((!t || 69 !== r) && r >= 65 && r <= 90) || (r >= 186 && r <= 188) || r >= 191 ) || e.preventDefault(), i && this.numberKeydownEvent(e); } this.triggerEvent(e); }, wheelEvent(e) { if (this.isNumType && this.controls && this.isActivated) { const t = e.deltaY; t > 0 ? this.numberNextEvent(e) : t < 0 && this.numberPrevEvent(e), e.preventDefault(); } this.triggerEvent(e); }, clickEvent(e) { const t = this.isDatePickerType; t && this.datePickerOpenEvent(e), this.triggerEvent(e); }, clickPrefixEvent(e) { const t = this.$refs, i = this.disabled, s = this.inputValue; i || this.$emit("prefix-click", { $panel: t.panel, value: s, $event: e, }); }, clickSuffixEvent(e) { const t = this.$refs, i = this.disabled, s = this.inputValue; i || (A.hasClass(e.currentTarget, "is--clear") ? (this.emitModel("", e), this.clearValueEvent(e, "")) : this.$emit("suffix-click", { $panel: t.panel, value: s, $event: e, })); }, clearValueEvent(e, t) { const i = this.$refs, s = this.type, n = this.isNumType; this.isDatePickerType && this.hidePanel(), (n || ["text", "search", "password"].indexOf(s) > -1) && this.focus(), this.$emit("clear", { $panel: i.panel, value: t, $event: e }); }, initValue() { const e = this.type, t = this.isDatePickerType, i = this.inputValue, s = this.digitsValue; if (t) this.changeValue(); else if ("float" === e && i) { const e = n.a.toFixed(n.a.floor(i, s), s); i !== e && this.emitModel(e, { type: "init" }); } }, changeValue() { this.isDatePickerType && (this.dateParseValue(this.inputValue), (this.inputValue = this.datePanelLabel)); }, afterCheckValue() { const e = this.type, t = this.exponential, i = this.inpReadonly, s = this.inputValue, o = this.isDatePickerType, r = this.isNumType, l = this.datetimePanelValue, a = this.dateLabelFormat, h = this.min, c = this.max; if (!i) if (r) { if (s) { let i = "integer" === e ? n.a.toInteger(s) : n.a.toNumber(s); if ( (this.vaildMinNum(i) ? this.vaildMaxNum(i) || (i = c) : (i = h), t) ) { const e = n.a.toString(s).toLowerCase(); e === n.a.toNumber(i).toExponential() && (i = e); } this.emitModel(Li(this, i), { type: "check" }); } } else if (o) if (s) if ("week" === e || "quarter" === e); else { let t; if ( ((t = "time" === e ? Ri(s) : n.a.toStringDate(s, a)), n.a.isValidDate(t)) ) if ("time" === e) (t = Ri(t)), s !== t && this.emitModel(t, { type: "check" }), (this.inputValue = t); else { let i = !1; "datetime" === e ? (s === n.a.toDateString(this.dateValue, a) && s === n.a.toDateString(t, a)) || ((i = !0), l.setHours(t.getHours()), l.setMinutes(t.getMinutes()), l.setSeconds(t.getSeconds())) : (i = !0), (this.inputValue = n.a.toDateString(t, a)), i && this.dateChange(t); } else this.dateRevert(); } else this.emitModel("", { type: "check" }); }, passwordToggleEvent(e) { const t = this.disabled, i = this.readonly, s = this.showPwd; t || i || (this.showPwd = !s), this.$emit("toggle-visible", { visible: this.showPwd, $event: e, }); }, searchEvent(e) { this.$emit("search-click", { $event: e }); }, vaildMinNum(e) { return null === this.min || e >= n.a.toNumber(this.min); }, vaildMaxNum(e) { return null === this.max || e <= n.a.toNumber(this.max); }, numberStopDown() { clearTimeout(this.downbumTimeout); }, numberDownPrevEvent(e) { this.downbumTimeout = setTimeout(() => { this.numberPrevEvent(e), this.numberDownPrevEvent(e); }, 60); }, numberDownNextEvent(e) { this.downbumTimeout = setTimeout(() => { this.numberNextEvent(e), this.numberDownNextEvent(e); }, 60); }, numberKeydownEvent(e) { const t = e.keyCode, i = 38 === t, s = 40 === t; (i || s) && (e.preventDefault(), i ? this.numberPrevEvent(e) : this.numberNextEvent(e)); }, numberMousedownEvent(e) { if ((this.numberStopDown(), 0 === e.button)) { const t = A.hasClass(e.currentTarget, "is--prev"); t ? this.numberPrevEvent(e) : this.numberNextEvent(e), (this.downbumTimeout = setTimeout(() => { t ? this.numberDownPrevEvent(e) : this.numberDownNextEvent(e); }, 500)); } }, numberPrevEvent(e) { const t = this.disabled, i = this.readonly; clearTimeout(this.downbumTimeout), t || i || this.numberChange(!0, e), this.$emit("prev-number", { $event: e }); }, numberNextEvent(e) { const t = this.disabled, i = this.readonly; clearTimeout(this.downbumTimeout), t || i || this.numberChange(!1, e), this.$emit("next-number", { $event: e }); }, numberChange(e, t) { const i = this.min, s = this.max, o = this.type, r = this.inputValue, l = this.stepValue, a = "integer" === o ? n.a.toInteger(r) : n.a.toNumber(r), h = e ? n.a.add(a, l) : n.a.subtract(a, l); let c; (c = this.vaildMinNum(h) ? (this.vaildMaxNum(h) ? h : s) : i), this.emitInputEvent(Li(this, c), t); }, datePickerOpenEvent(e) { const t = this.readonly; t || (e.preventDefault(), this.showPanel()); }, dateMonthHandle(e, t) { this.selectMonth = n.a.getWhatMonth(e, t, "first"); }, dateNowHandle() { const e = n.a.getWhatDay(Date.now(), 0, "first"); (this.currentDate = e), this.dateMonthHandle(e, 0); }, dateToggleTypeEvent() { let e = this.datePanelType; (e = "month" === e || "quarter" === e ? "year" : "month"), (this.datePanelType = e); }, datePrevEvent(e) { const t = this.isDisabledPrevDateBtn, i = this.type, s = this.datePanelType; t || ((this.selectMonth = "year" === i ? n.a.getWhatYear(this.selectMonth, -Ti, "first") : "month" === i || "quarter" === i ? "year" === s ? n.a.getWhatYear(this.selectMonth, -Ti, "first") : n.a.getWhatYear(this.selectMonth, -1, "first") : "year" === s ? n.a.getWhatYear(this.selectMonth, -Ti, "first") : "month" === s ? n.a.getWhatYear(this.selectMonth, -1, "first") : n.a.getWhatMonth(this.selectMonth, -1, "first")), this.$emit("date-prev", { type: i, $event: e })); }, dateTodayMonthEvent(e) { this.dateNowHandle(), this.dateChange(this.currentDate), this.hidePanel(), this.$emit("date-today", { type: this.type, $event: e }); }, dateNextEvent(e) { const t = this.isDisabledNextDateBtn, i = this.type, s = this.datePanelType; t || ((this.selectMonth = "year" === i ? n.a.getWhatYear(this.selectMonth, Ti, "first") : "month" === i || "quarter" === i ? "year" === s ? n.a.getWhatYear(this.selectMonth, Ti, "first") : n.a.getWhatYear(this.selectMonth, 1, "first") : "year" === s ? n.a.getWhatYear(this.selectMonth, Ti, "first") : "month" === s ? n.a.getWhatYear(this.selectMonth, 1, "first") : n.a.getWhatMonth(this.selectMonth, 1, "first")), this.$emit("date-next", { type: i, $event: e })); }, dateSelectEvent(e) { Ii(this, e) || this.dateSelectItem(e.date); }, dateSelectItem(e) { const t = this.type, i = this.datePanelType, s = "week" === t; "month" === t ? "year" === i ? ((this.datePanelType = "month"), this.dateCheckMonth(e)) : (this.dateChange(e), this.hidePanel()) : "year" === t ? (this.hidePanel(), this.dateChange(e)) : "quarter" === t ? "year" === i ? ((this.datePanelType = "quarter"), this.dateCheckMonth(e)) : (this.dateChange(e), this.hidePanel()) : "month" === i ? ((this.datePanelType = "week" === t ? t : "day"), this.dateCheckMonth(e)) : "year" === i ? ((this.datePanelType = "month"), this.dateCheckMonth(e)) : (this.dateChange(e), this.hidePanel()), s && this.changeValue(); }, dateMouseenterEvent(e) { if (!Ii(this, e)) { const t = this.datePanelType; "month" === t ? this.dateMoveMonth(e.date) : "quarter" === t ? this.dateMoveQuarter(e.date) : "year" === t ? this.dateMoveYear(e.date) : this.dateMoveDay(e.date); } }, dateHourEvent(e, t) { this.datetimePanelValue.setHours(t.value), this.dateTimeChangeEvent(e); }, dateConfirmEvent() { this.dateChange(this.dateValue || this.currentDate), this.hidePanel(); }, dateMinuteEvent(e, t) { this.datetimePanelValue.setMinutes(t.value), this.dateTimeChangeEvent(e); }, dateSecondEvent(e, t) { this.datetimePanelValue.setSeconds(t.value), this.dateTimeChangeEvent(e); }, dateTimeChangeEvent(e) { (this.datetimePanelValue = new Date( this.datetimePanelValue.getTime() )), this.updateTimePos(e.currentTarget); }, updateTimePos(e) { if (e) { const t = e.offsetHeight; e.parentNode.scrollTop = e.offsetTop - 4 * t; } }, dateMoveDay(e) { Ii(this, { date: e }) || (this.dayList.some((t) => n.a.isDateSame(t.date, e, "yyyyMMdd") ) || this.dateCheckMonth(e), this.dateParseValue(e)); }, dateMoveMonth(e) { Ii(this, { date: e }) || (this.monthList.some((t) => n.a.isDateSame(t.date, e, "yyyyMM") ) || this.dateCheckMonth(e), this.dateParseValue(e)); }, dateMoveQuarter(e) { Ii(this, { date: e }) || (this.quarterList.some((t) => n.a.isDateSame(t.date, e, "yyyyq") ) || this.dateCheckMonth(e), this.dateParseValue(e)); }, dateMoveYear(e) { Ii(this, { date: e }) || (this.yearList.some((t) => n.a.isDateSame(t.date, e, "yyyy")) || this.dateCheckMonth(e), this.dateParseValue(e)); }, dateParseValue(e) { const t = this.type, i = this.dateLabelFormat, s = this.valueFormat; let o = null, r = ""; e && (o = "time" === t ? Ri(e) : n.a.toStringDate(e, s)), n.a.isValidDate(o) ? (r = n.a.toDateString(o, i)) : (o = null), (this.datePanelValue = o), (this.datePanelLabel = r); }, dateOffsetEvent(e) { const t = this.isActivated, i = this.datePanelValue, s = this.datePanelType; if (t) { e.preventDefault(); const t = e.keyCode, o = 37 === t, r = 38 === t, l = 39 === t, a = 40 === t; if ("year" === s) { let e = n.a.getWhatYear(i || Date.now(), 0, "first"); o ? (e = n.a.getWhatYear(e, -1)) : r ? (e = n.a.getWhatYear(e, -4)) : l ? (e = n.a.getWhatYear(e, 1)) : a && (e = n.a.getWhatYear(e, 4)), this.dateMoveYear(e); } else if ("quarter" === s) { let e = n.a.getWhatQuarter(i || Date.now(), 0, "first"); o ? (e = n.a.getWhatQuarter(e, -1)) : r ? (e = n.a.getWhatQuarter(e, -2)) : l ? (e = n.a.getWhatQuarter(e, 1)) : a && (e = n.a.getWhatQuarter(e, 2)), this.dateMoveQuarter(e); } else if ("month" === s) { let e = n.a.getWhatMonth(i || Date.now(), 0, "first"); o ? (e = n.a.getWhatMonth(e, -1)) : r ? (e = n.a.getWhatMonth(e, -4)) : l ? (e = n.a.getWhatMonth(e, 1)) : a && (e = n.a.getWhatMonth(e, 4)), this.dateMoveMonth(e); } else { let e = i || n.a.getWhatDay(Date.now(), 0, "first"); o ? (e = n.a.getWhatDay(e, -1)) : r ? (e = n.a.getWhatWeek(e, -1)) : l ? (e = n.a.getWhatDay(e, 1)) : a && (e = n.a.getWhatWeek(e, 1)), this.dateMoveDay(e); } } }, datePgOffsetEvent(e) { const t = this.isActivated; if (t) { const t = 33 === e.keyCode; e.preventDefault(), t ? this.datePrevEvent(e) : this.dateNextEvent(e); } }, dateChange(e) { const t = this.value, i = this.datetimePanelValue, s = this.dateValueFormat; if ("week" === this.type) { const t = n.a.toNumber(this.selectDay); e = n.a.getWhatWeek(e, 0, t); } else this.hasTime && (e.setHours(i.getHours()), e.setMinutes(i.getMinutes()), e.setSeconds(i.getSeconds())); const o = n.a.toDateString(e, s); this.dateCheckMonth(e), n.a.isEqual(t, o) || this.emitModel(o, { type: "update" }); }, dateCheckMonth(e) { const t = n.a.getWhatMonth(e, 0, "first"); n.a.isEqual(t, this.selectMonth) || (this.selectMonth = t); }, dateOpenPanel() { const e = this.type, t = this.dateValue; ["year", "quarter", "month", "week"].indexOf(e) > -1 ? (this.datePanelType = e) : (this.datePanelType = "day"), (this.currentDate = n.a.getWhatDay(Date.now(), 0, "first")), t ? (this.dateMonthHandle(t, 0), this.dateParseValue(t)) : this.dateNowHandle(), this.hasTime && ((this.datetimePanelValue = this.datePanelValue || n.a.getWhatDay(Date.now(), 0, "first")), this.$nextTick(() => { n.a.arrayEach( this.$refs.timeBody.querySelectorAll("li.is--selected"), this.updateTimePos ); })); }, dateRevert() { this.inputValue = this.datePanelLabel; }, updateZindex() { this.panelIndex < g.getLastZIndex() && (this.panelIndex = g.nextZIndex()); }, showPanel() { const e = this.disabled, t = this.visiblePanel, i = this.isDatePickerType; e || t || (clearTimeout(this.hidePanelTimeout), (this.isActivated = !0), (this.animatVisible = !0), i && this.dateOpenPanel(), setTimeout(() => { this.visiblePanel = !0; }, 10), this.updateZindex(), this.updatePlacement()); }, hidePanel() { (this.visiblePanel = !1), (this.hidePanelTimeout = setTimeout(() => { this.animatVisible = !1; }, 350)); }, updatePlacement() { return this.$nextTick().then(() => { const e = this.$refs, t = this.transfer, i = this.placement, s = this.panelIndex, n = e.input, o = e.panel; if (n && o) { const e = n.offsetHeight, r = n.offsetWidth, l = o.offsetHeight, a = o.offsetWidth, h = 5, c = { zIndex: s }, d = A.getAbsolutePos(n), u = d.boundingTop, p = d.boundingLeft, f = d.visibleHeight, m = d.visibleWidth; let g = "bottom"; if (t) { let t = p, s = u + e; "top" === i ? ((g = "top"), (s = u - l)) : i || (s + l + h > f && ((g = "top"), (s = u - l)), s < h && ((g = "bottom"), (s = u + e))), t + a + h > m && (t -= t + a + h - m), t < h && (t = h), Object.assign(c, { left: `${t}px`, top: `${s}px`, minWidth: `${r}px`, }); } else "top" === i ? ((g = "top"), (c.bottom = `${e}px`)) : i || (u + e + l > f && u - e - l > h && ((g = "top"), (c.bottom = `${e}px`))); return ( (this.panelStyle = c), (this.panelPlacement = g), this.$nextTick() ); } }); }, handleGlobalMousedownEvent(e) { const t = this.$refs, i = this.$el, s = this.disabled, n = this.visiblePanel, o = this.isActivated; !s && o && ((this.isActivated = A.getEventTargetNode(e, i).flag || A.getEventTargetNode(e, t.panel).flag), this.isActivated || (this.isDatePickerType ? n && (this.hidePanel(), this.afterCheckValue()) : this.afterCheckValue())); }, handleGlobalKeydownEvent(e) { const t = this.isDatePickerType, i = this.visiblePanel, s = this.clearable, n = this.disabled; if (!n) { const n = e.keyCode, o = 9 === n, r = 46 === n, l = 27 === n, a = 13 === n, h = 37 === n, c = 38 === n, d = 39 === n, u = 40 === n, p = 33 === n, f = 34 === n, m = h || c || d || u; let g = this.isActivated; o ? (g && this.afterCheckValue(), (g = !1), (this.isActivated = g)) : m ? t && g && (i ? this.dateOffsetEvent(e) : (c || u) && this.datePickerOpenEvent(e)) : a ? t && (i ? this.datePanelValue ? this.dateSelectItem(this.datePanelValue) : this.hidePanel() : g && this.datePickerOpenEvent(e)) : (p || f) && t && g && this.datePgOffsetEvent(e), o || l ? i && this.hidePanel() : r && s && g && this.clearValueEvent(e, null); } }, handleGlobalMousewheelEvent(e) { const t = this.$refs, i = this.disabled, s = this.visiblePanel; i || (s && (A.getEventTargetNode(e, t.panel).flag ? this.updatePlacement() : (this.hidePanel(), this.afterCheckValue()))); }, handleGlobalBlurEvent() { const e = this.isActivated, t = this.visiblePanel; t ? (this.hidePanel(), this.afterCheckValue()) : e && this.afterCheckValue(); }, }, }, Ji = { name: "VxeCheckbox", mixins: [bt], props: { value: Boolean, label: [String, Number], indeterminate: Boolean, title: [String, Number], content: [String, Number], disabled: Boolean, size: { type: String, default: () => r.checkbox.size || r.size }, }, inject: { $xecheckboxgroup: { default: null } }, computed: { isGroup() { return this.$xecheckboxgroup; }, isDisabled() { return ( this.disabled || (this.isGroup && this.$xecheckboxgroup.disabled) ); }, }, render(e) { const t = this.$scopedSlots, i = this.$xecheckboxgroup, s = this.isGroup, o = this.isDisabled, r = this.title, l = this.vSize, a = this.indeterminate, h = this.value, c = this.label, d = this.content, u = {}; return ( r && (u.title = r), e( "label", { class: [ "vxe-checkbox", { [`size--${l}`]: l, "is--indeterminate": a, "is--disabled": o, }, ], attrs: u, }, [ e("input", { class: "vxe-checkbox--input", attrs: { type: "checkbox", disabled: o }, domProps: { checked: s ? n.a.includes(i.value, c) : h }, on: { change: this.changeEvent }, }), e("span", { class: "vxe-checkbox--icon" }), e( "span", { class: "vxe-checkbox--label" }, t.default ? t.default.call(this, {}) : [g.getFuncText(d)] ), ] ) ); }, methods: { changeEvent(e) { const t = this.$xecheckboxgroup, i = this.isGroup, s = this.isDisabled, n = this.label; if (!s) { const s = e.target.checked, o = { checked: s, label: n, $event: e }; i ? t.handleChecked(o) : (this.$emit("input", s), this.$emit("change", o)); } }, }, }; function Qi(e) { return !1 !== e.visible; } function es() { return n.a.uniqueId("opt_"); } function ts(e) { return e.optionId || "_XID"; } function is(e, t) { const i = t[ts(e)]; return i ? encodeURIComponent(i) : ""; } function ss(e, t, i) { const s = e.isGroup, n = e.visibleOptionList, o = e.visibleGroupList, r = e.valueField, l = e.groupOptionsField; let a, h, c, d; if (s) for (let u = 0; u < o.length; u++) { const e = o[u], s = e[l], n = e.disabled; if (s) for (let o = 0; o < s.length; o++) { const e = s[o], l = Qi(e), u = n || e.disabled; if ((a || u || (a = e), d && l && !u && ((c = e), !i))) return { offsetOption: c }; if (t === e[r]) { if (((d = e), i)) return { offsetOption: h }; } else l && !u && (h = e); } } else for (let u = 0; u < n.length; u++) { const e = n[u], s = e.disabled; if ((a || s || (a = e), d && !s && ((c = e), !i))) return { offsetOption: c }; if (t === e[r]) { if (((d = e), i)) return { offsetOption: h }; } else s || (h = e); } return { firstOption: a }; } function ns(e, t) { const i = e.isGroup, s = e.fullOptionList, n = e.fullGroupList, o = e.valueField; if (i) for (let r = 0; r < n.length; r++) { const e = n[r]; if (e.options) for (let i = 0; i < e.options.length; i++) { const s = e.options[i]; if (t === s[o]) return s; } } return s.find((e) => t === e[o]); } function os(e, t) { const i = ns(e, t); return n.a.toString(i ? i[e.labelField] : t); } function rs(e, t, i, s) { const n = t.isGroup, o = t.labelField, r = t.valueField, l = t.optionKey, a = t.value, h = t.multiple, c = t.currentValue; return i.map((i, d) => { const u = !n || Qi(i), p = (s && s.disabled) || i.disabled, f = i[r], m = is(t, i); return u ? e( "div", { key: l ? m : d, class: [ "vxe-select-option", i.className, { "is--disabled": p, "is--selected": h ? a && a.indexOf(f) > -1 : a === f, "is--hover": c === f, }, ], attrs: { optid: m }, on: { mousedown: t.mousedownOptionEvent, click: (e) => { p || t.changeOptionEvent(e, f); }, mouseenter: () => { p || t.setCurrentOption(i); }, }, }, g.formatText(g.getFuncText(i[o])) ) : null; }); } function ls(e, t) { const i = t.optionKey, s = t.visibleGroupList, n = t.groupLabelField, o = t.groupOptionsField; return s.map((s, r) => { const l = is(t, s), a = s.disabled; return e( "div", { key: i ? l : r, class: ["vxe-optgroup", s.className, { "is--disabled": a }], attrs: { optid: l }, }, [ e("div", { class: "vxe-optgroup--title" }, g.getFuncText(s[n])), e("div", { class: "vxe-optgroup--wrapper" }, rs(e, t, s[o], s)), ] ); }); } function as(e, t) { const i = t.isGroup, s = t.visibleGroupList, n = t.visibleOptionList; if (i) { if (s.length) return ls(e, t); } else if (n.length) return rs(e, t, n); return [ e( "div", { class: "vxe-select--empty-placeholder" }, t.emptyText || r.i18n("vxe.select.emptyText") ), ]; } var hs = { name: "VxeSelect", mixins: [bt], props: { value: null, clearable: Boolean, placeholder: String, loading: Boolean, disabled: Boolean, multiple: Boolean, multiCharOverflow: { type: [Number, String], default: () => r.select.multiCharOverflow, }, prefixIcon: String, placement: String, options: Array, optionProps: Object, optionGroups: Array, optionGroupProps: Object, className: [String, Function], size: { type: String, default: () => r.select.size || r.size }, emptyText: String, optionId: { type: String, default: () => r.select.optionId }, optionKey: Boolean, transfer: { type: Boolean, default: () => r.select.transfer }, }, components: { VxeInput: Ki }, provide() { return { $xeselect: this }; }, data() { return { inited: !1, collectOption: [], fullGroupList: [], fullOptionList: [], visibleGroupList: [], visibleOptionList: [], panelIndex: 0, panelStyle: null, panelPlacement: null, currentValue: null, visiblePanel: !1, animatVisible: !1, isActivated: !1, }; }, computed: { propsOpts() { return this.optionProps || {}; }, groupPropsOpts() { return this.optionGroupProps || {}; }, labelField() { return this.propsOpts.label || "label"; }, valueField() { return this.propsOpts.value || "value"; }, groupLabelField() { return this.groupPropsOpts.label || "label"; }, groupOptionsField() { return this.groupPropsOpts.options || "options"; }, isGroup() { return this.fullGroupList.some( (e) => e.options && e.options.length ); }, multiMaxCharNum() { return n.a.toNumber(this.multiCharOverflow); }, selectLabel() { const e = this.value, t = this.multiple, i = this.multiMaxCharNum; return e && t ? e .map((e) => { const t = os(this, e); return i > 0 && t.length > i ? `${t.substring(0, i)}...` : t; }) .join(", ") : os(this, e); }, }, watch: { collectOption(e) { e.some((e) => e.options && e.options.length) ? ((this.fullOptionList = []), (this.fullGroupList = e)) : ((this.fullGroupList = []), (this.fullOptionList = e)), this.updateCache(); }, options(e) { (this.fullGroupList = []), (this.fullOptionList = e), this.updateCache(); }, optionGroups(e) { (this.fullOptionList = []), (this.fullGroupList = e), this.updateCache(); }, }, created() { const e = this.options, t = this.optionGroups; t ? (this.fullGroupList = t) : e && (this.fullOptionList = e), this.updateCache(), M.on(this, "mousewheel", this.handleGlobalMousewheelEvent), M.on(this, "mousedown", this.handleGlobalMousedownEvent), M.on(this, "keydown", this.handleGlobalKeydownEvent), M.on(this, "blur", this.handleGlobalBlurEvent); }, beforeDestroy() { const e = this.$refs.panel; e && e.parentNode && e.parentNode.removeChild(e); }, destroyed() { M.off(this, "mousewheel"), M.off(this, "mousedown"), M.off(this, "keydown"), M.off(this, "blur"); }, render(e) { const t = this.$scopedSlots, i = this.vSize, s = this.className, o = this.inited, l = this.isActivated, a = this.loading, h = this.disabled, c = this.visiblePanel, d = t.prefix; return e( "div", { class: [ "vxe-select", s ? (n.a.isFunction(s) ? s({ $select: this }) : s) : "", { [`size--${i}`]: i, "is--visivle": c, "is--disabled": h, "is--active": l, }, ], }, [ e( "div", { class: "vxe-select-slots", ref: "hideOption" }, this.$slots.default ), e("vxe-input", { ref: "input", props: { clearable: this.clearable, placeholder: this.placeholder, readonly: !0, disabled: h, type: "text", prefixIcon: this.prefixIcon, suffixIcon: a ? r.icon.SELECT_LOADED : c ? r.icon.SELECT_OPEN : r.icon.SELECT_CLOSE, value: this.selectLabel, }, on: { clear: this.clearEvent, click: this.togglePanelEvent, focus: this.focusEvent, blur: this.blurEvent, "suffix-click": this.togglePanelEvent, }, scopedSlots: d ? { prefix: () => d({}) } : {}, }), e( "div", { ref: "panel", class: [ "vxe-table--ignore-clear vxe-select--panel", { [`size--${i}`]: i, "is--transfer": this.transfer, "animat--leave": !a && this.animatVisible, "animat--enter": !a && c, }, ], attrs: { placement: this.panelPlacement }, style: this.panelStyle, }, o ? [ e( "div", { ref: "optWrapper", class: "vxe-select-option--wrapper", }, as(e, this) ), ] : null ), ] ); }, methods: { updateCache() { const e = this.fullOptionList, t = this.fullGroupList, i = this.groupOptionsField, s = ts(this), n = (e) => { is(this, e) || (e[s] = es()); }; t.length ? t.forEach((e) => { n(e), e[i] && e[i].forEach(n); }) : e.length && e.forEach(n), this.refreshOption(); }, refreshOption() { const e = this.isGroup, t = this.fullOptionList, i = this.fullGroupList; return ( e ? (this.visibleGroupList = i.filter(Qi)) : (this.visibleOptionList = t.filter(Qi)), this.$nextTick() ); }, setCurrentOption(e) { e && (this.currentValue = e[this.valueField]); }, scrollToOption(e, t) { return this.$nextTick().then(() => { if (e) { const i = this.$refs, s = i.optWrapper, n = i.panel.querySelector(`[optid='${is(this, e)}']`); if (s && n) { const e = s.offsetHeight, i = 5; t ? n.offsetTop + n.offsetHeight - s.scrollTop > e && (s.scrollTop = n.offsetTop + n.offsetHeight - e) : (n.offsetTop + i < s.scrollTop || n.offsetTop + i > s.scrollTop + s.clientHeight) && (s.scrollTop = n.offsetTop - i); } } }); }, clearEvent(e, t) { this.clearValueEvent(t, null), this.hideOptionPanel(); }, clearValueEvent(e, t) { this.changeEvent(e, t), this.$emit("clear", { value: t, $event: e }); }, changeEvent(e, t) { t !== this.value && (this.$emit("input", t), this.$emit("change", { value: t, $event: e })); }, mousedownOptionEvent(e) { const t = 0 === e.button; t && e.stopPropagation(); }, changeOptionEvent(e, t) { const i = this.value, s = this.multiple; if (s) { let s; (s = i ? -1 === i.indexOf(t) ? i.concat([t]) : i.filter((e) => e !== t) : [t]), this.changeEvent(e, s); } else this.changeEvent(e, t), this.hideOptionPanel(); }, handleGlobalMousewheelEvent(e) { const t = this.$refs, i = this.disabled, s = this.visiblePanel; i || (s && (A.getEventTargetNode(e, t.panel).flag ? this.updatePlacement() : this.hideOptionPanel())); }, handleGlobalMousedownEvent(e) { const t = this.$refs, i = this.$el, s = this.disabled, n = this.visiblePanel; s || ((this.isActivated = A.getEventTargetNode(e, i).flag || A.getEventTargetNode(e, t.panel).flag), n && !this.isActivated && this.hideOptionPanel()); }, handleGlobalKeydownEvent(e) { const t = this.visiblePanel, i = this.currentValue, s = this.clearable, n = this.disabled; if (!n) { const n = e.keyCode, o = 9 === n, r = 13 === n, l = 27 === n, a = 38 === n, h = 40 === n, c = 46 === n, d = 32 === n; if ((o && (this.isActivated = !1), t)) if (l || o) this.hideOptionPanel(); else if (r) e.preventDefault(), e.stopPropagation(), this.changeOptionEvent(e, i); else if (a || h) { e.preventDefault(); let t = ss(this, i, a), s = t.firstOption, n = t.offsetOption; n || ns(this, i) || (n = s), this.setCurrentOption(n), this.scrollToOption(n, h); } else d && e.preventDefault(); else (a || h || r || d) && this.isActivated && (e.preventDefault(), this.showOptionPanel()); this.isActivated && c && s && this.clearValueEvent(e, null); } }, handleGlobalBlurEvent() { this.hideOptionPanel(); }, updateZindex() { this.panelIndex < g.getLastZIndex() && (this.panelIndex = g.nextZIndex()); }, focusEvent() { this.disabled || (this.isActivated = !0); }, blurEvent() { this.isActivated = !1; }, isPanelVisible() { return this.visiblePanel; }, togglePanel() { this.visiblePanel ? this.hideOptionPanel() : this.showOptionPanel(), this.$nextTick(); }, hidePanel() { this.visiblePanel && this.hideOptionPanel(), this.$nextTick(); }, showPanel() { this.visiblePanel || this.showOptionPanel(), this.$nextTick(); }, togglePanelEvent(e) { const t = e.$event; t.preventDefault(), this.visiblePanel ? this.hideOptionPanel() : this.showOptionPanel(); }, showOptionPanel() { const e = this.loading, t = this.disabled; e || t || (clearTimeout(this.hidePanelTimeout), this.inited || ((this.inited = !0), this.transfer && document.body.appendChild(this.$refs.panel)), (this.isActivated = !0), (this.animatVisible = !0), setTimeout(() => { const e = this.value, t = this.multiple, i = ns(this, t && e ? e[0] : e); (this.visiblePanel = !0), i && (this.setCurrentOption(i), this.scrollToOption(i)); }, 10), this.updateZindex(), this.updatePlacement()); }, hideOptionPanel() { (this.visiblePanel = !1), (this.hidePanelTimeout = setTimeout(() => { this.animatVisible = !1; }, 350)); }, updatePlacement() { return this.$nextTick().then(() => { const e = this.$refs, t = this.transfer, i = this.placement, s = this.panelIndex, n = e.input.$el, o = e.panel; if (o && n) { const e = n.offsetHeight, r = n.offsetWidth, l = o.offsetHeight, a = o.offsetWidth, h = 5, c = { zIndex: s }, d = A.getAbsolutePos(n), u = d.boundingTop, p = d.boundingLeft, f = d.visibleHeight, m = d.visibleWidth; let g = "bottom"; if (t) { let t = p, s = u + e; "top" === i ? ((g = "top"), (s = u - l)) : i || (s + l + h > f && ((g = "top"), (s = u - l)), s < h && ((g = "bottom"), (s = u + e))), t + a + h > m && (t -= t + a + h - m), t < h && (t = h), Object.assign(c, { left: `${t}px`, top: `${s}px`, minWidth: `${r}px`, }); } else "top" === i ? ((g = "top"), (c.bottom = `${e}px`)) : i || (u + e + l > f && u - e - l > h && ((g = "top"), (c.bottom = `${e}px`))); return ( (this.panelStyle = c), (this.panelPlacement = g), this.$nextTick() ); } }); }, focus() { return ( (this.isActivated = !0), this.$refs.input.focus(), this.$nextTick() ); }, blur() { return ( this.hideOptionPanel(), this.$refs.input.blur(), this.$nextTick() ); }, }, }; class cs { constructor(e, t) { Object.assign(this, { value: t.value, label: t.label, visible: t.visible, className: t.className, disabled: t.disabled, }); } update(e, t) { this[e] = t; } } function ds(e) { return e instanceof cs; } function us(e, t, i) { return ds(t) ? t : new cs(e, t, i); } function ps(e, t) { return us(e, t); } function fs(e) { const t = e.$xeselect, i = e.optionConfig, s = n.a.findTree(t.collectOption, (e) => e === i); s && s.items.splice(s.index, 1); } function ms(e) { const t = e.$el, i = e.$xeselect, s = e.$xeoptgroup, n = e.optionConfig, o = s ? s.optionConfig : null; (n.slots = e.$scopedSlots), o ? (o.options || (o.options = []), o.options.splice([].indexOf.call(s.$el.children, t), 0, n)) : i.collectOption.splice( [].indexOf.call(i.$refs.hideOption.children, t), 0, n ); } const gs = { value: null, label: { type: [String, Number, Boolean], default: "" }, visible: { type: Boolean, default: null }, className: [String, Function], disabled: Boolean, }, vs = {}; Object.keys(gs).forEach((e) => { vs[e] = function (t) { this.optionConfig.update(e, t); }; }); var _s = { name: "VxeOption", props: gs, inject: { $xeselect: { default: null }, $xeoptgroup: { default: null }, }, watch: vs, mounted() { ms(this); }, created() { this.optionConfig = ps(this.$xeselect, this); }, destroyed() { fs(this); }, render(e) { return e("div"); }, }, bs = { name: "VxeExportPanel", props: { defaultOptions: Object, storeData: Object }, components: { VxeModal: Ei, VxeInput: Ki, VxeCheckbox: Ji, VxeSelect: hs, VxeOption: _s, }, data() { return { isAll: !1, isIndeterminate: !1, loading: !1 }; }, computed: { vSize() { return this.size || this.$parent.size || this.$parent.vSize; }, checkedAll() { return this.storeData.columns.every((e) => e.checked); }, showSheet() { return ( ["html", "xml", "xlsx", "pdf"].indexOf( this.defaultOptions.type ) > -1 ); }, supportMerge() { const e = this.storeData, t = this.defaultOptions; return ( !t.original && "current" === t.mode && (e.isPrint || ["html", "xlsx"].indexOf(t.type) > -1) ); }, supportStyle() { const e = this.defaultOptions; return !e.original && ["xlsx"].indexOf(e.type) > -1; }, }, render(e) { const t = this._e, i = this.checkedAll, s = this.isAll, o = this.isIndeterminate, l = this.showSheet, a = this.supportMerge, h = this.supportStyle, c = this.defaultOptions, d = this.storeData, u = d.hasTree, p = d.hasMerge, f = d.isPrint, m = d.hasColgroup, v = c.isHeader, _ = []; return ( n.a.eachTree(d.columns, (t) => { const i = g.formatText(t.getTitle(), 1), s = t.children && t.children.length; _.push( e( "li", { class: [ "vxe-export--panel-column-option", `level--${t.level}`, { "is--group": s, "is--checked": t.checked, "is--indeterminate": t.halfChecked, "is--disabled": t.disabled, }, ], attrs: { title: i }, on: { click: () => { t.disabled || this.changeOption(t); }, }, }, [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color }, }), e("span", { class: "vxe-checkbox--label" }, i), ] ) ); }), e( "vxe-modal", { res: "modal", props: { value: d.visible, title: r.i18n( f ? "vxe.export.printTitle" : "vxe.export.expTitle" ), width: 660, mask: !0, lockView: !0, showFooter: !1, escClosable: !0, maskClosable: !0, loading: this.loading, }, on: { input(e) { d.visible = e; }, show: this.showEvent, }, }, [ e("div", { class: "vxe-export--panel" }, [ e( "table", { attrs: { cellspacing: 0, cellpadding: 0, border: 0 } }, [ e("tbody", [ [ f ? t() : e("tr", [ e("td", r.i18n("vxe.export.expName")), e("td", [ e("vxe-input", { ref: "filename", props: { value: c.filename, type: "text", clearable: !0, placeholder: r.i18n( "vxe.export.expNamePlaceholder" ), }, on: { modelValue(e) { c.filename = e; }, }, }), ]), ]), f ? t() : e("tr", [ e("td", r.i18n("vxe.export.expType")), e("td", [ e( "vxe-select", { props: { value: c.type }, on: { input(e) { c.type = e; }, }, }, d.typeList.map((t) => { return e("vxe-option", { props: { value: t.value, label: r.i18n(t.label), }, }); }) ), ]), ]), f || l ? e("tr", [ e("td", r.i18n("vxe.export.expSheetName")), e("td", [ e("vxe-input", { ref: "sheetname", props: { value: c.sheetName, type: "text", clearable: !0, placeholder: r.i18n( "vxe.export.expSheetNamePlaceholder" ), }, on: { modelValue(e) { c.sheetName = e; }, }, }), ]), ]) : t(), e("tr", [ e("td", r.i18n("vxe.export.expMode")), e("td", [ e( "vxe-select", { props: { value: c.mode }, on: { input(e) { c.mode = e; }, }, }, d.modeList.map((t) => { return e("vxe-option", { props: { value: t.value, label: r.i18n(t.label), }, }); }) ), ]), ]), e("tr", [ e("td", [r.i18n("vxe.export.expColumn")]), e("td", [ e( "div", { class: "vxe-export--panel-column" }, [ e( "ul", { class: "vxe-export--panel-column-header", }, [ e( "li", { class: [ "vxe-export--panel-column-option", { "is--checked": s, "is--indeterminate": o, }, ], attrs: { title: r.i18n("vxe.table.allTitle"), }, on: { click: this.allColumnEvent }, }, [ e("span", { class: "vxe-checkbox--icon vxe-checkbox--checked-icon", style: { "--checkedColor": $_theme.color, }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--unchecked-icon", style: { "--checkedColor": $_theme.color, }, }), e("span", { class: "vxe-checkbox--icon vxe-checkbox--indeterminate-icon", style: { "--checkedColor": $_theme.color, }, }), e( "span", { class: "vxe-checkbox--label" }, r.i18n( "vxe.export.expCurrentColumn" ) ), ] ), ] ), e( "ul", { class: "vxe-export--panel-column-body", }, _ ), ] ), ]), ]), e("tr", [ e("td", r.i18n("vxe.export.expOpts")), e("td", [ e( "div", { class: "vxe-export--panel-option-row" }, [ e("vxe-checkbox", { props: { value: v, title: r.i18n( "vxe.export.expHeaderTitle" ), content: r.i18n( "vxe.export.expOptHeader" ), }, on: { input(e) { c.isHeader = e; }, }, }), e("vxe-checkbox", { props: { value: c.isFooter, disabled: !d.hasFooter, title: r.i18n( "vxe.export.expFooterTitle" ), content: r.i18n( "vxe.export.expOptFooter" ), }, on: { input(e) { c.isFooter = e; }, }, }), e("vxe-checkbox", { props: { value: c.original, title: r.i18n( "vxe.export.expOriginalTitle" ), content: r.i18n( "vxe.export.expOptOriginal" ), }, on: { input(e) { c.original = e; }, }, }), ] ), e( "div", { class: "vxe-export--panel-option-row" }, [ e("vxe-checkbox", { props: { value: !!(v && m && a) && c.isColgroup, disabled: !v || !m || !a, title: r.i18n( "vxe.export.expColgroupTitle" ), content: r.i18n( "vxe.export.expOptColgroup" ), }, on: { input(e) { c.isColgroup = e; }, }, }), e("vxe-checkbox", { props: { value: !!(p && a && i) && c.isMerge, disabled: !p || !a || !i, title: r.i18n( "vxe.export.expMergeTitle" ), content: r.i18n( "vxe.export.expOptMerge" ), }, on: { input(e) { c.isMerge = e; }, }, }), f ? t() : e("vxe-checkbox", { props: { value: !!h && c.useStyle, disabled: !h, title: r.i18n( "vxe.export.expUseStyleTitle" ), content: r.i18n( "vxe.export.expOptUseStyle" ), }, on: { input(e) { c.useStyle = e; }, }, }), e("vxe-checkbox", { props: { value: !!u && c.isAllExpand, disabled: !u, title: r.i18n( "vxe.export.expAllExpandTitle" ), content: r.i18n( "vxe.export.expOptAllExpand" ), }, on: { input(e) { c.isAllExpand = e; }, }, }), ] ), ]), ]), ], ]), ] ), e("div", { class: "vxe-export--panel-btns" }, [ e("vxe-button", { props: { content: r.i18n("vxe.export.expCancel") }, on: { click: this.cancelEvent }, }), e("vxe-button", { ref: "confirmBtn", props: { status: "primary", content: r.i18n( f ? "vxe.export.expPrint" : "vxe.export.expConfirm" ), }, on: { click: this.confirmEvent }, }), ]), ]), ] ) ); }, methods: { changeOption(e) { const t = !e.checked; n.a.eachTree([e], (e) => { (e.checked = t), (e.halfChecked = !1); }), this.handleOptionCheck(e), this.checkStatus(); }, handleOptionCheck(e) { const t = n.a.findTree(this.storeData.columns, (t) => t === e); if (t && t.parent) { const e = t.parent; e.children && e.children.length && ((e.checked = e.children.every((e) => e.checked)), (e.halfChecked = !e.checked && e.children.some((e) => e.checked || e.halfChecked)), this.handleOptionCheck(e)); } }, checkStatus() { const e = this.storeData.columns; (this.isAll = e.every((e) => e.disabled || e.checked)), (this.isIndeterminate = !this.isAll && e.some((e) => !e.disabled && (e.checked || e.halfChecked))); }, allColumnEvent() { const e = !this.isAll; n.a.eachTree(this.storeData.columns, (t) => { t.disabled || ((t.checked = e), (t.halfChecked = !1)); }), (this.isAll = e), this.checkStatus(); }, showEvent() { this.$nextTick(() => { const e = this.$refs, t = e.filename || e.sheetname || e.confirmBtn; t && t.focus(); }), this.checkStatus(); }, getExportOption() { const e = this.checkedAll, t = this.storeData, i = this.defaultOptions, s = this.supportMerge, o = t.hasMerge, r = t.columns, l = n.a.searchTree(r, (e) => e.checked, { children: "children", mapChildren: "childNodes", original: !0, }); return Object.assign({}, i, { columns: l, isMerge: !!(o && s && e) && i.isMerge, }); }, cancelEvent() { this.storeData.visible = !1; }, confirmEvent(e) { this.storeData.isPrint ? this.printEvent(e) : this.exportEvent(e); }, printEvent() { const e = this.$parent; (this.storeData.visible = !1), e.print(Object.assign({}, e.printOpts, this.getExportOption())); }, exportEvent() { const e = this.$parent; (this.loading = !0), e .exportData( Object.assign({}, e.exportOpts, this.getExportOption()) ) .then(() => { (this.loading = !1), (this.storeData.visible = !1); }) .catch(() => { this.loading = !1; }); }, }, }, ys = { name: "VxeRadio", mixins: [bt], props: { value: [String, Number, Boolean], label: [String, Number, Boolean], title: [String, Number], content: [String, Number], disabled: Boolean, name: String, size: { type: String, default: () => r.radio.size || r.size }, }, inject: { $xeradiogroup: { default: null } }, computed: { isDisabled() { const e = this.$xeradiogroup; return this.disabled || (e && e.disabled); }, }, render(e) { const t = this.$scopedSlots, i = this.$xeradiogroup, s = this.isDisabled, n = this.title, o = this.vSize, r = this.value, l = this.label, a = this.name, h = this.content, c = {}; return ( n && (c.title = n), e( "label", { class: [ "vxe-radio", { [`size--${o}`]: o, "is--disabled": s }, ], attrs: c, }, [ e("input", { class: "vxe-radio--input", attrs: { type: "radio", name: i ? i.name : a, disabled: s }, domProps: { checked: i ? i.value === l : r === l }, on: { change: (e) => { if (!s) { const t = { label: l, $event: e }; i ? i.handleChecked(t) : (this.$emit("input", l), this.$emit("change", t)); } }, }, }), e("span", { class: "vxe-radio--icon" }), e( "span", { class: "vxe-radio--label" }, t.default ? t.default.call(this, {}) : [g.getFuncText(h)] ), ] ) ); }, methods: { changeEvent(e) { const t = this.$xeradiogroup, i = this.isDisabled, s = this.label; if (!i) { const i = { label: s, $event: e }; t ? t.handleChecked(i) : (this.$emit("input", s), this.$emit("change", i)); } }, }, }, xs = { name: "VxeImportPanel", props: { defaultOptions: Object, storeData: Object }, components: { VxeModal: Ei, VxeRadio: ys }, data() { return { loading: !1 }; }, computed: { vSize() { return this.size || this.$parent.size || this.$parent.vSize; }, selectName() { return `${this.storeData.filename}.${this.storeData.type}`; }, hasFile() { return this.storeData.file && this.storeData.type; }, parseTypeLabel() { const e = this.storeData, t = e.type, i = e.typeList; if (t) { const e = n.a.find(i, (e) => t === e.value); return e ? r.i18n(e.label) : "*.*"; } return `*.${i.map((e) => e.value).join(", *.")}`; }, }, render(e) { const t = this.hasFile, i = this.parseTypeLabel, s = this.defaultOptions, n = this.storeData, o = this.selectName; return e( "vxe-modal", { res: "modal", props: { value: n.visible, title: r.i18n("vxe.import.impTitle"), width: 440, mask: !0, lockView: !0, showFooter: !1, escClosable: !0, maskClosable: !0, loading: this.loading, }, on: { input(e) { n.visible = e; }, show: this.showEvent, }, }, [ e("div", { class: "vxe-export--panel" }, [ e( "table", { attrs: { cellspacing: 0, cellpadding: 0, border: 0 } }, [ e("tbody", [ e("tr", [ e("td", r.i18n("vxe.import.impFile")), e("td", [ t ? e( "div", { class: "vxe-import-selected--file", attrs: { title: o }, }, [ e("span", o), e("i", { class: r.icon.INPUT_CLEAR, on: { click: this.clearFileEvent }, }), ] ) : e( "button", { ref: "fileBtn", class: "vxe-import-select--file", attrs: { type: "button" }, on: { click: this.selectFileEvent }, }, r.i18n("vxe.import.impSelect") ), ]), ]), e("tr", [ e("td", r.i18n("vxe.import.impType")), e("td", i), ]), e("tr", [ e("td", r.i18n("vxe.import.impOpts")), e("td", [ e( "vxe-radio-group", { props: { value: s.mode }, on: { input(e) { s.mode = e; }, }, }, n.modeList.map((t) => { return e( "vxe-radio", { props: { label: t.value } }, r.i18n(t.label) ); }) ), ]), ]), ]), ] ), e("div", { class: "vxe-export--panel-btns" }, [ e( "vxe-button", { on: { click: this.cancelEvent } }, r.i18n("vxe.import.impCancel") ), e( "vxe-button", { props: { status: "primary", disabled: !t }, on: { click: this.importEvent }, }, r.i18n("vxe.import.impConfirm") ), ]), ]), ] ); }, methods: { clearFileEvent() { Object.assign(this.storeData, { filename: "", sheetName: "", type: "", }); }, selectFileEvent() { const e = this.$parent; e.readFile(this.defaultOptions) .then((e) => { const t = e.file; Object.assign(this.storeData, g.parseFile(t), { file: t }); }) .catch((e) => e); }, showEvent() { this.$nextTick(() => { const e = this.$refs, t = e.fileBtn; t && t.focus(); }); }, cancelEvent() { this.storeData.visible = !1; }, importEvent() { const e = this.$parent; (this.loading = !0), e .importByFile( this.storeData.file, Object.assign({}, e.importOpts, this.defaultOptions) ) .then(() => { (this.loading = !1), (this.storeData.visible = !1); }) .catch(() => { this.loading = !1; }); }, }, }; const ws = g.formatText, Ss = 'body{margin:0;color:#333333;font-size:14px;font-family:"Microsoft YaHei",微软雅黑,"MicrosoftJhengHei",华文细黑,STHeiti,MingLiu}body *{-webkit-box-sizing:border-box;box-sizing:border-box}.vxe-table{border-collapse:collapse;text-align:left;border-spacing:0}.vxe-table:not(.is--print){table-layout:fixed}.vxe-table,.vxe-table th,.vxe-table td,.vxe-table td{border-color:#D0D0D0;border-style:solid;border-width:0}.vxe-table.is--print{width:100%}.border--default,.border--full,.border--outer{border-top-width:1px}.border--default,.border--full,.border--outer{border-left-width:1px}.border--outer,.border--default th,.border--default td,.border--full th,.border--full td,.border--outer th,.border--inner th,.border--inner td{border-bottom-width:1px}.border--default,.border--outer,.border--full th,.border--full td{border-right-width:1px}.border--default th,.border--full th,.border--outer th{background-color:#f8f8f9}.vxe-table td>div,.vxe-table th>div{padding:.5em .4em}.col--center{text-align:center}.col--right{text-align:right}.vxe-table:not(.is--print) .col--ellipsis>div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:break-all}.vxe-table--tree-node{text-align:left}.vxe-table--tree-node-wrapper{position:relative}.vxe-table--tree-icon-wrapper{position:absolute;top:50%;width:1em;height:1em;text-align:center;-webkit-transform:translateY(-50%);transform:translateY(-50%);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer}.vxe-table--tree-unfold-icon,.vxe-table--tree-fold-icon{position:absolute;width:0;height:0;border-style:solid;border-width:.5em;border-right-color:transparent;border-bottom-color:transparent}.vxe-table--tree-unfold-icon{left:.3em;top:0;border-left-color:#939599;border-top-color:transparent}.vxe-table--tree-fold-icon{left:0;top:.3em;border-left-color:transparent;border-top-color:#939599}.vxe-table--tree-cell{display:block;padding-left:1.5em}.vxe-table input[type="checkbox"]{margin:0}.vxe-table input[type="checkbox"],.vxe-table input[type="radio"],.vxe-table input[type="checkbox"]+span,.vxe-table input[type="radio"]+span{vertical-align:middle;padding-left:0.4em}'; let Es, ks, Cs, Ts; const Os = "\ufeff", $s = "\r\n"; function Rs() { const e = document.createElement("iframe"); return (e.className = "vxe-table--print-frame"), e; } function As(e, t) { return window.Blob ? new Blob([e], { type: `text/${t.type}` }) : null; } function Ls(e, t) { const i = e.treeOpts; return t[i.children] && t[i.children].length > 0; } function Ds(e, t, i, s, n) { const o = e.seqOpts, r = o.seqMethod || s.seqMethod; return r ? r({ row: t, rowIndex: i, column: s, columnIndex: n }) : o.startIndex + i + 1; } function Is(e) { return ( e.property || ["seq", "index", "checkbox", "radio"].indexOf(e.type) > -1 ); } function Ms(e) { return !0 === e ? "full" : e || "default"; } function Ps(e) { return n.a.isBoolean(e) ? (e ? "TRUE" : "FALSE") : e; } function Ns(e, t, i, s) { const o = t.isAllExpand, r = e.treeConfig, l = e.treeOpts, a = e.radioOpts, h = e.checkboxOpts; if ((Es || (Es = document.createElement("div")), r)) { const r = []; return ( n.a.eachTree( s, (s, l, c, d, u, p) => { const f = s._row || s, m = u && u._row ? u._row : u; if (o || !m || e.isTreeExpandByRow(m)) { const s = Ls(e, f), o = { _row: f, _level: p.length - 1, _hasChild: s, _expand: s && e.isTreeExpandByRow(f), }; i.forEach((i, s) => { let r = ""; const c = i.editRender || i.cellRender; let d = i.exportMethod; if (!d && c && c.name) { const e = Ke.renderer.get(c.name); e && (d = e.exportMethod || e.cellExportMethod); } if (d) r = d({ $table: e, row: f, column: i, options: t }); else switch (i.type) { case "index": case "seq": r = Ds(e, f, l, i, s); break; case "checkbox": (r = Ps(e.isCheckedByCheckboxRow(f))), (o._checkboxLabel = h.labelField ? n.a.get(f, h.labelField) : ""), (o._checkboxDisabled = h.checkMethod && !h.checkMethod({ row: f })); break; case "radio": (r = Ps(e.isCheckedByRadioRow(f))), (o._radioLabel = a.labelField ? n.a.get(f, a.labelField) : ""), (o._radioDisabled = a.checkMethod && !a.checkMethod({ row: f })); break; default: if (t.original) r = g.getCellValue(f, i); else if ( ((r = e.getCellLabel(f, i)), "html" === i.type) ) (Es.innerHTML = r), (r = Es.innerText.trim()); else { const t = e.getCell(f, i); t && (r = t.innerText.trim()); } } o[i.id] = n.a.toString(r); }), r.push(Object.assign(o, f)); } }, l ), r ); } return s.map((s, o) => { const r = { _row: s }; return ( i.forEach((i, l) => { let c = ""; const d = i.editRender || i.cellRender; let u = i.exportMethod; if (!u && d && d.name) { const e = Ke.renderer.get(d.name); e && (u = e.exportMethod || e.cellExportMethod); } if (u) c = u({ $table: e, row: s, column: i, options: t }); else switch (i.type) { case "index": case "seq": c = Ds(e, s, o, i, l); break; case "checkbox": (c = Ps(e.isCheckedByCheckboxRow(s))), (r._checkboxLabel = h.labelField ? n.a.get(s, h.labelField) : ""), (r._checkboxDisabled = h.checkMethod && !h.checkMethod({ row: s })); break; case "radio": (c = Ps(e.isCheckedByRadioRow(s))), (r._radioLabel = a.labelField ? n.a.get(s, a.labelField) : ""), (r._radioDisabled = a.checkMethod && !a.checkMethod({ row: s })); break; default: if (t.original) c = g.getCellValue(s, i); else if (((c = e.getCellLabel(s, i)), "html" === i.type)) (Es.innerHTML = c), (c = Es.innerText.trim()); else { const t = e.getCell(s, i); t && (c = t.innerText.trim()); } } r[i.id] = n.a.toString(c); }), r ); }); } function Bs(e, t) { const i = t.columns, s = t.dataFilterMethod; let n = t.data; return ( s && (n = n.filter((e, t) => s({ row: e, $rowIndex: t }))), Ns(e, t, i, n) ); } function Fs(e) { return "TRUE" === e || "true" === e || !0 === e; } function Vs(e, t) { return (e.original ? t.property : t.getTitle()) || ""; } function zs(e, t, i, s) { const o = s.editRender || s.cellRender; let r = s.footerExportMethod; if (!r && o && o.name) { const e = Ke.renderer.get(o.name); e && (r = e.footerExportMethod || e.footerCellExportMethod); } const l = e.getVTColumnIndex(s), a = r ? r({ $table: e, items: i, itemIndex: l, _columnIndex: l, column: s, options: t, }) : n.a.toString(i[l]); return a; } function js(e, t) { const i = e.footerFilterMethod; return i ? t.filter((e, t) => i({ items: e, $rowIndex: t })) : t; } function Hs(e, t) { if (t) switch (e.cellType) { case "string": if (!isNaN(t)) return `\t${t}`; break; case "number": break; default: if (t.length >= 12 && !isNaN(t)) return `\t${t}`; break; } return t; } function Us(e) { return /[",\s\n]/.test(e) ? `"${e.replace(/"/g, '""')}"` : e; } function Ws(e, t, i, s) { let n = Os; if ( (t.isHeader && (n += i.map((e) => Us(Vs(t, e))).join(",") + $s), s.forEach((e) => { n += i.map((t) => Us(Hs(t, e[t.id]))).join(",") + $s; }), t.isFooter) ) { const s = e.footerTableData, o = js(t, s); o.forEach((s) => { n += i.map((i) => Us(zs(e, t, s, i))).join(",") + $s; }); } return n; } function Gs(e, t, i, s) { let n = ""; if ( (t.isHeader && (n += i.map((e) => Us(Vs(t, e))).join("\t") + $s), s.forEach((e) => { n += i.map((t) => Us(e[t.id])).join("\t") + $s; }), t.isFooter) ) { const s = e.footerTableData, o = js(t, s); o.forEach((s) => { n += i.map((i) => Us(zs(e, t, s, i))).join(",") + $s; }); } return n; } function Zs(e, t, i, s) { const o = t[i], r = n.a.isUndefined(o) || n.a.isNull(o) ? s : o, l = "ellipsis" === r, a = "title" === r, h = !0 === r || "tooltip" === r; let c = a || h || l; return (!e.scrollXLoad && !e.scrollYLoad) || c || (c = !0), c; } function Ys(e, t) { const i = e.style; return [ "", "", '', `${e.sheetName}`, ``, i ? `` : "", "", `${t}`, "", ].join(""); } function qs(e, t, i, s) { const o = e.id, r = e.border, l = e.treeConfig, a = e.treeOpts, h = e.isAllSelected, c = e.isIndeterminate, d = e.headerAlign, u = e.align, p = e.footerAlign, f = e.showOverflow, m = e.showHeaderOverflow, g = e.mergeList, v = t.print, _ = t.isHeader, b = t.isFooter, y = t.isColgroup, x = t.isMerge, w = t.colgroups, S = t.original, E = "check-all", k = [ "vxe-table", `border--${Ms(r)}`, v ? "is--print" : "", _ ? "is--header" : "", ].filter((e) => e), C = [ ``, `${i .map((e) => ``) .join("")}`, ]; if ( (_ && (C.push(""), y && !S ? w.forEach((i) => { C.push( `${i .map((i) => { const s = i.headerAlign || i.align || d || u, o = Zs(e, i, "showHeaderOverflow", m) ? ["col--ellipsis"] : [], r = Vs(t, i); let l = 0, a = 0; n.a.eachTree( [i], (e) => { (e.childNodes && i.childNodes.length) || a++, (l += e.renderWidth); }, { children: "childNodes" } ); const c = l - a; return ( s && o.push(`col--${s}`), "checkbox" === i.type ? `` : `` ); }) .join("")}` ); }) : C.push( `${i .map((i) => { const s = i.headerAlign || i.align || d || u, n = Zs(e, i, "showHeaderOverflow", m) ? ["col--ellipsis"] : [], o = Vs(t, i); return ( s && n.push(`col--${s}`), "checkbox" === i.type ? `` : `` ); }) .join("")}` ), C.push("")), s.length && (C.push(""), l ? s.forEach((t) => { C.push( "" + i .map((i) => { const s = i.align || u, n = Zs(e, i, "showOverflow", f) ? ["col--ellipsis"] : [], r = t[i.id]; if ((s && n.push(`col--${s}`), i.treeNode)) { let e = ""; return ( t._hasChild && (e = ``), n.push("vxe-table--tree-node"), "radio" === i.type ? `` : "checkbox" === i.type ? `` : `` ); } return "radio" === i.type ? `` : "checkbox" === i.type ? `` : ``; }) .join("") + "" ); }) : s.forEach((t) => { C.push( "" + i .map((i) => { const s = i.align || u, n = Zs(e, i, "showOverflow", f) ? ["col--ellipsis"] : [], r = t[i.id]; let l = 1, a = 1; if (x && g.length) { const s = e.getVTRowIndex(t._row), n = e.getVTColumnIndex(i), o = at(g, s, n); if (o) { const e = o.rowspan, t = o.colspan; if (!e || !t) return ""; e > 1 && (l = e), t > 1 && (a = t); } } return ( s && n.push(`col--${s}`), "radio" === i.type ? `` : "checkbox" === i.type ? `` : `` ); }) .join("") + "" ); }), C.push("")), b) ) { const s = e.footerTableData, n = js(t, s); n.length && (C.push(""), n.forEach((s) => { C.push( `${i .map((i) => { const n = i.footerAlign || i.align || p || u, o = Zs(e, i, "showOverflow", f) ? ["col--ellipsis"] : [], r = zs(e, t, s, i); return ( n && o.push(`col--${n}`), `` ); }) .join("")}` ); }), C.push("")); } const T = !h && c ? `
${r}
${ws(r, !0)}
${o}
${ws(o, !0)}
${e}
${ t._radioLabel }
${e}
${ t._checkboxLabel }
${e}
${r}
${ t._radioLabel }
${ t._checkboxLabel }
${ws(r, !0)}
${ t._radioLabel }
${ t._checkboxLabel }
${ws(r, !0)}
${ws(r, !0)}