Files
medicine_app/static/aliplayercomponents-1.0.9.min.js
@fawn-nine 9f0845f97d 未修复
2024-08-13 17:02:53 +08:00

5932 lines
247 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = 6);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
// css base code, injected by the css-loader
module.exports = function () {
var list = [];
// return the list of modules as css string
list.toString = function toString() {
var result = [];
for (var i = 0; i < this.length; i++) {
var item = this[i];
if (item[2]) {
result.push("@media " + item[2] + "{" + item[1] + "}");
} else {
result.push(item[1]);
}
}
return result.join("");
};
// import a list of modules into the list
list.i = function (modules, mediaQuery) {
if (typeof modules === "string") modules = [[null, modules, ""]];
var alreadyImportedModules = {};
for (var i = 0; i < this.length; i++) {
var id = this[i][0];
if (typeof id === "number") alreadyImportedModules[id] = true;
}
for (i = 0; i < modules.length; i++) {
var item = modules[i];
// skip already imported module
// this implementation is not 100% perfect for weird media query combinations
// when a module is imported multiple times with different media queries.
// I hope this will never occur (Hey this way we have smaller bundles)
if (typeof item[0] !== "number" || !alreadyImportedModules[item[0]]) {
if (mediaQuery && !item[2]) {
item[2] = mediaQuery;
} else if (mediaQuery) {
item[2] = "(" + item[2] + ") and (" + mediaQuery + ")";
}
list.push(item);
}
}
};
return list;
};
/***/ }),
/* 1 */
/***/ (function(module, exports) {
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
var stylesInDom = {},
memoize = function(fn) {
var memo;
return function () {
if (typeof memo === "undefined") memo = fn.apply(this, arguments);
return memo;
};
},
isOldIE = memoize(function() {
return /msie [6-9]\b/.test(self.navigator.userAgent.toLowerCase());
}),
getHeadElement = memoize(function () {
return document.head || document.getElementsByTagName("head")[0];
}),
singletonElement = null,
singletonCounter = 0,
styleElementsInsertedAtTop = [];
module.exports = function(list, options) {
if(typeof DEBUG !== "undefined" && DEBUG) {
if(typeof document !== "object") throw new Error("The style-loader cannot be used in a non-browser environment");
}
options = options || {};
// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
// tags it will allow on a page
if (typeof options.singleton === "undefined") options.singleton = isOldIE();
// By default, add <style> tags to the bottom of <head>.
if (typeof options.insertAt === "undefined") options.insertAt = "bottom";
var styles = listToStyles(list);
addStylesToDom(styles, options);
return function update(newList) {
var mayRemove = [];
for(var i = 0; i < styles.length; i++) {
var item = styles[i];
var domStyle = stylesInDom[item.id];
domStyle.refs--;
mayRemove.push(domStyle);
}
if(newList) {
var newStyles = listToStyles(newList);
addStylesToDom(newStyles, options);
}
for(var i = 0; i < mayRemove.length; i++) {
var domStyle = mayRemove[i];
if(domStyle.refs === 0) {
for(var j = 0; j < domStyle.parts.length; j++)
domStyle.parts[j]();
delete stylesInDom[domStyle.id];
}
}
};
}
function addStylesToDom(styles, options) {
for(var i = 0; i < styles.length; i++) {
var item = styles[i];
var domStyle = stylesInDom[item.id];
if(domStyle) {
domStyle.refs++;
for(var j = 0; j < domStyle.parts.length; j++) {
domStyle.parts[j](item.parts[j]);
}
for(; j < item.parts.length; j++) {
domStyle.parts.push(addStyle(item.parts[j], options));
}
} else {
var parts = [];
for(var j = 0; j < item.parts.length; j++) {
parts.push(addStyle(item.parts[j], options));
}
stylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};
}
}
}
function listToStyles(list) {
var styles = [];
var newStyles = {};
for(var i = 0; i < list.length; i++) {
var item = list[i];
var id = item[0];
var css = item[1];
var media = item[2];
var sourceMap = item[3];
var part = {css: css, media: media, sourceMap: sourceMap};
if(!newStyles[id])
styles.push(newStyles[id] = {id: id, parts: [part]});
else
newStyles[id].parts.push(part);
}
return styles;
}
function insertStyleElement(options, styleElement) {
var head = getHeadElement();
var lastStyleElementInsertedAtTop = styleElementsInsertedAtTop[styleElementsInsertedAtTop.length - 1];
if (options.insertAt === "top") {
if(!lastStyleElementInsertedAtTop) {
head.insertBefore(styleElement, head.firstChild);
} else if(lastStyleElementInsertedAtTop.nextSibling) {
head.insertBefore(styleElement, lastStyleElementInsertedAtTop.nextSibling);
} else {
head.appendChild(styleElement);
}
styleElementsInsertedAtTop.push(styleElement);
} else if (options.insertAt === "bottom") {
head.appendChild(styleElement);
} else {
throw new Error("Invalid value for parameter 'insertAt'. Must be 'top' or 'bottom'.");
}
}
function removeStyleElement(styleElement) {
styleElement.parentNode.removeChild(styleElement);
var idx = styleElementsInsertedAtTop.indexOf(styleElement);
if(idx >= 0) {
styleElementsInsertedAtTop.splice(idx, 1);
}
}
function createStyleElement(options) {
var styleElement = document.createElement("style");
styleElement.type = "text/css";
insertStyleElement(options, styleElement);
return styleElement;
}
function createLinkElement(options) {
var linkElement = document.createElement("link");
linkElement.rel = "stylesheet";
insertStyleElement(options, linkElement);
return linkElement;
}
function addStyle(obj, options) {
var styleElement, update, remove;
if (options.singleton) {
var styleIndex = singletonCounter++;
styleElement = singletonElement || (singletonElement = createStyleElement(options));
update = applyToSingletonTag.bind(null, styleElement, styleIndex, false);
remove = applyToSingletonTag.bind(null, styleElement, styleIndex, true);
} else if(obj.sourceMap &&
typeof URL === "function" &&
typeof URL.createObjectURL === "function" &&
typeof URL.revokeObjectURL === "function" &&
typeof Blob === "function" &&
typeof btoa === "function") {
styleElement = createLinkElement(options);
update = updateLink.bind(null, styleElement);
remove = function() {
removeStyleElement(styleElement);
if(styleElement.href)
URL.revokeObjectURL(styleElement.href);
};
} else {
styleElement = createStyleElement(options);
update = applyToTag.bind(null, styleElement);
remove = function() {
removeStyleElement(styleElement);
};
}
update(obj);
return function updateStyle(newObj) {
if(newObj) {
if(newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap)
return;
update(obj = newObj);
} else {
remove();
}
};
}
var replaceText = (function () {
var textStore = [];
return function (index, replacement) {
textStore[index] = replacement;
return textStore.filter(Boolean).join('\n');
};
})();
function applyToSingletonTag(styleElement, index, remove, obj) {
var css = remove ? "" : obj.css;
if (styleElement.styleSheet) {
styleElement.styleSheet.cssText = replaceText(index, css);
} else {
var cssNode = document.createTextNode(css);
var childNodes = styleElement.childNodes;
if (childNodes[index]) styleElement.removeChild(childNodes[index]);
if (childNodes.length) {
styleElement.insertBefore(cssNode, childNodes[index]);
} else {
styleElement.appendChild(cssNode);
}
}
}
function applyToTag(styleElement, obj) {
var css = obj.css;
var media = obj.media;
if(media) {
styleElement.setAttribute("media", media)
}
if(styleElement.styleSheet) {
styleElement.styleSheet.cssText = css;
} else {
while(styleElement.firstChild) {
styleElement.removeChild(styleElement.firstChild);
}
styleElement.appendChild(document.createTextNode(css));
}
}
function updateLink(linkElement, obj) {
var css = obj.css;
var sourceMap = obj.sourceMap;
if(sourceMap) {
// http://stackoverflow.com/a/26603875
css += "\n/*# sourceMappingURL=data:application/json;base64," + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + " */";
}
var blob = new Blob([css], { type: "text/css" });
var oldSrc = linkElement.href;
linkElement.href = URL.createObjectURL(blob);
if(oldSrc)
URL.revokeObjectURL(oldSrc);
}
/***/ }),
/* 2 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.parseDom = parseDom;
function parseDom(html) {
var ele = document.createElement('div');
ele.innerHTML = html;
return ele.childNodes[0];
}
module.exports.cookieSet = function (cname, cvalue, exdays) {
var d = new Date();
d.setTime(d.getTime() + exdays * 24 * 60 * 60 * 1000);
var expires = 'expires=' + d.toGMTString();
document.cookie = cname + '=' + escape(cvalue) + '; ' + expires;
};
/***/ }),
/* 3 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _typeof2 = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
var _typeof = typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol" ? function (obj) {
return typeof obj === "undefined" ? "undefined" : _typeof2(obj);
} : function (obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj === "undefined" ? "undefined" : _typeof2(obj);
};
// Save the previous value of the device variable.
var previousDevice = window.device;
var device = {};
var changeOrientationList = [];
// Add device as a global object.
window.device = device;
// The <html> element.
var documentElement = window.document.documentElement;
// The client user agent string.
// Lowercase, so we can use the more efficient indexOf(), instead of Regex
var userAgent = window.navigator.userAgent.toLowerCase();
// Detectable television devices.
var television = ['googletv', 'viera', 'smarttv', 'internet.tv', 'netcast', 'nettv', 'appletv', 'boxee', 'kylo', 'roku', 'dlnadoc', 'roku', 'pov_tv', 'hbbtv', 'ce-html'];
// Main functions
// --------------
device.macos = function () {
return find('mac');
};
device.ios = function () {
return device.iphone() || device.ipod() || device.ipad();
};
device.iphone = function () {
return !device.windows() && find('iphone');
};
device.ipod = function () {
return find('ipod');
};
device.ipad = function () {
return find('ipad');
};
device.android = function () {
return !device.windows() && find('android');
};
device.androidPhone = function () {
return device.android() && find('mobile');
};
device.androidTablet = function () {
return device.android() && !find('mobile');
};
device.blackberry = function () {
return find('blackberry') || find('bb10') || find('rim');
};
device.blackberryPhone = function () {
return device.blackberry() && !find('tablet');
};
device.blackberryTablet = function () {
return device.blackberry() && find('tablet');
};
device.windows = function () {
return find('windows');
};
device.windowsPhone = function () {
return device.windows() && find('phone');
};
device.windowsTablet = function () {
return device.windows() && find('touch') && !device.windowsPhone();
};
device.fxos = function () {
return (find('(mobile') || find('(tablet')) && find(' rv:');
};
device.fxosPhone = function () {
return device.fxos() && find('mobile');
};
device.fxosTablet = function () {
return device.fxos() && find('tablet');
};
device.meego = function () {
return find('meego');
};
device.cordova = function () {
return window.cordova && location.protocol === 'file:';
};
device.nodeWebkit = function () {
return _typeof(window.process) === 'object';
};
device.mobile = function () {
return device.androidPhone() || device.iphone() || device.ipod() || device.windowsPhone() || device.blackberryPhone() || device.fxosPhone() || device.meego();
};
device.tablet = function () {
return device.ipad() || device.androidTablet() || device.blackberryTablet() || device.windowsTablet() || device.fxosTablet();
};
device.desktop = function () {
return !device.tablet() && !device.mobile();
};
device.television = function () {
var i = 0;
while (i < television.length) {
if (find(television[i])) {
return true;
}
i++;
}
return false;
};
device.portrait = function () {
if (screen.orientation && Object.prototype.hasOwnProperty.call(window, 'onorientationchange')) {
return screen.orientation.type.includes('portrait');
}
return window.innerHeight / window.innerWidth > 1;
};
device.landscape = function () {
if (screen.orientation && Object.prototype.hasOwnProperty.call(window, 'onorientationchange')) {
return screen.orientation.type.includes('landscape');
}
return window.innerHeight / window.innerWidth < 1;
};
// Public Utility Functions
// ------------------------
// Run device.js in noConflict mode,
// returning the device variable to its previous owner.
device.noConflict = function () {
window.device = previousDevice;
return this;
};
// Private Utility Functions
// -------------------------
// Simple UA string search
function find(needle) {
return userAgent.indexOf(needle) !== -1;
}
// Check if documentElement already has a given class.
function hasClass(className) {
return documentElement.className.match(new RegExp(className, 'i'));
}
// Add one or more CSS classes to the <html> element.
function addClass(className) {
var currentClassNames = null;
if (!hasClass(className)) {
currentClassNames = documentElement.className.replace(/^\s+|\s+$/g, '');
documentElement.className = currentClassNames + ' ' + className;
}
}
// Remove single CSS class from the <html> element.
function removeClass(className) {
if (hasClass(className)) {
documentElement.className = documentElement.className.replace(' ' + className, '');
}
}
// HTML Element Handling
// ---------------------
// Insert the appropriate CSS class based on the _user_agent.
if (device.ios()) {
if (device.ipad()) {
addClass('ios ipad tablet');
} else if (device.iphone()) {
addClass('ios iphone mobile');
} else if (device.ipod()) {
addClass('ios ipod mobile');
}
} else if (device.macos()) {
addClass('macos desktop');
} else if (device.android()) {
if (device.androidTablet()) {
addClass('android tablet');
} else {
addClass('android mobile');
}
} else if (device.blackberry()) {
if (device.blackberryTablet()) {
addClass('blackberry tablet');
} else {
addClass('blackberry mobile');
}
} else if (device.windows()) {
if (device.windowsTablet()) {
addClass('windows tablet');
} else if (device.windowsPhone()) {
addClass('windows mobile');
} else {
addClass('windows desktop');
}
} else if (device.fxos()) {
if (device.fxosTablet()) {
addClass('fxos tablet');
} else {
addClass('fxos mobile');
}
} else if (device.meego()) {
addClass('meego mobile');
} else if (device.nodeWebkit()) {
addClass('node-webkit');
} else if (device.television()) {
addClass('television');
} else if (device.desktop()) {
addClass('desktop');
}
if (device.cordova()) {
addClass('cordova');
}
// Orientation Handling
// --------------------
// Handle device orientation changes.
function handleOrientation() {
if (device.landscape()) {
removeClass('portrait');
addClass('landscape');
walkOnChangeOrientationList('landscape');
} else {
removeClass('landscape');
addClass('portrait');
walkOnChangeOrientationList('portrait');
}
setOrientationCache();
}
function walkOnChangeOrientationList(newOrientation) {
for (var index in changeOrientationList) {
changeOrientationList[index](newOrientation);
}
}
device.onChangeOrientation = function (cb) {
if (typeof cb == 'function') {
changeOrientationList.push(cb);
}
};
// Detect whether device supports orientationchange event,
// otherwise fall back to the resize event.
var orientationEvent = 'resize';
if (Object.prototype.hasOwnProperty.call(window, 'onorientationchange')) {
orientationEvent = 'orientationchange';
}
// Listen for changes in orientation.
if (window.addEventListener) {
window.addEventListener(orientationEvent, handleOrientation, false);
} else if (window.attachEvent) {
window.attachEvent(orientationEvent, handleOrientation);
} else {
window[orientationEvent] = handleOrientation;
}
handleOrientation();
// Public functions to get the current value of type, os, or orientation
// ---------------------------------------------------------------------
function findMatch(arr) {
for (var i = 0; i < arr.length; i++) {
if (device[arr[i]]()) {
return arr[i];
}
}
return 'unknown';
}
device.type = findMatch(['mobile', 'tablet', 'desktop']);
device.os = findMatch(['ios', 'iphone', 'ipad', 'ipod', 'android', 'blackberry', 'windows', 'fxos', 'meego', 'television']);
function setOrientationCache() {
device.orientation = findMatch(['portrait', 'landscape']);
}
setOrientationCache();
exports.default = device;
/***/ }),
/* 4 */
/***/ (function(module, exports) {
module.exports = "data:application/vnd.ms-fontobject;base64,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"
/***/ }),
/* 5 */
/***/ (function(module, exports) {
module.exports = "data:application/vnd.ms-fontobject;base64,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"
/***/ }),
/* 6 */
/***/ (function(module, exports, __webpack_require__) {
__webpack_require__(7);
__webpack_require__(17);
__webpack_require__(22);
__webpack_require__(28);
__webpack_require__(34);
__webpack_require__(39);
__webpack_require__(44);
__webpack_require__(50);
__webpack_require__(55);
__webpack_require__(63);
__webpack_require__(69);
__webpack_require__(74);
__webpack_require__(79);
__webpack_require__(84);
__webpack_require__(90);
__webpack_require__(96);
__webpack_require__(101);
module.exports = __webpack_require__(107);
/***/ }),
/* 7 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(8);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.AliplayerDanmuComponent = _index2.default;
/***/ }),
/* 8 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(9);
var _index2 = _interopRequireDefault(_index);
var _danmuControl = __webpack_require__(10);
var _danmuControl2 = _interopRequireDefault(_danmuControl);
var _danmuInput = __webpack_require__(11);
var _danmuInput2 = _interopRequireDefault(_danmuInput);
__webpack_require__(12);
var _CommentCoreLibrary = __webpack_require__(14);
__webpack_require__(15);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 弹幕组件
*/
var AliplayerDanmuComponent = function () {
/**
* @constructor 弹幕组件构造函数
* @param {Array danmuList 弹幕数组, 参考 CommentCoreLibrary 文档 https://github.com/jabbany/CommentCoreLibrary/}
* @param {id 或者 Element, sendEl, 发送弹幕的输入框, 默认为 null}
*/
function AliplayerDanmuComponent(danmukuList) {
var sendEl = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'controlbar';
_classCallCheck(this, AliplayerDanmuComponent);
this.sendEl = sendEl;
this.danmukuList = danmukuList;
this.html = (0, _utils.parseDom)(_index2.default);
this.danmuControlHtml = (0, _utils.parseDom)(_danmuControl2.default);
this.sendEl = sendEl;
this.danmuInput = sendEl === null ? null : (0, _utils.parseDom)(_danmuInput2.default);
this.CM = null;
this.userDanmuOpen = true; // 用户打开关闭弹幕的状态, 默认为 true 打开
}
_createClass(AliplayerDanmuComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
console.log(player);
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
if (this.danmuInput !== null) {
this.danmuInput.querySelector('.danmu-input-enter').innerText = this.isEn ? 'Enter' : '发送';
this.danmuInput.querySelector('input').setAttribute('placeholder', this.isEn ? 'Input danmu' : '输入弹幕');
}
this.danmuControlHtml.querySelector('.player-tooltip.close').innerText = this.isEn ? 'Close Bullect' : '关闭弹幕';
this.danmuControlHtml.querySelector('.player-tooltip.open').innerText = this.isEn ? 'Open Bullect' : '打开弹幕';
if (this.sendEl === 'controlbar') {
var danmuInputWrapEle = this.danmuControlHtml.querySelector('.ali-danmu-input-wrap');
danmuInputWrapEle.style.display = 'inline-block';
danmuInputWrapEle.appendChild(this.danmuInput);
} else if (this.sendEl !== null) {
if ((0, _utils.isElement)(this.sendEl)) {
this.sendEl.appendChild(this.danmuInput);
} else if (typeof this.sendEl === 'string') {
var sendEl = document.querySelector(this.sendEl);
if ((0, _utils.isElement)(sendEl)) {
sendEl.appendChild(this.danmuInput);
} else {
throw new Error('sendEl must be an element or selector string');
}
} else {
throw new Error('sendEl must be an element or selector string');
}
}
el.querySelector('.prism-controlbar').appendChild(this.danmuControlHtml);
var videoSiblingElement = el.querySelector('video').nextElementSibling;
if (videoSiblingElement) {
el.insertBefore(this.html, videoSiblingElement);
} else {
el.appendChild(this.html);
}
this.CM = new _CommentCoreLibrary.CommentManager(this.html.querySelector('.danmu')); // 初始化 CommentManager
this.CM.init();
this.CM.load(this.danmukuList);
/* 根据视频播放器的 timeupdate 事件更新弹幕的事件轴 */
el.querySelector('video').ontimeupdate = function () {
if (el.querySelector('video') !== null) {
_this.CM.time(el.querySelector('video').currentTime * 1000);
}
};
var danmuCloseElement = this.danmuControlHtml.querySelector('.icon-danmu-close');
var danmuOpenElement = this.danmuControlHtml.querySelector('.icon-danmu-open');
/* 绑定控制条关闭弹幕处理函数 */
danmuCloseElement.onclick = function () {
_this.userDanmuOpen = false;
danmuCloseElement.style.display = 'none';
danmuOpenElement.style.display = 'inline-block';
_this.CM.clear();
_this.CM.stop();
};
/* 绑定控制条打开弹幕控制条 */
danmuOpenElement.onclick = function () {
danmuOpenElement.style.display = 'none';
danmuCloseElement.style.display = 'inline-block';
_this.userDanmuOpen = true;
_this.CM.start();
};
if (this.danmuInput !== null) {
var danmuInputEle = this.danmuInput.querySelector('.ali-danmu-input input');
var danmuEnter = this.danmuInput.querySelector('.danmu-input-enter');
danmuEnter.onclick = this.sendDanmuHandle.bind(this);
danmuInputEle.onkeydown = function (e) {
if (e.keyCode === 13) {
_this.sendDanmuHandle.call(_this);
}
};
}
}
// 弹幕发送按钮点击事件和弹幕输入框按下 enter 键, 处理事件
}, {
key: 'sendDanmuHandle',
value: function sendDanmuHandle() {
var danmuInputEle = this.danmuInput.querySelector('.ali-danmu-input input');
var danmuText = danmuInputEle.value;
var commentSize = [16, 18, 25, 36, 45];
var commentColor = [0xffffff, 0x0000ff, 0xcc0000, 0xff66ff, 0xffff33];
if (danmuText === '') {
return;
}
this.send({
"mode": 1,
"text": danmuText,
"stime": 1000,
"size": commentSize[this.randomIndex(5)],
"color": commentColor[this.randomIndex(5)]
});
danmuInputEle.value = '';
danmuInputEle.focus();
}
}, {
key: 'randomIndex',
value: function randomIndex(max) {
return Math.floor(Math.random() * max);
}
}, {
key: 'play',
value: function play(player, e) {
if (this.userDanmuOpen) {
this.CM.start();
}
}
}, {
key: 'pause',
value: function pause(player, e) {
if (this.userDanmuOpen) {
this.CM.stop();
}
}
}, {
key: 'send',
value: function send(danmuku) {
this.CM.send(danmuku);
}
/**
* 暴露出去的插入弹幕的方法
* @param {Object danmuku 弹幕对象 只能一条一条插入}
*/
}, {
key: 'insert',
value: function insert(danmuku) {
this.CM && this.CM.insert(danmuku);
}
}, {
key: 'dispose',
value: function dispose() {
if (this.danmuInput !== null) {
this.danmuInput.parentNode && this.danmuInput.parentNode.removeChild(this.danmuInput);
}
}
}]);
return AliplayerDanmuComponent;
}();
exports.default = AliplayerDanmuComponent;
/***/ }),
/* 9 */
/***/ (function(module, exports) {
module.exports = "<div class=\"aliplayer-danmuku abp\">\n <div class=\"danmu container\"></div>\n</div>";
/***/ }),
/* 10 */
/***/ (function(module, exports) {
module.exports = "<div class=\"ali-danmuku-control\">\n <div class=\"ali-danmu-input-wrap\"></div>\n <i class=\"iconfont icon-danmu-close\"></i>\n <div class=\"player-tooltip close\"></div>\n <i class=\"iconfont icon-danmu-open\" style=\"display: none;\"></i>\n <div class=\"player-tooltip open\"></div> \n</div>";
/***/ }),
/* 11 */
/***/ (function(module, exports) {
module.exports = "<div class=\"ali-danmu-input\">\n <input type=\"text\" placeholder=\"\">\n <button class=\"danmu-input-enter\"></button>\n</div>";
/***/ }),
/* 12 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(13);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 13 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".aliplayer-danmuku {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%; }\n .aliplayer-danmuku.abp {\n position: absolute; }\n .aliplayer-danmuku.abp .container {\n z-index: 0; }\n .aliplayer-danmuku .danmu {\n position: absolute;\n width: 100%;\n height: 100%; }\n\n.ali-danmuku-control {\n float: right;\n color: #fff;\n margin-right: 5px;\n position: relative;\n display: table-cell;\n margin-top: 8px; }\n .ali-danmuku-control .iconfont {\n font-size: 35px;\n cursor: pointer;\n vertical-align: middle;\n user-select: none;\n line-height: initial; }\n .ali-danmuku-control .iconfont.icon-danmu-close {\n display: inline-block; }\n .ali-danmuku-control .player-tooltip.close, .ali-danmuku-control .player-tooltip.open {\n right: -12px; }\n @media (min-width: 768px) {\n .ali-danmuku-control .icon-danmu-close:hover + .player-tooltip {\n display: block; }\n .ali-danmuku-control .icon-danmu-open:hover + .player-tooltip {\n display: block; } }\n .ali-danmuku-control .ali-danmu-input-wrap {\n width: 200px;\n display: none; }\n\n.ali-danmu-input {\n position: relative;\n width: 100%;\n display: inline-block; }\n .ali-danmu-input input {\n display: inline-block;\n width: 100%;\n padding-right: 40px;\n box-sizing: border-box;\n padding: 5px 40px 5px 5px;\n background-color: rgba(130, 132, 138, 0.4);\n border: 1px solid #c0c4cc;\n font-size: 14px;\n color: #fff;\n border-radius: 3px; }\n .ali-danmu-input input:focus {\n outline: none;\n border-color: #0f84fd; }\n .ali-danmu-input .danmu-input-enter {\n position: absolute;\n right: 0;\n top: 0;\n border: 1px solid;\n color: #fff;\n background-color: #0f84fd;\n border-color: #0f84fd;\n font-size: 12px;\n padding: 6px 7px;\n display: inline-block;\n height: 28px;\n border-radius: 0 3px 3px 0;\n cursor: pointer; }\n .ali-danmu-input .danmu-input-enter:focus {\n outline: none; }\n .ali-danmu-input .danmu-input-enter:hover {\n background-color: #288df5;\n border-color: #288df5; }\n", ""]);
// exports
/***/ }),
/* 14 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
/**
* Binary Search Stubs for JS Arrays
* @license MIT
* @author Jim Chen
*/
var BinArray = function () {
var BinArray = {};
BinArray.bsearch = function (arr, what, how) {
if (arr.length === 0) {
return 0;
}
if (how(what, arr[0]) < 0) {
return 0;
}
if (how(what, arr[arr.length - 1]) >= 0) {
return arr.length;
}
var low = 0;
var i = 0;
var count = 0;
var high = arr.length - 1;
while (low <= high) {
i = Math.floor((high + low + 1) / 2);
count++;
if (how(what, arr[i - 1]) >= 0 && how(what, arr[i]) < 0) {
return i;
}
if (how(what, arr[i - 1]) < 0) {
high = i - 1;
} else if (how(what, arr[i]) >= 0) {
low = i;
} else {
console.error('Program Error');
}
if (count > 1500) {
console.error('Too many run cycles.');
}
}
return -1; // Never actually run
};
BinArray.binsert = function (arr, what, how) {
var index = BinArray.bsearch(arr, what, how);
arr.splice(index, 0, what);
return index;
};
return BinArray;
}();
var __extends = undefined && undefined.__extends || function (d, b) {
for (var p in b) {
if (b.hasOwnProperty(p)) d[p] = b[p];
}function __() {
this.constructor = d;
}
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var CommentSpaceAllocator = function () {
function CommentSpaceAllocator(width, height) {
if (width === void 0) {
width = 0;
}
if (height === void 0) {
height = 0;
}
this._pools = [[]];
this.avoid = 1;
this._width = width;
this._height = height;
}
CommentSpaceAllocator.prototype.willCollide = function (existing, check) {
return existing.stime + existing.ttl >= check.stime + check.ttl / 2;
};
CommentSpaceAllocator.prototype.pathCheck = function (y, comment, pool) {
var bottom = y + comment.height;
var right = comment.right;
for (var i = 0; i < pool.length; i++) {
if (pool[i].y > bottom || pool[i].bottom < y) {
continue;
} else if (pool[i].right < comment.x || pool[i].x > right) {
if (this.willCollide(pool[i], comment)) {
return false;
} else {
continue;
}
} else {
return false;
}
}
return true;
};
CommentSpaceAllocator.prototype.assign = function (comment, cindex) {
while (this._pools.length <= cindex) {
this._pools.push([]);
}
var pool = this._pools[cindex];
if (pool.length === 0) {
comment.cindex = cindex;
return 0;
} else if (this.pathCheck(0, comment, pool)) {
comment.cindex = cindex;
return 0;
}
var y = 0;
for (var k = 0; k < pool.length; k++) {
y = pool[k].bottom + this.avoid;
if (y + comment.height > this._height) {
break;
}
if (this.pathCheck(y, comment, pool)) {
comment.cindex = cindex;
return y;
}
}
return this.assign(comment, cindex + 1);
};
CommentSpaceAllocator.prototype.add = function (comment) {
if (comment.height > this._height) {
comment.cindex = -2;
comment.y = 0;
} else {
comment.y = this.assign(comment, 0);
BinArray.binsert(this._pools[comment.cindex], comment, function (a, b) {
if (a.bottom < b.bottom) {
return -1;
} else if (a.bottom > b.bottom) {
return 1;
} else {
return 0;
}
});
}
};
CommentSpaceAllocator.prototype.remove = function (comment) {
if (comment.cindex < 0) {
return;
}
if (comment.cindex >= this._pools.length) {
throw new Error("cindex out of bounds");
}
var index = this._pools[comment.cindex].indexOf(comment);
if (index < 0) return;
this._pools[comment.cindex].splice(index, 1);
};
CommentSpaceAllocator.prototype.setBounds = function (width, height) {
this._width = width;
this._height = height;
};
return CommentSpaceAllocator;
}();
var AnchorCommentSpaceAllocator = function (_super) {
__extends(AnchorCommentSpaceAllocator, _super);
function AnchorCommentSpaceAllocator() {
_super.apply(this, arguments);
}
AnchorCommentSpaceAllocator.prototype.add = function (comment) {
_super.prototype.add.call(this, comment);
comment.x = (this._width - comment.width) / 2;
};
AnchorCommentSpaceAllocator.prototype.willCollide = function (a, b) {
return true;
};
AnchorCommentSpaceAllocator.prototype.pathCheck = function (y, comment, pool) {
var bottom = y + comment.height;
for (var i = 0; i < pool.length; i++) {
if (pool[i].y > bottom || pool[i].bottom < y) {
continue;
} else {
return false;
}
}
return true;
};
return AnchorCommentSpaceAllocator;
}(CommentSpaceAllocator);
//# sourceMappingURL=CommentSpaceAllocator.js.map
var __extends = undefined && undefined.__extends || function (d, b) {
for (var p in b) {
if (b.hasOwnProperty(p)) d[p] = b[p];
}function __() {
this.constructor = d;
}
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var CoreComment = function () {
function CoreComment(parent, init) {
if (init === void 0) {
init = {};
}
this.mode = 1;
this.stime = 0;
this.text = "";
this.ttl = 4000;
this.dur = 4000;
this.cindex = -1;
this.motion = [];
this.movable = true;
this._alphaMotion = null;
this.absolute = true;
this.align = 0;
this._alpha = 1;
this._size = 25;
this._color = 0xffffff;
this._border = false;
this._shadow = true;
this._font = "";
if (!parent) {
throw new Error("Comment not bound to comment manager.");
} else {
this.parent = parent;
}
if (init.hasOwnProperty("stime")) {
this.stime = init["stime"];
}
if (init.hasOwnProperty("mode")) {
this.mode = init["mode"];
} else {
this.mode = 1;
}
if (init.hasOwnProperty("dur")) {
this.dur = init["dur"];
this.ttl = this.dur;
}
this.dur *= this.parent.options.global.scale;
this.ttl *= this.parent.options.global.scale;
if (init.hasOwnProperty("text")) {
this.text = init["text"];
}
if (init.hasOwnProperty("motion")) {
this._motionStart = [];
this._motionEnd = [];
this.motion = init["motion"];
var head = 0;
for (var i = 0; i < init["motion"].length; i++) {
this._motionStart.push(head);
var maxDur = 0;
for (var k in init["motion"][i]) {
var m = init["motion"][i][k];
maxDur = Math.max(m.dur, maxDur);
if (m.easing === null || m.easing === undefined) {
init["motion"][i][k]["easing"] = CoreComment.LINEAR;
}
}
head += maxDur;
this._motionEnd.push(head);
}
this._curMotion = 0;
}
if (init.hasOwnProperty("color")) {
this._color = init["color"];
}
if (init.hasOwnProperty("size")) {
this._size = init["size"];
}
if (init.hasOwnProperty("border")) {
this._border = init["border"];
}
if (init.hasOwnProperty("opacity")) {
this._alpha = init["opacity"];
}
if (init.hasOwnProperty("alpha")) {
this._alphaMotion = init["alpha"];
}
if (init.hasOwnProperty("font")) {
this._font = init["font"];
}
if (init.hasOwnProperty("x")) {
this._x = init["x"];
}
if (init.hasOwnProperty("y")) {
this._y = init["y"];
}
if (init.hasOwnProperty("shadow")) {
this._shadow = init["shadow"];
}
if (init.hasOwnProperty("position")) {
if (init["position"] === "relative") {
this.absolute = false;
if (this.mode < 7) {
console.warn("Using relative position for CSA comment.");
}
}
}
}
CoreComment.prototype.init = function (recycle) {
if (recycle === void 0) {
recycle = null;
}
if (recycle !== null) {
this.dom = recycle.dom;
} else {
this.dom = document.createElement("div");
}
this.dom.className = this.parent.options.global.className;
this.dom.appendChild(document.createTextNode(this.text));
this.dom.textContent = this.text;
this.dom.innerText = this.text;
this.size = this._size;
if (this._color != 0xffffff) {
this.color = this._color;
}
this.shadow = this._shadow;
if (this._border) {
this.border = this._border;
}
if (this._font !== "") {
this.font = this._font;
}
if (this._x !== undefined) {
this.x = this._x;
}
if (this._y !== undefined) {
this.y = this._y;
}
if (this._alpha !== 1 || this.parent.options.global.opacity < 1) {
this.alpha = this._alpha;
}
if (this.motion.length > 0) {
this.animate();
}
};
Object.defineProperty(CoreComment.prototype, "x", {
get: function get() {
if (this._x === null || this._x === undefined) {
if (this.align % 2 === 0) {
this._x = this.dom.offsetLeft;
} else {
this._x = this.parent.width - this.dom.offsetLeft - this.width;
}
}
if (!this.absolute) {
return this._x / this.parent.width;
}
return this._x;
},
set: function set(x) {
this._x = x;
if (!this.absolute) {
this._x *= this.parent.width;
}
if (this.align % 2 === 0) {
this.dom.style.left = this._x + "px";
} else {
this.dom.style.right = this._x + "px";
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "y", {
get: function get() {
if (this._y === null || this._y === undefined) {
if (this.align < 2) {
this._y = this.dom.offsetTop;
} else {
this._y = this.parent.height - this.dom.offsetTop - this.height;
}
}
if (!this.absolute) {
return this._y / this.parent.height;
}
return this._y;
},
set: function set(y) {
this._y = y;
if (!this.absolute) {
this._y *= this.parent.height;
}
if (this.align < 2) {
this.dom.style.top = this._y + "px";
} else {
this.dom.style.bottom = this._y + "px";
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "bottom", {
get: function get() {
return this.y + this.height;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "right", {
get: function get() {
return this.x + this.width;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "width", {
get: function get() {
if (this._width === null || this._width === undefined) {
this._width = this.dom.offsetWidth;
}
return this._width;
},
set: function set(w) {
this._width = w;
this.dom.style.width = this._width + "px";
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "height", {
get: function get() {
if (this._height === null || this._height === undefined) {
this._height = this.dom.offsetHeight;
}
return this._height;
},
set: function set(h) {
this._height = h;
this.dom.style.height = this._height + "px";
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "size", {
get: function get() {
return this._size;
},
set: function set(s) {
this._size = s;
this.dom.style.fontSize = this._size + "px";
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "color", {
get: function get() {
return this._color;
},
set: function set(c) {
this._color = c;
var color = c.toString(16);
color = color.length >= 6 ? color : new Array(6 - color.length + 1).join("0") + color;
this.dom.style.color = "#" + color;
if (this._color === 0) {
this.dom.className = this.parent.options.global.className + " rshadow";
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "alpha", {
get: function get() {
return this._alpha;
},
set: function set(a) {
this._alpha = a;
this.dom.style.opacity = Math.min(this._alpha, this.parent.options.global.opacity) + "";
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "border", {
get: function get() {
return this._border;
},
set: function set(b) {
this._border = b;
if (this._border) {
this.dom.style.border = "1px solid #00ffff";
} else {
this.dom.style.border = "none";
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "shadow", {
get: function get() {
return this._shadow;
},
set: function set(s) {
this._shadow = s;
if (!this._shadow) {
this.dom.className = this.parent.options.global.className + " noshadow";
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CoreComment.prototype, "font", {
get: function get() {
return this._font;
},
set: function set(f) {
this._font = f;
if (this._font.length > 0) {
this.dom.style.fontFamily = this._font;
} else {
this.dom.style.fontFamily = "";
}
},
enumerable: true,
configurable: true
});
CoreComment.prototype.time = function (time) {
this.ttl -= time;
if (this.ttl < 0) {
this.ttl = 0;
}
if (this.movable) {
this.update();
}
if (this.ttl <= 0) {
this.finish();
}
};
CoreComment.prototype.update = function () {
this.animate();
};
CoreComment.prototype.invalidate = function () {
this._x = null;
this._y = null;
this._width = null;
this._height = null;
};
CoreComment.prototype._execMotion = function (currentMotion, time) {
for (var prop in currentMotion) {
if (currentMotion.hasOwnProperty(prop)) {
var m = currentMotion[prop];
this[prop] = m.easing(Math.min(Math.max(time - m.delay, 0), m.dur), m.from, m.to - m.from, m.dur);
}
}
};
CoreComment.prototype.animate = function () {
if (this._alphaMotion) {
this.alpha = (this.dur - this.ttl) * (this._alphaMotion["to"] - this._alphaMotion["from"]) / this.dur + this._alphaMotion["from"];
}
if (this.motion.length === 0) {
return;
}
var ttl = Math.max(this.ttl, 0);
var time = this.dur - ttl - this._motionStart[this._curMotion];
this._execMotion(this.motion[this._curMotion], time);
if (this.dur - ttl > this._motionEnd[this._curMotion]) {
this._curMotion++;
if (this._curMotion >= this.motion.length) {
this._curMotion = this.motion.length - 1;
}
return;
}
};
CoreComment.prototype.finish = function () {
this.parent.finish(this);
};
CoreComment.prototype.toString = function () {
return ["[", this.stime, "|", this.ttl, "/", this.dur, "]", "(", this.mode, ")", this.text].join("");
};
CoreComment.LINEAR = function (t, b, c, d) {
return t * c / d + b;
};
return CoreComment;
}();
var ScrollComment = function (_super) {
__extends(ScrollComment, _super);
function ScrollComment(parent, data) {
_super.call(this, parent, data);
this.dur *= this.parent.options.scroll.scale;
this.ttl *= this.parent.options.scroll.scale;
}
Object.defineProperty(ScrollComment.prototype, "alpha", {
set: function set(a) {
this._alpha = a;
this.dom.style.opacity = Math.min(Math.min(this._alpha, this.parent.options.global.opacity), this.parent.options.scroll.opacity) + "";
},
enumerable: true,
configurable: true
});
ScrollComment.prototype.init = function (recycle) {
if (recycle === void 0) {
recycle = null;
}
_super.prototype.init.call(this, recycle);
this.x = this.parent.width;
if (this.parent.options.scroll.opacity < 1) {
this.alpha = this._alpha;
}
this.absolute = true;
};
ScrollComment.prototype.update = function () {
this.x = this.ttl / this.dur * (this.parent.width + this.width) - this.width;
};
return ScrollComment;
}(CoreComment);
//# sourceMappingURL=Comment.js.map
/**
* Comment Filters Module Simplified (only supports modifiers & types)
* @license MIT
* @author Jim Chen
*/
function CommentFilter() {
this.modifiers = [];
this.runtime = null;
this.allowTypes = {
"1": true,
"4": true,
"5": true,
"6": true,
"7": true,
"8": true,
"17": true
};
this.doModify = function (cmt) {
for (var k = 0; k < this.modifiers.length; k++) {
cmt = this.modifiers[k](cmt);
}
return cmt;
};
this.beforeSend = function (cmt) {
return cmt;
};
this.doValidate = function (cmtData) {
if (!this.allowTypes[cmtData.mode]) return false;
return true;
};
this.addRule = function (rule) {};
this.addModifier = function (f) {
this.modifiers.push(f);
};
this.runtimeFilter = function (cmt) {
if (this.runtime == null) return cmt;
return this.runtime(cmt);
};
this.setRuntimeFilter = function (f) {
this.runtime = f;
};
}
/*!
* Comment Core Library CommentManager
* @license MIT
* @author Jim Chen
*
* Copyright (c) 2014 Jim Chen
*/
var CommentManager = function () {
var getRotMatrix = function getRotMatrix(yrot, zrot) {
// Courtesy of @StarBrilliant, re-adapted to look better
var DEG2RAD = Math.PI / 180;
var yr = yrot * DEG2RAD;
var zr = zrot * DEG2RAD;
var COS = Math.cos;
var SIN = Math.sin;
var matrix = [COS(yr) * COS(zr), COS(yr) * SIN(zr), SIN(yr), 0, -SIN(zr), COS(zr), 0, 0, -SIN(yr) * COS(zr), -SIN(yr) * SIN(zr), COS(yr), 0, 0, 0, 0, 1];
// CSS does not recognize scientific notation (e.g. 1e-6), truncating it.
for (var i = 0; i < matrix.length; i++) {
if (Math.abs(matrix[i]) < 0.000001) {
matrix[i] = 0;
}
}
return "matrix3d(" + matrix.join(",") + ")";
};
function CommentManager(stageObject) {
var __timer = 0;
this._listeners = {};
this._lastPosition = 0;
this.stage = stageObject;
this.options = {
global: {
opacity: 1,
scale: 1,
className: "cmt"
},
scroll: {
opacity: 1,
scale: 1
},
limit: 0
};
this.timeline = [];
this.runline = [];
this.position = 0;
this.limiter = 0;
this.filter = null;
this.csa = {
scroll: new CommentSpaceAllocator(0, 0),
top: new AnchorCommentSpaceAllocator(0, 0),
bottom: new AnchorCommentSpaceAllocator(0, 0),
reverse: new CommentSpaceAllocator(0, 0),
scrollbtm: new CommentSpaceAllocator(0, 0)
};
/** Precompute the offset width **/
this.width = this.stage.offsetWidth;
this.height = this.stage.offsetHeight;
this.startTimer = function () {
if (__timer > 0) return;
var lastTPos = new Date().getTime();
var cmMgr = this;
__timer = window.setInterval(function () {
var elapsed = new Date().getTime() - lastTPos;
lastTPos = new Date().getTime();
cmMgr.onTimerEvent(elapsed, cmMgr);
}, 10);
};
this.stopTimer = function () {
window.clearInterval(__timer);
__timer = 0;
};
}
/** Public **/
CommentManager.prototype.stop = function () {
this.stopTimer();
};
CommentManager.prototype.start = function () {
this.startTimer();
};
CommentManager.prototype.seek = function (time) {
this.position = BinArray.bsearch(this.timeline, time, function (a, b) {
if (a < b.stime) return -1;else if (a > b.stime) return 1;else return 0;
});
};
CommentManager.prototype.validate = function (cmt) {
if (cmt == null) return false;
return this.filter.doValidate(cmt);
};
CommentManager.prototype.load = function (a) {
this.timeline = a;
this.timeline.sort(function (a, b) {
if (a.stime > b.stime) return 2;else if (a.stime < b.stime) return -2;else {
if (a.date > b.date) return 1;else if (a.date < b.date) return -1;else if (a.dbid != null && b.dbid != null) {
if (a.dbid > b.dbid) return 1;else if (a.dbid < b.dbid) return -1;
return 0;
} else return 0;
}
});
this.dispatchEvent("load");
};
CommentManager.prototype.insert = function (c) {
var index = BinArray.binsert(this.timeline, c, function (a, b) {
if (a.stime > b.stime) return 2;else if (a.stime < b.stime) return -2;else {
if (a.date > b.date) return 1;else if (a.date < b.date) return -1;else if (a.dbid != null && b.dbid != null) {
if (a.dbid > b.dbid) return 1;else if (a.dbid < b.dbid) return -1;
return 0;
} else return 0;
}
});
if (index <= this.position) {
this.position++;
}
this.dispatchEvent("insert");
};
CommentManager.prototype.clear = function () {
while (this.runline.length > 0) {
this.runline[0].finish();
}
this.dispatchEvent("clear");
};
CommentManager.prototype.setBounds = function () {
this.width = this.stage.offsetWidth;
this.height = this.stage.offsetHeight;
this.dispatchEvent("resize");
for (var comAlloc in this.csa) {
this.csa[comAlloc].setBounds(this.width, this.height);
}
// Update 3d perspective
this.stage.style.perspective = this.width * Math.tan(40 * Math.PI / 180) / 2 + "px";
this.stage.style.webkitPerspective = this.width * Math.tan(40 * Math.PI / 180) / 2 + "px";
};
CommentManager.prototype.init = function () {
this.setBounds();
if (this.filter == null) {
this.filter = new CommentFilter(); //Only create a filter if none exist
}
};
CommentManager.prototype.time = function (time) {
time = time - 1;
if (this.position >= this.timeline.length || Math.abs(this._lastPosition - time) >= 2000) {
this.seek(time);
this._lastPosition = time;
if (this.timeline.length <= this.position) {
return;
}
} else {
this._lastPosition = time;
}
for (; this.position < this.timeline.length; this.position++) {
if (this.timeline[this.position]['stime'] <= time) {
if (this.options.limit > 0 && this.runline.length > this.limiter) {
continue; // Skip comments but still move the position pointer
} else if (this.validate(this.timeline[this.position])) {
this.send(this.timeline[this.position]);
}
} else {
break;
}
}
};
CommentManager.prototype.rescale = function () {};
CommentManager.prototype.send = function (data) {
if (data.mode === 8) {
console.log(data);
if (this.scripting) {
console.log(this.scripting.eval(data.code));
}
return;
}
if (this.filter != null) {
data = this.filter.doModify(data);
if (data == null) return;
}
if (data.mode === 1 || data.mode === 2 || data.mode === 6) {
var cmt = new ScrollComment(this, data);
} else {
var cmt = new CoreComment(this, data);
}
switch (cmt.mode) {
case 1:
cmt.align = 0;break;
case 2:
cmt.align = 2;break;
case 4:
cmt.align = 2;break;
case 5:
cmt.align = 0;break;
case 6:
cmt.align = 1;break;
}
cmt.init();
this.stage.appendChild(cmt.dom);
switch (cmt.mode) {
default:
case 1:
{
this.csa.scroll.add(cmt);
}break;
case 2:
{
this.csa.scrollbtm.add(cmt);
}break;
case 4:
{
this.csa.bottom.add(cmt);
}break;
case 5:
{
this.csa.top.add(cmt);
}break;
case 6:
{
this.csa.reverse.add(cmt);
}break;
case 17:
case 7:
{
if (data.rY !== 0 || data.rZ !== 0) {
/** TODO: revise when browser manufacturers make up their mind on Transform APIs **/
cmt.dom.style.transform = getRotMatrix(data.rY, data.rZ);
cmt.dom.style.webkitTransform = getRotMatrix(data.rY, data.rZ);
cmt.dom.style.OTransform = getRotMatrix(data.rY, data.rZ);
cmt.dom.style.MozTransform = getRotMatrix(data.rY, data.rZ);
cmt.dom.style.MSTransform = getRotMatrix(data.rY, data.rZ);
}
}break;
}
cmt.y = cmt.y;
this.dispatchEvent("enterComment", cmt);
this.runline.push(cmt);
};
CommentManager.prototype.sendComment = function (data) {
console.log("CommentManager.sendComment is deprecated. Please use send instead");
this.send(data); // Wrapper for Backwards Compatible APIs
};
CommentManager.prototype.finish = function (cmt) {
this.dispatchEvent("exitComment", cmt);
this.stage.removeChild(cmt.dom);
var index = this.runline.indexOf(cmt);
if (index >= 0) {
this.runline.splice(index, 1);
}
switch (cmt.mode) {
default:
case 1:
{
this.csa.scroll.remove(cmt);
}break;
case 2:
{
this.csa.scrollbtm.remove(cmt);
}break;
case 4:
{
this.csa.bottom.remove(cmt);
}break;
case 5:
{
this.csa.top.remove(cmt);
}break;
case 6:
{
this.csa.reverse.remove(cmt);
}break;
case 7:
break;
}
};
CommentManager.prototype.addEventListener = function (event, listener) {
if (typeof this._listeners[event] !== "undefined") {
this._listeners[event].push(listener);
} else {
this._listeners[event] = [listener];
}
};
CommentManager.prototype.dispatchEvent = function (event, data) {
if (typeof this._listeners[event] !== "undefined") {
for (var i = 0; i < this._listeners[event].length; i++) {
try {
this._listeners[event][i](data);
} catch (e) {
console.err(e.stack);
}
}
}
};
/** Static Functions **/
CommentManager.prototype.onTimerEvent = function (timePassed, cmObj) {
for (var i = 0; i < cmObj.runline.length; i++) {
var cmt = cmObj.runline[i];
if (cmt.hold) {
continue;
}
cmt.time(timePassed);
}
};
return CommentManager;
}();
/**
* AcFun Format Parser
* @license MIT License
* An alternative format comment parser
*/
function AcfunParser(jsond) {
var list = [];
try {
var jsondt = JSON.parse(jsond);
} catch (e) {
console.log('Error: Could not parse json list!');
return [];
}
for (var i = 0; i < jsondt.length; i++) {
//Read each comment and generate a correct comment object
var data = {};
var xc = jsondt[i]['c'].split(',');
if (xc.length > 0) {
data.stime = parseFloat(xc[0]) * 1000;
data.color = parseInt(xc[1]);
data.mode = parseInt(xc[2]);
data.size = parseInt(xc[3]);
data.hash = xc[4];
data.date = parseInt(xc[5]);
data.position = "absolute";
if (data.mode != 7) {
data.text = jsondt[i].m.replace(/(\/n|\\n|\n|\r\n|\\r)/g, "\n");
data.text = data.text.replace(/\r/g, "\n");
data.text = data.text.replace(/\s/g, '\xA0');
} else {
data.text = jsondt[i].m;
}
if (data.mode == 7) {
//High level positioned dm
try {
var x = JSON.parse(data.text);
} catch (e) {
console.log('[Err] Error parsing internal data for comment');
console.log('[Dbg] ' + data.text);
continue;
}
data.position = "relative";
data.text = x.n; /*.replace(/\r/g,"\n");*/
data.text = data.text.replace(/\ /g, '\xA0');
if (x.a != null) {
data.opacity = x.a;
} else {
data.opacity = 1;
}
if (x.p != null) {
data.x = x.p.x / 1000; // relative position
data.y = x.p.y / 1000;
} else {
data.x = 0;
data.y = 0;
}
data.shadow = x.b;
data.dur = 4000;
if (x.l != null) data.moveDelay = x.l * 1000;
if (x.z != null && x.z.length > 0) {
data.movable = true;
data.motion = [];
var moveDuration = 0;
var last = { x: data.x, y: data.y, alpha: data.opacity, color: data.color };
for (var m = 0; m < x.z.length; m++) {
var dur = x.z[m].l != null ? x.z[m].l * 1000 : 500;
moveDuration += dur;
var motion = {
x: { from: last.x, to: x.z[m].x / 1000, dur: dur, delay: 0 },
y: { from: last.y, to: x.z[m].y / 1000, dur: dur, delay: 0 }
};
last.x = motion.x.to;
last.y = motion.y.to;
if (x.z[m].t !== last.alpha) {
motion.alpha = { from: last.alpha, to: x.z[m].t, dur: dur, delay: 0 };
last.alpha = motion.alpha.to;
}
if (x.z[m].c != null && x.z[m].c !== last.color) {
motion.color = { from: last.color, to: x.z[m].c, dur: dur, delay: 0 };
last.color = motion.color.to;
}
data.motion.push(motion);
}
data.dur = moveDuration + (data.moveDelay ? data.moveDelay : 0);
}
if (x.r != null && x.k != null) {
data.rX = x.r;
data.rY = x.k;
}
}
list.push(data);
}
}
return list;
}
/**
* Bilibili Format Parser
* @license MIT License
* Takes in an XMLDoc/LooseXMLDoc and parses that into a Generic Comment List
**/
function BilibiliParser(xmlDoc, text, warn) {
function format(string) {
// Format the comment text to be JSON Valid.
return string.replace(/\t/, "\\t");
}
if (xmlDoc !== null) {
var elems = xmlDoc.getElementsByTagName('d');
} else {
if (!document || !document.createElement) {
// Maybe we are in a restricted context? Bail.
return [];
}
if (warn) {
if (!confirm("XML Parse Error. \n Allow tag soup parsing?\n[WARNING: This is unsafe.]")) {
return [];
}
} else {
// TODO: Make this safer in the future
text = text.replace(new RegExp("</([^d])", "g"), "</disabled $1");
text = text.replace(new RegExp("</(\S{2,})", "g"), "</disabled $1");
text = text.replace(new RegExp("<([^d/]\W*?)", "g"), "<disabled $1");
text = text.replace(new RegExp("<([^/ ]{2,}\W*?)", "g"), "<disabled $1");
}
var tmp = document.createElement("div");
tmp.innerHTML = text;
var elems = tmp.getElementsByTagName('d');
}
var tlist = [];
for (var i = 0; i < elems.length; i++) {
if (elems[i].getAttribute('p') != null) {
var opt = elems[i].getAttribute('p').split(',');
if (!elems[i].childNodes[0]) continue;
var text = elems[i].childNodes[0].nodeValue;
var obj = {};
obj.stime = Math.round(parseFloat(opt[0]) * 1000);
obj.size = parseInt(opt[2]);
obj.color = parseInt(opt[3]);
obj.mode = parseInt(opt[1]);
obj.date = parseInt(opt[4]);
obj.pool = parseInt(opt[5]);
obj.position = "absolute";
if (opt[7] != null) obj.dbid = parseInt(opt[7]);
obj.hash = opt[6];
obj.border = false;
if (obj.mode < 7) {
obj.text = text.replace(/(\/n|\\n|\n|\r\n)/g, "\n");
} else {
if (obj.mode == 7) {
try {
adv = JSON.parse(format(text));
obj.shadow = true;
obj.x = parseFloat(adv[0]);
obj.y = parseFloat(adv[1]);
if (Math.floor(obj.x) < obj.x || Math.floor(obj.y) < obj.y) {
obj.position = "relative";
}
obj.text = adv[4].replace(/(\/n|\\n|\n|\r\n)/g, "\n");
obj.rZ = 0;
obj.rY = 0;
if (adv.length >= 7) {
obj.rZ = parseInt(adv[5], 10);
obj.rY = parseInt(adv[6], 10);
}
obj.motion = [];
obj.movable = false;
if (adv.length >= 11) {
obj.movable = true;
var singleStepDur = 500;
var motion = {
x: { from: obj.x, to: parseFloat(adv[7]), dur: singleStepDur, delay: 0 },
y: { from: obj.y, to: parseFloat(adv[8]), dur: singleStepDur, delay: 0 }
};
if (adv[9] !== '') {
singleStepDur = parseInt(adv[9], 10);
motion.x.dur = singleStepDur;
motion.y.dur = singleStepDur;
}
if (adv[10] !== '') {
motion.x.delay = parseInt(adv[10], 10);
motion.y.delay = parseInt(adv[10], 10);
}
if (adv.length > 11) {
obj.shadow = adv[11];
if (obj.shadow === "true") {
obj.shadow = true;
}
if (obj.shadow === "false") {
obj.shadow = false;
}
if (adv[12] != null) {
obj.font = adv[12];
}
if (adv.length > 14) {
// Support for Bilibili Advanced Paths
if (obj.position === "relative") {
console.log("Cannot mix relative and absolute positioning");
obj.position = "absolute";
}
var path = adv[14];
var lastPoint = { x: motion.x.from, y: motion.y.from };
var pathMotion = [];
var regex = new RegExp("([a-zA-Z])\\s*(\\d+)[, ](\\d+)", "g");
var counts = path.split(/[a-zA-Z]/).length - 1;
var m = regex.exec(path);
while (m !== null) {
switch (m[1]) {
case "M":
{
lastPoint.x = parseInt(m[2], 10);
lastPoint.y = parseInt(m[3], 10);
}break;
case "L":
{
pathMotion.push({
"x": { "from": lastPoint.x, "to": parseInt(m[2], 10), "dur": singleStepDur / counts, "delay": 0 },
"y": { "from": lastPoint.y, "to": parseInt(m[3], 10), "dur": singleStepDur / counts, "delay": 0 }
});
lastPoint.x = parseInt(m[2], 10);
lastPoint.y = parseInt(m[3], 10);
}break;
}
m = regex.exec(path);
}
motion = null;
obj.motion = pathMotion;
}
}
if (motion !== null) {
obj.motion.push(motion);
}
}
obj.dur = 2500;
if (adv[3] < 12) {
obj.dur = adv[3] * 1000;
}
var tmp = adv[2].split('-');
if (tmp != null && tmp.length > 1) {
var alphaFrom = parseFloat(tmp[0]);
var alphaTo = parseFloat(tmp[1]);
obj.opacity = alphaFrom;
if (alphaFrom !== alphaTo) {
obj.alpha = { from: alphaFrom, to: alphaTo };
}
}
} catch (e) {
console.log('[Err] Error occurred in JSON parsing');
console.log('[Dbg] ' + text);
}
} else if (obj.mode == 8) {
obj.code = text; //Code comments are special
}
}
if (obj.text != null) obj.text = obj.text.replace(/\u25a0/g, '\u2588');
tlist.push(obj);
}
}
return tlist;
}
exports.CommentManager = CommentManager;
/***/ }),
/* 15 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(16);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 16 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".abp {\n position: relative; }\n\n.abp .container {\n -webkit-transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);\n transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);\n position: absolute;\n display: block;\n overflow: hidden;\n margin: 0;\n border: 0;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n z-index: 9999;\n touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.abp .container .cmt {\n -webkit-transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);\n transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);\n -webkit-transform-origin: 0% 0%;\n -ms-transform-origin: 0% 0%;\n transform-origin: 0% 0%;\n position: absolute;\n padding: 3px 0 0 0;\n margin: 0;\n color: #fff;\n font-family: SimHei, SimSun, Heiti, \"MS Mincho\", \"Meiryo\", \"Microsoft YaHei\", monospace;\n font-size: 25px;\n text-decoration: none;\n text-shadow: -1px 0 black, 0 1px black, 1px 0 black, 0 -1px black;\n -webkit-text-size-adjust: none;\n -ms-text-size-adjust: none;\n text-size-adjust: none;\n line-height: 100%;\n letter-spacing: 0;\n word-break: keep-all;\n white-space: pre; }\n\n.abp .container .cmt.noshadow {\n text-shadow: none; }\n\n.abp .container .cmt.rshadow {\n text-shadow: -1px 0 white, 0 1px white, 1px 0 white, 0 -1px white; }\n\n/** Aliases for Chinese named fonts because they don't work on *nix **/\n@font-face {\n font-family: \"\\9ED1\\4F53\";\n src: local(\"SimHei\"); }\n\n@font-face {\n font-family: \"\\5B8B\\4F53\";\n src: local(\"SimSun\"); }\n\n@font-face {\n font-family: \"\\534E\\6587\\6977\\4F53\";\n src: local(\"SimKai\"); }\n\n@font-face {\n font-family: \"\\5E7C\\5706\";\n src: local(\"YouYuan\"); }\n\n@font-face {\n font-family: \"\\5FAE\\8F6F\\96C5\\9ED1\";\n src: local(\"Microsoft YaHei\"); }\n", ""]);
// exports
/***/ }),
/* 17 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(18);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.BulletScreenComponent = _index2.default;
/***/ }),
/* 18 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(19);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(20);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 跑马灯组件
*/
var BulletScreenComponent = function () {
/**
* @constructor 跑马灯构造函数
* @param {String text 跑马灯内容}
* @param {Object style 跑马灯样式}
* param {String bulletPosition 跑马灯所在的位置, 可能的值 'top', 'bottom' , 'random, 默认为 'random'}
*/
function BulletScreenComponent(text, style) {
var bulletPosition = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'random';
_classCallCheck(this, BulletScreenComponent);
this.text = text;
this.style = style || { fontSize: '14px', color: '#fff' };
this.html = (0, _utils.parseDom)(_index2.default);
// this.html.style.animationPlayState = 'paused'
this.bulletPosition = bulletPosition;
}
_createClass(BulletScreenComponent, [{
key: 'createEl',
value: function createEl(el, player) {
this.html.innerText = this.text;
el.appendChild(this.html);
el.style.overflow = 'hidden';
}
}, {
key: 'ready',
value: function ready(player, e) {
var _this = this;
console.log(player.getOptions());
if (player.getOptions().autoplay === false) {
this.html.style.animationPlayState = 'paused';
}
Object.keys(this.style).forEach(function (key) {
return _this.html.style[key] = _this.style[key];
});
//字体高度
var bulletHeight = this.html.offsetHeight;
//播放器高度
var playerHeight = parseInt(getComputedStyle(player.tag).height.replace('px', ''));
//字体距离播放器底部最大高度
var maxHeight = playerHeight - bulletHeight;
if (this.bulletPosition === 'bottom') {
this.html.style.bottom = 0;
} else {
var top = this.bulletPosition === 'top' ? 0 : this.randomTop(maxHeight);
this.html.style.top = top;
}
if (this.bulletPosition === 'random') {
this.html.addEventListener('animationiteration', function () {
_this.html.style.top = _this.randomTop(maxHeight);
});
}
}
}, {
key: 'playing',
value: function playing(player, e) {
console.log('playering');
this.html.style.animationPlayState = 'running';
}
}, {
key: 'timeupdate',
value: function timeupdate(player, timeStamp) {
var el = player.el();
var componentEl = el.querySelector('.bullet-screen');
if (!componentEl) {
el.appendChild(this.html);
} else {
if (componentEl.className !== 'bullet-screen') {
componentEl.className = 'bullet-screen';
}
var cssStyles = getComputedStyle(componentEl);
var display = cssStyles.getPropertyValue('display');
var opacity = cssStyles.getPropertyValue('opacity');
var visibility = cssStyles.getPropertyValue('visibility');
var currentwords = this.text;
var modifywords = componentEl.innerText;
if (display === 'none') {
componentEl.style.setProperty('display', 'block');
}
if (opacity !== '1') {
componentEl.style.setProperty('opacity', '1');
}
if (visibility === 'hidden') {
componentEl.style.setProperty('visibility', 'visible');
}
if (currentwords != modifywords) {
componentEl.innerText = currentwords;
}
}
}
}, {
key: 'pause',
value: function pause(player, e) {
console.log('pause');
this.html.style.animationPlayState = 'paused';
}
}, {
key: 'randomTop',
value: function randomTop(max) {
return Math.floor(Math.random() * max) + 'px';
}
}]);
return BulletScreenComponent;
}();
exports.default = BulletScreenComponent;
/***/ }),
/* 19 */
/***/ (function(module, exports) {
module.exports = "<div class=\"bullet-screen paused\"></div>";
/***/ }),
/* 20 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(21);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 21 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".bullet-screen {\n position: absolute;\n white-space: nowrap;\n animation: bullet 10s linear infinite; }\n\n@keyframes bullet {\n from {\n left: 100%; }\n to {\n left: 0%;\n transform: translateX(-100%); } }\n", ""]);
// exports
/***/ }),
/* 22 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(23);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.CaptionComponent = _index2.default;
/***/ }),
/* 23 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(24);
var _index2 = _interopRequireDefault(_index);
var _captionModal = __webpack_require__(25);
var _captionModal2 = _interopRequireDefault(_captionModal);
__webpack_require__(26);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 字幕组件
*/
var CaptionComponent = function () {
/**
* @constructor 字幕组件构造函数
*/
function CaptionComponent() {
_classCallCheck(this, CaptionComponent);
this.captionList = null;
this.html = (0, _utils.parseDom)(_index2.default);
this.modalHtml = (0, _utils.parseDom)(_captionModal2.default);
this.hasCreated = false;
this.definition = '';
}
_createClass(CaptionComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
//this.html.querySelector('.current-caption').innerText = this.isEn ? 'Subtitle language' : '字幕语言'
this.modalHtml.querySelector('.switchimg').innerText = this.isEn ? 'Switching to you for' : '字幕切换到';
this.modalHtml.querySelector('.switchimg').style.display = 'none';
var eleControlbar = el.querySelector('.prism-controlbar');
eleControlbar.appendChild(this.html);
el.appendChild(this.modalHtml);
player.on('textTrackReady', function (_ref) {
var paramData = _ref.paramData;
_this.captionList = paramData;
var lis_ele = paramData.map(function (v) {
return '<li data-def="' + v.value + '">' + v.text + '</li>';
});
_this.html.querySelector('.caption-list').innerHTML = '<li style="background:rgba(88,87,86,.5);color:#fff">\u5B57\u5E55</li>' + lis_ele.join('');
});
var currentCaptionEle = this.html.querySelector('.current-caption');
var captionListEle = this.html.querySelector('.caption-list');
if (this.hasCreated == false && this.definition) {
var li_target = captionListEle.querySelector('li[data-def="' + this.definition + '"]');
li_target.className = 'current';
}
this.hasCreated = true;
var timeId = null;
currentCaptionEle.onclick = function () {
captionListEle.style.display = 'block';
};
currentCaptionEle.onmouseleave = function () {
timeId = setTimeout(function () {
captionListEle.style.display = 'none';
}, 100);
};
captionListEle.onmouseenter = function () {
clearTimeout(timeId);
};
captionListEle.onmouseleave = function () {
captionListEle.style.display = 'none';
// this.html.querySelector('.caption-modal').style.display = 'none'
_this.modalHtml.style.display = 'none';
};
captionListEle.onclick = function (_ref2) {
var target = _ref2.target;
var definition = target.dataset.def;
if (definition) {
if (target.className !== 'current') {
var caption = Array.isArray(_this.captionList) ? _this.captionList.filter(function (v) {
return v.value === definition;
})[0] : _this.captionList.find(function (v) {
return v.value === definition;
});
player._ccService.switch(caption.value);
_this.setCurrentCaption(caption.text, caption.value);
_this.modalHtml.style.display = 'block';
_this.modalHtml.querySelector('.switchimg').style.display = 'block';
_this.modalHtml.querySelector('span.current-caption-tag').innerText = caption.text;
}
}
};
}
}, {
key: 'setCurrentCaption',
value: function setCurrentCaption(caption, def) {
var currentCaption = this.html.querySelector('.current-caption');
currentCaption.innerText = caption;
currentCaption.dataset.def = def;
this.definition = def;
var captionListEle = this.html.querySelector('.caption-list');
var currentEle = captionListEle.querySelector('.current');
if (currentEle) {
currentEle.className = '';
}
//let li_target = captionListEle.querySelector(`li[data-def="${def}"]`)
var lis = captionListEle.querySelectorAll('li');
lis.forEach(function (element) {
var text = element.innerText;
if (text === caption) {
element.className = 'current';
}
});
if (lis) {
lis.className = 'current';
}
}
}, {
key: 'created',
value: function created(player) {}
}, {
key: 'ready',
value: function ready(player) {
this.modalHtml.style.display = 'none';
// 隐藏设置里面的倍速播放
var settingEle = document.querySelector('.prism-setting-item.prism-setting-cc');
if (settingEle) {
settingEle.classList.add('player-hidden');
}
}
}]);
return CaptionComponent;
}();
exports.default = CaptionComponent;
/***/ }),
/* 24 */
/***/ (function(module, exports) {
module.exports = "<div class=\"caption-components\">\n <div class=\"current-caption\" data-ref=\"\"></div>\n <ul class=\"caption-list\">\n </ul>\n </div>";
/***/ }),
/* 25 */
/***/ (function(module, exports) {
module.exports = "<div class=\"caption-modal prism-info-display prism-info-left-bottom\">\n <span class=\"switchimg\"></span> <span class=\"current-caption-tag\"></span>\n</div>";
/***/ }),
/* 26 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(27);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 27 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".player-hidden {\n display: none !important; }\n\n.caption-components {\n float: right;\n color: #fff;\n height: 35px;\n position: relative;\n box-sizing: border-box;\n margin-top: 5px; }\n\n.current-caption {\n display: flex;\n height: 100%;\n align-items: center;\n justify-content: center;\n width: 100px;\n cursor: pointer; }\n\n.caption-list {\n position: absolute;\n bottom: 46px;\n display: none;\n padding: 0;\n margin: 0;\n list-style: none;\n height: 150px;\n width: 100px;\n overflow-y: scroll; }\n .caption-list li {\n text-align: center;\n width: 100px;\n line-height: 30px;\n background-color: rgba(0, 0, 0, 0.6);\n cursor: pointer; }\n .caption-list li.current {\n color: #00c1de; }\n .caption-list li + li {\n border-top: 1px solid rgba(78, 78, 78, 0.3); }\n .caption-list li:hover {\n background-color: rgba(0, 0, 0, 0.5); }\n\n@media (max-width: 768px) {\n .current-caption {\n width: 40px; }\n .caption-list li {\n width: 43px; } }\n\n.prism-player .prism-info-display .switchimg {\n color: #fff; }\n", ""]);
// exports
/***/ }),
/* 28 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(29);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.ManyVideoADComponent = _index2.default;
/***/ }),
/* 29 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(30);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(31);
var _utils = __webpack_require__(2);
var _mbIndex = __webpack_require__(33);
var _mbIndex2 = _interopRequireDefault(_mbIndex);
var _currentDevice = __webpack_require__(3);
var _currentDevice2 = _interopRequireDefault(_currentDevice);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/*
* PC 多视频广告组件
*/
var ManyVideoAdComponent = function () {
/**
* @constructor PC 多视频广告的构造函数
* @param adVideoSource {@String 广告视频的视频地址 必须参数}
* @param adLink {@String 广告视频的链接地址 必须参数}
* @param adCloseFunction {@Function 关闭广告的点击事件处理函数, 可选参数, 不传则默认关闭广告视频}
* @param closeText {@String 关闭广告的文字内容, 可选参数, 不传则默认为 '关闭广告'}
*/
function ManyVideoAdComponent(adVideoSource, adCloseFunction) {
var closeText = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '关闭广告';
_classCallCheck(this, ManyVideoAdComponent);
this.adVideoSource = adVideoSource;
this.html = (0, _utils.parseDom)(_index2.default);
this.adInterval = null;
this.adCloseFunction = adCloseFunction;
this.html.querySelector('.many-video-ad-close-text').innerText = closeText;
this.adDuration = null; // 视频广告的时长, 用于倒计时,
this.player = null;
this.indexVideo = 1; //给广告视频标号
}
_createClass(ManyVideoAdComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.many-video-ad-detail').innerText = this.isEn ? 'For more information' : '查看广告详情';
this.html.querySelector('.limit').innerText = this.isEn ? 'Your browser limits autoplay' : '您的浏览器限制';
this.html.querySelector('.manual').innerText = this.isEn ? 'Please Click' : '自动播放请点击';
el.appendChild(this.html);
}
}, {
key: 'created',
value: function created(player) {
//添加video
var videos = this.adVideoSource.map(function (url, index) {
return '<video id="many-video-ad-content' + (index + 1) + '" style="' + (index === 0 ? 'display: block' : 'display:none') + ';width:100%;height:100%" x5-video-player-type="h5" x5-video-player-fullscreen="false" src="' + url.adVideo + '"></video>';
});
this.html.querySelector('.videos').innerHTML = videos.join(' ');
this.indexVideo = Number(this.indexVideo);
var indexVideo_ = this.indexVideo;
var adVideoSource_ = this.adVideoSource;
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + this.indexVideo);
var videoAdDetak = this.html.querySelector('.many-video-ad-detail');
var adDuration_ele = this.html.querySelector('#many-video-ad-duration');
var self = this;
function getManyVideoAdTime() {
manyVideoAd_ele.removeEventListener('canplay', getManyVideoAdTime);
videoAdDetak.href = adVideoSource_[indexVideo_ - 1].adVideoLink;
manyVideoAd_ele.play().then(function () {
var duration = Math.ceil(manyVideoAd_ele.duration);
adDuration_ele.innerText = duration;
self.setAdInterval();
}).catch(function (err) {
self.html.querySelector('.autoplay-many-video-ad').style.display = 'block';
self.html.querySelector('.icon-player-play').onclick = function () {
self.playManyVideoAd();
self.html.querySelector('.autoplay-many-video-ad').style.display = 'none';
};
});
}
//对浏览器会限制,有时会自动播放失败的判断
var promise = manyVideoAd_ele.play();
if (promise !== undefined) {
promise.then(function () {
manyVideoAd_ele.play(); //播放广告
}).catch(function (error) {
document.querySelector('.autoplay-many-video-ad').style.display = 'block';
manyVideoAd_ele.oncanplay = function () {
var ad_time = Math.ceil(manyVideoAd_ele.duration);
document.querySelector('#many-video-ad-duration').innerText = ad_time;
};
});
}
manyVideoAd_ele.addEventListener('canplay', getManyVideoAdTime);
}
}, {
key: 'ready',
value: function ready(player, e) {
var _this = this;
this.indexVideo = Number(this.indexVideo);
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + this.indexVideo);
var self = this;
manyVideoAd_ele.addEventListener('ended', function (event) {
// self.html.querySelector('.many-video-ad-detail').href=self.adVideoSource[self.indexVideo].adVideoLink
var flag = self.playNext(self);
if (flag == '-1') {
player.play();
}
});
this.html.querySelector('.many-video-ad-close label').onclick = function () {
if (typeof _this.adCloseFunction === 'function') {
_this.adCloseFunction(_this);
} else {
_this.closeManyVideoAd();
}
};
}
// 视频广告倒计时
}, {
key: 'setAdInterval',
value: function setAdInterval(index) {
var _this2 = this;
var adDuration_ele = this.html.querySelector('#many-video-ad-duration');
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + this.indexVideo);
this.adInterval = setInterval(function () {
var duration = Math.ceil(manyVideoAd_ele.duration);
var currentTime = Math.ceil(manyVideoAd_ele.currentTime);
var time = duration - currentTime;
adDuration_ele.innerText = time;
if (time == 1) {
clearInterval(_this2.adInterval);
}
}, 1000);
}
// 暂停视频广告
}, {
key: 'pauseManyVideoAd',
value: function pauseManyVideoAd() {
this.clearAdInterval();
this.html.querySelector('#many-video-ad-content' + this.indexVideo).pause();
}
// 播放视频广告
}, {
key: 'playManyVideoAd',
value: function playManyVideoAd() {
this.setAdInterval();
this.html.querySelector('#many-video-ad-content' + this.indexVideo).play();
}
// 清除视频广告倒计时
}, {
key: 'clearAdInterval',
value: function clearAdInterval() {
this.adInterval !== null && clearInterval(this.adInterval);
this.adInterval = null;
}
// 关闭当前广告并播放下一个视频
}, {
key: 'playNext',
value: function playNext(self) {
if (self.indexVideo >= self.adVideoSource.length) {
self.html.parentNode.removeChild(self.html);
return -1;
}
this.indexVideo = Number(this.indexVideo);
if (document.getElementById('many-video-ad-content' + this.indexVideo) != null) {
document.getElementById('many-video-ad-content' + this.indexVideo).remove();
}
var indexVideo_ = this.indexVideo + 1;
self.html.querySelector('.many-video-ad-detail').href = self.adVideoSource[self.indexVideo].adVideoLink;
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + indexVideo_);
var adDuration_ele = this.html.querySelector('#many-video-ad-duration');
manyVideoAd_ele.style.display = 'block';
if (this.adVideoSource.length >= this.indexVideo) {
this.indexVideo = this.indexVideo + 1;
}
var duration = Math.ceil(manyVideoAd_ele.duration);
adDuration_ele.innerText = duration;
self.setAdInterval();
manyVideoAd_ele.play();
manyVideoAd_ele.addEventListener('ended', function (event) {
var flag = self.playNext(self);
//广告结束之后自动播放主视频
if (flag == '-1') {
document.getElementById(player._options.id).getElementsByTagName('video')[0].play();
}
});
}
// 关闭视频广告
}, {
key: 'closeManyVideoAd',
value: function closeManyVideoAd() {
this.clearAdInterval();
this.html.parentNode.removeChild(this.html);
this.html = null;
//广告结束之后自动播放主视频
document.getElementById(player._options.id).getElementsByTagName('video')[0].play();
}
}]);
return ManyVideoAdComponent;
}();
/**
* 移动端多视频广告组件
*/
var MbManyVideoAdComponent = function () {
/**
* @constructor 移动端多视频广告组件
* @param {String adVideoSource 视频广告播放地址}
* @param {String adLink 广告链接}
* @param {Function adCloseFunction 关闭广告按钮点击出发的函数}
* @param {String closeText 可选参数 关闭按钮中的文字, 默认为 '关闭广告'}
*/
function MbManyVideoAdComponent(adVideoSource, adCloseFunction) {
var closeText = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '关闭广告';
_classCallCheck(this, MbManyVideoAdComponent);
this.adVideoSource = adVideoSource;
this.html = (0, _utils.parseDom)(_mbIndex2.default);
this.adInterval = null;
this.adCloseFunction = adCloseFunction;
this.html.querySelector('.many-video-ad-close-text').innerText = closeText;
this.adDuration = null; // 视频广告的时长, 用于倒计时,
this.player = null;
this.indexVideo = 1; //给广告视频标号
}
_createClass(MbManyVideoAdComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this3 = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.many-video-ad-detail').innerText = this.isEn ? 'For more information' : '查看广告详情';
this.html.querySelector('.limit').innerText = this.isEn ? 'Your browser limits autoplay' : '您的浏览器限制';
this.html.querySelector('.manual').innerText = this.isEn ? 'Please Click' : '自动播放请点击';
el.appendChild(this.html);
el.querySelector('.videosmb');
el.querySelector('.videosmb').setAttribute('preload', 'load');
// 隐藏 controlbar
var controlBar = el.querySelector('.prism-controlbar');
controlBar.className = controlBar.className + ' controlbar-element-hidden';
this.html.querySelector('.icon-player-play').onclick = function () {
_this3.playManyVideoAd();
_this3.html.querySelector('.autoplay-many-video-ad').style.display = 'none';
};
}
}, {
key: 'created',
value: function created(player) {
//添加video
var videos = this.adVideoSource.map(function (url, index) {
return '<video id="many-video-ad-content' + (index + 1) + '" style="' + (index === 0 ? 'display: block' : 'display:none') + ';width:100%;height:100%" x5-video-player-type="h5" x5-video-player-fullscreen="false" src="' + url.adVideo + '"></video>';
});
this.html.querySelector('.videosmb').innerHTML = videos.join(' ');
this.indexVideo = Number(this.indexVideo);
var indexVideo_ = this.indexVideo;
var adVideoSource_ = this.adVideoSource;
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + this.indexVideo);
var videoAdDetak = this.html.querySelector('.many-video-ad-detail');
var self = this;
function getManyVideoAdTime() {
manyVideoAd_ele.removeEventListener('canplay', getManyVideoAdTime);
videoAdDetak.href = adVideoSource_[indexVideo_ - 1].adVideoLink;
self.html.querySelector('#many-video-ad-duration').innerText = Math.ceil(manyVideoAd_ele.duration);
}
manyVideoAd_ele.addEventListener('canplay', getManyVideoAdTime);
}
}, {
key: 'ready',
value: function ready(player) {
var _this4 = this;
this.indexVideo = Number(this.indexVideo);
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + this.indexVideo);
var self = this;
manyVideoAd_ele.addEventListener('ended', function (event) {
var flag = self.playNext(self);
if (flag == '-1') {
player.play();
var controlBar = document.querySelector('.prism-controlbar');
controlBar.className = controlBar.className.replace(' controlbar-element-hidden', '');
}
});
this.html.querySelector('.many-video-ad-close label').onclick = function () {
if (typeof _this4.adCloseFunction === 'function') {
_this4.adCloseFunction(_this4);
} else {
_this4.closeManyVideoAd();
}
};
}
// 视频广告倒计时
}, {
key: 'setAdInterval',
value: function setAdInterval() {
var _this5 = this;
var adDuration_ele = this.html.querySelector('#many-video-ad-duration');
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + this.indexVideo);
this.adInterval = setInterval(function () {
var duration = Math.ceil(manyVideoAd_ele.duration);
var currentTime = Math.ceil(manyVideoAd_ele.currentTime);
var time = duration - currentTime;
adDuration_ele.innerText = time;
if (time == 1) {
clearInterval(_this5.adInterval);
}
}, 1000);
}
// 关闭视频广告
}, {
key: 'closeManyVideoAd',
value: function closeManyVideoAd() {
this.clearAdInterval();
var controlBar = this.html.parentNode.querySelector('.prism-controlbar');
controlBar.className = controlBar.className.replace(' controlbar-element-hidden', '');
this.html.parentNode.removeChild(this.html);
this.html = null;
//广告结束之后自动播放主视频
document.getElementById(player._options.id).getElementsByTagName('video')[0].play();
}
// 清除视频广告倒计时
}, {
key: 'clearAdInterval',
value: function clearAdInterval() {
this.adInterval !== null && clearInterval(this.adInterval);
this.adInterval = null;
}
// 播放视频广告
}, {
key: 'playManyVideoAd',
value: function playManyVideoAd() {
this.setAdInterval();
this.html.querySelector('#many-video-ad-content' + this.indexVideo).play();
}
// 暂停视频广告
}, {
key: 'pauseManyVideoAd',
value: function pauseManyVideoAd() {
this.clearAdInterval();
this.html.querySelector('#many-video-ad-content' + this.indexVideo).pause();
}
// 关闭当前广告并播放下一个视频
}, {
key: 'playNext',
value: function playNext(self) {
if (self.indexVideo >= self.adVideoSource.length) {
self.html.parentNode.removeChild(self.html);
return -1;
}
this.indexVideo = Number(this.indexVideo);
if (document.getElementById('many-video-ad-content' + this.indexVideo) != null) {
document.getElementById('many-video-ad-content' + this.indexVideo).remove();
}
var indexVideo_ = this.indexVideo + 1;
self.html.querySelector('.many-video-ad-detail').href = self.adVideoSource[self.indexVideo].adVideoLink;
var manyVideoAd_ele = this.html.querySelector('#many-video-ad-content' + indexVideo_);
var adDuration_ele = this.html.querySelector('#many-video-ad-duration');
manyVideoAd_ele.style.display = 'block';
if (this.adVideoSource.length >= this.indexVideo) {
this.indexVideo = this.indexVideo + 1;
}
var duration = Math.ceil(manyVideoAd_ele.duration);
adDuration_ele.innerText = duration;
self.setAdInterval();
manyVideoAd_ele.play();
manyVideoAd_ele.addEventListener('ended', function (event) {
var flag = self.playNext(self);
//广告结束之后自动播放主视频
if (flag == '-1') {
document.getElementById(player._options.id).getElementsByTagName('video')[0].play();
var controlBar = document.querySelector('.prism-controlbar');
controlBar.className = controlBar.className.replace(' controlbar-element-hidden', '');
}
});
}
}]);
return MbManyVideoAdComponent;
}();
var defaultComponent = ManyVideoAdComponent;
if (_currentDevice2.default.mobile()) {
defaultComponent = MbManyVideoAdComponent;
}
exports.default = defaultComponent;
/***/ }),
/* 30 */
/***/ (function(module, exports) {
module.exports = "<div class=\"many-video-ad-component\">\n <div class=\"videos\">\n <!-- <video id=\"many-video-ad-content1\" class=\"test\" style=\"display: block\" x5-video-player-type=\"h5\" x5-video-player-fullscreen=\"false\" src=\"https://alivc-demo-cms.alicdn.com/video/videoAD.mp4\"></video>\n <video id=\"many-video-ad-content2\" class=\"test\" style=\"display: none\" x5-video-player-type=\"h5\" x5-video-player-fullscreen=\"false\" src=\"https://player.alicdn.com/resource/player/qupai.mp4\"></video>\n <video id=\"many-video-ad-content3\" class=\"test\" style=\"display: none\" x5-video-player-type=\"h5\" x5-video-player-fullscreen=\"false\" src=\"https://player.alicdn.com/video/guanggao.mp4\"></video> -->\n </div>\n <a class=\"many-video-ad-link\" target=\"_blank\"></a>\n <div class=\"many-video-ad-close\">\n <span id=\"many-video-ad-duration\"></span>\n <label>\n <span class=\"many-video-ad-close-text\"></span>\n <i class=\"iconfont icon-close\"></i>\n </label>\n </div>\n <a class=\"many-video-ad-detail\" target=\"_blank\">查看详情</a>\n <div class=\"autoplay-many-video-ad\">\n <i class=\"iconfont icon-player-play\"></i>\n <span class=\"limit\"></span>\n <span class=\"manual\"></span>\n </div>\n <!-- <div id=\"loadflag\" class=\"prism-loading center\">\n <div class=\"circle\"></div> \n <div class=\"circle1\"></div>\n </div> -->\n</div>";
/***/ }),
/* 31 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(32);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 32 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".many-video-ad-component {\n width: 100%;\n height: 100%;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 2147483647;\n background-color: #000;\n font-size: 12px; }\n .many-video-ad-component #many-video-ad-content {\n width: 100%;\n height: 100%; }\n .many-video-ad-component .many-video-ad-link {\n width: 100%;\n height: 100%;\n display: block;\n position: absolute;\n top: 0;\n left: 0; }\n .many-video-ad-component .many-video-ad-close {\n background-color: rgba(59, 59, 59, 0.85);\n position: absolute;\n top: 15px;\n right: 20px;\n color: #fff;\n line-height: 26px;\n padding: 0 10px;\n user-select: none; }\n .many-video-ad-component .many-video-ad-close #many-video-ad-duration {\n color: #00c1de;\n vertical-align: top;\n font-size: 14px;\n position: relative;\n display: inline-block;\n text-align: right; }\n .many-video-ad-component .many-video-ad-close #many-video-ad-duration::after {\n background-color: #fff;\n position: absolute;\n content: '';\n right: -7px;\n top: 8px;\n bottom: 8px;\n width: 1px; }\n .many-video-ad-component .many-video-ad-close label {\n cursor: pointer;\n display: inline-block; }\n .many-video-ad-component .many-video-ad-close .icon-close {\n font-size: 12px;\n vertical-align: top; }\n @media (min-width: 768px) {\n .many-video-ad-component .many-video-ad-close .icon-close:hover {\n color: #00c1de; } }\n .many-video-ad-component .many-video-ad-close .many-video-ad-close-text {\n padding: 0 5px 0 10px; }\n .many-video-ad-component .many-video-ad-detail {\n position: absolute;\n right: 35px;\n bottom: 30px;\n background-color: rgba(0, 222, 255, 0.85);\n color: #fff;\n padding: 8px 12px;\n user-select: none;\n cursor: pointer;\n transition: background-color .15s; }\n @media (min-width: 768px) {\n .many-video-ad-component .many-video-ad-detail:hover {\n background-color: #00deff; } }\n .many-video-ad-component .autoplay-many-video-ad {\n position: absolute;\n color: #fff;\n top: 50%;\n left: 50%;\n text-align: center;\n padding: 10px;\n border-radius: 5px;\n background-color: rgba(144, 147, 153, 0.85);\n transform: translate(-50%, -50%);\n display: none; }\n .many-video-ad-component .autoplay-many-video-ad i {\n font-size: 42px;\n margin-bottom: 7px;\n display: inline-block;\n cursor: pointer; }\n .many-video-ad-component .autoplay-many-video-ad i + span {\n margin-bottom: 5px; }\n .many-video-ad-component .autoplay-many-video-ad span {\n display: block; }\n\n.controlbar-element-hidden {\n display: none !important; }\n", ""]);
// exports
/***/ }),
/* 33 */
/***/ (function(module, exports) {
module.exports = "<div class=\"many-video-ad-component\" style=\"background-color: transparent;\">\n <div class=\"videosmb\"></div>\n <a class=\"many-video-ad-link\" target=\"_blank\"></a>\n <div class=\"many-video-ad-close\">\n <span id=\"many-video-ad-duration\"></span>\n <label>\n <span class=\"many-video-ad-close-text\"></span>\n <i class=\"iconfont icon-close\"></i>\n </label>\n </div>\n <a class=\"many-video-ad-detail\" target=\"_blank\"></a>\n <div class=\"autoplay-many-video-ad\" style=\"display: block;\">\n <i class=\"iconfont icon-player-play\"></i>\n <span class=\"limit\"></span>\n <span class=\"manual\"></span>\n </div>\n</div>";
/***/ }),
/* 34 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(35);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.MemoryPlayComponent = _index2.default;
/***/ }),
/* 35 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(36);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(37);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 记忆播放组件
*/
var MemoryPlayComponent = function () {
/**
* @constructor 记忆播放组件构造函数
*/
function MemoryPlayComponent() {
var autoPlay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
var getTime = arguments[1];
var saveTimeFunction = arguments[2];
_classCallCheck(this, MemoryPlayComponent);
this.html = (0, _utils.parseDom)(_index2.default);
this.autoPlay = autoPlay;
this.getTime = getTime || this._getTime;
this.saveTimeFunction = saveTimeFunction || this._saveTime;
this.hasMemoryDisplay = false;
}
_createClass(MemoryPlayComponent, [{
key: 'createEl',
value: function createEl(el) {
el.appendChild(this.html);
}
}, {
key: 'ready',
value: function ready(player, e) {
var _this = this;
var playerOptions = player.getOptions();
var memoryVideo = playerOptions.vid || playerOptions.source.replace(/\?.*$/, ''); // 根据视频 vid 或者 source 去存储 localeStorage
var memoryTime = this.getTime(memoryVideo);
memoryTime = memoryTime ? parseInt(memoryTime) : 0;
if (memoryTime !== null && memoryTime !== 0 && !this.hasMemoryDisplay) {
// 标识记忆播放是否有触发, 解决清晰度切换也会触发记忆播放的问题
this.hasMemoryDisplay = true;
if (this.autoPlay) {
player.seek(memoryTime);
if (player.getStatus() !== 'playing') {
player.play();
}
} else {
var memoryVideoTime = this.getVideoTime(memoryTime);
//判断是否是视频播放完了,如果没到,就有拼接的跳转播放
if (memoryTime !== parseInt(player._duration)) {
var memoryDomString = '<div class="memory-play">\n <i class="iconfont icon-close"></i>\n <span>\u4E0A\u6B21\u770B\u5230</span>\n <span>' + memoryVideoTime + '</span>\n <span class="play-jump">\u8DF3\u8F6C\u64AD\u653E</span>\n </div>';
this.html.innerHTML = memoryDomString;
var timeoutMemory = setTimeout(function () {
_this.html.innerHTML = '';
}, 15000);
this.html.querySelector('.icon-close').onclick = function () {
_this.html.innerHTML = '';
clearTimeout(timeoutMemory);
};
this.html.querySelector('.play-jump').onclick = function () {
player.seek(memoryTime);
if (player.getStatus() !== 'playing') {
player.play();
}
_this.html.innerHTML = '';
clearTimeout(timeoutMemory);
};
}
}
}
document.onvisibilitychange = function () {
if (document.visibilityState === 'hidden' && player.getCurrentTime() !== 0) {
_this.saveTimeFunction(memoryVideo, player.getCurrentTime());
console.log(play);
}
};
window.onbeforeunload = function () {
if (player.getCurrentTime() !== 0) {
_this.saveTimeFunction(memoryVideo, player.getCurrentTime());
}
};
}
}, {
key: 'error',
value: function error(player, e) {
this.setMemory(player);
}
}, {
key: 'dispose',
value: function dispose(player, e) {
this.setMemory(player);
}
}, {
key: 'setMemory',
value: function setMemory(player) {
var playerOptions = player.getOptions();
var memoryVideo = playerOptions.vid || playerOptions.source.replace(/\?.*$/, '');
this.saveTimeFunction(memoryVideo, player.getCurrentTime());
}
}, {
key: 'getVideoTime',
value: function getVideoTime(duration) {
var secondTotal = Math.round(duration);
var hour = Math.floor(secondTotal / 3600);
var minute = Math.floor((secondTotal - hour * 3600) / 60);
var second = secondTotal - hour * 3600 - minute * 60;
if (minute < 10) {
minute = '0' + minute;
}
if (second < 10) {
second = '0' + second;
}
return hour === 0 ? minute + ':' + second : hour + ':' + minute + ':' + second;
}
}, {
key: '_getTime',
value: function _getTime(memoryVideo) {
return localStorage.getItem(memoryVideo);
}
}, {
key: '_saveTime',
value: function _saveTime(memoryVideo, currentTime) {
localStorage.setItem(memoryVideo, currentTime);
}
}]);
return MemoryPlayComponent;
}();
exports.default = MemoryPlayComponent;
/***/ }),
/* 36 */
/***/ (function(module, exports) {
module.exports = "<div class=\"memory-play-wrap\"></div>";
/***/ }),
/* 37 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(38);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 38 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".memory-play-wrap {\n position: absolute;\n right: 10px;\n bottom: 55px; }\n .memory-play-wrap .memory-play {\n padding: 13px 20px;\n background-color: #191919;\n background-color: rgba(25, 25, 25, 0.88);\n border-radius: 4px;\n color: #fff;\n font-size: 14px;\n user-select: none; }\n .memory-play-wrap .memory-play .icon-close {\n transition: color .3s;\n font-size: 14px;\n cursor: pointer; }\n @media (min-width: 768px) {\n .memory-play-wrap .memory-play .icon-close:hover {\n color: #00c1de; } }\n .memory-play-wrap .memory-play .play-jump {\n color: #00c1de;\n padding: 5px;\n border-radius: 3px;\n cursor: pointer; }\n @media (min-width: 768px) {\n .memory-play-wrap .memory-play .play-jump:hover {\n background-color: rgba(255, 255, 255, 0.2); } }\n", ""]);
// exports
/***/ }),
/* 39 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(40);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.PauseADComponent = _index2.default;
/***/ }),
/* 40 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(41);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(42);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 暂停图片广告组件
*/
var PauseADComponent = function () {
/**
* @constructor 暂停图片广告组件构造函数
* @param {String coverUrl 封面图片地址}
* @param {String adUrl 广告地址}
*/
function PauseADComponent(coverUrl, adUrl) {
_classCallCheck(this, PauseADComponent);
this.coverUrl = coverUrl;
this.adUrl = adUrl;
this.html = (0, _utils.parseDom)(_index2.default);
}
_createClass(PauseADComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.ad-text').innerText = this.isEn ? 'Ad' : '广告';
var adContent = this.html.querySelector('.ad-content');
var adImg = adContent.querySelector('img');
adContent.setAttribute('href', this.adUrl);
adImg.setAttribute('src', this.coverUrl);
var btnClose = this.html.querySelector('.btn-close');
btnClose.onclick = function () {
_this.html.style.display = 'none';
};
el.appendChild(this.html);
}
}, {
key: 'play',
value: function play(player, e) {
this.html.style.display = 'none';
}
}, {
key: 'pause',
value: function pause(player, e) {
this.html.style.display = 'block';
}
}]);
return PauseADComponent;
}();
exports.default = PauseADComponent;
/***/ }),
/* 41 */
/***/ (function(module, exports) {
module.exports = "<div class=\"pause-ad\">\n <a class=\"btn-close\">\n <i class=\"split-left\"></i>\n <i class=\"split-right\"></i>\n <a>\n <span class=\"ad-text\"></span>\n <a class=\"ad-content\" target=\"_blank\">\n <img />\n </a>\n</div>";
/***/ }),
/* 42 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(43);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 43 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".pause-ad {\n width: 60%;\n height: 50%;\n background: #000;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n position: absolute;\n display: none; }\n .pause-ad .btn-close {\n position: absolute;\n top: 5px;\n right: 5px;\n background-color: #333;\n width: 2px;\n height: 15px;\n padding: 2px 8px;\n cursor: pointer; }\n .pause-ad .btn-close i {\n background-color: #fff;\n width: 2px;\n height: 15px;\n position: absolute; }\n .pause-ad .btn-close .split-left {\n transform: rotate(-45deg); }\n .pause-ad .btn-close .split-right {\n transform: rotate(45deg); }\n .pause-ad .ad-text {\n position: absolute;\n left: 5px;\n top: 5px;\n background-color: #333;\n color: #fff;\n padding: 3px 5px;\n font-size: 14px; }\n .pause-ad .ad-content {\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n justify-content: center; }\n .pause-ad .ad-content img {\n max-width: 100%;\n max-height: 100%; }\n", ""]);
// exports
/***/ }),
/* 44 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(45);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.PlaylistComponent = _index2.default;
/***/ }),
/* 45 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(46);
var _index2 = _interopRequireDefault(_index);
var _list = __webpack_require__(47);
var _list2 = _interopRequireDefault(_list);
__webpack_require__(48);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 播放列表事件
*/
var PlaylistComponentEvent = {
VideoClick: 'plugin-playlist-click-video',
PrevClick: 'plugin-playlist-click-prev',
NextClick: 'plugin-playlist-click-next',
VideoChange: 'plugin-playlist-change'
/**
* 播放列表组件
*/
};
var PlaylistComponent = function () {
/**
* @constructor 播放列表组件构造函数
* @param {Array playlist 播放列表数组}
*/
function PlaylistComponent(playlist) {
_classCallCheck(this, PlaylistComponent);
this.controlHtml = (0, _utils.parseDom)(_index2.default);
this.listHtml = (0, _utils.parseDom)(_list2.default);
this.playlist = playlist;
this.playingVideoIndex = 0;
this.listHideTimeout = null;
}
_createClass(PlaylistComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.controlHtml.querySelector('.player-tooltip.prev').innerText = this.isEn ? 'Previous' : '上一个';
this.controlHtml.querySelector('.player-tooltip.list').innerText = this.isEn ? 'Playlist' : '播放列表';
this.controlHtml.querySelector('.player-tooltip.next').innerText = this.isEn ? 'Next' : '下一个';
var controlbarElement = el.querySelector('.prism-controlbar');
var siblingElement = controlbarElement.querySelector('.prism-time-display');
controlbarElement.insertBefore(this.controlHtml, siblingElement);
this.listHtml.onmouseleave = function () {
_this.listHtml.style.width = 0;
};
this.listHtml.onmouseenter = this.clearHideListTimeout.bind(this);
this.controlHtml.querySelector('.icon-list').onclick = this.tooglePlaylist.bind(this);
this.listHtml.querySelector('.list').innerHTML = this.computedListDom(this.playlist);
var source = player.getOptions() && player.getOptions().source;
var defaultPlayIndex = 0;
if (source) {
defaultPlayIndex = this.playlist.findIndex(function (item) {
return item.source === source;
});
defaultPlayIndex = defaultPlayIndex > -1 ? defaultPlayIndex : 0;
this.playingVideoIndex = defaultPlayIndex > -1 ? defaultPlayIndex : 0;
}
this.listHtml.querySelector('.list').childNodes[0].className = 'video-item active';
el.appendChild(this.listHtml);
}
}, {
key: 'ready',
value: function ready(player, e) {
var _this2 = this;
this.controlHtml.querySelector('.icon-skip-previous').onclick = function () {
player && player.trigger(PlaylistComponentEvent.PrevClick, {
currentIndex: Math.max(_this2.playingVideoIndex - 1, 0)
});
if (_this2.playingVideoIndex === 0) {
_this2.playlistTip(_this2.isEn ? 'Already the first one~' : '已经是第一个了~', player._el);
return;
}
_this2.playVideo(player, _this2.playingVideoIndex - 1);
};
this.controlHtml.querySelector('.icon-skipnext').onclick = function () {
player && player.trigger(PlaylistComponentEvent.NextClick, {
currentIndex: Math.min(_this2.playingVideoIndex + 1, _this2.playlist.length - 1)
});
if (_this2.playingVideoIndex === _this2.playlist.length - 1) {
_this2.playlistTip(_this2.isEn ? 'Already the last one~' : '已经是最后一个了~', player._el);
return;
}
_this2.playVideo(player, _this2.playingVideoIndex + 1);
};
this.listHtml.querySelector('.list').onclick = function (e) {
var target = e.target;
var videoIndex = parseInt(target.getAttribute('data-index'));
player && player.trigger(PlaylistComponentEvent.VideoClick, {
currentIndex: _this2.playingVideoIndex,
clickedIndex: videoIndex
});
if (target.className === 'video-item') {
_this2.playVideo(player, videoIndex);
}
};
}
/* clear 自动隐藏右侧播放列表 timeout 的函数 */
}, {
key: 'clearHideListTimeout',
value: function clearHideListTimeout() {
if (this.listHideTimeout !== null) {
clearTimeout(this.listHideTimeout);
this.listHideTimeout = null;
}
}
/* 播放 playlist 中 index 为 @param videoIndex 的视频 */
}, {
key: 'playVideo',
value: function playVideo(player, videoIndex) {
if (this.playingVideoIndex === videoIndex) {
return;
}
player && player.trigger(PlaylistComponentEvent.VideoChange, { currentIndex: videoIndex });
this.playingVideoIndex = parseInt(videoIndex);
player.loadByUrl(this.playlist[videoIndex].source);
this.listHtml.querySelector('.video-item.active').className = 'video-item';
this.listHtml.querySelector('.list').childNodes[videoIndex].className = 'video-item active';
}
/* 点击 controlbar 上的播放列表按钮显示隐藏播放列表 */
}, {
key: 'tooglePlaylist',
value: function tooglePlaylist() {
var _this3 = this;
this.clearHideListTimeout();
if (this.listHtml.style.width === '30%') {
this.listHtml.style.width = 0;
} else {
this.listHtml.style.width = '30%';
this.listHideTimeout = setTimeout(function () {
_this3.listHtml.style.width = 0;
}, 5000);
}
}
/* 播放器提示信息 */
}, {
key: 'playlistTip',
value: function playlistTip(msg, el) {
var tipElement = document.createElement('div');
tipElement.className = 'playlist-skip-tip';
tipElement.innerText = msg;
el.appendChild(tipElement);
setTimeout(function () {
el.removeChild(tipElement);
}, 3000);
}
}, {
key: 'computedListDom',
value: function computedListDom(playlist) {
var domList = playlist.map(function (item, index) {
return '<div class="video-item" data-index="' + index + '" title="' + item.name + '">' + item.name + '</div>';
});
return domList.join('');
}
}]);
return PlaylistComponent;
}();
exports.default = PlaylistComponent;
/***/ }),
/* 46 */
/***/ (function(module, exports) {
module.exports = "<div class=\"playlist-component\">\n <i class=\"iconfont icon-skip-previous\"></i>\n <div class=\"player-tooltip prev\">上一个</div>\n <i class=\"iconfont icon-list\"></i>\n <div class=\"player-tooltip list\">播放列表</div>\n <i class=\"iconfont icon-skipnext\"></i>\n <div class=\"player-tooltip next\">下一个</div> \n</div>";
/***/ }),
/* 47 */
/***/ (function(module, exports) {
module.exports = "<div class=\"playlist-content\">\n <div class=\"list\"></div>\n</div>";
/***/ }),
/* 48 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(49);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 49 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".playlist-component {\n color: #fff;\n float: left;\n height: 35px;\n margin-top: 5px;\n display: flex;\n align-items: center;\n position: relative; }\n .playlist-component i {\n color: #fff;\n display: inline-block;\n font-size: 22px;\n display: block;\n margin-top: 7px;\n cursor: pointer; }\n .playlist-component i + i {\n margin-left: 3px; }\n @media (min-width: 768px) {\n .playlist-component i:hover + .player-tooltip {\n display: block; } }\n .playlist-component .player-tooltip.prev {\n left: -10px; }\n .playlist-component .player-tooltip.list {\n left: 5px; }\n .playlist-component .player-tooltip.next {\n right: -12px; }\n\n.playlist-content {\n position: absolute;\n right: 0;\n width: 0px;\n padding-bottom: 48px;\n box-sizing: border-box;\n height: 100%;\n transition: all .38s ease-in-out;\n overflow: hidden; }\n .playlist-content .list {\n background-color: #000;\n background-color: rgba(0, 0, 0, 0.3);\n height: 100%;\n overflow: auto; }\n .playlist-content .list .video-item {\n color: #fff;\n padding: 0px 10px;\n line-height: 35px;\n font-size: 14px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n cursor: pointer; }\n .playlist-content .list .video-item.active {\n background-color: #000;\n color: #00ddff; }\n @media (min-width: 768px) {\n .playlist-content .list .video-item:hover {\n background-color: #000;\n color: #00ddff; } }\n\n.player-tooltip {\n position: absolute;\n display: none;\n font-size: 12px;\n color: #fff;\n line-height: 28px;\n letter-spacing: 0;\n text-align: center;\n background: #3c3c3c;\n box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.1);\n height: 28px;\n top: -48px;\n padding: 0 5px;\n white-space: nowrap; }\n\n.playlist-skip-tip {\n padding: 5px 15px;\n position: absolute;\n top: 50%;\n left: 50%;\n z-index: 30;\n line-height: 30px;\n font-size: 14px;\n border-radius: 4px;\n background: rgba(255, 255, 255, 0.8);\n color: #000;\n text-align: center;\n transform: translate(-50%, -50%); }\n", ""]);
// exports
/***/ }),
/* 50 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(51);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.PreviewVodComponent = _index2.default;
/***/ }),
/* 51 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(52);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(53);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 结合点播服务的试看组件
*/
var PreviewVodComponent = function () {
/**
* @constructor 试看组件构造函数
* @param {Number previewDuration 试看时长单位为秒, 传入0表示可以完整观看}
* @param {String previewEndHtml 可选参数, 插入到试看结束之后显示的 dom 字符串, 默认为 null}
* @param {String previewBarHtml 可选参数, 插入到免费试看多少分钟之后的 html}
*/
function PreviewVodComponent(previewDuration) {
var previewEndHtml = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
var previewBarHtml = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
_classCallCheck(this, PreviewVodComponent);
this.previewDuration = previewDuration;
this.html = (0, _utils.parseDom)(_index2.default);
// 在试看结束之后, 如果用户自定义
if (previewEndHtml !== null) {
this.insertHTtml(previewEndHtml, 'previewEndHtml');
}
if (previewBarHtml !== null) {
this.insertHTtml(previewBarHtml, 'previewBarHtml');
}
}
_createClass(PreviewVodComponent, [{
key: 'play',
value: function play(player) {
if (this.previewEnd) {
player._el.querySelector('.center').classList.remove('preview-hide');
player.seek(0);
this.previewEnd = false;
}
}
}, {
key: 'insertHTtml',
value: function insertHTtml(idOrHmtl, params) {
var parentSelector = params === 'previewEndHtml' ? '.preview-custom' : '.preview-custom-bar';
var parentEle = this.html.querySelector(parentSelector);
if (typeof idOrHmtl === 'string') {
if (idOrHmtl[0] === '#') {
var templeteEle = document.querySelector(idOrHmtl);
if (templeteEle) {
parentEle.innerHTML = templeteEle.innerHTML;
} else {
console.warn('[aliplayer components warn]: Invalid parameter ' + params + ', can\'t find element by this id');
}
} else {
parentEle.innerHTML = idOrHmtl;
}
} else {
console.warn('[aliplayer components warn]: Invalid parameter ' + params + ', ' + params + ' must be a string type');
}
}
}, {
key: 'ready',
value: function ready(player) {
var videoDuration = parseInt(player.getDuration());
this.videoDuration = videoDuration;
if (!this.invalidPreview && this.previewDuration >= videoDuration) {
this.invalidPreview = true;
console.warn('[aliplayer components warn]: Invalid parameter previewDuration, previewDuration must be less than the video duration!');
}
if (this.previewDuration !== 0 && this.previewDuration < videoDuration) {
this.html.style.display = 'block';
}
}
}, {
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
console.log(this.html.querySelector('.preview-default'));
var previewDefaultEle = this.html.querySelector('.preview-default');
if (previewDefaultEle) {
previewDefaultEle.innerText = this.isEn ? 'Preview is over' : '试看已结束';
}
this.html.querySelector('.can-preview').innerText = this.isEn ? 'Try' : '可试看';
var previewDuration = this.previewDuration;
if (previewDuration === 0) {
this.html.style.display = 'none';
}
var previewDuration_text = previewDuration / 60;
var decimal = previewDuration_text.toString().split('.')[1];
if (decimal && decimal.length > 1) {
previewDuration_text = ' ' + previewDuration + (this.isEn ? ' senconds' : ' 秒');
} else {
previewDuration_text = ' ' + previewDuration_text + (this.isEn ? ' minutes' : ' 分钟');
}
if (previewDuration < 60) {
previewDuration_text = ' ' + previewDuration + (this.isEn ? ' senconds' : ' 秒');
}
// 考虑到可能不是整分钟数, 整分钟数去掉小数点后面的 0
this.html.querySelector('.preview-time').innerText = previewDuration_text;
var videoSiblingElement = el.querySelector('video').nextElementSibling;
if (videoSiblingElement) {
el.insertBefore(this.html, videoSiblingElement);
} else {
el.appendChild(this.html);
}
var closeSpan = this.html.querySelector('.preview-vod-close');
closeSpan.addEventListener('click', function () {
_this.html.querySelector('.preview-component-tip').style.display = 'none';
});
player.setPreviewTime(Number(this.previewDuration));
}
}, {
key: 'closePreviewLayer',
value: function closePreviewLayer() {
this.previewEnd = false;
this.html.querySelector('.preview-component-layer').style.display = 'none';
}
}, {
key: 'timeupdate',
value: function timeupdate(player) {
if (!this.previewEnd && this.previewDuration !== 0 && this.previewDuration < this.videoDuration) {
var previewTime = player.getPreviewTime();
var currentTime = player.getCurrentTime();
if (Math.floor(previewTime) < currentTime) {
this.previewEnd = true;
player._el.querySelector('.center') && player._el.querySelector('.center').classList.add('preview-hide');
player.seek(previewTime);
player.pause();
this.html.querySelector('.preview-component-layer').style.display = 'block';
}
}
}
}, {
key: 'ended',
value: function ended(player, e) {
if (player.isPreview()) {
this.html.querySelector('.preview-component-layer').style.display = 'block';
}
}
}]);
return PreviewVodComponent;
}();
exports.default = PreviewVodComponent;
/***/ }),
/* 52 */
/***/ (function(module, exports) {
module.exports = "<div class=\"preview-vod-component\">\n <div class=\"preview-component-layer\">\n <div class=\"preview-custom\">\n <p class=\"preview-default\"></p>\n </div>\n </div>\n <div class=\"preview-component-tip\">\n <span class=\"can-preview\"></span><span class=\"preview-time\"></span> <span class=\"preview-custom-bar\">Become VIP Watch Full Version </span>\n <span class=\"preview-vod-close\">x</span>\n </div>\n</div>";
/***/ }),
/* 53 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(54);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 54 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".preview-hide {\n display: none !important; }\n\n.preview-vod-component {\n display: none; }\n .preview-vod-component .preview-component-layer {\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n background-color: rgba(0, 0, 0, 0.8);\n z-index: 9998;\n box-sizing: border-box;\n padding: 20px 20px 70px;\n display: none; }\n .preview-vod-component .preview-component-layer .preview-close {\n position: absolute;\n right: 18px;\n top: 15px;\n border-radius: 50%;\n color: #000;\n background: white;\n width: 20px;\n height: 20px;\n text-align: center;\n line-height: 18px;\n vertical-align: top;\n color: #333;\n box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);\n cursor: pointer;\n z-index: 9998; }\n .preview-vod-component .preview-component-layer .preview-custom {\n width: 100%;\n height: 100%;\n position: relative; }\n .preview-vod-component .preview-component-layer .preview-custom .preview-default {\n font-size: 14px;\n color: #fff;\n text-align: center;\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n width: 100%; }\n .preview-vod-component .preview-custom {\n color: #fff;\n font-size: 14px; }\n .preview-vod-component .preview-component-tip {\n position: absolute;\n bottom: 50px;\n left: 25px;\n border-radius: 15px;\n background-color: #333;\n color: #fff;\n line-height: 26px;\n font-size: 14px;\n padding: 0 12px;\n z-index: 9998; }\n .preview-vod-component .preview-vod-close {\n font-size: 18px;\n cursor: pointer;\n padding: 0 5px;\n font-family: PingFangSC-Regular, sans-serif;\n font-weight: 200; }\n .preview-vod-component .preview-vod-close:hover {\n color: #00c1de; }\n", ""]);
// exports
/***/ }),
/* 55 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(56);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.ProgressComponent = _index2.default;
/***/ }),
/* 56 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(57);
var _index2 = _interopRequireDefault(_index);
var _utils = __webpack_require__(2);
__webpack_require__(58);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 视频打点组件
*/
var ProgressMarker = function () {
function ProgressMarker() {
_classCallCheck(this, ProgressMarker);
this.html = (0, _utils.parseDom)(_index2.default);
this.imgEle = this.html.querySelector('.img-wrap img');
this.timeEle = this.html.querySelector('.time');
this.playBtnEle = this.html.querySelector('.pregress-play-btn');
this.describeEle = this.html.querySelector('.describe');
this.timer = null;
this.currentOffset = null;
}
_createClass(ProgressMarker, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
el.appendChild(this.html);
this.html.onmouseenter = function () {
if (_this.timer !== null) {
clearTimeout(_this.timer);
_this.timer = null;
}
};
this.html.onmouseleave = function () {
_this.html.style.display = 'none';
};
this.html.onclick = function () {
_this.html.style.display = 'none';
};
this.html.querySelector('.pregress-play-btn').addEventListener('click', function () {
player.seek(_this.currentOffset);
});
}
}, {
key: 'markerDotOver',
value: function markerDotOver(player, data) {
var maxWidth = player._el.clientWidth;
var componentLeft = 'calc(' + data.left * 100 + '% - 10px)';
if (maxWidth * data.left + 323 > maxWidth) {
componentLeft = maxWidth - 330 + 'px';
this.html.querySelector('.icon-arrowdown').style.left = maxWidth * data.left - maxWidth + 317 + 'px';
} else {
this.html.querySelector('.icon-arrowdown').style.left = '-2px';
}
var _data$progressMarker = data.progressMarker,
coverUrl = _data$progressMarker.coverUrl,
title = _data$progressMarker.title,
describe = _data$progressMarker.describe,
offset = _data$progressMarker.offset;
this.currentOffset = offset;
this.html.style.left = componentLeft;
this.imgEle.src = coverUrl;
this.timeEle.innerText = title;
this.describeEle.innerText = describe;
this.html.style.display = 'block';
}
}, {
key: 'markerDotOut',
value: function markerDotOut(player, data) {
var _this2 = this;
this.timer = setTimeout(function () {
_this2.html.style.display = 'none';
}, 100);
}
}]);
return ProgressMarker;
}();
exports.default = ProgressMarker;
/***/ }),
/* 57 */
/***/ (function(module, exports) {
module.exports = "<div class=\"progress-component\">\n <div class=\"progress-content clearfix\">\n <div class=\"img-wrap\"><img /></div> \n\n <div class=\"info\">\n <div class=\"time\"></div>\n <div class=\"describe\"></div>\n </div>\n\n <i href=\"\" target=\"_blank\" class=\"iconfont icon-play pregress-play-btn\"></i>\n </div>\n <i class=\"iconfont icon-arrowdown\"></i>\n</div>";
/***/ }),
/* 58 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(59);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 59 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, "@font-face {\n font-family: \"iconfont\";\n src: url(" + __webpack_require__(4) + ");\n /* IE9 */\n src: url(" + __webpack_require__(4) + "#iefix) format(\"embedded-opentype\"), url(\"data:application/x-font-woff2;charset=utf-8;base64,d09GMgABAAAAAALoAAsAAAAABswAAAKZAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHEIGVgCDBgqBLIEoATYCJAMMCwgABCAFhG0HPxv3BciemjwJBBawWJiKrz0ASDwe/hv7dt/MfNW2KmnPdtG6CbVE49AhkkRLp5FIhAwheQn/z+kv/1pWQYEwj7X+Uuyl/nTcdSTtTi8NcwkH30gwCtRYSyHREE3ufj9P1OLQShNpd5+4d/rneReO/SzLZW3rorEmfwww7rwLcKxFEQ2RQLxh7AKXcJhA07wmodOhiRQqVFijAvHU1GVUmAsrCsvVhWrNwiLeqKinV+kQr8Pvx397KSSpZNbEyyeDGur5VflDWJ2tols+IUKAyyvI2IUU4k5t+hpBML6gaRfbS6uKkOaK/T+hXndWd/rHS0SVVd0Gm9CWbsrgqgh+00EB8vtVFGxALmYoJOTctiY+K0kvXH6mrr7SNz/Z6+9Zx5qJtFlNxSWTO6vj1HYuhJefJ9ftXh9abHpfLGqU77bG13rmtKH98PROBBAh724RzHCxLE2XTr/nplZqkQ6eox7Wz9KPuBAIal+/fLw7HX+FxQX8PFYXDpmtiii/QP1UnuDXdSohKNxkuXJR7VqrA9nqbYxMaGpihrB/6Hm8c9K7mlA3SZHUzCGrWyULu4uKln1U1R2gacfw8pYRRhClgW1bAKFvD0nXN2R9R2Rhn1Ax9YuqfgQ0XYmyDVvWY0r9DMsca6DMgalSjzhuLkW1CaxPOTLLmkJpBrPAjEEsHC3mhrGH2RxTgmk9zjkBwqgLQ+A47DgUfEYtrPKwwbnfFomQuheFVeoiyQkGk3GYBijmAJOK8hC/NSeVPp+A6aY4ZKyFU1PPwJiA2T2ICYv2IIftXi/OvTwTmKaL4zgCEAzlAkOgH+ZwUMCv72fBVFyYMSLpaxOxm5G+9vD6Tvf7tkGTNSlHihxF9z5jdEZzenvNKvXnRN+R5xACAAAA\") format(\"woff2\"), url(" + __webpack_require__(60) + ") format(\"woff\"), url(" + __webpack_require__(61) + ") format(\"truetype\"), url(" + __webpack_require__(62) + "#iconfont) format(\"svg\");\n /* iOS 4.1- */ }\n\n.iconfont {\n font-family: \"iconfont\" !important;\n font-size: 16px;\n font-style: normal;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.icon-play:before {\n content: \"\\E726\"; }\n\n.icon-arrowdown:before {\n content: \"\\E623\"; }\n\n.clearfix:before, .clearfix:after {\n content: \"\";\n display: table;\n line-height: 0; }\n\n.clearfix:after {\n clear: both; }\n\n.clearfix {\n *zoom: 1; }\n\n.progress-component {\n padding: 8px;\n background-color: rgba(0, 0, 0, 0.35);\n position: absolute;\n display: none;\n box-sizing: border-box;\n bottom: 55px;\n font-size: 12px;\n color: #fff;\n height: 74px;\n z-index: 10; }\n .progress-component .progress-content {\n height: 100%;\n position: relative;\n padding-right: 45px; }\n .progress-component .img-wrap {\n float: left;\n width: 100px;\n text-align: center;\n border: 1px solid rgba(0, 0, 0, 0.6);\n height: 100%; }\n .progress-component .img-wrap img {\n vertical-align: top;\n max-width: 100%;\n max-height: 100%;\n object-fit: contain; }\n .progress-component .info {\n float: left;\n padding-left: 10px;\n width: 150px; }\n .progress-component .info .describe {\n line-height: 18px;\n margin-top: 8px;\n height: 36px;\n overflow: hidden; }\n .progress-component .pregress-play-btn {\n display: inline-block;\n position: absolute;\n right: 6px;\n bottom: 0px;\n font-size: 28px;\n color: #ca7838;\n cursor: pointer; }\n .progress-component .icon-arrowdown {\n left: -2px;\n position: absolute;\n font-size: 31px;\n color: rgba(0, 0, 0, 0.35);\n line-height: 6px;\n top: 100%; }\n", ""]);
// exports
/***/ }),
/* 60 */
/***/ (function(module, exports) {
module.exports = "data:application/font-woff;base64,d09GRgABAAAAAARoAAsAAAAABswAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAADMAAABCsP6z7U9TLzIAAAE8AAAARAAAAFY8mUkYY21hcAAAAYAAAABWAAABhmkn0RRnbHlmAAAB2AAAAJEAAACsoFCg7WhlYWQAAAJsAAAALwAAADYU+6wjaGhlYQAAApwAAAAeAAAAJAfeA4VobXR4AAACvAAAAAwAAAAMDAEAAGxvY2EAAALIAAAACAAAAAgADgBWbWF4cAAAAtAAAAAeAAAAIAEQADBuYW1lAAAC8AAAAUUAAAJtPlT+fXBvc3QAAAQ4AAAALgAAAD/D5yXjeJxjYGRgYOBikGPQYWB0cfMJYeBgYGGAAJAMY05meiJQDMoDyrGAaQ4gZoOIAgCKIwNPAHicY2BkYWCcwMDKwMHUyXSGgYGhH0IzvmYwYuRgYGBiYGVmwAoC0lxTGByeKT9XY27438AQw9zA0AAUZgTJAQDi6gwteJztkMENgDAMAy9p6QOxBRLiwUC8GJ+OUdwUtsDSxYqTl4EJSOIQGezC6DqVWuSJOfIcP0Vu+L3WrTX4XDLdSrhrFH4tMfd3897WoDdbtwH+ADzlDm4AAHicTYu7DcIwGITvt/FDjiIEQnFtRTItBQTmQGIBJskWbOQeUURykyI7pEKGP12uuu8eILDEQB8IgIIXQ7kzvZdYAr9+A9mjgkfLvYZp4DtcI2TEkQ2jhmwOW9Lxsjt3XiCVWSlyKZFTqswpl5E55EyBeXxaO9m6tvKxlKvx97RaZX6JyuzNSxtHN2c0/rNfLF8AAAB4nGNgZGBgAGLxnctexvPbfGXgZmEAgRvvTIQR9P8GFgbmBiCXg4EJJAoAMOgKOgB4nGNgZGBgbvjfwBDDAmQxMLAwMIBpJMAMAEciAm0AAAQAAAAEAAAABAEAAAAAAAAADgBWeJxjYGRgYGBmUAFiEGACYi4gZGD4D+YzAAAMZAFBAAB4nGWPTU7DMBCFX/oHpBKqqGCH5AViASj9EatuWFRq911036ZOmyqJI8et1ANwHo7ACTgC3IA78EgnmzaWx9+8eWNPANzgBx6O3y33kT1cMjtyDRe4F65TfxBukF+Em2jjVbhF/U3YxzOmwm10YXmD17hi9oR3YQ8dfAjXcI1P4Tr1L+EG+Vu4iTv8CrfQ8erCPuZeV7iNRy/2x1YvnF6p5UHFockikzm/gple75KFrdLqnGtbxCZTg6BfSVOdaVvdU+zXQ+ciFVmTqgmrOkmMyq3Z6tAFG+fyUa8XiR6EJuVYY/62xgKOcQWFJQ6MMUIYZIjK6Og7VWb0r7FDwl57Vj3N53RbFNT/c4UBAvTPXFO6stJ5Ok+BPV8bUnV0K27LnpQ0kV7NSRKyQl7WtlRC6gE2ZVeOEXpc0Yk/KGdI/wAJWm7IAAAAeJxjYGKAAC4G7ICZkYmRmZGFgS+xqCi/PCW/PE83Ob+gkqUgJ7GSgQEAYa8HrwAA"
/***/ }),
/* 61 */
/***/ (function(module, exports) {
module.exports = "data:application/x-font-ttf;base64,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"
/***/ }),
/* 62 */
/***/ (function(module, exports) {
module.exports = ""
/***/ }),
/* 63 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(64);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.QualityComponent = _index2.default;
/***/ }),
/* 64 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(65);
var _index2 = _interopRequireDefault(_index);
var _qualityModal = __webpack_require__(66);
var _qualityModal2 = _interopRequireDefault(_qualityModal);
__webpack_require__(67);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 切换清晰度组件
*/
var QualityComponent = function () {
function QualityComponent(getQuality) {
_classCallCheck(this, QualityComponent);
this.html = (0, _utils.parseDom)(_index2.default);
this.modalHtml = (0, _utils.parseDom)(_qualityModal2.default);
this.hasCreated = false;
this.definition = '';
this.getQuality = getQuality;
}
_createClass(QualityComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.current-quality').innerText = this.isEn ? 'Resolution' : '清晰度';
this.modalHtml.querySelector('.switchimg').innerText = this.isEn ? 'Switching to you for' : '正在为您切换到';
this.modalHtml.querySelector('.wait').innerText = this.isEn ? 'Please wait...' : '请稍后...';
var eleControlbar = el.querySelector('.prism-controlbar');
eleControlbar.appendChild(this.html);
el.appendChild(this.modalHtml);
}
}, {
key: 'setCurrentQuality',
value: function setCurrentQuality(quality, def) {
var currentQuality = this.html.querySelector('.current-quality');
currentQuality.innerText = quality;
currentQuality.dataset.def = def;
this.definition = def;
var qualityListEle = this.html.querySelector('.quality-list');
var currentEle = qualityListEle.querySelector('.current');
if (currentEle) {
currentEle.className = '';
}
var li_target = qualityListEle.querySelector('li[data-def="' + def + '"]');
if (li_target) {
li_target.className = 'current';
}
}
}, {
key: 'created',
value: function created(player) {
var _this = this;
this._urls = player._urls;
var currentQualityEle = this.html.querySelector('.current-quality');
var qualityListEle = this.html.querySelector('.quality-list');
var lis_ele = this._urls.map(function (url) {
return '<li data-def="' + url.definition + '">' + url.desc + '</li>';
});
this.html.querySelector('.quality-list').innerHTML = lis_ele.join('');
console.log(this.definition);
if (this.hasCreated == false && this.definition) {
var li_target = qualityListEle.querySelector('li[data-def="' + this.definition + '"]');
li_target.className = 'current';
}
this.hasCreated = true;
var timeId = null;
currentQualityEle.onclick = function () {
var listVisible = qualityListEle.style.display !== 'none';
if (listVisible) {
qualityListEle.style.display = 'none';
} else {
qualityListEle.style.display = 'block';
}
};
currentQualityEle.onmouseleave = function () {
if (timeId) clearTimeout(timeId);
timeId = setTimeout(function () {
qualityListEle.style.display = 'none';
}, 150);
};
qualityListEle.onmouseenter = function () {
clearTimeout(timeId);
};
qualityListEle.onmouseleave = function () {
if (timeId) clearTimeout(timeId);
timeId = setTimeout(function () {
qualityListEle.style.display = 'none';
}, 150);
};
qualityListEle.onclick = function (_ref) {
var target = _ref.target;
var definition = target.dataset.def;
var desc = target.innerText;
if (definition && target.className !== 'current') {
var url = Array.isArray(_this._urls) ? _this._urls.filter(function (url) {
return url.definition === definition;
})[0] : _this._urls.find(function (url) {
return url.definition === definition;
});
if (url) {
(0, _utils.cookieSet)('selectedStreamLevel', url.definition, 365);
if (player._switchLevel && !player._options.isLive) {
player._switchLevel(url.Url);
} else {
player._loadByUrlInner(url.Url, player.getCurrentTime(), true /*autoPlay*/, true /* isSwitchLevel */);
}
_this.setCurrentQuality(url.desc, url.definition);
_this.modalHtml.style.display = 'block';
_this.modalHtml.querySelector('span.current-quality-tag').innerText = url.desc;
}
}
//点击切换清晰度时,调用这个方法
_this.getQuality(definition, desc);
};
}
}, {
key: 'ready',
value: function ready(player) {
this.modalHtml.style.display = 'none';
// 隐藏设置里面的倍速播放
var settingEle = document.querySelector('.prism-setting-item.prism-setting-quality');
if (settingEle) {
settingEle.classList.add('player-hidden');
}
}
}]);
return QualityComponent;
}();
exports.default = QualityComponent;
/***/ }),
/* 65 */
/***/ (function(module, exports) {
module.exports = "<div class=\"quality-components\">\n <div class=\"current-quality\" data-ref=\"\"></div>\n <ul class=\"quality-list\">\n </ul>\n</div>";
/***/ }),
/* 66 */
/***/ (function(module, exports) {
module.exports = "<div class=\"quality-modal\">\n <span class=\"switchimg\"></span> <span class=\"current-quality-tag\"></span> , <span class=\"wait\"></span>\n</div>";
/***/ }),
/* 67 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(68);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 68 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".player-hidden {\n display: none !important; }\n\n.quality-components {\n float: right;\n color: #fff;\n height: 35px;\n position: relative;\n box-sizing: border-box;\n margin-top: 4px; }\n\n.current-quality {\n display: flex;\n height: 100%;\n align-items: center;\n justify-content: center;\n width: 70px;\n cursor: pointer; }\n\n.quality-list {\n position: absolute;\n bottom: 46px;\n display: none;\n padding: 0;\n margin: 0;\n list-style: none; }\n .quality-list li {\n text-align: center;\n width: 70px;\n line-height: 30px;\n background-color: rgba(0, 0, 0, 0.6);\n cursor: pointer; }\n .quality-list li.current {\n color: #00c1de; }\n .quality-list li + li {\n border-top: 1px solid rgba(78, 78, 78, 0.3); }\n .quality-list li:hover {\n background-color: rgba(0, 0, 0, 0.5); }\n\n.quality-modal {\n position: absolute;\n bottom: 20%;\n left: 5%;\n background-color: rgba(0, 0, 0, 0.6);\n border-radius: 5px;\n color: #fff;\n padding: 10px 15px;\n font-size: 14px;\n display: none; }\n .quality-modal span.current-quality-tag {\n color: #00c1de; }\n\n@media (max-width: 768px) {\n .current-quality {\n width: 40px; }\n .quality-list li {\n width: 45px; } }\n", ""]);
// exports
/***/ }),
/* 69 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(70);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.RateComponent = _index2.default;
/***/ }),
/* 70 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(71);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(72);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 倍速播放组件
*/
var RateComponent = function () {
/**
* @constructor 倍速播放组件构造函数
*/
function RateComponent() {
_classCallCheck(this, RateComponent);
this.html = (0, _utils.parseDom)(_index2.default);
}
_createClass(RateComponent, [{
key: 'createEl',
value: function createEl(el) {
var eleControlbar = el.querySelector('.prism-controlbar');
eleControlbar.appendChild(this.html);
}
}, {
key: 'ready',
value: function ready(player, e) {
var currentRateEle = this.html.querySelector('.current-rate');
var rateListEle = this.html.querySelector('.rate-list');
var timeId = null;
// 隐藏设置里面的倍速播放
var settingRate = document.querySelector('.prism-setting-item.prism-setting-speed');
if (settingRate) {
settingRate.classList.add('player-hidden');
}
currentRateEle.onclick = function () {
rateListEle.style.display = 'block';
};
currentRateEle.onmouseleave = function () {
timeId = setTimeout(function () {
rateListEle.style.display = 'none';
}, 100);
};
rateListEle.onmouseenter = function () {
clearTimeout(timeId);
};
rateListEle.onmouseleave = function () {
rateListEle.style.display = 'none';
};
rateListEle.onclick = function (_ref) {
var target = _ref.target;
var rate = target.dataset.rate;
if (rate) {
player.setSpeed(rate);
if (target.className !== 'current') {
var currentEle = rateListEle.querySelector('.current');
if (currentEle) {
currentEle.className = '';
}
target.className = 'current';
}
rateListEle.style.display = 'none';
currentRateEle.innerText = rate + 'x';
}
};
}
}]);
return RateComponent;
}();
exports.default = RateComponent;
/***/ }),
/* 71 */
/***/ (function(module, exports) {
module.exports = "<div class=\"rate-components\">\n <div class=\"current-rate\">1.0x</div>\n <ul class=\"rate-list\">\n <li data-rate=\"2.0\">2.0x</li>\n <li data-rate=\"1.5\">1.5x</li>\n <li data-rate=\"1.25\">1.25x</li>\n <li data-rate=\"1.0\" class=\"current\">1.0x</li>\n <li data-rate=\"0.5\">0.5x</li>\n </ul>\n</div>";
/***/ }),
/* 72 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(73);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 73 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".player-hidden {\n display: none !important; }\n\n.rate-components {\n float: right;\n color: #fff;\n height: 35px;\n position: relative;\n box-sizing: border-box;\n margin-top: 5px; }\n\n.current-rate {\n display: flex;\n height: 100%;\n align-items: center;\n justify-content: center;\n width: 70px;\n cursor: pointer; }\n\n.rate-list {\n position: absolute;\n bottom: 46px;\n display: none;\n padding: 0;\n margin: 0;\n list-style: none; }\n .rate-list li {\n text-align: center;\n width: 70px;\n line-height: 30px;\n background-color: rgba(0, 0, 0, 0.6);\n cursor: pointer; }\n .rate-list li.current {\n color: #00c1de; }\n .rate-list li + li {\n border-top: 1px solid rgba(78, 78, 78, 0.3); }\n .rate-list li:hover {\n background-color: rgba(0, 0, 0, 0.5); }\n\n@media (max-width: 768px) {\n .current-rate {\n width: 40px; }\n .rate-list li {\n width: 43px; } }\n", ""]);
// exports
/***/ }),
/* 74 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(75);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.RotateMirrorComponent = _index2.default;
/***/ }),
/* 75 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(76);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(77);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 旋转镜像组件
*/
var RotateMirrorComponent = function () {
/**
* @constructor 旋转镜像组件构造函数
*/
function RotateMirrorComponent() {
_classCallCheck(this, RotateMirrorComponent);
this.html = (0, _utils.parseDom)(_index2.default);
}
_createClass(RotateMirrorComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.player-tooltip.counterclockwise').innerText = this.isEn ? 'Rotate 45 degrees counterclockwise' : '逆时针旋转45度';
this.html.querySelector('.mirror-item[data-id="counterclockwise"]').innerText = this.isEn ? 'Rotate left 45 ̊' : '左旋转45˚';
this.html.querySelector('.player-tooltip.clockwise').innerText = this.isEn ? 'Rotate 45 degrees clockwise' : '顺时针旋转45度';
this.html.querySelector('.mirror-item[data-id="clockwise"]').innerText = this.isEn ? 'Rotate right 45 ̊' : '右旋转45˚';
this.html.querySelector('.player-tooltip.switch').innerText = this.isEn ? 'Mirror' : '镜像';
this.html.querySelector('.mirror-item[data-id=vertical]').innerText = this.isEn ? 'Vertical mirroring' : '垂直镜像';
this.html.querySelector('.mirror-item[data-id=horizon]').innerText = this.isEn ? 'Horizontal mirroring' : '水平镜像';
var eleControlbar = el.querySelector('.prism-controlbar');
eleControlbar.appendChild(this.html);
}
}, {
key: 'ready',
value: function ready(player, e) {
this.html.querySelector('.icon-player-rotate-left').onclick = function () {
var rotate = player.getRotate();
player.setRotate(rotate - 45);
};
this.html.querySelector('.icon-player-rotate-right').onclick = function () {
var rotate = player.getRotate();
player.setRotate(rotate + 45);
};
var eleMirror = this.html.querySelector('.mirror-option');
this.html.querySelector('.icon-player-switch').onclick = function () {
var displayStyle = eleMirror.style.display;
eleMirror.style.display = displayStyle === 'none' ? 'block' : 'none';
};
eleMirror.onmouseleave = function () {
this.style.display = 'none';
};
eleMirror.onclick = function (e) {
var target = e.target;
if (target.dataset.id === 'counterclockwise') {
var rotate = player.getRotate();
player.setRotate(rotate - 45);
return;
}
if (target.dataset.id === 'clockwise') {
var _rotate = player.getRotate();
player.setRotate(_rotate + 45);
return;
}
if (!target.className.match('active')) {
var siblingEle = target.dataset.id === 'horizon' ? target.previousElementSibling : target.nextElementSibling;
if (siblingEle.className.match('active')) {
siblingEle.className = 'mirror-item';
player.cancelImage();
}
var param = target.getAttribute('data-id');
player.setImage(param);
target.className = 'mirror-item active';
} else {
player.cancelImage();
target.className = 'mirror-item';
}
};
}
}]);
return RotateMirrorComponent;
}();
exports.default = RotateMirrorComponent;
/***/ }),
/* 76 */
/***/ (function(module, exports) {
module.exports = "<div class=\"aliplayer-rotate-mirror\">\n <i class=\"iconfont icon-player-rotate-left\"></i>\n <div class=\"player-tooltip counterclockwise\"></div>\n <i class=\"iconfont icon-player-rotate-right\"></i>\n <div class=\"player-tooltip clockwise\"></div>\n <i class=\"iconfont icon-player-switch\"></i>\n <div class=\"player-tooltip switch\"></div>\n <div class=\"mirror-option\" style=\"display: none;\">\n <div class=\"mirror-item\" data-id=\"vertical\"></div>\n <div class=\"mirror-item\" data-id=\"horizon\"></div>\n <div class=\"mirror-item\" data-id=\"counterclockwise\"></div>\n <div class=\"mirror-item\" data-id=\"clockwise\"></div>\n </div>\n</div>";
/***/ }),
/* 77 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(78);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 78 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".aliplayer-rotate-mirror {\n float: right;\n color: #fff;\n display: flex;\n align-items: center;\n height: 35px;\n position: relative;\n margin-top: 5px; }\n .aliplayer-rotate-mirror i {\n color: #fff;\n display: inline-block;\n font-size: 22px;\n display: block;\n margin-top: 7px;\n cursor: pointer;\n margin-right: 10px; }\n .aliplayer-rotate-mirror i.icon-player-switch {\n font-size: 24px;\n font-weight: bold; }\n @media (min-width: 768px) {\n .aliplayer-rotate-mirror i:hover + .player-tooltip {\n display: block; } }\n .aliplayer-rotate-mirror .mirror-option {\n position: absolute;\n background-color: #3c3c3c;\n top: 0;\n transform: translateY(-103%);\n right: -20px; }\n .aliplayer-rotate-mirror .mirror-option .mirror-item {\n font-size: 14px;\n color: #ebecec;\n line-height: 30px;\n white-space: nowrap;\n padding: 0 15px;\n cursor: pointer;\n user-select: none; }\n .aliplayer-rotate-mirror .mirror-option .mirror-item[data-id=\"counterclockwise\"] {\n display: none; }\n .aliplayer-rotate-mirror .mirror-option .mirror-item[data-id=\"clockwise\"] {\n display: none; }\n .aliplayer-rotate-mirror .mirror-option .mirror-item.active {\n background-color: rgba(216, 216, 216, 0.1);\n color: #00c1de; }\n .aliplayer-rotate-mirror .player-tooltip.counterclockwise {\n left: -35px; }\n .aliplayer-rotate-mirror .player-tooltip.clockwise {\n left: -5px; }\n .aliplayer-rotate-mirror .player-tooltip.switch {\n right: 7px; }\n @media (max-width: 768px) {\n .aliplayer-rotate-mirror .mirror-option .mirror-item[data-id=\"counterclockwise\"] {\n display: block; }\n .aliplayer-rotate-mirror .mirror-option .mirror-item[data-id=\"clockwise\"] {\n display: block; } }\n", ""]);
// exports
/***/ }),
/* 79 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(80);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.StartADComponent = _index2.default;
/***/ }),
/* 80 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(81);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(82);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 开始图片广告组件
*/
var StartADComponent = function () {
/**
* @constructor 开始图片广告组件构造函数
* @param {String coverUrl 广告图片地址}
* @param {String adUrl 广告链接}
* @param {Number adDuration 广告时长, 单位为秒}
*/
function StartADComponent(coverUrl, adUrl, adDuration) {
_classCallCheck(this, StartADComponent);
this.coverUrl = coverUrl;
this.adUrl = adUrl;
this.adDuration = adDuration;
if (adDuration <= 0) {
throw Error('adDuration must must be greater than 0');
}
this.html = (0, _utils.parseDom)(_index2.default);
}
_createClass(StartADComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.ad-name').innerText = this.isEn ? 'Ad' : '广告';
this.html.querySelector('.second').innerText = this.isEn ? 's' : '秒';
var adUrlElement = this.html.querySelector('.ad-content');
adUrlElement.setAttribute('href', this.adUrl);
var adImgElement = adUrlElement.querySelector('img');
adImgElement.setAttribute('src', this.coverUrl);
var durationElement = this.html.querySelector('.tip i');
durationElement.innerText = this.adDuration;
el.appendChild(this.html);
if (this.html !== null) {
if (player.getStatus() !== 'init') {
player.pause();
}
var duration = this.adDuration;
var _durationElement = this.html.querySelector('.tip i');
var durationInterval = setInterval(function () {
duration = duration - 1;
_durationElement.innerText = duration;
if (duration === 0) {
clearInterval(durationInterval);
_this.removeComponent();
// 如果试看组件和记忆播放组件一起用了, 那么不让播放器播放
var playerOptions = player.getOptions();
var memoryVideo = playerOptions.vid || playerOptions.source.replace(/\?.*$/, '');
var memoryTime = localStorage.getItem(memoryVideo) || 0;
if (memoryTime) {
memoryTime = parseInt(memoryTime);
}
var components = player.getOptions() && player.getOptions().components;
var memoryComponent = Array.isArray(components) ? components.filter(function (item) {
return item.type.name === 'MemoryPlayComponent';
})[0] : components.find(function (item) {
return item.type.name === 'MemoryPlayComponent';
});
var memoryAutoPlay = memoryComponent && memoryComponent.args[0];
if (!memoryAutoPlay || player.getCurrentTime() >= memoryTime) {
player.play();
}
}
}, 1000);
}
}
}, {
key: 'removeComponent',
value: function removeComponent() {
this.html.parentNode.removeChild(this.html);
this.html = null;
}
}, {
key: 'ready',
value: function ready(player) {
if (this.html !== null) {
player.pause();
}
}
}]);
return StartADComponent;
}();
exports.default = StartADComponent;
/***/ }),
/* 81 */
/***/ (function(module, exports) {
module.exports = "<div class=\"start-ad\">\n <span class=\"tip\"><span class=\"ad-name\">广告</span>: <i></i><span class=\"second\">秒</span></span>\n <a class=\"ad-content\" target=\"_blank\">\n <img />\n </a>\n</div>";
/***/ }),
/* 82 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(83);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 83 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".start-ad {\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n background-color: #000;\n position: absolute;\n z-index: 9999; }\n .start-ad .tip {\n position: absolute;\n right: 5px;\n top: 5px;\n background-color: #333;\n color: #fff;\n font-size: 14px;\n text-align: center;\n padding: 3px 7px; }\n .start-ad .tip i {\n font-style: normal; }\n .start-ad a {\n width: 100%;\n height: 100%;\n display: inline-block;\n text-align: center;\n display: flex;\n align-items: center;\n justify-content: center; }\n .start-ad a img {\n max-width: 100%;\n max-height: 100%; }\n", ""]);
// exports
/***/ }),
/* 84 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(85);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.TrackComponent = _index2.default;
/***/ }),
/* 85 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(86);
var _index2 = _interopRequireDefault(_index);
var _trackModal = __webpack_require__(87);
var _trackModal2 = _interopRequireDefault(_trackModal);
__webpack_require__(88);
var _utils = __webpack_require__(2);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/**
* 音轨组件
*/
var TrackComponent = function () {
/**
* @constructor 音轨组件构造函数
*/
function TrackComponent() {
_classCallCheck(this, TrackComponent);
this.trackList = null;
this.html = (0, _utils.parseDom)(_index2.default);
this.modalHtml = (0, _utils.parseDom)(_trackModal2.default);
this.hasCreated = false;
this.definition = '';
}
_createClass(TrackComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.modalHtml.querySelector('.switchimg').innerText = this.isEn ? 'Track to you for' : '音轨切换到';
this.modalHtml.querySelector('.switchimg').style.display = 'none';
var eleControlbar = el.querySelector('.prism-controlbar');
eleControlbar.appendChild(this.html);
el.appendChild(this.modalHtml);
player.on('audioTrackReady', function (_ref) {
var paramData = _ref.paramData;
_this.trackList = paramData;
var lis_ele = paramData.map(function (v) {
return '<li data-def="' + v.value + '">' + v.text + '</li>';
});
_this.html.querySelector('.track-list').innerHTML = '<li style="background:rgba(88,87,86,.5);color:#fff">\u97F3\u8F68</li>' + lis_ele.join('');
});
var currentTrackEle = this.html.querySelector('.current-track');
var trackListEle = this.html.querySelector('.track-list');
if (this.hasCreated == false && this.definition) {
var li_target = trackListEle.querySelector('li[data-def="' + this.definition + '"]');
li_target.className = 'current';
}
this.hasCreated = true;
var timeId = null;
currentTrackEle.onclick = function () {
trackListEle.style.display = 'block';
};
currentTrackEle.onmouseleave = function () {
timeId = setTimeout(function () {
trackListEle.style.display = 'none';
}, 100);
};
trackListEle.onmouseenter = function () {
clearTimeout(timeId);
};
trackListEle.onmouseleave = function () {
trackListEle.style.display = 'none';
_this.modalHtml.style.display = 'none';
};
trackListEle.onclick = function (_ref2) {
var target = _ref2.target;
var definition = target.dataset.def;
if (definition) {
if (target.className !== 'current') {
var track = Array.isArray(_this.trackList) ? _this.trackList.filter(function (v) {
return v.value.toString() === definition;
})[0] : _this.trackList.find(function (v) {
return v.value.toString() === definition;
});
player._audioTrackService.switch(track.value);
_this.setCurrentTrack(track.text, track.value);
_this.modalHtml.style.display = 'block';
_this.modalHtml.querySelector('.switchimg').style.display = 'block';
_this.modalHtml.querySelector('span.current-track-tag').innerText = track.text;
}
}
};
}
}, {
key: 'setCurrentTrack',
value: function setCurrentTrack(track, def) {
var currentTrack = this.html.querySelector('.current-track');
currentTrack.innerText = track;
currentTrack.dataset.def = def;
this.definition = def;
var trackListEle = this.html.querySelector('.track-list');
var currentEle = trackListEle.querySelector('.current');
if (currentEle) {
currentEle.className = '';
}
// let li_target = trackListEle.querySelector(`li[data-def="${def}"]`)
var lis = trackListEle.querySelectorAll('li');
lis.forEach(function (element) {
var text = element.innerText;
if (text === track) {
element.className = 'current';
}
console.log(text);
});
if (lis) {
lis.className = 'current';
}
}
}, {
key: 'created',
value: function created(player) {}
}, {
key: 'ready',
value: function ready(player) {
this.modalHtml.style.display = 'none';
// 隐藏设置里面的音轨
var settingEle = document.querySelector('.prism-setting-item.prism-setting-audio');
if (settingEle) {
settingEle.classList.add('player-hidden');
}
}
}]);
return TrackComponent;
}();
exports.default = TrackComponent;
/***/ }),
/* 86 */
/***/ (function(module, exports) {
module.exports = "<div class=\"track-components\">\n <div class=\"current-track\"></div>\n <ul class=\"track-list\">\n \n </ul>\n</div>";
/***/ }),
/* 87 */
/***/ (function(module, exports) {
module.exports = "<div class=\"track-modal prism-info-display prism-info-left-bottom\">\n <span class=\"switchimg\"></span> <span class=\"current-track-tag\"></span>\n</div>";
/***/ }),
/* 88 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(89);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 89 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".player-hidden {\n display: none !important; }\n\n.track-components {\n float: right;\n color: #fff;\n height: 35px;\n position: relative;\n box-sizing: border-box;\n margin-top: 5px; }\n\n.current-track {\n display: flex;\n height: 100%;\n align-items: center;\n justify-content: center;\n width: 100px;\n cursor: pointer; }\n\n.track-list {\n position: absolute;\n bottom: 46px;\n display: none;\n padding: 0;\n margin: 0;\n list-style: none;\n height: auto;\n width: 100px;\n overflow-y: scroll; }\n .track-list li {\n text-align: center;\n width: 100px;\n line-height: 30px;\n background-color: rgba(0, 0, 0, 0.6);\n cursor: pointer; }\n .track-list li.current {\n color: #00c1de; }\n .track-list li + li {\n border-top: 1px solid rgba(78, 78, 78, 0.3); }\n .track-list li:hover {\n background-color: rgba(0, 0, 0, 0.5); }\n\n@media (max-width: 768px) {\n .current-track {\n width: 40px; }\n .track-list li {\n width: 43px; } }\n\n.prism-player .prism-info-display .switchimg {\n color: #fff; }\n", ""]);
// exports
/***/ }),
/* 90 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(91);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.VideoADComponent = _index2.default;
/***/ }),
/* 91 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _index = __webpack_require__(92);
var _index2 = _interopRequireDefault(_index);
__webpack_require__(93);
var _utils = __webpack_require__(2);
var _mbIndex = __webpack_require__(95);
var _mbIndex2 = _interopRequireDefault(_mbIndex);
var _currentDevice = __webpack_require__(3);
var _currentDevice2 = _interopRequireDefault(_currentDevice);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
/*
* PC 视频广告组件
*/
var VideoAdComponent = function () {
/**
* @constructor PC 视频广告的构造函数
* @param adVideoSource {@String 广告视频的视频地址 必须参数}
* @param adLink {@String 广告视频的链接地址 必须参数}
* @param adCloseFunction {@Function 关闭广告的点击事件处理函数, 可选参数, 不传则默认关闭广告视频}
* @param closeText {@String 关闭广告的文字内容, 可选参数, 不传则默认为 '关闭广告'}
*/
function VideoAdComponent(adVideoSource, adLink, adCloseFunction) {
var closeText = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '关闭广告';
_classCallCheck(this, VideoAdComponent);
this.adVideoSource = adVideoSource;
this.adLink = adLink;
this.html = (0, _utils.parseDom)(_index2.default);
this.adInterval = null;
this.adCloseFunction = adCloseFunction;
this.html.querySelector('.video-ad-close-text').innerText = closeText;
this.adDuration = null; // 视频广告的时长, 用于倒计时,
this.player = null;
}
_createClass(VideoAdComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var _this = this;
this.player = player;
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.video-ad-detail').innerText = this.isEn ? 'For more information' : '查看广告详情';
this.html.querySelector('.limit').innerText = this.isEn ? 'Your browser limits autoplay' : '您的浏览器限制';
this.html.querySelector('.manual').innerText = this.isEn ? 'Please Click' : '自动播放请点击';
// 给广告视频添加 source
var videoAd_ele = this.html.querySelector('#video-ad-content');
videoAd_ele.setAttribute('src', this.adVideoSource);
// 获取广告视频的时长, 并赋值到 this.duration 中
var self = this;
function getVideoAdTime() {
videoAd_ele.removeEventListener('canplay', getVideoAdTime);
//广告起播loading
document.getElementById('loadflag').style.display = 'none';
self.adDuration = Math.ceil(videoAd_ele.duration);
var adDuration_ele = self.html.querySelector('#video-ad-duration');
adDuration_ele.innerText = self.adDuration;
videoAd_ele.play().then(function () {
self.setAdInterval();
}).catch(function (err) {
self.html.querySelector('.autoplay-video-ad').style.display = 'block';
});
}
this.html.querySelector('.icon-player-play').onclick = function () {
_this.playVideoAd();
_this.html.querySelector('.autoplay-video-ad').style.display = 'none';
};
videoAd_ele.addEventListener('canplay', getVideoAdTime);
// 查看详情 整个广告链接添加 href
var videoLink = this.html.querySelector('.video-ad-link');
var videoDetail = this.html.querySelector('.video-ad-detail');
videoLink.setAttribute('href', this.adLink);
videoDetail.setAttribute('href', this.adLink);
el.appendChild(this.html);
// handle close
this.html.querySelector('.video-ad-close label').onclick = function () {
if (typeof _this.adCloseFunction === 'function') {
_this.adCloseFunction(_this);
} else {
_this.closeVideoAd();
}
};
}
}, {
key: 'ready',
value: function ready(player, e) {
if (this.html !== null) {
player.pause();
this.player = player;
}
}
// 暂停视频广告
}, {
key: 'pauseVideoAd',
value: function pauseVideoAd() {
this.clearAdInterval();
this.html.querySelector('#video-ad-content').pause();
}
// 播放视频广告
}, {
key: 'playVideoAd',
value: function playVideoAd() {
this.setAdInterval();
this.html.querySelector('#video-ad-content').play();
}
// 清除视频广告倒计时
}, {
key: 'clearAdInterval',
value: function clearAdInterval() {
this.adInterval !== null && clearInterval(this.adInterval);
this.adInterval = null;
}
// 视频广告倒计时
}, {
key: 'setAdInterval',
value: function setAdInterval() {
var _this2 = this;
var adDuration_ele = this.html.querySelector('#video-ad-duration');
this.adInterval = setInterval(function () {
_this2.adDuration -= 1;
if (_this2.adDuration <= 0) {
_this2.closeVideoAd();
//广告播放完了之后自动播放视频
document.getElementById(_this2.player.id()).getElementsByTagName('video')[0].play();
} else {
adDuration_ele.innerText = _this2.adDuration;
}
}, 1000);
}
// 关闭视频广告
}, {
key: 'closeVideoAd',
value: function closeVideoAd() {
this.clearAdInterval();
this.html.parentNode.removeChild(this.html);
this.html = null;
if (this.player && this.player.getOptions().autoplay) {
this.player.play();
}
}
}]);
return VideoAdComponent;
}();
/**
* 移动端视频广告组件
*/
var MbVideoAdComponent = function () {
/**
* @constructor 移动端视频广告组件
* @param {String adVideoSource 视频广告播放地址}
* @param {String adLink 广告链接}
* @param {Function adCloseFunction 关闭广告按钮点击出发的函数}
* @param {String closeText 可选参数 关闭按钮中的文字, 默认为 '关闭广告'}
*/
function MbVideoAdComponent(adVideoSource, adLink, adCloseFunction) {
var closeText = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '关闭广告';
_classCallCheck(this, MbVideoAdComponent);
this.adVideoSource = adVideoSource;
this.adLink = adLink;
this.html = (0, _utils.parseDom)(_mbIndex2.default);
this.adInterval = null;
this.adCloseFunction = adCloseFunction;
this.html.querySelector('.video-ad-close-text').innerText = closeText;
this.html.querySelector('.video-ad-link').setAttribute('href', this.adLink);
this.html.querySelector('.video-ad-detail').setAttribute('href', this.adLink);
this.adDuration = null; // 视频广告的时长, 用于倒计时,
}
_createClass(MbVideoAdComponent, [{
key: 'createEl',
value: function createEl(el, player) {
var lang = player._options && player._options.language;
this.isEn = lang && lang === 'en-us';
this.html.querySelector('.video-ad-detail').innerText = this.isEn ? 'For more information' : '查看广告详情';
this.html.querySelector('.limit').innerText = this.isEn ? 'Your browser limits autoplay' : '您的浏览器限制';
this.html.querySelector('.manual').innerText = this.isEn ? 'Please Click' : '自动播放请点击';
el.appendChild(this.html);
el.querySelector('video');
el.querySelector('video').setAttribute('preload', 'load');
// 隐藏 controlbar
var controlBar = el.querySelector('.prism-controlbar');
controlBar.className = controlBar.className + ' controlbar-element-hidden';
// 隐藏播放暂停按钮
var pauseBtn = el.querySelector('.prism-big-play-btn');
pauseBtn.className = pauseBtn.className + ' controlbar-element-hidden';
}
}, {
key: 'created',
value: function created(player) {
var _this3 = this;
this.player = player;
this.vdSource = player.getOptions().source;
player.loadByUrl(this.adVideoSource);
var btnPlay_el = this.html.querySelector('.autoplay-video-ad');
btnPlay_el.onclick = function () {
//alert('created')
if (_this3.adDuration === null) {
return;
}
player.loadByUrl(_this3.adVideoSource);
_this3.html.parentNode.querySelector('.prism-big-play-btn').click();
};
if (this.adDuration === null) {
var _timeupdateHandle = function _timeupdateHandle() {
var duration = aliplayer_el.duration;
if (!isNaN(duration) && duration !== 0) {
aliplayer_el.removeEventListener('timeupdate', _timeupdateHandle);
self.adDuration = Math.ceil(aliplayer_el.duration);
if (self.html.querySelector('.autoplay-video-ad').style.display !== 'none') {
self.html.querySelector('.autoplay-video-ad').style.display = 'none';
player.play();
}
self.html.querySelector('#video-ad-duration').innerText = self.adDuration;
self.setAdInterval();
// document.getElementById('loadflag').style.display = 'none'
}
};
//player.loadByUrl(this.adVideoSource)
this.adDuration = undefined;
var aliplayerWrap_el = this.html.parentNode;
var aliplayer_el = aliplayerWrap_el.querySelector('video');
var self = this;
aliplayer_el.addEventListener('timeupdate', _timeupdateHandle);
}
}
}, {
key: 'ready',
value: function ready(player) {
var _this4 = this;
//alert("2222222")
// let btnPlay_el = this.html.querySelector('.autoplay-video-ad')
// btnPlay_el.onclick = () => {
// alert('ready')
// if (this.adDuration === null) {
// return
// }
// this.html.parentNode.querySelector('.prism-big-play-btn').click()
// }
// if (this.adDuration === null) {
// player.loadByUrl(this.adVideoSource)
// this.adDuration = undefined
// let aliplayerWrap_el = this.html.parentNode
// let aliplayer_el = aliplayerWrap_el.querySelector('video')
// let self = this
// function timeupdateHandle () {
// let duration = aliplayer_el.duration
// console.log('duration', duration)
// if (!isNaN(duration) && duration !== 0) {
// aliplayer_el.removeEventListener('timeupdate', timeupdateHandle)
// self.adDuration = Math.ceil(aliplayer_el.duration)
// if (self.html.querySelector('.autoplay-video-ad').style.display !== 'none') {
// self.html.querySelector('.autoplay-video-ad').style.display = 'none'
// player.play()
// }
// self.html.querySelector('#video-ad-duration').innerText = self.adDuration
// self.setAdInterval()
// }
// }
// aliplayer_el.addEventListener('timeupdate', timeupdateHandle)
// 关闭广告点击事件
this.html.querySelector('.video-ad-close label').onclick = function () {
if (typeof _this4.adCloseFunction === 'function') {
_this4.adCloseFunction(_this4);
} else {
_this4.closeVideoAd();
}
//广告播放完了之后自动播放视频
document.getElementById(player.id()).getElementsByTagName('video')[0].play();
};
// }
}
// 视频广告倒计时
}, {
key: 'setAdInterval',
value: function setAdInterval() {
var _this5 = this;
var adDuration_ele = this.html.querySelector('#video-ad-duration');
this.adInterval = setInterval(function () {
_this5.adDuration -= 1;
if (_this5.adDuration <= 0) {
_this5.closeVideoAd();
//广告播放完了之后自动播放视频
document.getElementById(_this5.player.id()).getElementsByTagName('video')[0].play();
} else {
adDuration_ele.innerText = _this5.adDuration;
}
}, 1000);
}
// 关闭视频广告
}, {
key: 'closeVideoAd',
value: function closeVideoAd() {
this.clearAdInterval();
this.player.loadByUrl(this.vdSource);
var controlBar = this.html.parentNode.querySelector('.prism-controlbar');
controlBar.className = controlBar.className.replace(' controlbar-element-hidden', '');
var pauseBtn = this.html.parentNode.querySelector('.prism-big-play-btn');
pauseBtn.className = pauseBtn.className.replace(' controlbar-element-hidden', '');
if (this.player.getOptions().autoplay) {
this.player.play();
}
this.html.parentNode.removeChild(this.html);
}
// 清除视频广告倒计时
}, {
key: 'clearAdInterval',
value: function clearAdInterval() {
this.adInterval !== null && clearInterval(this.adInterval);
this.adInterval = null;
}
// 播放视频广告
}, {
key: 'playVideoAd',
value: function playVideoAd() {
this.setAdInterval();
this.player.play();
}
// 暂停视频广告
}, {
key: 'pauseVideoAd',
value: function pauseVideoAd() {
this.clearAdInterval();
this.player.pause();
}
}]);
return MbVideoAdComponent;
}();
var defaultComponent = VideoAdComponent;
if (_currentDevice2.default.mobile()) {
defaultComponent = MbVideoAdComponent;
}
exports.default = defaultComponent;
/***/ }),
/* 92 */
/***/ (function(module, exports) {
module.exports = "<div class=\"video-ad-component\">\n <video id=\"video-ad-content\" x5-video-player-type=\"h5\" x5-video-player-fullscreen=\"false\"></video>\n <a class=\"video-ad-link\" target=\"_blank\"></a>\n <div class=\"video-ad-close\">\n <span id=\"video-ad-duration\"></span>\n <label>\n <span class=\"video-ad-close-text\"></span>\n <i class=\"iconfont icon-close\"></i>\n </label>\n </div>\n <a class=\"video-ad-detail\" target=\"_blank\"></a>\n <div class=\"autoplay-video-ad\">\n <i class=\"iconfont icon-player-play\"></i>\n <span class=\"limit\"></span>\n <span class=\"manual\"></span>\n </div>\n <div id=\"loadflag\" class=\"prism-loading loading-center\">\n <div class=\"circle\"></div> \n <div class=\"circle1\"></div>\n </div>\n</div>";
/***/ }),
/* 93 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(94);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 94 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".video-ad-component {\n width: 100%;\n height: 100%;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 2147483647;\n background-color: #000;\n font-size: 12px; }\n .video-ad-component #video-ad-content {\n width: 100%;\n height: 100%; }\n .video-ad-component .video-ad-link {\n width: 100%;\n height: 100%;\n display: block;\n position: absolute;\n top: 0;\n left: 0; }\n .video-ad-component .video-ad-close {\n background-color: rgba(59, 59, 59, 0.85);\n position: absolute;\n top: 15px;\n right: 20px;\n color: #fff;\n line-height: 26px;\n padding: 0 10px;\n user-select: none; }\n .video-ad-component .video-ad-close #video-ad-duration {\n color: #00c1de;\n vertical-align: top;\n font-size: 14px;\n position: relative;\n display: inline-block;\n text-align: right; }\n .video-ad-component .video-ad-close #video-ad-duration::after {\n background-color: #fff;\n position: absolute;\n content: '';\n right: -7px;\n top: 8px;\n bottom: 8px;\n width: 1px; }\n .video-ad-component .video-ad-close label {\n cursor: pointer;\n display: inline-block; }\n .video-ad-component .video-ad-close .icon-close {\n font-size: 12px;\n vertical-align: top; }\n @media (min-width: 768px) {\n .video-ad-component .video-ad-close .icon-close:hover {\n color: #00c1de; } }\n .video-ad-component .video-ad-close .video-ad-close-text {\n padding: 0 5px 0 10px; }\n .video-ad-component .video-ad-detail {\n position: absolute;\n right: 35px;\n bottom: 30px;\n background-color: rgba(0, 222, 255, 0.85);\n color: #fff;\n padding: 8px 12px;\n user-select: none;\n cursor: pointer;\n transition: background-color .15s; }\n @media (min-width: 768px) {\n .video-ad-component .video-ad-detail:hover {\n background-color: #00deff; } }\n .video-ad-component .autoplay-video-ad {\n position: absolute;\n color: #fff;\n top: 50%;\n left: 50%;\n text-align: center;\n padding: 10px;\n border-radius: 5px;\n background-color: rgba(144, 147, 153, 0.85);\n transform: translate(-50%, -50%);\n display: none; }\n .video-ad-component .autoplay-video-ad i {\n font-size: 42px;\n margin-bottom: 7px;\n display: inline-block;\n cursor: pointer; }\n .video-ad-component .autoplay-video-ad i + span {\n margin-bottom: 5px; }\n .video-ad-component .autoplay-video-ad span {\n display: block; }\n\n.controlbar-element-hidden {\n display: none !important; }\n", ""]);
// exports
/***/ }),
/* 95 */
/***/ (function(module, exports) {
module.exports = "<div class=\"video-ad-component\" style=\"background-color: transparent;\">\n <a class=\"video-ad-link\" target=\"_blank\"></a>\n <div class=\"video-ad-close\">\n <span id=\"video-ad-duration\"></span>\n <label>\n <span class=\"video-ad-close-text\"></span>\n <i class=\"iconfont icon-close\"></i>\n </label>\n </div>\n <a class=\"video-ad-detail\" target=\"_blank\"></a>\n <div class=\"autoplay-video-ad\" style=\"display: block;\">\n <i class=\"iconfont icon-player-play\"></i>\n <span class=\"limit\"></span>\n <span class=\"manual\"></span>\n </div>\n</div>";
/***/ }),
/* 96 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(97);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.PlayerNextComponent = _index2.default;
/***/ }),
/* 97 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
__webpack_require__(98);
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var PlayerNextComponent = function () {
function PlayerNextComponent(clickHandle) {
_classCallCheck(this, PlayerNextComponent);
this.clickHandle = clickHandle;
this._html = document.createElement('div');
this._html.setAttribute('class', 'player-olympic-player-next');
var innerDiv = document.createElement('div');
innerDiv.setAttribute('class', 'player-olympic-player-next-tip');
innerDiv.textContent = "Next";
this._html.appendChild(innerDiv);
}
_createClass(PlayerNextComponent, [{
key: 'createEl',
value: function createEl(el) {
this._html.addEventListener('click', this.clickHandle);
el.querySelector('.prism-play-btn').insertAdjacentElement('afterend', this._html);
}
}]);
return PlayerNextComponent;
}();
exports.default = PlayerNextComponent;
/***/ }),
/* 98 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(99);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 99 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".player-olympic-player-next {\n width: 32px;\n height: 32px;\n background: url(" + __webpack_require__(100) + ") center no-repeat;\n background-size: contain;\n float: left;\n margin-left: 10px;\n margin-top: 8px;\n cursor: pointer;\n position: relative; }\n\n.player-olympic-player-next-tip {\n position: absolute;\n top: -45px;\n display: none;\n font-size: 12px;\n color: #ffffff;\n line-height: 28px;\n letter-spacing: 0;\n text-align: center;\n background: #3c3c3c;\n box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.1);\n width: 58px;\n height: 28px; }\n\n.player-olympic-player-next:hover .player-olympic-player-next-tip {\n display: block; }\n", ""]);
// exports
/***/ }),
/* 100 */
/***/ (function(module, exports) {
module.exports = ""
/***/ }),
/* 101 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
var _index = __webpack_require__(102);
var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
if (!window.AliPlayerComponent) {
window.AliPlayerComponent = {};
}
window.AliPlayerComponent.StaticAdComponent = _index2.default;
/***/ }),
/* 102 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var html = __webpack_require__(103);
__webpack_require__(105);
/**
* 静态广告组件
*/
var StaticADComponent = Aliplayer.Component({
/**
* 初始函数在new对象时调用
*
* @param {string} adAddress - 广告视频地址
* @param {string} toAddress - 广告链接地址
*/
init: function init(adAddress, toAddress) {
this.adAddress = adAddress;
this.toAddress = toAddress;
this.$html = $(html);
},
/**
* 创建广告Dom元素
*/
createEl: function createEl(el) {
(Array.isArray(this.$html) ? this.$html.filter('.ad')[0] : this.$html.find('.ad')).attr('src', this.adAddress);
var $adWrapper = Array.isArray(this.$html) ? this.$html.filter('.ad-wrapper')[0] : this.$html.find('.ad-wrapper');
$adWrapper.attr('href', this.toAddress);
$adWrapper.click(function () {
Aliplayer.util.stopPropagation();
});
(Array.isArray(this.$html) ? this.$html.filter('.close')[0] : this.$html.find('.close')).click(function () {
this.$html.hide();
});
$(el).append(this.$html);
},
ready: function ready(player, e) {},
/**
* 隐藏广告
*/
play: function play(player, e) {
this.$html.hide();
},
/**
* 显示广告
*/
pause: function pause(player, e) {
this.$html.show();
},
/**
* 隐藏广告
*/
playing: function playing(player, e) {
this.$html.hide();
},
waiting: function waiting(player, e) {},
timeupdate: function timeupdate(player, e) {},
error: function error(player, e) {},
/**
* 显示广告
*/
ended: function ended(player, e) {
this.$html.show();
}
});
exports.default = StaticADComponent;
/***/ }),
/* 103 */
/***/ (function(module, exports, __webpack_require__) {
module.exports = "<div class=\"ad-container\">\n <span>广告</span>\n <img class=\"close\" src=\"" + __webpack_require__(104) + "\"></img>\n <a class='ad-wrapper' target=\"_blank\">\n <img class=\"ad\"></img>\n </a>\n</div>";
/***/ }),
/* 104 */
/***/ (function(module, exports) {
module.exports = ""
/***/ }),
/* 105 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(106);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 106 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, ".ad-container {\n display: none;\n position: absolute;\n left: 50%;\n top: 50%;\n margin-left: -150px;\n margin-top: -100px; }\n\n.ad-container span {\n width: 27px;\n height: 16px;\n border-radius: 1px;\n background-color: rgba(0, 0, 0, 0.5);\n position: absolute;\n font-size: 10px;\n color: #fff;\n line-height: 16px;\n text-align: center;\n top: 0px;\n left: 0px; }\n\n.ad-container .close {\n position: absolute;\n top: 2px;\n right: 2px;\n width: 20px;\n height: 20px; }\n\n.ad-container .close:hover {\n cursor: pointer; }\n\n.ad-container .ad {\n width: 300px;\n height: 200px; }\n", ""]);
// exports
/***/ }),
/* 107 */
/***/ (function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(108);
if(typeof content === 'string') content = [[module.i, content, '']];
// add the styles to the DOM
var update = __webpack_require__(1)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {}
/***/ }),
/* 108 */
/***/ (function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(0)();
// imports
// module
exports.push([module.i, "@charset \"UTF-8\";\n@font-face {\n font-family: \"iconfont\";\n src: url(" + __webpack_require__(5) + ");\n /* IE9*/\n src: url(" + __webpack_require__(5) + "#iefix) format(\"embedded-opentype\"), url(\"data:application/x-font-woff;charset=utf-8;base64,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\") format(\"woff\"), url(" + __webpack_require__(109) + ") format(\"truetype\"), url(" + __webpack_require__(110) + "#iconfont) format(\"svg\");\n /* iOS 4.1- */ }\n\n.iconfont {\n font-family: \"iconfont\" !important;\n font-size: 16px;\n font-style: normal;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.icon-list:before {\n content: \"\\E643\"; }\n\n.icon-skipnext:before {\n content: \"\\EA9E\"; }\n\n.icon-skip-previous:before {\n content: \"\\E6D3\"; }\n\n.icon-close:before {\n content: \"\\E616\"; }\n\n.icon-player-rotate-left:before {\n content: \"\\E658\"; }\n\n.icon-player-rotate-right:before {\n content: \"\\E659\"; }\n\n.icon-player-switch:before {\n content: \"\\E781\"; }\n\n.icon-danmu-close:before {\n content: \"\\E696\"; }\n\n.icon-danmu-open:before {\n content: \"\\E697\"; }\n\n.icon-player-play:before {\n content: \"\\E641\"; }\n\nbody {\n font-family: \"Helvetica Neue\",Helvetica,\"PingFang SC\",\"Hiragino Sans GB\",\"Microsoft YaHei\",\"\\5FAE\\8F6F\\96C5\\9ED1\",Arial,sans-serif; }\n\n/* previewVodComponents 中的自定义 css */\n.vip-join {\n color: #00c1de; }\n\n.vip_limit_content {\n display: flex;\n width: 100%;\n height: 100%;\n flex-wrap: wrap;\n justify-content: center;\n align-items: center; }\n\n.vip_limit_content .title {\n font-size: 18px;\n line-height: 36px;\n color: #fff;\n text-align: center;\n width: 100%; }\n\n.vip_limit_button_box {\n text-align: center;\n white-space: nowrap;\n overflow: hidden;\n width: 100%; }\n\n.vip_limit_btn {\n display: inline-block;\n min-width: 100px;\n position: relative;\n background: #f60;\n padding: 0 35px;\n margin: 0px 5px 20px 5px;\n border-radius: 38px;\n font-size: 18px;\n line-height: 38px;\n color: #623A0C;\n text-align: center;\n background-image: linear-gradient(-135deg, #FBE8A8 0%, #F8E7AC 15%, #E2C078 100%);\n cursor: pointer; }\n\n.vip_limit_close {\n text-align: center; }\n .vip_limit_close span {\n display: inline-block;\n width: 40px;\n height: 40px;\n line-height: 36px;\n background: rgba(165, 165, 165, 0.54);\n border-radius: 50%;\n font-size: 24px;\n cursor: pointer; }\n", ""]);
// exports
/***/ }),
/* 109 */
/***/ (function(module, exports) {
module.exports = "data:application/x-font-ttf;base64,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Ly8vRS8vL0YuLi6jAmNKSmMCAmNKSmP+0wFJNjZJAQFJNjZJtQcHUjEHDhIIQQcHYgcSAAACAAD/0wOqAzQAIQBDAAA3IT4BNzU0NjIWHQEOAQchFxYUBiIvAS4BNTQ/ATYyFhQHASEOAQcVFAYiJj0BPgE3IScmNDYyHwEeARUUDwEGIiY0N8YCGio1AREeEQJZRf3NdgoUGQqcBQUKnAoZFAoCJ/2WKjUBER4RAllFAlNdCRMZCp0FBQqdChkTCcABNSpgDxERD2BFWQJ2ChkUCp0FDAUOCJ0KFBkKAUoBNSpgDxERD2BFWQJdChkTCaAFDQUNCZ0KFBkKAAAAEgDeAAEAAAAAAAAAFQAAAAEAAAAAAAEACAAVAAEAAAAAAAIABwAdAAEAAAAAAAMACAAkAAEAAAAAAAQACAAsAAEAAAAAAAUACwA0AAEAAAAAAAYACAA/AAEAAAAAAAoAKwBHAAEAAAAAAAsAEwByAAMAAQQJAAAAKgCFAAMAAQQJAAEAEACvAAMAAQQJAAIADgC/AAMAAQQJAAMAEADNAAMAAQQJAAQAEADdAAMAAQQJAAUAFgDtAAMAAQQJAAYAEAEDAAMAAQQJAAoAVgETAAMAAQQJAAsAJgFpCkNyZWF0ZWQgYnkgaWNvbmZvbnQKaWNvbmZvbnRSZWd1bGFyaWNvbmZvbnRpY29uZm9udFZlcnNpb24gMS4waWNvbmZvbnRHZW5lcmF0ZWQgYnkgc3ZnMnR0ZiBmcm9tIEZvbnRlbGxvIHByb2plY3QuaHR0cDovL2ZvbnRlbGxvLmNvbQAKAEMAcgBlAGEAdABlAGQAIABiAHkAIABpAGMAbwBuAGYAbwBuAHQACgBpAGMAbwBuAGYAbwBuAHQAUgBlAGcAdQBsAGEAcgBpAGMAbwBuAGYAbwBuAHQAaQBjAG8AbgBmAG8AbgB0AFYAZQByAHMAaQBvAG4AIAAxAC4AMABpAGMAbwBuAGYAbwBuAHQARwBlAG4AZQByAGEAdABlAGQAIABiAHkAIABzAHYAZwAyAHQAdABmACAAZgByAG8AbQAgAEYAbwBuAHQAZQBsAGwAbwAgAHAAcgBvAGoAZQBjAHQALgBoAHQAdABwADoALwAvAGYAbwBuAHQAZQBsAGwAbwAuAGMAbwBtAAAAAAIAAAAAAAAACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAECAQMBBAEFAQYBBwEIAQkBCgELAQwBDQABeAUxbXVsdQhza2lwbmV4dAVjbG9zZQRwbGF5DXNraXAtcHJldmlvdXMRYXJyb3ctcm90YXRlLWxlZnQSYXJyb3ctcm90YXRlLXJpZ2h0EmJvZmFuZ3FpLWRhbm11Z3VhbhFib2ZhbmdxaS1kYW5tdWthaQ5uZWlyb25ncWllaHVhbgAA"
/***/ }),
/* 110 */
/***/ (function(module, exports) {
module.exports = ""
/***/ })
/******/ ]);