UNPKG

vue-multi-split-player

Version:
570 lines 162 kB
var Ct = (a, e) => (e = Symbol[a]) ? e : Symbol.for("Symbol." + a); var f = (a, e, i) => new Promise((t, l) => { var n = (u) => { try { d(i.next(u)); } catch (c) { l(c); } }, s = (u) => { try { d(i.throw(u)); } catch (c) { l(c); } }, d = (u) => u.done ? t(u.value) : Promise.resolve(u.value).then(n, s); d((i = i.apply(a, e)).next()); }), L = function(a, e) { this[0] = a, this[1] = e; }, W = (a, e, i) => { var t = (s, d, u, c) => { try { var m = i[s](d), I = (d = m.value) instanceof L, C = m.done; Promise.resolve(I ? d[0] : d).then((y) => I ? t(s === "return" ? s : "next", d[1] ? { done: y.done, value: y.value } : y, u, c) : u({ value: y, done: C })).catch((y) => t("throw", y, u, c)); } catch (y) { c(y); } }, l = (s) => n[s] = (d) => new Promise((u, c) => t(s, d, u, c)), n = {}; return i = i.apply(a, e), n[Ct("asyncIterator")] = () => n, l("next"), l("throw"), l("return"), n; }; import { ref as g, inject as ft, computed as vt, onMounted as It, onBeforeUnmount as wt, watch as he, nextTick as Bt } from "vue"; import { Notification as Ye } from "element-ui"; function Qt(a) { var e = /^1[3,5,8,2,4,6,7,9]\d{9}$/; return !!e.test(a); } function Dt() { let a = navigator.userAgent; return ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod", "Mobile"].filter((i) => a.indexOf(i) !== -1).length; } function ot() { return /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor); } function Mt(a) { let e = new RegExp("[?&]" + a + "=([^&#]*)").exec(window.location.href); return e ? e[1] : ""; } function kt(a) { var e = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/; return e.test(a); } function bt(a) { var e = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/; return e.test(a); } Date.prototype.format = function(a) { var e = { "M+": this.getMonth() + 1, //月份 "d+": this.getDate(), //日 "h+": this.getHours(), //小时 "m+": this.getMinutes(), //分 "s+": this.getSeconds(), //秒 "q+": Math.floor((this.getMonth() + 3) / 3), //季度 S: this.getMilliseconds() //毫秒 }; /(y+)/.test(a) && (a = a.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length))); for (var i in e) new RegExp("(" + i + ")").test(a) && (a = a.replace(RegExp.$1, RegExp.$1.length == 1 ? e[i] : ("00" + e[i]).substr(("" + e[i]).length))); return a; }; function Rt(a, e) { return new Date(a).format(e); } function St(a = 0, e = 0) { let i = 86400, t = 60 * 60, l = 60, n = 0; if (i = parseInt(a / i), t = parseInt(a / t % 24), l = parseInt(a / l % 60), n = parseInt(a % 60), t < 10 && (t = "0" + t), l < 10 && (l = "0" + l), n < 10 && (n = "0" + n), e === 0) return i === 0 ? i = "" : i = `${i}-`, t === "00" ? t = "" : t = `${t}:`, `${i}${t}${l || "00"}:${n || "00"}`; if (e === 1) return `${t || "00"}:${l || "00"}:${n || "00"}`; if (e === 2) return `${i || "00"}-${t || "00"}:${l || "00"}`; } function ct(a, e = 500) { let i = Array.prototype.slice.call(arguments, 2); a.timer || (a.timer = setTimeout(() => { a.apply(this, i), a.timer = ""; }, e)); } function J(a, e = 500) { return (...i) => { clearTimeout(a.timer), a.timer = setTimeout(() => { a.apply(this, i); }, e); }; } function xt(a, e = 1e3) { let i = Array.prototype.slice.call(arguments, 2); a.looked || (a.apply(this, i), a.looked = !0), !a.timer && (a.timer = setTimeout(() => { a.looked = !1, a.timer = ""; }, e)); } function Ee(a, e = 500) { let i = Array.prototype.slice.call(arguments, 2); clearTimeout(a.timer), a.timer = setTimeout(() => { a.apply(this, i); }, e); } function Ot(a, e = 1e3) { let i = Array.prototype.slice.call(arguments, 2); a.looked || (a.apply(this, i), a.looked = !0), clearTimeout(a.timer), a.timer = setTimeout(() => { a.looked = !1; }, e); } function ut(a) { return a.endsWith(".m3u8"); } function Ce(a) { switch (Object.prototype.toString.call(a)) { case "[object Object]": return "object"; case "[object Array]": return "array"; case "[object String]": return "string"; case "[object Number]": return "number"; case "[object Boolean]": return "boolean"; case "[object Symbol]": return "symbol"; default: return typeof a; } } function Lt(a) { let e = Array.prototype.slice.call(arguments, 1); if (a.clicked) { a.call(this, ...e), a.clicked = !1; return; } a.clicked = !0, setTimeout(() => { a.clicked = !1; }, 500); } function dt(a) { let e = Object.freeze({ "-1": "老师", 0: "老师", 1: "老师全景", 2: "学生", 3: "学生全景", 4: "板书", 5: "双视图", 6: "跟踪", 7: "老师左辅助", 8: "老师右辅助", 50: "板书辅助" }), i = a.split(","); return new Set(i.map((t) => e[t])); } const ht = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, dateResult: Rt, dblclick: Lt, debounce: ct, debounceBind: J, debounceExecute: xt, filterTime: St, filterVoiceConfigId: dt, getParam: Mt, isChrome: ot, isEmail: kt, isM3u8: ut, isMobile: Dt, isPhone: Qt, isValidIP: bt, luck: Ot, throttle: Ee, typeDetection: Ce }, Symbol.toStringTag, { value: "Module" })); function fe(a, e, i, t, l, n, s, d) { var u = typeof a == "function" ? a.options : a; return e && (u.render = e, u.staticRenderFns = i, u._compiled = !0), n && (u._scopeId = "data-v-" + n), { exports: a, options: u }; } const Gt = { model: { prop: "current", event: "change" }, props: { // 播放进度 current: { type: Number, default: 0 }, // 播放时长 duration: { type: Number, default: 0 }, // 当前的最后分屏路径URL httpPath: { type: String, default: "" }, // mark点列表 mark: { type: Array, default: (a) => [] } }, data() { return { common: ht, disabled: !1, startX: 0, startPosition: 0, distance: 0, // 可滑行的距离 is_show_pic: !0, // 是否展示缩略图 // 缩略图信息 thumbnail: { url: "", // 图片地址 time: "" // 时间 }, show_block: !1, // 是否展示移动块 loading: !1, note_item: {}, // 当前查看的知识点 is_draging: !1 // 是否拖动过程中 }; }, computed: { lineStyle() { if (this.distance && this.current && this.duration) return { width: this.current * (this.distance / this.duration) + "px" }; }, slideStyle() { if (this.distance && this.current && this.duration) return { left: this.current * (this.distance / this.duration) + "px" }; } }, mounted() { this._getDistance(); }, methods: { /** * @description 点击line修改时间 */ handleClick(a) { if (this.is_draging || !a.target.id) return; let e = a.target.getBoundingClientRect().left, i = (a.pageX - e) * (this.duration / this.distance); this.updateCurrentTime(i); }, /** * @description 鼠标/触摸板开始 */ onButtonDown(a) { this.disabled || (a.preventDefault(), this.onDragStart(a), window.addEventListener("mousemove", this.onDragging), window.addEventListener("touchmove", this.onDragging), window.addEventListener("mouseup", this.onDragEnd), window.addEventListener("touchend", this.onDragEnd), window.addEventListener("contextmenu", this.onDragEnd)); }, /** * @description 拖拽开始 */ onDragStart(a) { this.is_draging = !0, a.type === "touchstart" && (a.pageY = a.touches[0].pageY, a.pageX = a.touches[0].pageX), this.startPosition = parseFloat(this.current), this.startX = a.pageX; }, /** * @description 拖拽过程中 */ onDragging(a) { if (!this.is_draging) return; a.type === "touchmove" && (a.pageY = a.touches[0].pageY, a.pageX = a.touches[0].pageX); let e = 0; e = (a.pageX - this.startX) * (this.duration / this.distance); let i = this.startPosition + e; this.updateCurrentTime(i); }, /** * @description 拖拽结束 */ onDragEnd() { this.is_draging && (window.removeEventListener("mousemove", this.onDragging), window.removeEventListener("touchmove", this.onDragging), window.removeEventListener("mouseup", this.onDragEnd), window.removeEventListener("touchend", this.onDragEnd), window.removeEventListener("contextmenu", this.onDragEnd), setTimeout((a) => { this.is_draging = !1; }, 50)); }, updateCurrentTime(a) { a < 0 && (a = 0), a >= this.duration && (a = this.duration), window.requestIdleCallback ? window.requestIdleCallback((e) => this.$emit("update", a)) : ct((e) => this.$emit("update", a), 100); }, /** * @description 鼠标移入,显示移动块 */ handleMouseEnter(a) { }, /** * @description 鼠标移动,修改移动块 */ onDraggingThumbnail(a) { if (!this.show_block) return; let e = document.getElementById("videoPlayer"), i = document.getElementById("indicator"), t = document.getElementById("thumbnail"), l = a.clientX - this._getLeft(e); i.style.transform = `translateX(${l}px)`, t.style.transform = `translateX(${l - 180 / 2 + 4}px)`; let n = l * (this.duration / this.distance); this.$set(this.thumbnail, "time", n.toFixed(0)), this.mark.length && this._getNoteItem(n), !this.loading && (this.loading = !0); }, /** * @description 鼠标移出,隐藏移动块 */ handleMouseLeave() { this.show_block = !1; }, /** * @description 获取当前所在区域的知识点 * @param {Number} time: 当前所在时间点 */ _getNoteItem(a) { let e = this.mark.findIndex((i) => a < i.startSecond); this.mark[e - 1] ? this.note_item = this.mark[e - 1] : this.note_item = {}; }, /** * @description 点击知识点 * @param {Object} item: 当前选中项 * @param {Number} index: 选中项下标index */ handle_click_note(a, e) { this.$emit("update", a.startSecond); }, // 获取知识点的位置信息 getNotePosition(a) { if (this.distance && this.duration) return a * (this.distance / this.duration); }, /** * @description 获取元素距离页面左边的间距 * @param {Object} el: 要获取的元素 */ _getLeft(a) { let e = a.offsetLeft; return a.offsetParent !== null && (e += this._getLeft(a.offsetParent)), e; }, /** * @description 获取滑行区域距离 */ _getDistance() { this.$nextTick((a) => { this.distance = document.getElementById("track").offsetWidth; }); } } }; var zt = function() { var e = this, i = e._self._c; return i("div", { staticClass: "slide", attrs: { id: "videoPlayer" }, on: { mousedown: function(t) { return t.preventDefault(), e.handleClick(t); }, touchstart: function(t) { return t.preventDefault(), e.handleClick(t); }, mouseenter: e.handleMouseEnter, mousemove: e.onDraggingThumbnail, mouseleave: e.handleMouseLeave } }, [i("div", { staticClass: "custom_cursor", style: e.slideStyle, attrs: { id: "box", tabindex: "0" }, on: { mousedown: e.onButtonDown, touchstart: e.onButtonDown } }), i("div", { style: e.lineStyle, attrs: { id: "track_line" } }), i("div", { attrs: { id: "track" } }), e.show_block ? i("div", { attrs: { id: "indicator" } }, [i("i", { staticClass: "el-icon-caret-bottom" }), i("i", { staticClass: "el-icon-caret-top" })]) : e._e(), e.show_block ? i("div", { staticClass: "thumbnail", attrs: { id: "thumbnail" } }, [i("div", { staticClass: "img_wrap" }, [i("img", { attrs: { src: e.thumbnail.url, alt: "" } })]), i("div", { staticClass: "text" }, [e._v(e._s(e.note_item.content))]), i("div", { staticClass: "time" }, [e._v(e._s(e.common.filterTime(+e.thumbnail.time * 1e3, 1)))])]) : e._e(), e._l(e.mark, function(t, l) { return i("div", { staticClass: "noteItem", style: { left: e.getNotePosition(t.startSecond) + "px" }, on: { click: function(n) { return e.handle_click_note(t, l); } } }, [i("div", { staticClass: "note_detail" }, [i("div", { staticClass: "note_wrap" }, [i("div", { staticClass: "img_wrap" }, [i("img", { attrs: { src: t.imgUrl, alt: "" } })]), i("div", { staticClass: "note_content" }, [e._v(e._s(t.content))]), e._m(0, !0)]), i("div", { staticClass: "note_time _flex_center" }, [e._v(e._s(e.common.filterTime(t.startSecond, 1)))])])]); })], 2); }, Kt = [function() { var a = this, e = a._self._c; return e("div", { staticClass: "icon _flex_center" }, [e("i", { staticClass: "el-icon-caret-bottom" })]); }], Ht = /* @__PURE__ */ fe( Gt, zt, Kt, !1, null, "753614c7" ); const qt = Ht.exports, Pt = { model: { prop: "value", event: "input" }, props: { // 全屏状态 value: { type: Boolean, default: !1 }, // 全屏的类型 0 logo全屏 1 自定义slot全屏 type: { type: Number, default: 0 } }, date() { return { tip: "" // 提示信息 }; }, methods: { // 全屏 handleFullscreen(a) { let e = a || document.body; this.value ? document.exitFullscreen ? document.exitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitCancelFullScreen ? document.webkitCancelFullScreen() : document.msExitFullscreen && document.msExitFullscreen() : e.requestFullscreen ? e.requestFullscreen() : e.mozRequestFullScreen ? e.mozRequestFullScreen() : e.webkitRequestFullScreen ? e.webkitRequestFullScreen() : e.msRequestFullscreen && e.msRequestFullscreen(); }, // change handleChange(a) { this.handleFullscreen(a); } }, mounted() { let a = document.fullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || document.fullScreen || document.mozFullScreen || document.webkitIsFullScreen; a = !!a, document.addEventListener("fullscreenchange", () => { this.$emit("input", !this.value), this.$emit("on-change", !this.value); }), document.addEventListener("mozfullscreenchange", () => { this.$emit("input", !this.value), this.$emit("on-change", !this.value); }), document.addEventListener("webkitfullscreenchange", () => { this.$emit("input", !this.value), this.$emit("on-change", !this.value); }), document.addEventListener("msfullscreenchange", () => { this.$emit("input", !this.value), this.$emit("on-change", !this.value); }), this.$emit("input", a); } }; var Ft = function() { var e = this, i = e._self._c; return i("div", [e.type ? e._t("default", function() { return [e._v("点击全屏")]; }) : i("div", { staticClass: "logo _flex_center" })], 2); }, Tt = [], Nt = /* @__PURE__ */ fe( Pt, Ft, Tt, !1, null, "0a15f553" ); const jt = Nt.exports; class Jt { constructor(e) { this.playId = e.id, this.content = (e.content || "vue-multi-split-player").toString(), this.timer = null, this.waterMarkerDom = null, this.observer_c = null, this.observer_p = null, this.create(); } create() { return f(this, null, function* () { this.getElement() && this.getElement().remove(), yield this.wait(500 + Math.random() * 200); let e = this.content, i = document.getElementById(this.playId); if (!i) return; this.width = i.offsetWidth, this.height = i.offsetHeight; let t = document.createElement("div"); t.style.display = "inline-block", t.style.position = "absolute", t.id = `water_marker_${this.playId}`, t.style.top = "40px", t.style.left = "40px", t.style.lineHeight = "20px", t.style.color = "#fff", t.style.fontSize = "14px", t.style.textAlign = "left", t.style.pointerEvents = "none", t.style.filter = "opacity(0.3)", t.style.textShadow = `1px 1px 0px rgba(0, 0, 0, 0.2), 1px 2px 0px rgba(0, 0, 0, 0.2), 1px 3px 0px rgba(0, 0, 0, 0.2)`, t.style.mixBlendMode = "lighten", t.style.zIndex = 99, t.innerHTML = e, this.waterMarkerDom = t, i == null || i.appendChild(t), this.create_animate1(t), yield this.wait(1e3), this.observe_c(t), this.observe_p(i); }); } create_animate1(e) { let i = 2, t = this.width - e.offsetWidth - 40, l = this.height - e.offsetHeight - 40, n = (Math.random() * t).toFixed(0), s = (Math.random() * l).toFixed(0), d = { transform: `translate(calc(${n}px),calc(${s}px))` }; e.animate(d, { duration: 0, fill: "forwards", easing: "cubic-bezier(.31,.01,1,1.27)", delay: 0 }), this.timer = setInterval(() => { i--, i === 0 && (i = 3, clearInterval(this.timer), this.create_animate1(e)); }, 1e3); } create_animate(e) { e.animate([ { transform: "translate(0 ,0) rotateZ(-45deg)" }, // 起始位置 { transform: `translate(calc(${this.width - 40}px - 100%), 0) rotateZ(45deg)` }, // 右侧 { transform: `translate(calc(${this.width - 40}px - 100%), calc(${this.height - 140}px - 100%)) rotateZ(45deg)` }, // 底部 { transform: `translate(0, calc(${this.height - 140}px - 100%)) rotateZ(-45deg)` }, // 左侧 { transform: "translate(0, 0) rotateZ(-45deg)" } // 返回起始位置 ], { duration: 6e3, iterations: 1 / 0, // 无限循环 easing: "linear", delay: 0 }); } observe_c(e) { let i = { attributes: !0, characterData: !0, childList: !0, subtree: !0 }; this.observer_c = new MutationObserver((t, l) => { for (let n of t) switch (n.type) { case "attributes": case "childList": case "characterData": Ye({ title: "提示", message: "请勿篡改水印哦,尊重版权!", type: "warning", showClose: !0 }), this.destroy(this.getElement()), this.create(); break; } }), this.observer_c.observe(e, i); } observe_p(e) { let i = { attributes: !0, characterData: !0, childList: !0, subtree: !0 }; this.observer_p = new MutationObserver((t, l) => { for (let n of t) switch (n.type) { case "childList": let s = Array.from(n.removedNodes); s.length && s[0].id === `water_marker_${this.playId}` && (Ye({ title: "提示", message: "请勿删除水印哦,尊重版权!", type: "warning", showClose: !0 }), this.destroy(this.getElement()), this.create()); break; } }), this.observer_p.observe(e, i); } destroy(e = this.getElement()) { var i, t; clearInterval(this.timer), (i = this.observer_c) == null || i.disconnect(), (t = this.observer_p) == null || t.disconnect(), e && e.remove(); } getElement() { return this.waterMarkerDom || document.getElementById(`water_marker_${this.playId}`); } wait(e) { return f(this, null, function* () { return new Promise((i) => setTimeout(i, e)); }); } } const te = "