您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Uppod HTML5 (http://uppod.ru/html5) исправлен для подключения в Greasemonkey userscript
当前为
此脚本不应直接安装。它是供其他脚本使用的外部库,要使用该库请加入元指令 // @require https://update.greasyfork.icu/scripts/22693/144280/uppod-01305.js
// Uppod HTML5 0.8.3 (http://uppod.ru/html5) var uppod_players; var uppod_active_player_uid; var uppodstyle = ''; function Uppod(loadvars) { var _this = this; var canvasObjs = []; var vars; var brw; var ierr = ''; var ipad = false; var iphone = false; var android = false; var opera = false; var mobile = false; var nativecontrols = false; var ihtml5 = false; var init = false; var initevent = false; var iplay = false; var istart = false; var ifull = false; var irealfull = false; var ihide = false; var lastXY = 0; var lastdXY = 0; var ibuff = false; var iover = false; var istartevnt = false; var iline = false; var iloaded = false; var igo = false; var iwebkit = false; var firefox = false; var safari = false; var chrome = false; var nametip; var name_txt; var controls; var youtubeElemId; var youtubeIframe; var mouseMoveCatcher; var playlist; var pl_mc; var pl; var plwidth; var plheight; var ipl; var plbg; var pltext; var plplayed; var plrandom; var plpage = 0; var v; var vvv; var muted; var hideInterval; var rmenu; var timelength = 4; var timeitems = 0; var line_s; var volbarline_s; var lastTime = 0; var ltc = 0; var layer; var player; var uibg; var uibg_gl; var oo; var play_b; var pause_b; var back_b; var stop_b; var start_b; var time_play_b; var time_back_b; var time_all_b; var volume_b; var volume_mute_b; var volbarline_b; var volbarline_all_b; var volbarline_play_b; var volbar_b; var volbars; var sep_b; var run_b; var run_pos; var runvolume_b; var runvolume_pos; var sep; var download_b; var next_b; var prev_b; var plnext_b; var plprev_b; var full_b; var full_back_b; var line_b; var line_all_b; var line_load_b; var line_play_b; var line_but_b; var space_b; var buffer_b; var menu_b; var playlist_b; var hd_b; var hdselect; var hd1_b; var sub_b; var sub_text; var sub_bg; var sub; var sub_lang = 0; var sub_showed = false; var sub_menu; var sub_menu2; var sub_menu_bg; var isub_menu_color; var isub_menu_bgcolor; var sub_last; var sub_lang_all = false; var mybuts = []; var cntrlength; var cntrl; var cntrls; var cntrli; var controls; var browser = new Uppod.Browser(); var logo; var uppod = { _controls: null, _mediaW: null, _parentDom: null, _ads: null, iframe: {}, window: {}, document: {}, toolTipOn: function(domElment) { domElment.onmouseover = function() { ToolTip(domElment, domElment.title) }; domElment.onmouseout = function() { ToolTipHide(domElment) } }, createMediaW: function() { this._mediaW = new Uppod.MediaW({ mode: vars.m, vars: vars, mobile: mobile, ads: this.ads() }); this._mediaW.onError.bind(function() { onReady(); NotFound() }); if (vars.hlsautoquality == 1) { this._mediaW.onQuality.bind(function() { onHlsQuality() }) } return this._mediaW }, mediaW: function() { return this._mediaW }, controls: function() { if (!this._controls) { this._controls = new Uppod.Controls() } return this._controls }, playerBodyElement: function() { return body }, parentDom: function() { return this._parentDom }, ads: function() { if (!this._ads && Uppod.Ads) { this._ads = new Uppod.Ads({ containerDom: uppod.document, containerDiv: uppod.iframe, uid: vars.uid, playerDom: this.playerBodyElement().c, prerollVast: CreateLink(vars.vast_preroll), postrollVast: CreateLink(vars.vast_postroll), pauserollVast: CreateLink(vars.vast_pauseroll), midrollVast: CreateLink(vars.vast_midroll), midrollTimes: CreateLink(vars.midroll_times), adEachPlaylistItem: parseInt(vars.vast_pl) === 1, pauseOnClick: parseInt(vars.vast_pauseonclick) === 1, prerollPauseOnClick: parseInt(vars.vast_preroll_pauseonclick) === 1, }) } return this._ads }, vars: function() { return vars }, toogleFullscreen: function() { return Full.apply(this, arguments) }, isFullscreen: function() { return ifull }, }; if (loadvars.uid) { if (!uppod_players) { uppod_players = [] } this.uid = loadvars.id = loadvars.uid }; uppod_players.push(this); if (document.getElementById(loadvars.id)) { Init() } else { document.addEventListener('DOMContentLoaded', Init) }; function createBody() { body = new Shaper2({ w: vars.sw, h: vars.sh, bgc: vars.bodycolor, brd: vars.brd, brdc: vars.brdcolor, h0: (vars.cntrlout == 1 ? vars.sh - vars.cntrloutheight : 0) - (vars.pl && vars.plplace == "bottom" ? vars.plth + 20 : 0), a: (vars.transparent == 1 ? -1 : 1) }); uppod.document.appendChild(body.c); CSS(uppod.iframe, { '-webkit-user-select': 'none', '-khtml-user-select': 'none', '-moz-user-select': 'none', '-o-user-select': 'none', 'user-select': 'none', 'overflow': 'hidden', 'margin': '0px', 'padding': '0px', 'width': '100%', 'height': '100%', }); CSS(body.c, { 'position': 'absolute', 'top': 0, 'left': 0 }) }; function createScreen() { scrn = new Shaper2({ w: vars.scrn_w, h: vars.scrn_h, bgc: vars.screencolor, o: (vars.padding > 0 ? vars.o / 2 : 0), a: (vars.transparent == 1 ? -1 : 1) }); body.c.appendChild(scrn.c); CSS(scrn.c, { 'position': 'absolute', 'top': vars.padding, 'left': vars.padding, 'zIndex': 1 }) }; function createPlaylists() { var iyt; var stop = false; if (vars.pl) { if (typeof(vars.pl) == 'object') { CreatePl() }; if (typeof(vars.pl) == 'string') { vars.pl_original = vars.pl; var str; if (vars.pl.indexOf("{") == 0) { str = vars.pl; str = str.replace(/'/g, '"') } else { if (vars.pl.indexOf("youtube:") == 0) { if (vars.pl.indexOf('user_') == 8) { vars.pl = 'https://www.googleapis.com/youtube/v3/channels?part=contentDetails&forUsername=' + vars.pl.substr(13) + '&key=' + vars.ytapi } if (vars.pl.indexOf('search_') == 8) { vars.pl = 'https://www.googleapis.com/youtube/v3/search?part=snippet&q=' + Ytpl(vars.pl.substr(15)) + '&maxResults=' + vars.ytpllimit + '&order=' + vars.ytplorder + '&relevanceLanguage=' + vars.lang + '&key=' + vars.ytapi } if (vars.pl.indexOf('pl_') == 8) { vars.pl = 'https://www.googleapis.com/youtube/v3/playlistItems?part=snippet&playlistId=' + vars.pl.substr(11) + '&maxResults=' + vars.ytpllimit + '&key=' + vars.ytapi } iyt = true } str = LoadFile(vars.pl) }; if (str) { if (str.indexOf('#') == 0) { str = un(str) }; try { if (str.indexOf("\'") > -1) { str = str.replace(/\\'/g, "'") }; vars.pl = JSON.parse(str); if (iyt) { var obj = vars.pl; var newobj = {}; newobj["playlist"] = []; var i; if (obj.error) { if (obj.error.errors[0].reason == "keyInvalid") {} } else { if (obj.items[0].contentDetails) { vars.pl = 'youtube:pl_' + obj.items[0].contentDetails.relatedPlaylists.uploads; createPlaylists(); stop = true } else { if (obj.items.length > 0) { for (i = 0; i < obj.items.length; i++) { if (obj.items[i].snippet) { newobj["playlist"][i] = new Object(); if (vars.pl_original.indexOf(":pl_") > 0) { newobj["playlist"][i].file = 'http' + (vars.https == 1 ? 's' : '') + '://youtube.com/watch?v=' + obj.items[i].snippet.resourceId.videoId } if (vars.pl_original.indexOf(":search_") > 0) { newobj["playlist"][i].file = 'http' + (vars.https == 1 ? 's' : '') + '://youtube.com/watch?v=' + obj.items[i].id.videoId } newobj["playlist"][i].poster = obj.items[i].snippet.thumbnails.default.url; vars.ytposter == 1 ? newobj["playlist"][i].bigposter = obj.items[i].snippet.thumbnails.high.url : ''; newobj["playlist"][i].link = newobj["playlist"][i].file; newobj["playlist"][i].comment = obj.items[i].snippet.title } } vars.pl = newobj } } } } vars.pl.playlist ? vars.pl = vars.pl.playlist : '' } catch (err) { console.log(err); Alert(vars.lang2.errjson_decode + ' ' + Filename(vars.pl_original), true) } }; !stop ? CreatePl() : '' }; if (vars.file == '') { ipl = 0; if (vars.random == 1) { ipl = getRandomInt(0, pl.length - 1); Opacity(plbg[0], vars.plalpha); Opacity(plbg[ipl], vars.plalpha_play) } if (vars.pl[ipl].playlist) { if (vars.pl[ipl].playlist[0].playlist) { UpdatedVarsFromPlaylist(vars.pl[ipl].playlist[0].playlist[0]) } else { UpdatedVarsFromPlaylist(vars.pl[ipl].playlist[0]) } } else { UpdatedVarsFromPlaylist(vars.pl[ipl]) } } } }; function Ytpl(str) { var myAmpPattern = / /g; var itmp = str.split(' ').length; for (var i = 0; i < itmp; i++) { str = str.replace(myAmpPattern, "%20") } return str } function createAlert() { alrt = createElement('div'); alrt.className = 'uppod-alert'; CSS(alrt, { 'width': '100%', 'position': 'absolute', 'top': vars.padding, 'left': vars.padding, 'color': '#' + ReColor(vars.commentcolor), 'zIndex': 3 }); body.c.appendChild(alrt); vars.commentbgcolor.indexOf('|') == -1 ? vars.commentbgcolor = vars.commentbgcolor + '|' + vars.commentbgcolor : ''; alrt_bg = new Shaper2({ w: vars.sw - vars.padding * 2, h: '20', o: 0, bgc: vars.commentbgcolor, bga1: vars.commentbgalpha1, bga2: vars.commentbgalpha2 }); alrt.appendChild(alrt_bg.c); alrt_txt = createElement('div'); alrt.appendChild(alrt_txt); CSS(alrt_txt, { 'position': 'absolute', 'top': 0, 'left': 0, "paddingTop": (vars.commentmargin + vars.commenttopmargin), "paddingLeft": (vars.commentmargin + 5), "paddingBottom": (vars.commentmargin * 1.3), "fontFamily": vars.namefont, "fontSize": vars.namefontsize, "fontStyle": FontStyle(vars.namefontstyle), "fontWeight": FontWeight(vars.namefontstyle) }); alrt_x = createElement('div'); alrt.appendChild(alrt_x); CSS(alrt_x, { 'position': 'absolute', 'top': 0, 'right': 0, "paddingTop": 5, "paddingRight": 10, "cursor": "pointer", "color": "#" + vars.commentcolor }); alrt_x.innerHTML = 'x'; alrt_x.onclick = CloseAlrt; alrt.style.display = 'none'; disableSelection(alrt) } function createTip() { if (vars.tip == 1) { tip = createElement('div'); tip.className = 'uppod-tip'; uppod.iframe.appendChild(tip); CSS(tip, { 'position': 'absolute', 'top': 0, 'left': 0, "visibility": "hidden", "color": "#" + ReColor(vars.tipfontcolor), "borderRadius": vars.tipbgo / 2, "fontFamily": vars.tipfont, "fontSize": vars.tipfontsize, "fontWeight": FontWeight(vars.namefontstyle), "padding": "4px", "lineHeight": "normal" }); tip.style.zIndex = 9; CheckGradiendDiv(tip, vars.tipbgcolor) } } function CreateLink(x) { if (x) { x = x.replace(/\(referer\)/g, encodeURIComponent(vars.referer)); x = x.replace(/\(random\)/g, Math.random()) } return x } function createComment() { if (vars.comment != undefined && vars.comment != '' && vars.showname == 1) { if (vars.shownameliketip == 1) { CreateNameTip(vars.comment); vars.shownameonover == 1 && vars.shownameonstop == 0 ? Hide(nametip) : '' } else { Alert(vars.comment, false) } } }; function createIframe(afterCreateCallback) { var _this = this; uppod.iframe = createElement('div'); CSS(uppod.iframe, { 'position': 'relative', 'width': '100%', 'height': '100%', 'border': 'none' }); if (vars.transparent == 0) { CSS(uppod.iframe, { 'backgroundColor': '#' + ReColor(vars.bgcolor) }) } uppod.window = window; uppod.document = uppod.iframe; vars.stg.appendChild(uppod.iframe) }; function createMouseMoveCatcher() { mouseMoveCatcher = createElement('div'); mouseMoveCatcher.className = 'uppod-mouse-move-catcher'; CSS(mouseMoveCatcher, { display: 'none', 'z-index': '103', position: 'absolute', top: '0px', left: '0px', width: '100%', height: '100%' }); body.c.appendChild(mouseMoveCatcher) }; function createPlayer() { createIframe(); createBody(); ScreenSize(); createScreen(); createPlaylists(); if (vars.file) { if (vars.file && vars.hd) { QualityLinks() } } createAlert(); createComment(); createMouseMoveCatcher(); Logo(); Media(); Controls(); oRadius(); Events(); createTip(); if (ierr != '') { Alert(ierr, true) } sizeInterval = setInterval(Sizing, 100) } var _onReadyOnce = false; function onReady() { if (!_onReadyOnce && loadvars.onReady) { _onReadyOnce = true; setTimeout(function() { loadvars.onReady.call(_this, _this) }, 50) } } function initHtml5() { vars.stg.innerHTML = ''; CSS(vars.stg, { 'lineHeight': '1', 'textAlign': 'left', 'text-align': 'left', '-moz-user-select': '-moz-none', '-o-user-select': 'none', '-khtml-user-select': 'none', '-webkit-user-select': 'none', 'user-select': 'none', 'overflow': 'hidden' }); if (vars.transparent == 0) { CSS(vars.stg, { 'backgroundColor': '#' + ReColor(vars.bgcolor) }) } createPlayer() } function initFlash() { var params = { allowFullScreen: "true", allowScriptAccess: "always" }; loadvars.file.replace("|", "or"); delete loadvars.st; if (loadvars.stflash) { loadvars.st = loadvars.stflash } new swfobject.embedSWF(vars.swf, vars.id, vars.sw, vars.sh, "10.0.0", false, loadvars, params); onReady() } function Init() { if (!loadvars.id) { return } Detect(); vars = new Vars(); vars.uid = loadvars.uid; vars.config.loader("NONFhGFsrp5ZrwxQhDFXJweUCLTKJwkUNGx7NP1srp5ZrwxQhDFZyOcLNOg1Rs4SCaTFmLRBfskSRwtLR2VIhBnSCL9FyHYMyLdSCa1ZIpeMmZE1m1o0RsxiNL5sRs9cn2FFRYoQNwkSCLULfHY6CL50h1o0RsxiNLdaoDYMlPcMNDdFILRiRsVXhwtZNHdQOD8Uk3gLqp5ByHx7r2FMhwkSCL0cyOcYp2kSCLxrmpchC118lwkSCLx9qa1hNBViC3gMh24SNHx7RsV0rOIijwghNV19OPcxmpN1hso0qp9iyGx7RsV0rOIiI1TRrLUBlPcZmPt9f3rSqpTxywEcJHx7qpCSq1cZOHx7Rv1XJBIxRwTFC2kShsV3jtIxN0V4RGdBOtTDILcxywEMyLrROwjBJGrBILYUq1cZOHx9lOIxruVLhDWXlHdBELFayOc0yGx9NDbayvjiCHe9rHx7ELdLJseioLFRIL5FOGRMmZbMA3jSyO19NBULJBeihP0LJs59faESED5BjP1RI1XByOU0jvk9ED5BJskSOGRUOGRMfaESED5XmP0TyOUayvkMAandfP1Zf2SSoGWMmPb7qPX1Jsn7qHUKyOULJsUioLd1p2xryP4cEP85mOd6OGrRI30ayvYMAadSyO19lO0ayvjiqGe9OGrRILx7oGb2mPjiqG5xytXBJtXByPczyvndqP0Xf2Y8oD5Yf2YKyLx7ELdLJsUioLd2p2xryP4cEHx7fGdMlO19nHb4yGx7ED5DmP1RI3MRIa8LJBY9EPMRI1XBfajiCZ09OGrGOGR/ED5vmPe6OGrRIaULJsj9mVXBgxXBmajigP0TfxXBOGR7ED5UjP1RI1XBmajigv0LJsX6OGrRIaULJs89ED53fajirZ1ZlHRUovjUovjUI3T8rstLR3TMNBT2COI8rOIURuIQrwVZrt9FlwIFhs5xNt9FlwxiNwV4P2N8VOIUksVYqOIxC3g8r3IQhsr8R3rsluVLhuIxNwxLNpo0lugLrpV8hwViN3gSluoXhwx0lwVUR2V8rOIURuIQrwVZruTDCp5iNpg8lwNQRBTLNpNxRsVLluVLhuWLh3gxC3glhwxiq3TMhs5xRYFkPkT8hs9Srw1UoOTLNpgMRsVZrugFRsrxruT1RsTXRs90Npo0O3IxNBTarwr8qp5MreNUCOoSlwxSrw1UoOTMhsx0HugchvV8rp5YNpNMhsVYluVLhuWLh3gxC3glN298rOIURsVYqOIxC3glrwtLN2V0lwNFhuoxluIxNwxLNpo0O3WUCOx8RwTFAOTsrp5ZrwxQhBTZhwxZq3TLNpgMRsVZrt9ZhwxZq3TLNpgMRsVZruTLNpgMRsVZrt9xhsg8Np5YIL5aRwTMrGdBlGRMJvbUA30MynS=") } var body; var scrn; var alrt; var tip; function Comment() { if (vars.comment != undefined && vars.comment != '' && vars.showname == 1) { if (vars.shownameliketip == 1) { NameTip((vars.marquee == 1 ? '<marquee>' : '') + vars.comment + (vars.marquee == 1 ? '</marquee>' : '')) } else { Alert((vars.marquee == 1 ? '<marquee>' : '') + vars.comment + (vars.marquee == 1 ? '</marquee>' : ''), false) } } else { Hide(alrt) } } function Detect() { brw = navigator.userAgent.toLowerCase(); if (brw.indexOf("ipad") > 0 || brw.indexOf("iphone") > 0) { brw.indexOf("iphone") > 0 ? iphone = true : ''; ipad = true; mobile = true } else { if (brw.indexOf("webkit") > -1) { iwebkit = true } if (brw.indexOf("firefox") > -1) { firefox = true } if (brw.indexOf("android") > -1) { android = true; mobile = true } if (brw.indexOf("chrome") > -1) { chrome = true } if (brw.indexOf("opera") > -1) { opera = true } } if (navigator.vendor) { if (navigator.vendor.indexOf("Apple") > -1) { safari = true } } ihtml5 = !!document.createElement('canvas').getContext; ihtml5 ? ihtml5 = !!document.createElement('video').canPlayType : ''; if (loadvars) { if (loadvars.file) { var tmp = loadvars.file; if (tmp.indexOf('#') == 0) { tmp = un(tmp) } if (tmp.indexOf(".flv") > 0) { ihtml5 = false } } } } function Alert(str, x) { if (alrt) { Show(alrt); alrt_txt.innerHTML = str; CSS(alrt_bg.canvas, { 'height': alrt_txt.offsetHeight, 'width': (vars.sw - vars.padding * 2) }); if (x) { Show(alrt_x) } else { Hide(alrt_x) } } else { alert('Uppod HTML5: ' + str) } } function CloseAlrt() { Hide(alrt) } function CreateNameTip(str) { nametip = createElement('div'); CSS(nametip, { 'width': '100%', 'position': 'absolute', 'top': 5 + vars.namemargin_v + vars.padding, 'left': 5 + vars.namemargin_h + vars.padding, 'color': '#' + ReColor(vars.namecolor) }); body.c.appendChild(nametip); name_txt = createElement('div'); nametip.appendChild(name_txt); CSS(name_txt, { 'position': 'absolute', 'top': 0, 'left': 0, 'padding': vars.namepadding / 2 + 'px ' + vars.namepadding + 'px', "fontFamily": vars.namefont, "fontSize": vars.namefontsize + 'px', "fontStyle": FontStyle(vars.namefontstyle), "fontWeight": FontWeight(vars.namefontstyle), 'zIndex': 2 }); name_txt.innerHTML = (vars.marquee == 1 ? '<marquee>' : '') + str + (vars.marquee == 1 ? '</marquee>' : ''); var name_bg = new Shaper2({ w: name_txt.offsetWidth, h: name_txt.offsetHeight, o: vars.namebgo / 2, bgc: vars.namebgcolor + '|' + vars.namebgcolor, bga1: vars.namebgalpha, bga2: vars.namebgalpha }); nametip.appendChild(name_bg.c); CSS(name_bg.canvas, { 'zIndex': 1 }) }; function NameTip(str) { name_txt.innerHTML = str }; function Logo(str) { if (vars.logo != '') { logo = document.createElement('img'); logo.src = vars.logo; logo.onload = PositionLogo; uppod.document.appendChild(logo); Opacity(logo, vars.logoalpha); if (vars.logopause == 0 && !iplay) { Hide(logo) } if (vars.logolink != '') { logo.onmouseover = function(e) { Opacity(logo, 1) }; logo.onmouseout = function(e) { Opacity(logo, vars.logoalpha) }; logo.onclick = function(e) { window.open(vars.logolink, vars.logotarget) } }; PositionLogo(); if (vars.logohide) { setTimeout(function() { CSS(logo, { 'visibility': 'hidden' }) }, vars.logohide * 1000) } } }; function PositionLogo() { if (vars.logoplace == 1) { CSS(logo, { 'cursor': 'pointer', 'position': 'absolute', 'top': vars.logomargin_v, 'left': vars.logomargin_h }) } if (vars.logoplace == 2) { CSS(logo, { 'cursor': 'pointer', 'position': 'absolute', 'top': vars.logomargin_v, 'right': vars.logomargin_h }) } if (vars.logoplace == 3) { CSS(logo, { 'cursor': 'pointer', 'position': 'absolute', 'bottom': (vars.logomargin_v + (vars.cntrlout == 0 ? vars.cntrloutheight : 0)), 'left': vars.logomargin_h }) } if (vars.logoplace == 4) { CSS(logo, { 'cursor': 'pointer', 'position': 'absolute', 'bottom': (vars.logomargin_v + (vars.cntrlout == 0 ? vars.cntrloutheight : 0)), 'right': vars.logomargin_h }) } } function Events() { if (!mobile && vars.hotkey == 1) { body.c.addEventListener("dblclick", function() { !ifull ? Full() : FullOff() }) } body.c.onmousemove = MouseMove; body.c.onmouseup = function MouseUp(e) { volbarline_b ? volbarline_s['active'] = false : ''; line_b ? line_s['active'] = false : '' }; body.c.onmouseover = function MouseOver(event) { iover = true; vars.shownameonover == 1 ? Show(nametip) : '' }; body.c.onmouseout = function MouseOut(event) { iover = false; vars.shownameonover == 1 && ((vars.shownameonstop == 1 && iplay) || vars.shownameonstop == 0) ? Hide(nametip) : '' }; var rightMenu = 'Uppod HTML5<br>0.8.3'; if (rightMenu != 'native') { body.c.oncontextmenu = function ContextMenu(e) { if (!e) var e = window.event; e.cancelBubble = true; if (e.stopPropagation) e.stopPropagation(); var x = e.pageX - findLeft(vars.stg); var y = e.pageY - findTop(vars.stg); if (rmenu) { CSS(rmenu, { "display": "block", "position": "absolute", "top": y, "left": x }) } else { rmenu = createElement('div'); rmenu.id = "rmenu"; uppod.document.appendChild(rmenu); var rmenu1 = createElement('div'); rmenu.appendChild(rmenu1); rmenu1.innerHTML = rightMenu; CSS(rmenu, { "borderRadius": "0px", "cursor": "pointer", "position": "absolute", "top": y, "left": x, "backgroundColor": "#000", "color": "#fff", "borderStyle": "solid", "borderColor": "#000000", "borderWidth": "1px", "padding": "2px 5px 3px 5px", "font": "9px Tahoma", "opacity": "1" }); rmenu.style.zIndex = 999 } setTimeout(function() { document.getElementById("rmenu").style.display = "none" }, 1000); return false } } document.addEventListener("click", DocClick) } function MouseMove(event) { if (ihide) { lastdXY = lastXY - (event.clientX + event.clientY); if (lastdXY != 0) { CntrlShow(); if (vars.cntrlhide == 1 || (ifull && vars.fullcntrlhide == 1)) { clearInterval(hideInterval); hideInterval = setInterval(CntrlHide, 3000) } } } lastXY = event.clientX + event.clientY } function DocClick(e) { if (rmenu) { Hide(rmenu) } } function KeyHandler(event) { if (uppod_active_player_uid == vars.uid) { if (event.target.tagName.toLowerCase() == 'input' || event.target.tagName.toLowerCase() == 'textarea') { return } var keyCode = event.which; if (keyCode == undefined) { keyCode = event.keyCode } if (ifull && keyCode == 27) { FullOff() } if (keyCode == 38) { if (media) { event.preventDefault(); (media.volume + 0.1) < 1 ? media.volume += 0.1 : media.volume = 1 } } if (keyCode == 40) { if (media) { event.preventDefault(); (media.volume - 0.1) > 0 ? media.volume -= 0.1 : media.volume = 0 } } if (keyCode == 39) { if (media && Duration() > 0) { var t = line_all_b.w / Duration(); if (line_play_b.offsetWidth + t * vars.keyseek < line_all_b.w) { Seek(line_play_b.offsetWidth + t * vars.keyseek) } else { Seek(line_all_b.w) } } } if (keyCode == 37) { if (media && Duration() > 0) { var t = line_all_b.w / Duration(); if (line_play_b.offsetWidth - t * vars.keyseek > 0) { Seek(line_play_b.offsetWidth - t * vars.keyseek) } else { Seek(0) } } } if (keyCode == 68) { Mute() } if (keyCode == 70) { !ifull ? Full() : FullOff() } if (vars.hotkey == 1 && keyCode == 32) { event.preventDefault(); Toggle() } } } var o11; var o12; var o21; var o22; var media_mc; var poster_mc; var media; var media_yt; var playInterval; function DestroyMedia() { if (media) { if (uppod.mediaW()) { uppod.mediaW().destroy() } if (playInterval) { clearInterval(playInterval); media.removeEventListener('play', OnPlay, false); media.removeEventListener('pause', OnPause, false); media.removeEventListener('canplay', onCanPlay, false); media.removeEventListener('volumechange', OnVolume, false) } or = []; ori = 0; vars.hls_quality = false; if (isYoutube()) { media_yt.stopVideo(); delete media_yt; var element = document.getElementById('yt_media_' + vars.uid); element.parentNode.removeChild(element); vars.youtube = false; vars.youtube_quality_received = false; !ifull && layer ? Show(layer) : '' } else { media.pause(); media.src = ''; media_mc.removeChild(media) } delete media; media = undefined; vars.events = new Array(); if (line_b) { CSS(line_play_b, { 'width': '0' }); CSS(line_load_b, { 'width': '0' }) } igo = false; init = false; iplay = false; startX = 0 } } function Media() { DestroyMedia(); vars.config.loader("NONFhGFsrp5ZrwxQhDFXJweUCLTKJwkUNGx7NP1srp5ZrwxQhDFZyOcLNOg1Rs4dCL50h1o0RsxiNLdaoDx9f2xsyGeBIL5LNOWUCpoxyG9AJLTPruIMhsRMyOc3qwxUNHFZJH0MA2ghCL50h1o0RsxiNLFFyV09q1cZOOT8CL50h1o0RsxiNLFFyO1KmVcsrp5ZrwxQhDFxyOcLNOg1Rs4dNtcxOO1rf2k9NBViC3gMh24SyOcLNOg1Rs4BOtT3yLr9f2E9EO07r2FMhwkSCL0cyOcMNDFKp2oryOcXmObiRsVXhwtZNHFiNORdksVBgOFXyGrROwjBy2kSCLYKI1TRCDRUI2RByHTKp2oryO19RsV0rOIijuW9yGR3yGeTyOUTmPdioDFRIagRILY7EDdTJucRIaoRIaMRIaVRILTRIaxRIaMRI2VRILTRI2tRIaSXJtXBNxXBfZW9yPcDJsEiqGdTyPUTJsn9N30BJve4Jve4JGr8hpVYqptlhpo8n1oPlwIFC2cBRs91hsgvh2TQRBTYqON8ruIFhBoXCOIxhBg8C3IxCOgxgpTxhpViruTMNBTYh2o1hpViruTXh3oMrwxQhBTUNpN0luoZRs58lw9iC2TMC2c8CpIah2T1rwV8rw9XltgQN2rUNOTFRuWxhsgvqwxUNGRiR3WUqOnSI3XByHXXJuc9yHYy"); if (vars.file.indexOf('youtube.com/') > -1 || vars.file.indexOf('youtu.be/') > -1) { if (vars.file.indexOf('youtu.be/') > -1) { vars.youtube_id = vars.file.substr(vars.file.indexOf(".be/") + 4); vars.youtube_id.replace("/", "") } else { vars.youtube_id = vars.file.split(/(youtu.be\/|v\/|embed\/|watch\?|youtube.com\/user\/[^#]*#([^\/]*?\/)*)\??v?=?([^#\&\?]*)/)[3] } if (vars.youtube_id.length == 11) { vars.youtube = true } } if (vars.hls_quality && vars.hlsautoquality == 1) { vars.hd = ''; vars.hda = vars.hd.split(','); vars.quality = null; HdSelect() } if (vars.youtube) { if (isYoutubeApiLoaded()) { YoutubeInit() } else { uppod.window.onYouTubeIframeAPIReady = function() { for (var i = 0; i < uppod_players.length; i++) { if (uppod_players[i].isYoutube()) { uppod_players[i].YoutubeInit() } } }; var youTubeScript = document.createElement('script'); youTubeScript.src = "https://www.youtube.com/iframe_api"; body.c.appendChild(youTubeScript) } vars.youtube_created = true } else { if (vars.youtube_created && hd_b) { vars.hd = ''; vars.hda = vars.hd.split(','); vars.quality = null; HdSelect() } media = uppod.createMediaW().dom; media.addEventListener('canplay', onCanPlay); media.addEventListener('play', OnPlay); media.addEventListener('pause', OnPause); media.setAttribute("onplay", OnPlay); uppod.mediaW().onEnded.bind(OnEnded); media_mc.appendChild(media); CSS(media_mc, { 'width': vars.sw - (!ifull ? vars.padding * 2 : 0) + 'px' }); media.setAttribute('width', '100%'); media.setAttribute('height', (!ifull ? vars.ph : vars.sh) - (!ifull ? vars.padding * 2 : 0) - (vars.cntrlout == 1 ? vars.cntrloutheight : 0) + 'px'); media.setAttribute('x-webkit-airplay', 'allow'); media.setAttribute('webkit-playsinline', '1'); media.controls = false; CSS(media, { 'position': 'absolute', 'top': 0, 'left': 0 }); if (vars.scale == "width") { CSS(media, { 'object-fit': 'cover' }) } if (vars.scale == "stretch") { CSS(media, { 'object-fit': 'fill' }) } if (vars.m == 'audio') { CSS(media, { 'width': '0px', 'height': '0px' }) } if (browser.isOpera && vars.auto == "firstframe") { vars.auto = "none" } if (vars.auto == "none" || vars.radio == 1) { if (vars.radio == 1 && vars.radiodropcache == 1 && vars.file) { if (vars.file.indexOf('?') > 0) { vars.file = vars.file + '&' + getRandomInt(1, 100) } else { vars.file = vars.file + '?' + getRandomInt(1, 100) } } } else { if (vars.auto == 'load') { media.preload = 'auto' } else { media.preload = 'metadata' } } if (vars.auto != 'none') { Source() } if (vars.auto == 'play') { uppod.mediaW().play() } setTimeout(checkStart, 100) } if (vars.screenposter != '') { vars.screenposter = CheckBase64(vars.screenposter); CSS(scrn.c, { 'width': vars.sw, 'height': vars.sh, 'background': 'url(' + vars.screenposter + ') no-repeat center center', 'background-size': 'cover' }) } if (vars.poster != '') { function createPosterHtml() { if (vars.m == 'audio') { return true } if (vars.fillposter == 1) { return true } if (vars.youtube) { if (browser.restrictMediaPlay == false) { return true } } else { if (browser.hasMediaPosterShown == false) { return true } } return false } if (createPosterHtml()) { if (!poster_mc) { poster_mc = createElement('div'); poster_mc.className = 'uppod-poster'; scrn.c.appendChild(poster_mc) } vars.poster = CheckBase64(vars.poster); CSS(poster_mc, { 'position': 'absolute', 'left': 0, 'top': 0, 'width': vars.sw, 'height': vars.ph - vars.padding * 2 - (vars.cntrlout == 1 ? vars.cntrloutheight : 0), 'background': 'url("' + vars.poster + '") no-repeat center center', 'background-size': 'cover' }) } else { if (media) { media.setAttribute('poster', vars.poster) } ifull && playlist ? Resize() : '' } } if (vars.m == 'video' && mobile && media) { media.ontouchstart = ClickScreenMobile } if (!layer) { Layer(); isYoutube() ? Hide(layer) : '' } } function ClickScreenMobile() { if (!nativecontrols) { var hide = vars.cntrlhide == 1 && vars.cntrlout == 0; var fullHide = ifull && vars.fullcntrlhide == 1; if (hide || fullHide) { CntrlShow(); clearInterval(hideInterval); hideInterval = setInterval(CntrlHide, 3000) } } } function Layer() { if (layer) { Remove('layer') } layer = createElement('div'); layer.setAttribute('id', 'layer'); body.c.appendChild(layer); CSS(layer, { 'width': '100%', 'height': scrn.canvas.offsetHeight, 'position': 'absolute', 'top': 0, 'left': 0, 'zIndex': 2 }); layer.onclick = LayerClick; layer.style.zIndex = 2; alrt.style.zIndex = 3; nametip ? nametip.style.zIndex = 4 : ''; controls ? controls.style.zIndex = 5 : ''; logo ? logo.style.zIndex = 6 : '' } function LayerClick() { if (vars.redirect != '' && vars.redirect_click == 1) { window.open(vars.redirect, vars.redirecttarget) } else { if (vars.m == 'video') { Toggle(); if (nativecontrols) { Remove('layer') } } } } function oRadius() { if (vars.o > 0) { oo = createElement('div'); o11 = document.createElement('canvas'); var ratio = 1; var ctx = o11.getContext("2d"); if (ctx.webkitBackingStorePixelRatio < 2) { var ratio = window.devicePixelRatio || 1 } o11.height = vars.o * ratio; o11.width = vars.o * ratio; ctx.fillStyle = '#' + ReColor(vars.bgcolor); ctx.beginPath(); ctx.scale(ratio, ratio); ctx.moveTo(0, 0); ctx.lineTo(vars.o / 2, 0); ctx.quadraticCurveTo(0, 0, 0, vars.o / 2); ctx.closePath(); ctx.fill(); oo.appendChild(o11); o12 = document.createElement('canvas'); var ctx = o12.getContext("2d"); o12.height = vars.o * ratio; o12.width = vars.o * ratio; ctx.fillStyle = '#' + ReColor(vars.bgcolor); ctx.beginPath(); ctx.scale(ratio, ratio); ctx.moveTo(0, 0); ctx.quadraticCurveTo(vars.o / 2, 0, vars.o / 2, vars.o / 2); ctx.lineTo(vars.o / 2, 0); ctx.closePath(); ctx.fill(); oo.appendChild(o12); o22 = document.createElement('canvas'); var ctx = o22.getContext("2d"); o22.height = vars.o * ratio; o22.width = vars.o * ratio; ctx.fillStyle = '#' + ReColor(vars.bgcolor); ctx.beginPath(); ctx.scale(ratio, ratio); ctx.moveTo(vars.o / 2, 0); ctx.quadraticCurveTo(vars.o / 2, vars.o / 2, 0, vars.o / 2); ctx.lineTo(vars.o / 2, vars.o / 2); ctx.closePath(); ctx.fill(); oo.appendChild(o22); o21 = document.createElement('canvas'); var ctx = o21.getContext("2d"); o21.height = vars.o * ratio; o21.width = vars.o * ratio; ctx.fillStyle = '#' + ReColor(vars.bgcolor); ctx.beginPath(); ctx.scale(ratio, ratio); ctx.moveTo(0, 0); ctx.quadraticCurveTo(0, vars.o / 2, vars.o / 2, vars.o / 2); ctx.lineTo(0, vars.o / 2); ctx.closePath(); ctx.fill(); oo.appendChild(o21); body.c.appendChild(oo); CSS(oo, { 'z-index': 7, 'position': 'absolute', 'top': 0, 'left': 0, 'pointer-events': 'none', 'height': 'auto', 'overflow': 'hidden', 'width': '100%', 'height': '100%' }); oo.style.zIndex = 7; oPos() } } function oPos() { CSS(o11, { 'position': 'absolute', 'top': 0, 'left': 0, 'width': vars.o + 'px', 'height': vars.o + 'px' }); CSS(o12, { 'position': 'absolute', 'top': 0, 'left': Math.round(vars.sw - vars.o / 2), 'width': vars.o + 'px', 'height': vars.o + 'px' }); CSS(o22, { 'position': 'absolute', 'top': Math.round(vars.sh - vars.o / 2), 'left': Math.round(vars.sw - vars.o / 2), 'width': vars.o + 'px', 'height': vars.o + 'px' }); CSS(o21, { 'position': 'absolute', 'top': Math.round(vars.sh - vars.o / 2), 'left': 0, 'width': vars.o + 'px', 'height': vars.o + 'px' }) } function Source() { if (vars.file != '') { if (vars.file.indexOf(' or ') > -1) { vars.or = vars.file.split(' or '); for (var i = 0; i < vars.or.length; i++) { if (vars.or[i].indexOf(" and ") > -1) { var _urls_and = vars.or[i].split(" and "); vars.or[i] = _urls_and[getRandomInt(0, _urls_and.length - 1)] } } vars.ori = 0; vars.file = vars.or[0] } else { if (vars.file.indexOf(" and ") > -1) { var _urls_and = vars.file.split(" and "); vars.file = _urls_and[getRandomInt(0, _urls_and.length - 1)] } } } uppod.mediaW().setSources(vars.file) } function CreatePl() { playlist = createElement('div'); playlist.className = 'uppod-playlist'; pl_mc = createElement('div'); playlist.appendChild(pl_mc); pl = new Array(); plbg = new Array(); pltext = new Array(); plplayed = new Array(); plrandom = new Array(); var droprow = 0; for (i = 0; i < vars.pl.length; i++) { pl[i] = createElement('div'); pl_mc.appendChild(pl[i]); CSS(pl[i], { 'cursor': 'pointer', 'color': '#' + ReColor(vars.plcolor), 'width': vars.pltw, 'height': vars.plth }); if (vars.plplace == 'inside' || vars.plplace == 'bottom') { CSS(pl[i], { 'position': 'absolute', 'top': (vars.plth * vars.pl_rows), 'left': (vars.pltw * i + vars.plmargin * i - vars.pltw * droprow) }); if (vars.plrows > 0) { if (i % vars.plrows == 0) { vars.pl[i]['endrow'] = 1 } } if (vars.pl[i]['endrow'] == 1) { vars.pl_rows++; droprow = i + 1 } } if (vars.plplace == 'bottomrow') { CSS(pl[i], { 'position': 'absolute', 'top': (vars.plth * i + vars.plmargin * i), 'left': 0, 'width': vars.sw - vars.plmargin * 2 }) } pl_mc.appendChild(pl[i]); plbg[i] = createElement('div'); pl[i].appendChild(plbg[i]); CSS(plbg[i], { 'height': vars.plth, 'borderRadius': (vars.o > 0 ? 4 : 0) }); Opacity(plbg[i], vars.plalpha); CheckGradiendDiv(plbg[i], vars.plbgcolor); if (vars.plplace == 'inside' || vars.plplace == 'bottom') { CSS(plbg[i], { 'width': vars.pltw }) } if (vars.plplace == 'botomrow') { CSS(plbg[i], { 'width': (vars.sw - vars.plmargin_h * 2) }) } if (vars.pl[i]['poster'] && vars.pltumbs >= 1) { plbg[i].innerHTML = "<img src='" + vars.pl[i]['poster'] + "' width='100%' id='plim" + i + "' class='uppod-playlist-" + i + "'>"; Opacity(plbg[i], 1) } pltext[i] = createElement('div'); pl[i].appendChild(pltext[i]); CSS(pltext[i], { 'padding': 5, 'position': 'absolute', 'top': 0, 'left': 0, 'fontFamily': vars.plfont, 'fontSize': vars.plfontsize, "pointerEvents": "none" }); if (vars.plplace == 'botomrow') { CSS(pltext[i], { 'height': vars.plth }) } if (vars.pl[i]['comment']) { pltext[i].innerHTML = vars.pl[i].comment } else { Hide(pltext[i]) } if (vars.pl[i]['poster'] && vars.pltumbs >= 1) { CheckGradiendDiv(pltext[i], vars.plbgcolor); CSS(plbg[i], { 'background': 'none' }); vars.pltumbs == 1 && i > 0 ? Hide(pltext[i]) : '' } pl[i].className = 'uppod-playlist-' + i; plbg[i].className = 'uppod-playlist-' + i + '_background'; pltext[i].className = 'uppod-playlist-' + i + '_text'; if (mobile) { pl[i].onclick = PlClick } else { pl[i].onmouseover = PlOver; pl[i].onmouseout = PlOut; pl[i].onclick = PlClick } plplayed[i] = false; plrandom[i] = i } if (mobile) { pl_mc.ontouchstart = PlTouchStart; pl_mc.ontouchmove = PlTouchMove; pl_mc.ontouchend = PlTouchEnd } body.c.appendChild(playlist); if (vars.plplace == 'inside' || vars.plplace == 'bottom') { CSS(playlist, { 'position': 'absolute', 'width': (vars.sw - vars.plmargin_h * 2), 'height': vars.plth * (vars.pl_rows + 1) + 10, 'overflow': 'hidden' }); vars.plplace == 'bottom' ? CSS(pl_mc, { 'position': 'absolute', 'top': 0, 'left': 0 }) : CSS(pl_mc, { 'position': 'absolute', 'top': 10, 'left': 0 }); plwidth = (vars.pl.length - droprow) * vars.pltw + (vars.pl.length - droprow - 1) * vars.plmargin; plheight = vars.plth * (vars.pl_rows + 1) + 10 } if (vars.plplace == 'bottomrow') { CSS(playlist, { 'position': 'absolute', 'width': (vars.sw - vars.plmargin_h * 2), 'height': vars.bottomrowheight - vars.plmargin - vars.padding * 2 - vars.plmargin_v * 2, 'overflow': 'hidden' }); CSS(pl_mc, { 'position': 'absolute', 'top': 0, 'left': 0 }); plwidth = vars.sw - vars.plmargin_h * 2; plheight = vars.pl.length * vars.plth + (vars.pl.length - 1) * vars.plmargin } if (vars.plarrows == 1) { plnext_b = new Element((vars.plplace == "bottomrow" ? 'download' : 'next'), 20, 20); body.c.appendChild(plnext_b.c); CSS(plnext_b.c, { 'cursor': 'pointer' }); plnext_b.c.onclick = PlArrowNext; plprev_b = new Element((vars.plplace == "bottomrow" ? 'download' : 'next'), 20, 20); CSS(plprev_b.c, { "transform": "rotate(-180deg)", "-webkit-transform": "rotate(-180deg)", "-moz-transform": "rotate(-180deg)", "-o-transform": "rotate(-180deg)", "-ms-transform": "rotate(-180deg)" }); body.c.appendChild(plprev_b.c); CSS(plprev_b.c, { 'cursor': 'pointer', 'display': 'none' }); plprev_b.c.onclick = PlArrowPrev; plnext_b.c.style.zIndex = 6; plprev_b.c.style.zIndex = 6; PlArrows() } ipl = 0; if (vars.plbgcolor_play != undefined) { CSS(plbg[ipl], { "background-color": '#' + vars.plbgcolor_play }) } if (vars.plcolor_play != undefined) { CSS(pl[ipl], { "color": '#' + vars.plcolor_play }) } Opacity(plbg[ipl], vars.plalpha_play); playlist.style.zIndex = 6; PlPlace(); if (vars.plplace == "inside" && vars.pliview == 0) { ShowHide(playlist); if (plnext_b) { if (playlist.style.display == "none") { Hide(plnext_b.c); Hide(plprev_b.c) } else { Show(plnext_b.c); Show(plprev_b.c) } } } } function Pl() { if (playlist) { if (vars.plplace == 'inside') { ShowHide(playlist); if (plnext_b) { if (playlist.style.display == "none") { Hide(plnext_b.c); Hide(plprev_b.c) } else { PlPlace(); Show(plnext_b.c); Show(plprev_b.c); PlArrows() } } } } else { CreatePl() } } function RemovePl() { if (playlist) { playlist.removeChild(pl_mc); body.c.removeChild(playlist); plnext_b ? body.c.removeChild(plnext_b.c) : ''; plprev_b ? body.c.removeChild(plprev_b.c) : '' } } function PlPlace() { if (vars.plplace == 'inside') { CSS(playlist, { 'width': (vars.sw - vars.plmargin_h * 2) }); CSS(playlist, { 'top': ((ifull ? vars.sh : vars.stageheight) - vars.plth - vars.cntrloutheight - 10) - vars.plth * vars.pl_rows, 'left': vars.plmargin_h }); if (plnext_b) { CSS(plprev_b.c, { 'position': 'absolute', 'top': playlist.offsetTop + vars.plth / 2 + (20 * vars.cntrlsize) / 2 + 10, 'left': playlist.offsetLeft - 10 }); CSS(plnext_b.c, { 'position': 'absolute', 'top': playlist.offsetTop + vars.plth / 2 - (20 * (vars.cntrlsize - 1)) / 2, 'left': playlist.offsetLeft + playlist.offsetWidth + 10 }) } if (pl_mc.offsetLeft < -plwidth + playlist.offsetWidth) { CSS(pl_mc, { 'position': 'absolute', 'top': 10, 'left': (-plwidth + playlist.offsetWidth) }) } if (plwidth <= (vars.sw - vars.plmargin_h * 2)) { CSS(pl_mc, { 'position': 'absolute', 'top': 10, 'left': 0 }) } } if (!ifull) { if (vars.plplace == 'bottomrow') { CSS(playlist, { 'width': (vars.sw - vars.plmargin_h * 2) }); CSS(playlist, { 'position': 'absolute', 'top': (vars.ph + (vars.cntrlout == 1 ? vars.cntrloutheight : 0) + 10 + vars.plmargin_v), 'left': vars.plmargin_h }); if (plnext_b) { CSS(plprev_b.c, { 'position': 'absolute', 'top': playlist.offsetTop - 5, 'left': playlist.offsetLeft + playlist.offsetWidth / 2 + 10 }); CSS(plnext_b.c, { 'position': 'absolute', 'top': playlist.offsetTop + playlist.offsetHeight + 5, 'left': playlist.offsetLeft + playlist.offsetWidth / 2 - 10 }) } if (ipl !== null) { SlidePLs(ipl) } } if (vars.plplace == 'bottom') { CSS(playlist, { 'width': (vars.sw - vars.plmargin_h * 2) }); CSS(playlist, { 'position': 'absolute', 'top': (vars.ph + 10), 'left': vars.plmargin_h }); if (plnext_b) { CSS(plprev_b.c, { 'position': 'absolute', 'top': playlist.offsetTop + vars.plth / 2 + (20 * vars.cntrlsize) / 2, 'left': playlist.offsetLeft - 10 }); CSS(plnext_b.c, { 'position': 'absolute', 'top': playlist.offsetTop + vars.plth / 2 - (20 * vars.cntrlsize) / 2, 'left': playlist.offsetLeft + playlist.offsetWidth + 10 }) } if (ipl !== null) { SlidePLs(ipl) } } } } var touchStartX; var touchStartY; var touchLastX; var touchLastY; var ipltouch; function PlTouchStart(e) { touchLastX = touchStartX = e.targetTouches[0].pageX; touchLastY = touchStartY = e.targetTouches[0].pageY } function PlTouchMove(e) { var dx = e.targetTouches[0].pageX - touchLastX; var dy = e.targetTouches[0].pageY - touchLastY; touchLastX = e.targetTouches[0].pageX; touchLastY = e.targetTouches[0].pageY; if (vars.plplace == 'inside' || vars.plplace == 'bottom') { var aim = pl_mc.offsetLeft + dx; if (aim < 0 && aim > (-plwidth + playlist.offsetWidth)) { CSS(pl_mc, { 'position': 'absolute', 'top': (vars.plplace == 'bottom' ? 0 : 10), 'left': aim }) } } if (vars.plplace == 'bottomrow') { var aim = pl_mc.offsetTop + dy; if (aim < 0 && aim > -plheight + playlist.offsetHeight - 10) { CSS(pl_mc, { 'position': 'absolute', 'top': aim, 'left': 0 }) } } e.preventDefault() } function PlTouchStart1(e) { ipltouch = getPlaylistId(e.target) } function PlTouchEnd(e) { var dx = touchLastX - touchStartX; var dy = touchLastY - touchStartY; if (dx == 0 && dy == 0) { if (ipltouch !== null && ipltouch !== undefined) { PlClick0(); ipl = ipltouch; PlClickCont(); ipltouch = null } } else { PlTouchGo(dx, dy) } } function getPlaylistId(dom) { return dom.className.replace('uppod-playlist-', '').split('_')[0] } function PlTouchGo(dx, dy) { if (vars.plplace == 'inside' || vars.plplace == 'bottom') { var aim = pl_mc.offsetLeft + dx; aim > 0 ? aim = 0 : ''; aim < -plwidth + playlist.offsetWidth ? aim = -plwidth + playlist.offsetWidth : ''; clearInterval(plInterval); plaim = aim; plInterval = setInterval(SlidePLProcess, 20) } if (vars.plplace == 'bottomrow') { var aim = pl_mc.offsetTop + dy; aim > 0 ? aim = 0 : ''; aim < -plheight + playlist.offsetHeight - 10 ? aim = -plheight + playlist.offsetHeight - 10 : ''; clearInterval(plInterval); plaim = aim; plInterval = setInterval(SlidePLProcess, 20) } } function PlOver(e) { var plid = getPlaylistId(e.target); Opacity(plbg[plid], 1); SlidePLs(plid); if (plid) { if (vars.pl[plid]['poster'] && vars.pl[plid]['comment']) { Show(pltext[plid]) } } } function PlOut(e) { var plid = getPlaylistId(e.target); if (plid) { if (vars.pl[plid]['poster'] && vars.pltumbs >= 1) { if (ipl != plid) { vars.pltumbs == 1 ? Hide(pltext[plid]) : ''; Opacity(plbg[plid], (plplayed[plid] ? 0.5 : 1)) } } else { if (ipl != plid) { Opacity(plbg[plid], (plplayed[plid] ? vars.plalpha2 : vars.plalpha)) } else { Opacity(plbg[plid], vars.plalpha_play) } } } } function PlClick(e) { if (ipl !== null && ipl !== undefined) { PlClick0() } ipl = getPlaylistId(e.target); PlClickCont(); if (vars.redirect != '' && vars.redirect_clickpl == 1) { window.open(vars.redirect, vars.redirecttarget) } } function PlClickCont() { if (vars.pl[ipl].playlist) { PlClick1() } else { PlClick1(); if (vars.plplace == "inside") { Hide(playlist); plnext_b ? Hide(plnext_b.c) : ''; plprev_b ? Hide(plprev_b.c) : '' } if (!iplay) { istart = true; Toggle() } } CheckPrevNext() } function Next() { if (ipl < (pl.length - 1)) { PlNext() } } function PlArrowNext() { var onpage = PlOnPage(); var i = (plpage + 1) * onpage; if (i < pl.length) { plpage++; if (vars.plplace == 'inside' || vars.plplace == 'bottom') { CSS(pl_mc, { 'position': 'absolute', 'left': -pl[i].offsetLeft }) } if (vars.plplace == 'bottomrow') { CSS(pl_mc, { 'position': 'absolute', 'top': -pl[i].offsetTop }) } PlArrows() } } function PlOnPage() { if (vars.plplace == 'inside' || vars.plplace == 'bottom') { return Math.floor((vars.sw - vars.plmargin_h * 2) / vars.pltw) } else { return Math.floor((vars.bottomrowheight - vars.plmargin_v * 2) / vars.plth) } } function PlArrows() { var onpage = PlOnPage(); var i = plpage * onpage; if (i + onpage >= pl.length) { Hide(plnext_b.c) } else { Show(plnext_b.c) } i == 0 ? Hide(plprev_b.c) : Show(plprev_b.c); if (vars.plplace != "inside" && ifull) { Hide(plnext_b.c); Hide(plprev_b.c) } } function PlArrowPrev() { var onpage = Math.floor((vars.sw - 80) / vars.pltw); var i = (plpage - 1) * onpage; if (i >= 0) { plpage--; if (vars.plplace == 'inside' || vars.plplace == 'bottom') { CSS(pl_mc, { 'position': 'absolute', 'left': -pl[i].offsetLeft }) } if (vars.plplace == 'bottomrow') { CSS(pl_mc, { 'position': 'absolute', 'top': -pl[i].offsetTop }) } PlArrows() } } function PlNext() { if (vars.random == 1) { if (plrandom.length > 1) { if (ipl !== null) { PlClick0() } ipl = plrandom[getRandomInt(0, plrandom.length - 1)]; PlClick1(); Event('next') } else { EndPl(); prev_b ? CSS(prev_b.c, { 'opacity': 1, 'filter': 'alpha(opacity=100)', 'cursor': 'pointer' }) : '' } } else { if (ipl < (pl.length - 1)) { if (ipl !== null) { PlClick0() } var start_in_folder = 0; if (vars.pl[ipl].playlist && !vars.pl[ipl].file && ipl == 0) { start_in_folder = 2 } else { ipl++ } PlClick1(); if (vars.pl[ipl].playlist && !vars.pl[ipl].file) { if (start_in_folder != 2) { start_in_folder = 1 } } if (start_in_folder > 0) { PlClick0(); ClearOldVars(); ipl = start_in_folder; UpdatedVarsFromPlaylist(vars.pl[ipl]); QualityLinks(); if (uppod.ads()) { uppod.ads().newPlaylistItem() } NewFile(vars.file, true); if (vars.plbgcolor_play != undefined) { CSS(plbg[ipl], { "background-color": '#' + vars.plbgcolor_play }) } if (vars.plcolor_play != undefined) { CSS(pl[ipl], { "color": '#' + vars.plcolor_play }) } Opacity(plbg[ipl], vars.plalpha_play) } Event('next') } else { EndPl() } } CheckPrevNext(); !iplay ? OnPlay() : '' } function CheckPrevNext() { if (vars.random == 0) { if (ipl == 0) { prev_b ? CSS(prev_b.c, { 'opacity': 0.3, 'filter': 'alpha(opacity=30)', 'cursor': 'default' }) : '' } else { prev_b ? CSS(prev_b.c, { 'opacity': 1, 'filter': 'alpha(opacity=100)', 'cursor': 'pointer' }) : '' } if (ipl == pl.length - 1) { next_b ? CSS(next_b.c, { 'opacity': 0.3, 'filter': 'alpha(opacity=30)', 'cursor': 'default' }) : '' } else { next_b ? CSS(next_b.c, { 'opacity': 1, 'filter': 'alpha(opacity=100)', 'cursor': 'pointer' }) : '' } } } function Prev() { PlPrev() } function PlPrev() { if (vars.random == 1) { if (plrandom.length > 1) { if (ipl !== null) { PlClick0() } ipl = plrandom[getRandomInt(0, plrandom.length - 1)]; PlClick1(); Event('prev') } else { EndPl() } } else { if (ipl > 0) { if (ipl !== null) { PlClick0() } ipl--; PlClick1(); Event('prev'); ipl == 0 && prev_b ? CSS(prev_b.c, { 'opacity': 0.3, 'filter': 'alpha(opacity=30)', 'cursor': 'default' }) : '' } else {} } CheckPrevNext() } function EndPl() { if (vars.plplay1 == 1) { TheEnd() } else { if (vars.random == 1) { for (p = 0; p < pl.length; p++) { plrandom[p] = p } PlNext() } else { PlClick0(); ipl = 0; PlClick1(); Event('next') } } } function PlClick0() { if (vars.pl[ipl]['poster'] && vars.pltumbs >= 1) { vars.pltumbs == 1 ? Hide(pltext[ipl]) : ''; Opacity(plbg[ipl], 0.5) } else { if (vars.plbgcolor_play != undefined) { CSS(plbg[ipl], { "background-color": '#' + vars.plbgcolor }) } if (vars.plcolor_play != undefined) { CSS(pl[ipl], { "color": '#' + vars.plcolor }) } Opacity(plbg[ipl], vars.plalpha2) } plplayed[ipl] = true; var idx = plrandom.indexOf(ipl); if (idx != -1) plrandom.splice(idx, 1) } function PlClick1() { if (vars.pl[ipl].playlist) { if (vars.pl[ipl].playlist != "back") { vars.pl_history.push(vars.pl); var newpl = vars.pl[ipl].playlist; vars.pl = [{ "comment": "←", "playlist": "back" }]; vars.pl = vars.pl.concat(newpl) } else { vars.pl = vars.pl_history[vars.pl_history.length - 1]; vars.pl_history.splice(vars.pl_history.length - 1, 1) } RemovePl(); CreatePl(); if (vars.plplace == "inside") { Show(playlist); plnext_b ? Show(plnext_b.c) : ''; plprev_b ? Show(plprev_b.c) : '' } } else { ClearOldVars(); UpdatedVarsFromPlaylist(vars.pl[ipl]); QualityLinks(); if (uppod.ads()) { uppod.ads().newPlaylistItem() } NewFile(vars.file, true); if (vars.plbgcolor_play != undefined) { CSS(plbg[ipl], { "background-color": '#' + vars.plbgcolor_play }) } if (vars.plcolor_play != undefined) { CSS(pl[ipl], { "color": '#' + vars.plcolor_play }) } Opacity(plbg[ipl], vars.plalpha_play) } if (plnext_b) { PlArrows() } } function UpdatedVarsFromPlaylist(obj) { for (var key in obj) { if (obj[key].indexOf('#') == 0) { obj[key] = un(obj[key]) } if (key == 'poster' && vars['poster'] == undefined) { vars['poster'] = obj['poster'] } else { vars[key] = obj[key] } if (key == 'bigposter') { vars['poster'] = obj['bigposter'] } } } function SlidePLs(plid) { if (vars.plplace == "inside" || vars.plplace == "bottom") { if (plwidth > (vars.sw - vars.plmargin_h * 2)) { SlidePL(plid) } } if (vars.plplace == "bottomrow") { if (plheight > vars.bottomrowheight) { SlidePL(plid) } } } var plInterval; var plaim; function SlidePL(i) { if (vars.plarrows == 0) { clearInterval(plInterval); if (vars.plplace == 'inside' || vars.plplace == 'bottom') { var aim = -pl[i].offsetLeft + playlist.offsetWidth / 2 - vars.pltw / 2; if (aim > 0 || plwidth < vars.sw) { aim = 10 } if (aim < 0 && aim < -plwidth + playlist.offsetWidth - 10) { aim = -plwidth + playlist.offsetWidth - 10 } plaim = aim; plInterval = setInterval(SlidePLProcess, 20) } if (vars.plplace == 'bottomrow') { var aim = -pl[i].offsetTop + playlist.offsetHeight / 2 - vars.plth / 2; if (aim > 0) { aim = 10 } if (aim < -plheight + playlist.offsetHeight - 10) { aim = -plheight + playlist.offsetHeight - 10 } plaim = aim; plInterval = setInterval(SlidePLProcess, 20) } } } function SlidePLProcess() { var aim = plaim; if (vars.plplace == 'inside' || vars.plplace == 'bottom') { if (Math.abs((pl_mc.offsetLeft - aim) / 10) <= 1) { clearInterval(plInterval) } else { CSS(pl_mc, { 'position': 'absolute', 'top': (vars.plplace == 'bottom' ? 0 : 10), 'left': pl_mc.offsetLeft - (pl_mc.offsetLeft - aim) / 10 }) } } if (vars.plplace == 'bottomrow') { if (Math.abs((pl_mc.offsetTop - aim) / 10) <= 1) { clearInterval(plInterval) } else { CSS(pl_mc, { 'position': 'absolute', 'top': pl_mc.offsetTop - (pl_mc.offsetTop - aim) / 10, 'left': 0 }) } } } function ClearOldVars() { if (sub) { KillSub(); sub = null } vars.ors = 0 } function NewFile(s, autoplay) { Uppod.trace('NewFile s=' + s + ' autoplay=' + autoplay); iplay = false; istartevnt = false; vars.file = s; if (autoplay) { vars.auto = 'play' } Media(); Comment(); if (autoplay) { OnPlay() } } function checkStart() { if (media != undefined) { if (Uppod.browser.doSendCanPlay == false || !vars.file || vars.file == '' || vars.auto != 'play') { onReady() } if (media.networkState >= 0 || vars.youtube) { init = true; CSS(media, { 'opacity': 1, 'filter': 'alpha(opacity=100)' }); Opacity(media, 1); playInterval = setInterval(Playing, 100); media.addEventListener('pause', OnPause, false); media.addEventListener('seeking', OnSeeking, false); media.addEventListener('seeked', OnSeeked, false); media.addEventListener('volumechange', OnVolume, false); function isFullscreen() { if (document.fullscreen) { document.fullscreen } else if (document.webkitIsFullScreen) { document.webkitIsFullScreen } else if (document.mozFullScreen) { document.mozFullScreen } } function FullscreenChange() {} document.addEventListener("fullscreenchange", function() { !document.fullscreen && ifull && !opera ? FullOff() : ''; FullscreenChange() }, false); document.addEventListener("mozfullscreenchange", function() { !document.mozFullScreen && ifull ? FullOff() : ''; FullscreenChange() }, false); document.addEventListener("webkitfullscreenchange", function() { !document.webkitIsFullScreen && ifull ? FullOff() : ''; FullscreenChange() }, false); document.addEventListener("MSFullscreenChange", function() { (document.fullscreenElement != undefined) && ifull ? FullOff() : ''; FullscreenChange() }, false); muted || v == 0 ? Volume(0) : (v > 0 ? Volume(-v) : ''); if (!initevent) { Event("init"); initevent = true } } else { setTimeout(checkStart, 100) } } } function Play() { iplay = false; Toggle() } function Pause() { iplay = true; Toggle() } function Toggle(e) { var stop = false; if (vars.redirect != '' && vars.redirect_play == 1) { window.open(vars.redirect, vars.redirecttarget); vars.redirect_play = 0 } Protection(); if (!stop) { Uppod.trace("Toggle e=" + e); if (vars.auto == 'none' && !vars.youtube) { media.autoplay = true; Source(); istart = true } vars.auto = 'play'; if (!vars.file || vars.file == '') { Event('player_error', 'nofile') } istart = true; if (!iplay) { if (isYoutube()) { media_yt.playVideo(); OnPlay() } else { uppod.mediaW().play(); OnPlay() } } else { if (isYoutube()) { media_yt.pauseVideo(); OnPause() } else { uppod.mediaW().pause(); OnPause() } } } } function Mybut(m) { if (mybuts[m.substr(11)]) { var act = mybuts[m.substr(11)].s.link; if (act.indexOf('http') == 0) { Link(act, (mybuts[m.substr(11)].s.target ? mybuts[m.substr(11)].s.target : "_blank")) } else { if (act == 'toggle') { Toggle() } if (act.indexOf('js:') == 0) { var js_vars = ''; if (act.indexOf(',') > 0) { js_vars = act.substr(act.indexOf(',') + 1); act = act.substr(0, act.indexOf(',')) } eval(act.substr(3) + '(' + js_vars + ')') } } Event('mybut', act) } } function Link(l, t) { if (l) { l = l.replace('(referer)', encodeURIComponent(vars.referer)); l = l.replace('(link)', encodeURIComponent(vars.link)); l = l.replace('(file)', encodeURIComponent(vars.file)); l = l.replace('(redirect)', encodeURIComponent(vars.redirect)); l = l.replace('(comment)', encodeURIComponent(vars.comment)); l = l.replace('(time)', CurrentTime()); if (l.substr(0, 3) == 'js:') { var myjsa = l.substr(3).split(','); eval(myjsa[0] + '(' + (myjsa.length > 1 ? myjsa[1] : '') + (myjsa.length > 2 ? ',' + myjsa[2] : '') + (myjsa.length > 3 ? ',' + myjsa[3] : '') + ');') } if (l.indexOf('http') == 0) { window.open(l, t) } } } function Stop() { Uppod.trace('Stop'); if (iplay) { Toggle(); OnPause() } vars.radio == 0 ? Seek(0) : ''; time_play_b ? time_play_b.c.innerHTML = formatTime(0) : ''; time_back_b ? time_back_b.c.innerHTML = formatTime(Duration()) : ''; vars.auto = 'none'; if (isYoutube()) { media_yt.stopVideo() } Media(); Event('stop'); line_b && run_b ? RunPos(run_b, line_b, line_play_b, line_all_b, run_pos) : ''; sub ? StopSub() : '' } function Download() { iplay ? Toggle() : ''; var downloadUrl = vars.download != 1 && vars.download != '' ? vars.download : (uppod.mediaW().length > 0 ? uppod.mediaW().sources[0] : (vars.file.indexOf("|") > 0 ? vars.file.substr(0, vars.file.indexOf("|")) : vars.file)); window.open(downloadUrl, "_blank"); Event('download') } function Protection() { if (vars.urlprotect_go) { if (vars.urlprotect_stop == 1) { media.src = '' } if (vars.urlprotect_warning == 1) { Alert((vars.redirect != '' ? '<a href="' + vars.redirect + '" style="font-size:200%;color:#fff">' : '') + (vars.urlprotect_msg != '' ? vars.urlprotect_msg : vars.redirect) + (vars.redirect != '' ? '</a>' : ''), false) } } } function Quality() { if (hd_b) { if (vars.filehd) { vars.start = media.currentTime; var fileold = vars.file; NewFile(vars.filehd, true); vars.filehd = fileold; if (hd1_b.c.style.display == 'none') { Hide(hd_b.c); Show(hd1_b.c); Event('quality', '1') } else { Hide(hd1_b.c); Show(hd_b.c); Event('quality', '0') } } } } function QualityLinks() { if (vars.youtube) {} else { if (vars.hd && vars.file) { if (vars.hd.indexOf('::') > 0) { vars.filehd = vars.file.replace(vars.hd.split('::')[0], vars.hd.split('::')[1]); var change = false; if (hd1_b) { if (hd1_b.c.style.display == 'block') { change = true } } else { if (vars.hd1 == 1) { change = true } } if (change) { var fileold = vars.file; vars.file = vars.filehd; vars.filehd = fileold } } if (vars.file.indexOf(",") > -1 && vars.file.indexOf('[') == -1) { vars.file = '[' + vars.file + ']' } if (vars.file.indexOf('[') > -1 && vars.file.indexOf(']') > -1) { var hdf = vars.file.substr(vars.file.indexOf('[') + 1, vars.file.indexOf(']') - vars.file.indexOf('[') - 1).split(vars.hdseparator); var files = ''; for (h = 0; h < hdf.length; h++) { files += hdf[h] != '' ? vars.file.substr(0, vars.file.indexOf('[')) + hdf[h] + vars.file.substr(vars.file.indexOf(']') + 1) : ''; h < hdf.length - 1 ? files += vars.hdseparator : '' } vars.hdlinks = files.split(vars.hdseparator); HdSelect(); if (hdselect) { vars.file = hdselect.value } else { for (h = 0; h < vars.hdlinks.length; h++) { if (vars.hdlinks[h] != '') { vars.file = vars.hdlinks[h]; break } } } } } } } function onHlsQuality() { var q = uppod.mediaW().hls.levels; console.log(q); var q1 = []; var q2 = []; q1[0] = 'hls0'; q2[0] = vars.lang2['auto']; if (q.length > 1) { for (var i = 0; i < q.length; i++) { q1[i + 1] = 'hls' + i; q2[i + 1] = q[i].height ? q[i].height + 'p' : i } } vars.hdlinks = q1; vars.hda = q2; HdSelect(); vars.hls_quality = true } function HdSelect() { if (hd_b) { if (hdselect && vars.hdlinks) { var start = 0; var hdselects = []; var hh = 0; hdselect.innerHTML = ''; vars.hd1 == 1 ? vars.quality = vars.hda[vars.hda.length - 1] : ''; for (h = 0; h < vars.hda.length; h++) { if (vars.hdlinks[h]) { if (vars.hdlinks[h] != '') { hdselects[h] = document.createElement('option'); hdselects[h].value = vars.hdlinks[h]; hdselects[h].innerHTML = vars.hda[h]; hdselect.appendChild(hdselects[h]); if (vars.hda[h] == vars.quality) { start = hh; hdselects[h].setAttribute("selected", "true"); QualitySelect(false) } hh++ } } } SelectRework(hdselect.options[start].text, hd_b) } } } function QualitySelecter() { QualitySelect(true) } function QualitySelect(autostart) { if (hd_b && vars.hdlinks) { var hdvalue = hdselect.value; if (hdvalue.indexOf("hls") == 0) { autostart ? vars.start = media.currentTime : ''; if (hdvalue == 'hlsauto') { uppod.mediaW().hls.nextLevel = -1 } else { uppod.mediaW().hls.nextLevel = hdvalue.substr(3) * 1 } } else { if (vars.youtube) { autostart ? vars.start = media_yt.getCurrentTime() : ''; if (isYoutube()) { var t = CurrentTime(); media_yt.stopVideo(); media_yt.setPlaybackQuality(hdselect.value); media_yt.playVideo(); media_yt.seekTo(t) } } else { autostart ? vars.start = media.currentTime : ''; vars.file = hdselect.value; NewFile(hdselect.value, (mobile ? false : autostart)) } } SelectRework(hdselect.options[hdselect.selectedIndex].text, hd_b); vars.quality = hdselect.options[hdselect.selectedIndex].text; Event('quality', vars.quality) } } function Full(re) { if (!ifull || re == 're') { if (nativecontrols) { if (!media.controls) { CSS(controls, { 'visibility': 'hidden' }); media.controls = true; Remove('layer'); media_mc.onclick = null; if (poster_mc && vars.m == 'video') { poster_mc.style.display = 'none' } } } else { if (vars.realfullscreen == 1 && Uppod.Fullscreen.request(vars.stg)) { irealfull = true } Uppod.Fullscreen.hack(vars.stg); if ((vars.iframe != '' || vars.iframeobject) && !irealfull) { CSS((vars.iframeobject ? vars.iframeobject : window.parent.document.getElementById(vars.iframe)), { 'width': window.parent.innerWidth, 'height': window.parent.innerHeight, 'position': 'fixed', 'left': 0, 'top': 0 }) } if (re != 're') { ifull = true; vars.stagewidth = vars.sw; vars.stageheight = vars.sh; CSS(body.canvas, { 'visibility': 'hidden', 'height': (vars.iframe != '' ? window.parent.innerHeight : window.innerHeight) }); setTimeout(function() { CSS(body.canvas, { 'visibility': 'hidden', 'height': (vars.iframe != '' ? window.parent.innerHeight : window.innerHeight) }) }, 500); setTimeout(function() { CSS(body.canvas, { 'visibility': 'hidden', 'height': (vars.iframe != '' ? window.parent.innerHeight : window.innerHeight) }) }, 700); CSS(scrn.canvas, { 'visibility': 'hidden' }); CSS(media_mc, { 'backgroundColor': '#000', 'position': 'fixed', 'left': 0, 'top': 0 }) } full_b.c.style.display = 'none'; full_back_b.c.style.display = 'block'; vars.stageposition = getCss(vars.stg, 'position'); vars.stageleft = getCss(vars.stg, 'left'); vars.stagetop = getCss(vars.stg, 'top'); vars.stageMargins = getCss(vars.stg, 'margin'); CSS(vars.stg, { 'width': '100%', 'height': '100%', 'margin': '0', 'position': 'fixed', 'left': '0px', 'top': '0px', 'z-index': '999999999', 'overflow': 'hidden' }); layer != undefined ? layer.style.display = 'none' : ''; oo ? oo.style.display = 'none' : ''; clearInterval(hideInterval); hideInterval = setInterval(CntrlHide, 3000); if (re != 're') { Event('fullscreen') } if (tip) { if (tip.parentNode) { tip.parentNode.removeChild(tip) } } } if (playlist) { vars.plplace != 'inside' ? CSS(playlist, { 'top': -1000 }) : ''; if (plnext_b && vars.plplace != 'inside') { Hide(plnext_b.c); Hide(plprev_b.c) } } } else { FullOff() } setTimeout(MenuPosition, 100); logo ? PositionLogo() : ''; sub || sub_menu ? setTimeout(PositionSub, 500) : '' } function FullOff() { if (document.cancelFullScreen) { document.cancelFullScreen() } else if (document.exitFullscreen) { document.exitFullscreen() } else if (document.cancelFullscreen) { document.cancelFullscreen() } else if (document.mozCancelFullScreen) { document.mozCancelFullScreen() } else if (document.webkitCancelFullScreen) { document.webkitCancelFullScreen() } else if (document.msExitFullscreen) { document.msExitFullscreen() } ifull = false; if ((vars.iframe != '' || vars.iframeobject) && !irealfull) { CSS((vars.iframeobject ? vars.iframeobject : window.parent.document.getElementById(vars.iframe)), { 'width': vars.stagewidth, 'height': vars.stageheight, 'margin': vars.stageMargins, 'position': 'static', 'left': 0, 'top': 0 }) } CSS(media_mc, { 'backgroundColor': 'transparent', 'position': 'absolute', 'left': 0, 'top': 0 }); CSS(vars.stg, { 'width': (vars.stagewidthproc != '' ? vars.stagewidthproc : vars.stagewidth), 'height': vars.stageheight, 'margin': vars.stageMargins, 'position': vars.stageposition, 'left': vars.stageleft, 'top': vars.stagetop }); CSS(body.canvas, { 'visibility': 'visible', 'height': vars.stageheight }); CSS(scrn.canvas, { 'visibility': 'visible' }); if (!isYoutube() && layer != undefined) { layer.style.display = 'block' } if (oo) { oo.style.display = 'block' } full_b.c.style.display = 'block'; full_back_b.c.style.display = 'none'; if (playlist) { PlPlace() } logo ? PositionLogo() : ''; sub || sub_menu ? setTimeout(PositionSub, 500) : ''; if (tip) { if (tip.parentNode) { tip.parentNode.removeChild(tip) } } Event('exitfullscreen') } var menu_big; function Menu() { if (menu_big) { ShowHide(menu_big) } else { menu_big = createElement('div'); var mb_w = vars.scrn_w < 320 ? vars.scrn_w - 30 : 350; var mb_h = (vars.download != '' && vars.download != 0 ? 45 : 0) + (vars.menu_nocode == 1 ? 0 : 45) + (vars.link != '' ? 45 : 0) + 11; vars.menu_w = mb_w; vars.menu_h = mb_h; var menu_big_bg = new Shaper2({ w: mb_w, h: mb_h, o: 10, bgc: '000000|000000', bga1: 0.5, bga2: 0.5 }); menu_big.appendChild(menu_big_bg.c); CSS(menu_big_bg.c, { 'position': 'relative', 'top': '0', 'left': '0' }); if (vars.download != '' && vars.download != 0) { MenuBigItem("menu_download", (vars.download == 1 ? vars.file : vars.download), mb_w, mb_h) } if (vars.link != '') { MenuBigItem("menu_link", vars.link, mb_w, mb_h) } CSS(menu_big, { 'color': '#ffffff', 'font': '10px Verdana' }); menu_big.style.zIndex = 100; MenuBigItem("menu_code", (vars.iframeurl != '' ? '<iframe title="sample" width="' + vars.w + '" height="' + vars.h + '" src="' + vars.iframeurl + '" frameborder="0" allowfullscreen></iframe>' : vars.embedcode != '' ? vars.embedcode : ''), mb_w, mb_h); var mbx = createElement('div'); mbx.innerHTML = ' x '; menu_big.appendChild(mbx); CSS(mbx, { 'position': 'absolute', 'top': 3, 'left': mb_w - 25, 'cursor': 'pointer' }); mbx.onclick = MenuClose; body.c.appendChild(menu_big); MenuPosition() } } var menuitems = 0; function MenuBigItem(what, content, mb_w, mb_h) { var mbkodt = createElement('div'); mbkodt.innerHTML = vars.lang2[what]; menu_big.appendChild(mbkodt); CSS(mbkodt, { 'position': 'absolute', 'top': (5 + menuitems * 45), 'left': 15 }); var mbkodbg = new Shaper2({ w: mb_w - 20, h: 23, o: 5, bgc: 'ffffff' }); CSS(mbkodbg.c, { 'position': 'absolute', 'top': (22 + menuitems * 45), 'left': 10 }); menu_big.appendChild(mbkodbg.c); var mbkode = document.createElement('input'); menu_big.appendChild(mbkode); CSS(mbkode, { 'position': 'absolute', 'outline': 'none', 'font': '10px Verdana', 'top': (25 + menuitems * 45), 'left': 13, 'width': mb_w - 28, 'height': 15, 'color': '#000000', 'border': 0, 'background': 'none' }); mbkode.value = content; mbkode.onclick = function() { this.select() }; menuitems++ } function MenuClose() { if (menu_big) { CSS(menu_big, { 'display': 'none' }) } } function MenuPosition() { if (menu_big) { CSS(menu_big, { 'position': 'absolute', 'top': ((ifull ? vars.sh : vars.stageheight) - vars.menu_h) / 2, 'left': ((ifull ? vars.sw : vars.stagewidth) - vars.menu_w) / 2 }) } } function CntrlHide() { var hide_force = false; if (uppod.ads()) { uppod.ads().isActive() ? hide_force = true : '' } if ((iplay && CurrentTime() > 0) || hide_force) { var hide = !iover && vars.cntrlhide == 1; var fullHide = ifull && vars.fullcntrlhide == 1; if (hide || fullHide || hide_force) { clearInterval(hideInterval); CSS(controls, { 'visibility': 'hidden' }); if (playlist && vars.plplace == 'inside') { if (playlist.style.display != "none") { Pl() } } CSS(uppod.iframe, { 'cursor': 'none' }); if (isYoutube()) { mouseMoveCatcher.style.display = 'block' } ihide = true } } } function CntrlShow() { clearInterval(hideInterval); mouseMoveCatcher.style.display = 'none'; if (!nativecontrols) { CSS(controls, { 'visibility': 'visible' }); CSS(uppod.iframe, { 'cursor': 'auto' }); ihide = false } } function ScreenSize() { vars.scrn_w = vars.sw - vars.padding * 2; vars.scrn_h = vars.ph - vars.padding * 2 - (vars.cntrlout == 1 ? vars.cntrloutheight : 0) } function Resize() { if (vars.sw != 0 && vars.sh != 0 && vars.stg.offsetHeight != 0 && vars.stg.offsetWidth != 0) { if (vars.sw != vars.stg.offsetWidth && vars.sh == vars.stg.offsetHeight) { vars.stg.style.height = vars.stg.offsetWidth / (vars.sw / vars.sh) + 'px' } if (vars.ph != vars.sh) { vars.ph = vars.stg.offsetHeight - (vars.sh - vars.ph) } else { vars.ph = vars.stg.offsetHeight } vars.sh = vars.stg.offsetHeight; vars.sw = vars.stg.offsetWidth; if (!ifull) { vars.stagewidth = vars.sw; vars.stageheight = vars.sh } ScreenSize(); var nh = (!ifull ? vars.ph : vars.sh) - vars.padding * 2 - (vars.cntrlout == 1 ? vars.cntrloutheight : 0); if (!ifull) { CSS(body.canvas, { 'width': vars.sw, 'height': vars.sh }); CSS(scrn.canvas, { 'width': vars.sw - vars.padding * 2, 'height': nh }); CSS(layer, { 'height': nh }) } if (alrt) { CSS(alrt_bg.canvas, { 'width': '' + vars.sw - (ifull ? 0 : vars.padding * 2) + 'px' }); if (vars.padding > 0) { CSS(alrt, { 'top': (ifull ? 0 : vars.padding), 'left': (ifull ? 0 : vars.padding) }) } } if (poster_mc) { CSS(poster_mc, { 'width': vars.sw, 'height': vars.ph - vars.padding * 2 - (vars.cntrlout == 1 ? vars.cntrloutheight : 0) }) } CSS(media_mc, { 'width': '' + vars.sw - (!ifull ? vars.padding * 2 : 0) + 'px', 'height': '' + nh + 'px' }); CSS(media, { 'width': '' + vars.sw - (!ifull ? vars.padding * 2 : 0) + 'px', 'height': '' + nh + 'px' }); if (isYoutube()) { CSS(document.getElementById('yt_media_' + vars.uid), { 'width': '' + vars.sw - (!ifull ? vars.padding * 2 : 0) + 'px', 'height': '' + nh + 'px' }) } vars.o > 0 ? oPos() : ''; uppod.controls().ControlBar.resize(); if (uibg) { CSS(uibg.canvas, { 'width': '' + (vars.sw - (ifull ? 0 : vars.padding * 2) - vars.cntrlbgmargin * 2 - vars.cntrlbgmarginleft - vars.cntrlbgmarginright) + 'px', 'height': '' + vars.cntrloutheight + 'px' }); uibg_gl ? CSS(uibg_gl.canvas, { 'width': '' + (vars.sw - (ifull ? 0 : vars.padding * 2) - vars.cntrlbgmargin * 2) + 'px' }) : '' } start_b ? CSS(start_b.c, { 'left': vars.sw / 2 - start_b.w / 2, 'top': (!ifull ? vars.ph : vars.sh) / 2 - start_b.h / 2 }) : ''; PlaceControls(); if (playlist) { PlPlace(); if (plnext_b) { if ((vars.plplace == "inside" && playlist.style.display != "none") || !ifull) { Show(plnext_b.c); Show(plprev_b.c); PlArrows(); if (plpage > 0) { plpage = plpage - 1; PlArrowNext() } } } } if (sub) { PositionSub() } } } function Back() { Seek(0) } function Mute() { if (isYoutube()) { if (!media_yt.isMuted()) { media_yt.mute(); muted = true } else { media_yt.unMute(); muted = false } } else { if (media.muted) { media.muted = false; muted = false } else { media.muted = true; muted = true } } MuteControl() } function MuteControl() { if (volume_b) { if (muted) { volume_b.c.style.display = 'none' } else { volume_b.c.style.display = 'block' } } if (volume_mute_b) { if (muted) { volume_mute_b.c.style.display = 'block' } else { volume_mute_b.c.style.display = 'none' } } } function OnPlay() { Uppod.trace('OnPlay'); if (!iplay) { if (nativecontrols && !media.controls) { CSS(controls, { 'visibility': 'hidden' }); media.controls = true; Remove('layer'); media_mc.onclick = null } if (poster_mc && vars.m == 'video') { poster_mc.style.display = 'none' } if (play_b != undefined) { play_b.c.style.display = 'none'; pause_b.c.style.display = 'block' } iplay = true; var hide = vars.cntrlhide == 1 && vars.cntrlout == 0; var fullHide = ifull && vars.fullcntrlhide == 1; if (hide || fullHide) { clearInterval(hideInterval); hideInterval = setInterval(CntrlHide, 3000) } if (vars.comment != undefined && vars.comment != '' && vars.showname == 1) { vars.shownameliketip == 1 ? (vars.shownameonstop == 1 ? Hide(nametip) : '') : Hide(alrt) } if (vars.plplace == "inside" && playlist) { Hide(playlist); plnext_b ? Hide(plnext_b.c) : ''; plprev_b ? Hide(plprev_b.c) : '' } if (start_b) { start_b.c.style.display = 'none' } if (logo) { if (vars.logoplay == 1) { Show(logo) } else { Hide(logo) } } Event('play'); if (uppod_active_player_uid != vars.uid) { uppod_active_player_uid = vars.uid; document.addEventListener("keydown", KeyHandler) } if (!istartevnt) { Event('start'); istart = true; istartevnt = true } if (vars.sub && (vars.substart == 1 || (mobile && nativecontrols))) { CreateSubs() } } } function OnSeeking() { Event('seeking') } function OnSeeked() { Event('seeked') } function OnPause() { Uppod.trace('OnPause'); if (iplay) { if (play_b != undefined) { play_b.c.style.display = 'block'; pause_b.c.style.display = 'none' } iplay = false; if (vars.comment != undefined && vars.comment != '' && vars.showname == 1) { vars.shownameliketip == 1 ? Show(nametip) : Show(alrt) } start_b ? start_b.c.style.display = 'block' : ''; if (logo) { if (vars.logopause == 1) { Show(logo) } else { Hide(logo) } } Event('pause') } } function Event(s, msg) { vars.events[s] = msg; var evObj = document.createEvent('Events'); evObj.initEvent(s, true, true); vars.stg.dispatchEvent(evObj) } function onCanPlay() { Uppod.trace('onCanPlay'); if (vars.start > 0) { Uppod.trace('onCanPlay set currentTime to ' + vars.start); media.currentTime = vars.start; vars.start = 0 } onReady() } function OnVolume() { if (volbarline_all_b) { vars.ivolbar_v ? VolumeDraw(media.volume * volbarline_s['h']) : VolumeDraw(media.volume * volbarline_s['w']) } if (volbar_b) { VolumeDraw(media.volume * vars.cntrlvolbar.w) } } function OnEnded() { Uppod.trace('OnEnded'); if (media.ended || isYoutube()) { Event('end'); if (vars.radio == 1) { Reload() } else { if (vars.repeat == 1) { Play() } else { if (!isYoutube()) { Back() } if (vars.plplay == 1 && pl) { PlNext() } else { TheEnd() } } } } } function Reload() { Uppod.trace('Reload'); Stop(); Toggle() } function Sizing() { if (vars.stg.offsetWidth != vars.sw || vars.stg.offsetHeight < vars.sh - 5 || vars.stg.offsetHeight > vars.sh + 5) { Resize() } } function Playing() { if (media != undefined) { updateTimeDisplay(); if (iline) { var time = 0; var duration = 0; time = CurrentTime(); duration = Duration(); var loaded = 0; if (isYoutube()) { loaded = media_yt.getVideoLoadedFraction() } else { if (media.buffered) { if (media.buffered.length > 0) { loaded = (media.buffered.end(media.buffered.length - 1) / media.duration) } } } if (loaded > 0) { CSS(line_load_b, { 'width': '' + (loaded * line_all_b.w) + 'px' }); if (loaded == 1) { if (!iloaded) { iloaded = true; Event("loaded") } } else { iloaded = false } } CSS(line_play_b, { 'width': '' + (time / duration) * line_all_b.w + 'px' }); if (ibuff && !igo) { if (time > 0) { HideBuffer(); igo = true } } if (iplay && time == lastTime) { if (ltc > 5) { !ibuff ? ShowBuffer() : ''; ibuff = true } else { ltc++ } } else { if (ibuff) { ibuff = false; HideBuffer() } ltc = 0 } lastTime = time } if (iplay && vars.reloader == 1) { if (CurrentTime() == vars.reloadertime) { vars.reloadercounter++; if (vars.reloadercounter > 200 && media.currentTime != undefined) { vars.reloadercounter = 0; Reload() } } else { vars.reloadercounter = 0 } vars.reloadertime = CurrentTime() } if (vars.eventtime != 0) { if (iplay) { if (is_array(vars.eventtime)) { for (i = 0; i < vars.eventtime.length; i++) { if (!vars.events['time' + vars.eventtime[i]]) { if (CurrentTime() > vars.eventtime[i]) { Event('time' + vars.eventtime[i], CurrentTime()) } } } } else { if (!vars.events['time']) { if (CurrentTime() > vars.eventtime) { Event('time', CurrentTime()) } } } } } if (vars.eventplayed != 0) { if (iplay) { if (is_array(vars.eventplayed)) { for (i = 0; i < vars.eventplayed.length; i++) { if (!vars.events['played' + vars.eventplayed[i]]) { if ((CurrentTime() / Duration()) * 100 > vars.eventplayed[i]) { Event('played' + vars.eventplayed[i], (CurrentTime() / Duration()) * 100) } } } } else { if (!vars.events['played']) { if ((CurrentTime() / Duration()) * 100 > vars.eventplayed) { Event('played', (CurrentTime() / Duration()) * 100) } } } } } line_b && run_b ? RunPos(run_b, line_b, line_play_b, line_all_b, run_pos) : ''; if (sub != undefined && vars.substart == 1) { if (sub[sub_lang]) { if (sub[sub_lang][1]) { var t = parseInt(CurrentTime() * 10); if (sub[sub_lang][1][t] != null) { var str = ''; if (vars.sublangsall == 1 && sub_lang_all) { for (var i = 0; i < sub.length; i++) { str += sub[i][0][sub[i][1][t]] ? sub[i][0][sub[i][1][t]] + (i < sub.length - 1 ? '<br>' : '') : '' } } else { str = sub[sub_lang][0][sub[sub_lang][1][t]] } if (sub) { var stop = false; if (sub_last) { sub_last == str ? stop = true : '' }!sub_showed ? stop = false : ''; !stop ? ShowSub(str) : '' } } if (sub[sub_lang][1][t] == undefined && sub_showed) { StopSub() } } } } } if (ifull && !irealfull) { if (vars.iframe != '') { window.parent.innerWidth != vars.stg.offsetWidth || window.parent.innerHeight != vars.stg.offsetHeight ? Full('re') : '' } else { window.innerWidth != vars.stg.offsetWidth || window.innerHeight != vars.stg.offsetHeight ? Full('re') : '' } } } function CurrentTime() { t = 0; if (isYoutube()) { t = media_yt.getCurrentTime() } else { media ? t = media.currentTime : '' } return t } function Duration() { t = 0; if (isYoutube()) { t = media_yt.getDuration() } else { if (media) { if (media.duration && media.duration != 'Infinity') { t = media.duration } } } return t } function NotFound() { if (vars.or.length > 1 && vars.ors < vars.or_limit) { if (vars.ori == vars.or.length - 1) { vars.ori = -1; vars.ors++ } vars.ori++; NewFile(vars.or[vars.ori], (vars.auto == "play" && mobile ? true : false)) } else { Pause(); if (vars.alerts == 1) { var message = vars.lang2['file'] + ' ' + vars.lang2['notfound']; Alert(message) } Event('player_error', 'file not found') } } function TheEnd() { if (!nativecontrols) { CntrlShow() } if (vars.redirect != '' && vars.redirect_end == 1) { window.open(vars.redirect, vars.redirecttarget); vars.redirect_end = 0 } if (media) { if (!isYoutube()) { media.currentTime = 0; media.pause() } else { media_yt.pauseVideo() } } if (poster_mc && vars.m == 'video') { Show(poster_mc) } if (vars.menuauto == 1 && menu_b) { isVisible(menu_big) ? '' : Menu() } } function isVisible(mc) { var out = false; if (mc) { mc.style.visible != 'none' ? out = true : '' } return out } function FontStyle(f) { var out = 'normal'; if (f == 'i' || f == 'b><i') { out = 'italic' } return out } function FontWeight(f) { var out = 'normal'; if (f == 'b' || f == 'b><i') { out = 'bold' } return out } function ShowBuffer() { if (buffer_b) { uppod.controls().Buffer.show() } } function HideBuffer() { if (buffer_b) { uppod.controls().Buffer.hide() } ibuff = false } function updateTimeDisplay() { time_play_b ? time_play_b.c.innerHTML = formatTime(CurrentTime()) : ''; if (Duration() > 0) { time_back_b ? time_back_b.c.innerHTML = formatTime(Duration() - CurrentTime()) : ''; time_all_b ? time_all_b.c.innerHTML = formatTime(Duration()) : '' } } function formatTime(seconds, tip) { var seconds = Math.round(seconds); var minutes = Math.floor(seconds / 60); var hours = Math.floor(minutes / 60); minutes = Math.floor(minutes % 60); seconds = Math.floor(seconds % 60); (hours > 0 || timelength > 5) && minutes < 10 ? minutes = "0" + minutes : ""; seconds = (seconds >= 10) ? seconds : "0" + seconds; var out = (hours > 0 || timelength > 5 ? hours + ":" : "") + minutes + ":" + seconds; if (out.length != timelength && !tip) { timelength = out.length; PlaceControls() } return out } function CreateSubs() { if (vars.sub.indexOf('#') == 0) { vars.sub = un(vars.sub) } var subs = vars.sub.split(','); var clangs = vars.sublangs ? vars.sublangs.split(',') : Array(); sub = Array(); for (var i = 0; i < subs.length; i++) { if (subs[i] != '') { if (clangs[i] == undefined) { var filename = subs[i].substr(subs[i].lastIndexOf('/') + 1); filename = filename.substr(0, filename.lastIndexOf('.')); clangs[i] = filename } CreateSub(i, subs[i], clangs[i]); clangs[i] && vars.sublang ? (clangs[i] == vars.sublang ? sub_lang = i : '') : '' } else { if (sub_lang == i) { sub_lang++ } } } vars.sub_tmp = vars.sub; delete vars.sub } function CreateSub(l, url, label) { if (url) { if (url.indexOf('#') == 0) { url = un(url) } var url_shift = vars.sub_shift; if (url.indexOf('shift=') > 0) { url_shift = url.substr(url.indexOf('shift=') + 6) * 1 } if (mobile && (nativecontrols || iphone)) { var track = document.createElement('track'); track.setAttribute('src', url); track.setAttribute('label', label); vars.substart == 1 && l == 0 ? track.setAttribute('default', 'true') : ''; media.appendChild(track) } else { var subtxt = LoadFile(url); if (subtxt) { if (url.indexOf('.srt') > -1 || url.indexOf('.ass') > -1 || url.indexOf('.ssa') > -1 || url.indexOf('.vtt') > -1) { sub[l] = Object(); sub[l][0] = Array(); sub[l][1] = Array(); var rows = Array(); rows = subtxt.split('\n'); var cnt = 1; var t1 = 0; var t2 = 0; for (i = 0; i < rows.length; i++) { if (url.indexOf('.srt') > -1 || url.indexOf('.vtt') > -1) { if (rows[i].indexOf('-->') > -1 && rows[i].indexOf(':') > -1) { t1 = TimerSub(rows[i].substr(0, rows[i].indexOf('-->'))) * 1 + url_shift; t2 = TimerSub(rows[i].substr(rows[i].indexOf('-->') + 4, 12)) * 1 + url_shift; sub[l][0][t1] = ''; for (var j = t1; j < t2; j++) { sub[l][1][j] = t1 } cnt++ } else { if (rows[i] != '' && rows[i].length > 1 && rows[i] != cnt) { sub[l][0][t1] += (sub[l][0][t1] != '' ? '<br>' : '') + rows[i] } } } if (url.indexOf('.ass') > -1 || url.indexOf('.ssa') > -1) { if (rows[i].indexOf('Dialogue:') > -1) { t1 = TimerSub(rows[i].substr((url.indexOf('.ssa') > -1 ? rows[i].indexOf('=0') + 3 : 12), 12)) * 1 + url_shift; t2 = TimerSub(rows[i].substr((url.indexOf('.ssa') > -1 ? rows[i].indexOf('=0') + 14 : 23), 10)) * 1 + url_shift; var p = ''; if (rows[i].indexOf('0,,') > 0) { p = rows[i].substr(rows[i].indexOf('0,,') + 3) } else { if (rows[i].indexOf('ffect,') > 0) { p = rows[i].substr(rows[i].indexOf('ffect,') + 6) } } if (sub[l][0][t1] != undefined) { sub[l][0][t1] += '\n' + p } else { sub[l][0][t1] = p } sub[l][0][t1] = sub[l][0][t1].replace(/{.*?}/, ''); sub[l][0][t1] = sub[l][0][t1].replace(/\\\\N/, '\n'); for (var j = t1; j < t2; j++) { sub[l][1][j] = t1 } } } } } } vars.substart = 1 } } } function ShowSub(str) { if (sub_text) { KillSub() } sub_text = createElement('div'); sub_bg = createElement('div'); body.c.appendChild(sub_bg); body.c.appendChild(sub_text); Show(sub_text); Show(sub_bg); sub_last = str; sub_text.innerHTML = str; sub_showed = true; PositionSub() } function StopSub() { if (sub_text) { KillSub(); sub_showed = false } } function KillSub() { if (sub_text) { sub_text.innerHTML = ''; body.c.removeChild(sub_bg); body.c.removeChild(sub_text); sub_bg = null; sub_text = null } } function PositionSub() { var h = (!ifull ? vars.ph : vars.sh) - (vars.cntrlout == 1 && !ifull ? vars.padding / 2 : vars.cntrloutheight); if (sub_text) { var width = vars.sw - 60; CSS(sub_text, { "position": "absolute", "color": (vars.subcolor.length == 6 ? '#' : '') + vars.subcolor, 'fontFamily': vars.subfont, 'fontSize': (vars.subsize * (ifull ? 1.5 : 1)) + '%', 'text-align': 'center', 'line-height': '120%', 'text-shadow': '1px 1px 1px rgba(1,1,1,0.4)' }); CSS(sub_bg, { "position": "absolute", "backgroundColor": (vars.subbgcolor.length == 6 ? '#' : '') + vars.subbgcolor, 'opacity': vars.subbgalpha, 'borderRadius': vars.subbgo / 2 }); CSS(sub_text, { 'max-width': width }); var top = h - vars.submargin * (ifull ? vars.sh / vars.stageheight : 1) - 10 - sub_text.offsetHeight - 5; var left = (vars.sw - (sub_text.offsetWidth + 20)) / 2; CSS(sub_text, { "position": "absolute", "top": top, "left": left + 10 }); CSS(sub_bg, { "width": sub_text.offsetWidth + 20, "height": sub_text.offsetHeight + 10, "position": "absolute", "top": top - 5, "left": left }) } if (sub_menu) { var top2 = (h - sub_menu.offsetHeight); var left2 = sub_b.c.offsetLeft - sub_menu.offsetWidth + sub_b.w + 5; left2 < 0 ? left2 = 0 : ''; CSS(sub_menu, { "position": "absolute", "top": top2, "left": left2 }); CSS(sub_menu_bg, { "position": "absolute", "top": top2, "left": left2 }) } } function TimerSub(srt) { var tmp = srt.split(':'); var out = 0; tmp.length == 2 ? tmp.unshift("00") : ''; tmp[0] != '00' ? out += tmp[0] * 3600 : ''; tmp[1] != '00' ? out += tmp[1] * 60 : ''; out += tmp[2].substr(0, 2) * 1; out = out * 10 + tmp[2].substr(3, 1) * 1; return out } function SetSub() { if (vars.submenu == 1) { if (sub_menu) { ToggleView(sub_menu_bg); ToggleView(sub_menu); PositionSub() } else { sub_menu = createElement('div'); sub_menu_bg = createElement('div'); body.c.appendChild(sub_menu_bg); body.c.appendChild(sub_menu); sub_menu.innerHTML = '<div id="uppodplayer_sub_switcher" style="width:47px;height:18px;border:1px solid rgba(255,255,255,0.5);border-radius:20px;margin-bottom:10px;padding:1px;cursor:pointer"><div id="uppodplayer_sub_switcher_bg" style="width:45px;height:16px;background:#fff;border-radius:18px;padding:1px;"><div id="uppodplayer_sub_switcher_dot" style="width:16px;height:16px;background:#000;border-radius:17px;color:#000;text-align:center;' + (vars.substart == 0 ? 'float:left' : 'float:right') + '"></div></div></div>'; document.getElementById("uppodplayer_sub_switcher").onclick = ToggleSub; var sub_menu_x = createElement('div'); sub_menu.appendChild(sub_menu_x); CSS(sub_menu_x, { "fontSize": "80%", "position": "absolute", "top": 5, "right": 7, "color": "#fff", "opacity": 0.5, "margin-top": "-2px", "cursor": "pointer" }); sub_menu_x.innerHTML = '×'; sub_menu_x.onclick = SetSub; CSS(sub_menu, { "position": "absolute", "top": 0, "left": 0, "color": "#fff", "font": "90% sans-serif", "borderRadius": 10, "padding": 10, "width": 119 }); sub_menu2 = createElement('div'); ToggleSubStyle(); sub_menu.appendChild(sub_menu2); var b1 = createElement('div'); SetSubButStyle(b1, false); b1.innerHTML = '+'; CSS(b1, { "margin": "0 5px 5px 0" }); var b2 = createElement('div'); SetSubButStyle(b2, false); b2.innerHTML = '-'; CSS(b2, { "margin": "0 20px 5px 0" }); b1.onclick = function() { vars.subsize += 10; PositionSub() }; b2.onclick = function() { vars.subsize -= 10; PositionSub() }; var b3 = createElement('div'); SetSubButStyle(b3, false); b3.innerHTML = '∧'; CSS(b3, { "margin": "0 5px 5px 0" }); var b4 = createElement('div'); SetSubButStyle(b4, false); b4.innerHTML = '∨'; CSS(b4, { "margin": "0 0 5px 0" }); b3.onclick = function() { vars.submargin += 10; PositionSub() }; b4.onclick = function() { vars.submargin -= 10; PositionSub() }; var s1 = document.createElement('br'); sub_menu2.appendChild(s1); var c = Array(); var ccolors = Array("FFFFFF", "000000", "FAED54", "FFB0BE", "72CCF8", "62DE50", "E8BBFF", "FEBA54"); var c_def = 2; for (var i = 0; i < 7; i++) { c[i] = createElement('div'); SetSubButStyle(c[i], true); CSS(c[i], { "border": "1px solid #" + (i == 1 ? '666' : ccolors[i]), "opacity": 0.7, "color": "#" + (ccolors[i]) }); c[i].onclick = function() { vars.subcolor = this.style.color; isub_menu_color.style.opacity = 0.7; this.style.opacity = 1; isub_menu_color = this; PositionSub() }; vars.subcolor == ccolors[i] ? c_def = i : '' } c[c_def].style.opacity = 1; isub_menu_color = c[c_def]; var s2 = document.createElement('br'); sub_menu2.appendChild(s2); var cbg = Array(); var cbgcolors = Array("FFFFFF", "000000", "FEF370", "D90000", "073DA0", "409829", "644082", "a56305"); var cbg_def = 1; for (i = 0; i < 7; i++) { cbg[i] = createElement('div'); SetSubButStyle(cbg[i], true); CSS(cbg[i], { "background-color": "#" + (cbgcolors[i]), "borderColor": "#" + (i == 1 ? '666' : cbgcolors[i]), "opacity": 0.7, "color": "#fff" }); i == 0 || i == 2 ? CSS(cbg[i], { "color": "#000" }) : ''; cbg[i].onclick = function() { vars.subbgcolor = this.style.backgroundColor; isub_menu_bgcolor.style.opacity = 0.7; this.style.opacity = 1; isub_menu_bgcolor = this; PositionSub() }; vars.subbgcolor == cbgcolors[i] ? cbg_def = i : '' } cbg[cbg_def].style.opacity = 1; isub_menu_bgcolor = cbg[cbg_def]; var s3 = document.createElement('br'); sub_menu2.appendChild(s3); var ca0 = createElement('div'); sub_menu2.appendChild(ca0); CSS(ca0, { "float": "left", "margin": "0 2px 0 2px", "cursor": "default" }); ca0.innerHTML = '-'; var ca = createElement('div'); CSS(ca, { "width": 91, "height": 4, "border": "1px solid #fff", "borderRadius": 4, "float": "left", "margin": "5px 3px", "cursor": "pointer" }); sub_menu2.appendChild(ca); var ca2 = createElement('div'); ca.appendChild(ca2); CSS(ca2, { "width": (vars.subbgalpha * 100) + "%", "height": 4, "borderRadius": 4, "background": "#fff" }); var ca1 = createElement('div'); sub_menu2.appendChild(ca1); CSS(ca1, { "float": "left", "margin": "0 0 0 2px", "fontSize": "80%", "cursor": "default" }); ca1.innerHTML = '+'; ca.onclick = function(e) { var n = e.clientX - findLeft(this); n < 5 ? n = 0 : ''; CSS(this.firstElementChild, { 'width': n }); vars.subbgalpha = n / this.offsetWidth; PositionSub() }; if (vars.sublangs) { var clang = document.createElement('select'); var clangs = vars.sublangs.split(','); var subs = vars.sub_tmp.split(','); for (var l = 0; l < clangs.length; l++) { var cl = document.createElement('option'); cl.innerHTML = clangs[l]; clang.appendChild(cl); if (clangs[l] == vars.sublang) { sub_lang = l; cl.setAttribute("selected", "true") } if (subs[l] == '') { cl.setAttribute("disabled", "true") } } if (vars.sublangsall == 1 && clangs.length > 1) { var cl = document.createElement('option'); cl.innerHTML = vars.lang2['all']; clang.appendChild(cl) } sub_menu2.appendChild(clang); clang.onchange = function() { if (vars.sublangsall == 1 && this.selectedIndex == this.length - 1) { sub_lang = 0; sub_lang_all = true } else { sub_lang_all = false; sub_lang = this.selectedIndex } }; CSS(clang, { 'width': 120, 'cursor': 'pointer' }) } CSS(sub_menu_bg, { "position": "absolute", "top": 0, "left": 0, "background": "#000", "width": sub_menu.offsetWidth, "height": sub_menu.offsetHeight, "opacity": "0.7", "borderRadius": 10 }); PositionSub(); sub_menu.style.zIndex = 7; sub_menu_bg.style.zIndex = 7 } } else { ToggleSub() } } function ToggleSub() { if (vars.submenu == 1) { var el = sub_menu.firstElementChild.firstElementChild.firstElementChild; CSS(el, { "float": (vars.substart == 1 ? "left" : "right") }) } if (sub) { vars.substart == 0 ? vars.substart = 1 : vars.substart = 0 } else { if (vars.sub && vars.substart == 0) { CreateSubs(); vars.substart = 1 } else { vars.substart == 0 ? vars.substart = 1 : vars.substart = 0 } } if (vars.substart == 0) { StopSub() } if (vars.submenu == 1) { ToggleSubStyle() } else { if (sub_b) { vars.substart ? CSS(sub_b.c, { 'opacity': sub_b.s.alpha }) : CSS(sub_b.c, { 'opacity': sub_b.s.alpha0 }) } } } function ToggleSubStyle() { vars.substart == 0 ? CSS(sub_menu2, { "visibility": "hidden" }) : CSS(sub_menu2, { "visibility": "visible" }); CSS(document.getElementById("uppodplayer_sub_switcher_dot"), { "background": (vars.substart == 0 ? "#fff" : "#000") }); CSS(document.getElementById("uppodplayer_sub_switcher_bg"), { "background": (vars.substart == 0 ? 0 : "#fff") }) } function SetSubButStyle(b, small) { sub_menu2.appendChild(b); CSS(b, { "float": "left", "textAlign": "center", "width": (small ? 11 : 20), "height": (small ? 11 : "auto"), "border": "1px solid rgba(255,255,255,0.5)", "borderRadius": (small ? 11 : 20), "margin": (small ? "3px 2px 7px 2px" : 0), "padding": (small ? "0" : "0 0 0 0"), "cursor": "pointer" }) } function Controls() { if (vars.youtube && browser.restrictMediaPlay) {} var controlsObj = uppod.controls(); controlsObj.add(new Uppod.ControlBar(uppod)); controls = controlsObj.ControlBar.dom; sep_b = []; sep = 0; CntrlBg(); cntrl = vars.controls.split(','); cntrlength = 0; cntrls = []; cntrli = []; for (var i = 0; i < cntrl.length; i++) { if (cntrl[i] == 'play' || cntrl[i] == 'playstop') { play_b = new Element('play', 20, 20); controlsObj.addElement('Play', play_b); controls.appendChild(play_b.c); CSS(play_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - play_b.h) / 2 + play_b.s.margintop - play_b.s.marginbottom }); play_b.c.onclick = Toggle; if (vars.tip == 1 && play_b.s.notip == 0) { play_b.c.onmouseover = function() { var txt = play_b.s.play_tip ? play_b.s.play_tip : vars.lang2['play']; ToolTip(play_b.c, txt) }; play_b.c.onmouseout = function() { ToolTipHide(play_b.c) } } pause_b = new Element((cntrl[i] == 'playstop' ? 'stop' : 'pause'), 20, 20, '', 'play'); controlsObj.addElement('Pause', pause_b); controls.appendChild(pause_b.c); CSS(pause_b.c, { 'cursor': 'pointer', 'display': 'none', 'position': 'absolute', 'top': (vars.cntrloutheight - pause_b.h) / 2 + pause_b.s.margintop - pause_b.s.marginbottom }); cntrl[i] == 'playstop' ? pause_b.c.onclick = Stop : pause_b.c.onclick = Toggle; cntrls[i] = pause_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + play_b.s.marginleft + play_b.s.marginright; cntrli[i] = play_b; if (vars.tip == 1 && pause_b.s.notip == 0) { pause_b.c.onmouseover = function() { ToolTip(pause_b.c, pause_b.s.pause_tip ? pause_b.s.pause_tip : vars.lang2['pause']) }; pause_b.c.onmouseout = function() { ToolTipHide(pause_b.c) } } } if (cntrl[i] == 'back') { back_b = new Element('back', 30, 20); controlsObj.addElement('Back', back_b); controls.appendChild(back_b.c); CSS(back_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - back_b.h) / 2 + back_b.s.margintop - back_b.s.marginbottom }); back_b.c.onclick = Back; cntrls[i] = back_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + back_b.s.marginleft + back_b.s.marginright; cntrli[i] = back_b; if (vars.tip == 1 && back_b.s.notip == 0) { back_b.c.onmouseover = function() { ToolTip(back_b.c, back_b.s.tip ? back_b.s.tip : vars.lang2['back']) }; back_b.c.onmouseout = function() { ToolTipHide(back_b.c) } } } if (cntrl[i] == 'stop') { stop_b = new Element('stop', 20, 20); controlsObj.addElement('Stop', stop_b); controls.appendChild(stop_b.c); CSS(stop_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - stop_b.h) / 2 + stop_b.s.margintop - stop_b.s.marginbottom }); stop_b.c.onclick = Stop; cntrls[i] = stop_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + stop_b.s.marginleft + stop_b.s.marginright; cntrli[i] = stop_b; if (vars.tip == 1 && stop_b.s.notip == 0) { stop_b.c.onmouseover = function() { ToolTip(stop_b.c, stop_b.s.tip ? stop_b.s.tip : vars.lang2['stop']) }; stop_b.c.onmouseout = function() { ToolTipHide(stop_b.c) } } } if (cntrl[i].indexOf('my') == 0) { var m = cntrl[i].substr(2); mybuts[m] = new Element('my' + m, 20, 20); controls.appendChild(mybuts[m].c); CSS(mybuts[m].c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - mybuts[m].h) / 2 + mybuts[m].s.margintop - mybuts[m].s.marginbottom }); mybuts[m].c.id = 'uppod_mybut' + m; mybuts[m].c.onclick = function() { Mybut(this.id) }; cntrls[i] = mybuts[m].w + vars.cntrlmargin; cntrlength += cntrls[i] + mybuts[m].s.marginleft + mybuts[m].s.marginright; cntrli[i] = mybuts[m]; if (vars.tip == 1 && mybuts[m].s.notip == 0 && mybuts[m].s.tip) { mybuts[m].c.onmouseover = function() { ToolTip(mybuts[m].c, mybuts[m].s.tip) }; mybuts[m].c.onmouseout = function() { ToolTipHide(mybuts[m].c) } } } if (cntrl[i] == 'download') { download_b = new Element('download', 20, 20); controlsObj.addElement('Download', download_b); controls.appendChild(download_b.c); CSS(download_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - download_b.h) / 2 + download_b.s.margintop - download_b.s.marginbottom }); download_b.c.onclick = Download; cntrls[i] = download_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + download_b.s.marginleft + download_b.s.marginright; cntrli[i] = download_b; if (vars.tip == 1 && download_b.s.notip == 0) { download_b.c.onmouseover = function() { ToolTip(download_b.c, download_b.s.tip ? download_b.s.tip : vars.lang2['download']) }; download_b.c.onmouseout = function() { ToolTipHide(download_b.c) } } } if (cntrl[i] == 'next') { next_b = new Element('next', 20, 20); controlsObj.addElement('Next', next_b); controls.appendChild(next_b.c); CSS(next_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - next_b.h) / 2 + next_b.s.margintop - next_b.s.marginbottom }); next_b.c.onclick = Next; cntrls[i] = next_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + next_b.s.marginleft + next_b.s.marginright; cntrli[i] = next_b; if (vars.tip == 1 && next_b.s.notip == 0) { next_b.c.onmouseover = function() { ToolTip(next_b.c, next_b.s.tip ? next_b.s.tip : vars.lang2['next']) }; next_b.c.onmouseout = function() { ToolTipHide(next_b.c) } } } if (cntrl[i] == 'prev') { prev_b = new Element('prev', 20, 20); controlsObj.addElement('Prev', prev_b); controls.appendChild(prev_b.c); CSS(prev_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - prev_b.h) / 2 + prev_b.s.margintop - prev_b.s.marginbottom }); if (vars.random == 0) { CSS(prev_b.c, { 'opacity': 0.3, 'filter': 'alpha(opacity=30)', 'cursor': 'default' }) } prev_b.c.onclick = Prev; cntrls[i] = prev_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + prev_b.s.marginleft + prev_b.s.marginright; cntrli[i] = prev_b; if (vars.tip == 1 && prev_b.s.notip == 0) { prev_b.c.onmouseover = function() { ToolTip(prev_b.c, prev_b.s.tip ? prev_b.s.tip : vars.lang2['prev']) }; prev_b.c.onmouseout = function() { ToolTipHide(prev_b.c) } } } if (cntrl[i] == 'time_play') { time_play_b = new Element('time_play', 30, 20); controlsObj.addElement('TimePlay', time_play_b); controls.appendChild(time_play_b.c); CSS(time_play_b.c, { 'cursor': 'default', 'position': 'absolute', 'top': (vars.cntrloutheight - time_play_b.h) / 2 + 3 + time_play_b.s.margintop * 1 - time_play_b.s.marginbottom * 1, 'white-space': 'nowrap' }); cntrls[i] = time_play_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + time_play_b.s.marginleft + time_play_b.s.marginright; cntrli[i] = time_play_b; timeitems++ } if (cntrl[i] == 'time_back') { time_back_b = new Element('time_back', 30, 20); controlsObj.addElement('TimeBack', time_back_b); controls.appendChild(time_back_b.c); CSS(time_back_b.c, { 'cursor': 'default', 'position': 'absolute', 'top': (vars.cntrloutheight - time_back_b.h) / 2 + 3 + time_back_b.s.margintop * 1 - time_back_b.s.marginbottom * 1, 'white-space': 'nowrap' }); cntrls[i] = time_back_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + time_back_b.s.marginleft + time_back_b.s.marginright; cntrli[i] = time_back_b; timeitems++ } if (cntrl[i] == 'time_all') { time_all_b = new Element('time_all', 30, 20); controlsObj.addElement('TimeAll', time_all_b); controls.appendChild(time_all_b.c); CSS(time_all_b.c, { 'cursor': 'default', 'position': 'absolute', 'top': (vars.cntrloutheight - time_all_b.h) / 2 + 3 + time_all_b.s.margintop * 1 - time_all_b.s.marginbottom * 1, 'white-space': 'nowrap' }); cntrls[i] = time_all_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + time_all_b.s.marginleft + time_all_b.s.marginright; cntrli[i] = time_all_b; timeitems++ } if (cntrl[i] == '|') { sep_b[sep] = new Element('separator', 5, 20); controlsObj.addElement('Separator', sep_b[sep]); controls.appendChild(sep_b[sep].c); CSS(sep_b[sep].c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - sep_b[sep].h) / 2 + sep_b[sep].s.margintop - sep_b[sep].s.marginbottom }); cntrls[i] = sep_b[sep].w + vars.cntrlmargin; cntrlength += cntrls[i] + sep_b[sep].s.marginleft + sep_b[sep].s.marginright; cntrli[i] = sep_b[sep]; sep++ } if (cntrl[i] == 'run_line') { var run_s = Cntrl_Style('run'); run_b = createElement('div'); controlsObj.addDom('RunLine', run_b); controls.appendChild(run_b); var lh = vars.cntrlline['h']; if (vars.cntrl_line) { if (vars.cntrl_line['h']) { lh = vars.cntrl_line['h'] } } if (run_s['position'] == 0) { if (lh % 2 != run_s['h'] % 2) { run_s['h']++ } if (run_s['o'] == 1) { run_s['w'] = run_s['h'] } } CSS(run_b, { 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': run_s['margintop'] * 1 - run_s['marginbottom'] * 1, 'width': run_s['w'] + 'px', 'height': run_s['h'] + 'px', 'borderRadius': (run_s['w'] * run_s['o']) + 'px', 'opacity(': run_s['alpha'], 'filter': 'alpha(opacity=' + (run_s['alpha'] * 100) + ')' }); CheckGradiendDiv(run_b, run_s['color']); if (run_s['icon']) { if (String(run_s['icon']).indexOf("http") == 0) { IconImg(run_s['icon'], run_b, 0, run_s['pic_w'], run_s['pic_h'], run_s['halficonisover']) } } if (run_s['bg'] == 1) { CSS(run_b, { 'border': '2px solid #' + ReColor(run_s['bgcolor']) }) } run_pos = run_s['position']; if (vars.tip == 1 && line_s['notip'] == 0) { run_b.onmouseover = function() { media.duration ? ToolTip(run_b, 'line') : '' }; run_b.onmouseout = function() { ToolTipHide(run_b) } } } if (cntrl[i] == 'run_volume' && !mobile) { var run_s = Cntrl_Style('run_volume'); runvolume_b = createElement('div'); controlsObj.addDom('RunVolume', runvolume_b); controls.appendChild(runvolume_b); CSS(runvolume_b, { 'pointer-events': 'none', 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': 0, 'width': run_s['w'] + 'px', 'height': run_s['h'] + 'px', 'borderRadius': (run_s['w'] * run_s['o']) + 'px', 'opacity': run_s['alpha'], 'filter': 'alpha(opacity=' + (run_s['alpha'] * 100) + ')' }); CheckGradiendDiv(runvolume_b, run_s['color']); runvolume_pos = run_s['position']; if (vars.ivolbar_v) { Hide(runvolume_b) } if (run_s['bg'] == 1) { CSS(runvolume_b, { 'border': '2px solid #' + ReColor(run_s['bgcolor']) }) } } if (cntrl[i] == 'sound' && !mobile && vars.controls.indexOf("volbarline") > -1) { cntrl[i] = 'volume'; vars.cntrl_volume = vars.cntrl_sound } if ((cntrl[i] == 'volume' || cntrl[i] == 'volbarline_v') && !mobile) { volume_b = new Element('volume', 20, 20); controlsObj.addElement('Volume', volume_b); controls.appendChild(volume_b.c); CSS(volume_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - volume_b.h) / 2 + volume_b.s.margintop - volume_b.s.marginbottom }); volume_b.c.onclick = Mute; volume_mute_b = new Element('volume_mute', 20, 20, '', 'volume'); controlsObj.addElement('VolumeMute', volume_mute_b); controls.appendChild(volume_mute_b.c); CSS(volume_mute_b.c, { 'display': 'none', 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - volume_mute_b.h) / 2 + volume_mute_b.s.margintop - volume_mute_b.s.marginbottom }); cntrls[i] = volume_mute_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + volume_mute_b.s.marginleft + volume_mute_b.s.marginright; volume_mute_b.c.onclick = Mute; cntrli[i] = volume_b; if (vars.tip == 1 && volume_b.s.notip == 0) { volume_b.c.addEventListener("mouseover", function() { var txt = vars.lang2['sound']; ToolTip(volume_b.c, txt) }); volume_b.c.addEventListener("mouseout", function() { ToolTipHide(volume_b.c) }); volume_mute_b.c.addEventListener("mouseover", function() { var txt = vars.lang2['sound_off']; ToolTip(volume_mute_b.c, txt) }); volume_mute_b.c.addEventListener("mouseout", function() { ToolTipHide(volume_mute_b.c) }) } if (cntrl[i] == 'volbarline_v') { vars.ivolbar_v = true; volbarline_b = createElement('div'); controlsObj.addDom('VolumeBarlineV', volbarline_b); controls.appendChild(volbarline_b); vars.cntrl_volbarline_v.bg = 0; CSS(volbarline_b, { 'cursor': 'pointer', 'position': 'absolute', 'top': 0 }); volbarline_s = Cntrl_Style('volbarline_v'); volbarline_all_b = createElement('div'); volbarline_b.appendChild(volbarline_all_b); CSS(volbarline_all_b, { 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': 0, 'width': volbarline_s['w'], 'height': volbarline_s['h'], 'borderRadius': ((volbarline_s['h'] / 2) * volbarline_s['o']) + 'px', 'opacity': volbarline_s['all_a'], 'filter': 'alpha(opacity=' + (volbarline_s['all_a'] * 100) + ')' }); CheckGradiendDiv(volbarline_all_b, volbarline_s['color_all']); volbarline_s['active'] = false; CSS(volbarline_b, { 'display': 'none', 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - volbarline_s['h']) - 10 }); volbarline_play_b = createElement('div'); volbarline_b.appendChild(volbarline_play_b); CSS(volbarline_play_b, { 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': 0, 'width': volbarline_s['w'], 'height': volbarline_s['h'], 'borderRadius': ((volbarline_s['h'] / 2) * volbarline_s['o']) + 'px', 'opacity': volbarline_s['play_a'], 'filter': 'alpha(opacity=' + (volbarline_s['play_a'] * 100) + ')' }); CheckGradiendDiv(volbarline_play_b, volbarline_s['color_play']); CSS(volbarline_b, { 'cursor': 'pointer', 'position': 'absolute', 'top': (-volbarline_s['h']) }); CSS(volbarline_play_b, { 'height': volbarline_s['h'] * vars.volume, 'top': volbarline_s['h'] - volbarline_s['h'] * vars.volume }); volbarline_b.onmousedown = function VolbarlineDown(e) { volbarline_s['active'] = true; if (!e) var e = window.event; VolumeMove_v(e) }; volbarline_b.onmousemove = function VolbarlineMove(e) { if (!e) var e = window.event; VolumeMove_v(e) }; volbarline_b.onmouseup = function VolbarlineUp(e) { volbarline_s['active'] = false }; volbarline_b.onmouseover = function VolbarlineOver(e) { volbarline_s['over'] = true }; volbarline_b.onmouseout = function VolbarlineOut(e) { volbarline_s['over'] = false }; volume_mute_b.c.addEventListener("mouseover", VolumeButOver); volume_b.c.addEventListener("mouseout", VolumeButOver); volume_mute_b.c.addEventListener("mouseout", VolumeButOver); volume_b.c.addEventListener("mouseover", VolumeButOver); volume_mute_b.c.onmouseout = volume_b.c.onmouseout = VolbarHide; volbarline_b.style.zIndex = 7; if (runvolume_b) { Hide(runvolume_b) } } } if (cntrl[i] == 'tune' && !mobile) { cntrl[i] = 'volbarline'; vars.cntrl_volbarline = vars.cntrl_tune } if (cntrl[i] == 'volbarline' && !mobile) { volbarline_b = createElement('div'); controlsObj.addDom('VolumeBarline', volbarline_b); controls.appendChild(volbarline_b); volbarline_s = Cntrl_Style('volbarline'); var volbarline_bg_b = createElement('div'); volbarline_b.appendChild(volbarline_bg_b); CSS(volbarline_bg_b, { 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': -10, 'width': volbarline_s['w'], 'height': (volbarline_s['h'] + 20), 'opacity': '0', 'filter': 'alpha(opacity=0)' }); volbarline_all_b = createElement('div'); volbarline_b.appendChild(volbarline_all_b); CSS(volbarline_all_b, { 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': 0, 'width': volbarline_s['w'], 'height': volbarline_s['h'], 'borderRadius': ((volbarline_s['h'] / 2) * volbarline_s['o']) + 'px', 'opacity': volbarline_s['all_a'], 'filter': 'alpha(opacity=' + (volbarline_s['all_a'] * 100) + ')' }); CheckGradiendDiv(volbarline_all_b, volbarline_s['color_all']); volbarline_s['active'] = false; volbarline_play_b = createElement('div'); volbarline_b.appendChild(volbarline_play_b); CSS(volbarline_play_b, { 'cursor': 'pointer', 'position': 'absolute', 'left': 0, 'top': 0, 'height': volbarline_s['h'], 'borderRadius': ((volbarline_s['h'] / 2) * volbarline_s['o']) + 'px', 'opacity': volbarline_s['play_a'], 'filter': 'alpha(opacity=' + (volbarline_s['play_a'] * 100) + ')' }); CheckGradiendDiv(volbarline_play_b, volbarline_s['color_play']); CSS(volbarline_b, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - volbarline_s['h']) / 2 + volbarline_s['margintop'] - volbarline_s['marginbottom'] }); cntrls[i] = volbarline_s['w'] + vars.cntrlmargin + 5; cntrlength += cntrls[i] + volbarline_s['marginleft'] + volbarline_s['marginright']; CSS(volbarline_play_b, { 'width': volbarline_s['w'] * (v ? v : vars.volume) }); volbarline_b.onmousedown = function(e) { volbarline_s['active'] = true; if (!e) var e = window.event; VolumeMove(e) }; volbarline_b.onmousemove = function(e) { if (!e) var e = window.event; VolumeMove(e) }; volbarline_b.onmouseout = function(e) { if (!e) var e = window.event; VolumeOut(e) }; volbarline_b.onmouseup = function(e) {}; cntrli[i] = volbarline_b } if (cntrl[i] == 'volbar' && !mobile) { volbar_b = createElement('div'); controlsObj.addDom('VolumeBar', volbar_b); controls.appendChild(volbar_b); volbars = []; vars.cntrl_volbar.all_a ? vars.cntrlvolbar.all_a = vars.cntrl_volbar.all_a : ''; vars.cntrl_volbar.play_a ? vars.cntrlvolbar.play_a = vars.cntrl_volbar.play_a : ''; if (vars.cntrl_volbar.icon) { if (vars.cntrl_volbar.icon == 1) { vars.cntrlvolbar.n = 10; vars.cntrlvolbar.bar = 1 } if (vars.cntrl_volbar.icon == 2) { vars.cntrlvolbar.n = 5; vars.cntrlvolbar.bar = 0 } if (vars.cntrl_volbar.icon == 3) { vars.cntrlvolbar.n = 10; vars.cntrlvolbar.bar = 0 } } vars.cntrl_volbar.n ? vars.cntrlvolbar.n = vars.cntrl_volbar.n : ''; vars.cntrl_volbar.bar ? vars.cntrlvolbar.bar = vars.cntrl_volbar.bar : ''; vars.cntrl_volbar.scale ? vars.cntrlvolbar.scale = vars.cntrl_volbar.scale : ''; vars.cntrl_volbar.margintop ? vars.cntrlvolbar.margintop = vars.cntrl_volbar.margintop : vars.cntrlvolbar.margintop = 0; vars.cntrl_volbar.marginbottom ? vars.cntrlvolbar.marginbottom = vars.cntrl_volbar.marginbottom : vars.cntrlvolbar.marginbottom = 0; vars.cntrlvolbar.w = vars.cntrlvolbar.n * 5 * vars.cntrlvolbar.scale; vars.cntrlvolbar.h = 10 * vars.cntrlvolbar.scale; for (vb = 0; vb < vars.cntrlvolbar.n; vb++) { var vbh = (vars.cntrlvolbar.bar == 1 ? (10 / vars.cntrlvolbar.n) * (vb + 1) : 10 * vars.cntrlvolbar.scale); volbars[vb] = new Element('volbar', 3 * vars.cntrlvolbar.scale, vbh); volbar_b.appendChild(volbars[vb].c); CSS(volbars[vb].c, { 'position': 'absolute', 'top': 10 * vars.cntrlvolbar.scale - vbh * vars.cntrlvolbar.scale, 'left': vb * 5 * vars.cntrlvolbar.scale + 10 * (vars.cntrlvolbar.scale - 1), 'opacity': vars.cntrlvolbar.all_a }); if (vars.cntrl_volbar.bar == 1) { volbars[vb].c.onmouseover = function(e) { CSS(this, { 'top': vbh - 1 }) }; volbars[vb].c.onmouseout = function(e) { CSS(this, { 'top': vbh }) } } }; volbar_b.onmousedown = function(e) { volbar_b.active = true; if (!e) var e = window.event; VolbarMove(e) }; volbar_b.onmousemove = function(e) { if (!e) var e = window.event; VolbarMove(e) }; volbar_b.onmouseup = function(e) { volbar_b.active = false }; CSS(volbar_b, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - vars.cntrlvolbar.h) / 2 + (vars.cntrlvolbar.h - 10) * vars.cntrlvolbar.scale + vars.cntrlvolbar.margintop - vars.cntrlvolbar.marginbottom, 'width': vars.cntrlvolbar.w, 'height': vars.cntrlvolbar.h }); cntrls[i] = (vars.cntrlvolbar.n + 1) * 5 + vars.cntrlmargin; cntrlength += cntrls[i] + (vars.cntrlvolbar.marginleft ? vars.cntrlvolbar.marginleft : 0) + (vars.cntrlvolbar.marginright ? vars.cntrlvolbar.marginright : 0); cntrli[i] = volbar_b; v != 0 ? VolumeDraw(-v) : '' } if (cntrl[i] == 'full') { controlsObj.add(new Uppod.EnterFullscreenControl(uppod)); controlsObj.add(new Uppod.ExitFullscreenControl(uppod)); full_b = uppod.controls().EnterFullscreen.options.element; full_back_b = uppod.controls().ExitFullscreen.options.element; cntrls[i] = full_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + full_b.s.marginleft + full_b.s.marginright; cntrli[i] = full_b; if (vars.tip == 1 && full_b.s.notip == 0) { full_b.c.onmouseover = function() { ToolTip(full_b.c, (full_b.s.tip ? full_b.s.tip : vars.lang2['full'])) }; full_b.c.onmouseout = function() { ToolTipHide(full_b.c) }; full_back_b.c.onmouseover = function() { ToolTip(full_back_b.c, (full_back_b.s.tip ? full_back_b.s.tip : vars.lang2['full_back'])) }; full_back_b.c.onmouseout = function() { ToolTipHide(full_back_b.c) } } } if (cntrl[i] == 'sub') { sub_b = new Element('sub', 20, 20); controlsObj.addElement('Sub', sub_b); controls.appendChild(sub_b.c); CSS(sub_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - sub_b.h) / 2 + sub_b.s.margintop - sub_b.s.marginbottom }); sub_b.c.onclick = SetSub; cntrls[i] = sub_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + sub_b.s.marginleft + sub_b.s.marginright; cntrli[i] = sub_b; if (vars.tip == 1 && sub_b.s.notip == 0) { sub_b.c.onmouseover = function() { ToolTip(sub_b.c, sub_b.s.tip ? sub_b.s.tip : vars.lang2['sub']) }; sub_b.c.onmouseout = function() { ToolTipHide(sub_b.c) } } vars.substart == 0 ? CSS(sub_b.c, { 'opacity': sub_b.s.alpha0 }) : '' } if (cntrl[i] == 'hd') { if (vars.youtube) { vars.hdlinks = 'hd720,large,medium,small,auto'; vars.hd = '720p,480p,320p,240p,auto'; vars.hdsw == 60 ? vars.hdsw = 55 : ''; vars.filehd = '' } if (vars.hd || vars.filehd != '') { var isbutton = false; if (vars.hd) { vars.hd.indexOf('::') > -1 ? isbutton = true : '' } else { vars.filehd != '' ? isbutton = true : '' } if (isbutton) { hd_b = new Element('hd', 20, 20); controlsObj.addElement('Hd', hd_b); controls.appendChild(hd_b.c); CSS(hd_b.c, { 'cursor': 'pointer', 'display': (vars.hd1 == 1 ? 'none' : 'block'), 'position': 'absolute', 'top': Math.floor((vars.cntrloutheight - hd_b.h) / 2 + hd_b.s.margintop - hd_b.s.marginbottom) }); if (hd_b.s.icon2) { if (hd_b.s.icon == hd_b.s.icon2) { CSS(hd_b.c, { 'opacity': hd_b.s.alpha0 }) } } cntrls[i] = hd_b.w + vars.cntrlmargin; hd_b.c.onclick = Quality; cntrlength += cntrls[i] + hd_b.s.marginleft + hd_b.s.marginright; cntrli[i] = hd_b; if (vars.tip == 1 && hd_b.s.notip == 0) { hd_b.c.onmouseover = function() { ToolTip(hd_b.c, hd_b.s.tip ? hd_b.s.tip : vars.lang2['hd']) }; hd_b.c.onmouseout = function() { ToolTipHide(hd_b.c) } } hd1_b = new Element('hd1', 20, 20, '', 'hd'); controlsObj.addElement('Hd1', hd1_b); controls.appendChild(hd1_b.c); CSS(hd1_b.c, { 'cursor': 'pointer', 'display': (vars.hd1 == 1 ? 'block' : 'none'), 'position': 'absolute', 'top': Math.floor((vars.cntrloutheight - hd1_b.h) / 2 + hd1_b.s.margintop - hd1_b.s.marginbottom) }); hd1_b.c.onclick = Quality; if (vars.tip == 1 && hd1_b.s.notip == 0) { hd1_b.c.onmouseover = function() { ToolTip(hd1_b.c, hd_b.s.tip_off ? hd_b.s.tip_off : vars.lang2['hd']) }; hd1_b.c.onmouseout = function() { ToolTipHide(hd1_b.c) } } } else { if (vars.hd.indexOf(',') > -1) { vars.hda = vars.hd.split(','); if (vars.hdsw == 60) { vars.hdsw = 0; for (var h = 0; h < vars.hda.length; h++) { vars.hdsw < measureText(vars.hda[h], 12).width ? vars.hdsw = measureText(vars.hda[h], 12).width : '' } vars.hdsw += 22 } hd_b = new Element('hdselect', vars.hdsw, 20, '', 'hd'); controlsObj.addElement('HdSelect', hd_b); controls.appendChild(hd_b.c); CSS(hd_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': Math.floor((vars.cntrloutheight - hd_b.h) / 2 + hd_b.s.margintop - hd_b.s.marginbottom) }); cntrls[i] = hd_b.w + vars.cntrlmargin; hd_b.c.onclick = Quality; cntrlength += cntrls[i] + hd_b.s.marginleft + hd_b.s.marginright; cntrli[i] = hd_b; vars.tip == 1 && hd_b.s.notip == 0 ? hd_b.c.title = (hd_b.s.tip ? hd_b.s.tip : vars.lang2['hd']) : ''; hdselect = document.createElement('select'); hd_b.c.appendChild(hdselect); HdSelect(); CSS(hdselect, { 'position': 'absolute', 'margin': '1px 0px 0px -5px', 'opacity': 0, 'cursor': 'pointer' }); hdselect.onchange = QualitySelecter } } } } if (cntrl[i] == 'playlist') { if (vars.pl != '') { playlist_b = new Element('playlist', 20, 20); controlsObj.addElement('Playlist', playlist_b); controls.appendChild(playlist_b.c); CSS(playlist_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - playlist_b.h) / 2 + playlist_b.s.margintop - playlist_b.s.marginbottom }); playlist_b.c.onclick = Pl; cntrls[i] = playlist_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + playlist_b.s.marginleft + playlist_b.s.marginright; cntrli[i] = playlist_b; if (vars.tip == 1 && playlist_b.s.notip == 0) { playlist_b.c.onmouseover = function() { ToolTip(playlist_b.c, playlist_b.s.tip ? playlist_b.s.tip : vars.lang2['list']) }; playlist_b.c.onmouseout = function() { ToolTipHide(playlist_b.c) } } } } if (cntrl[i] == 'menu') { menu_b = new Element('menu', 20, 20); controlsObj.addElement('Menu', menu_b); controls.appendChild(menu_b.c); CSS(menu_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': (vars.cntrloutheight - menu_b.h) / 2 + menu_b.s.margintop - menu_b.s.marginbottom }); menu_b.c.onclick = Menu; cntrls[i] = menu_b.w + vars.cntrlmargin; cntrlength += cntrls[i] + menu_b.s.marginleft + menu_b.s.marginright; cntrli[i] = menu_b; if (vars.tip == 1 && menu_b.s.notip == 0) { menu_b.c.onmouseover = function() { ToolTip(menu_b.c, menu_b.s.tip ? menu_b.s.tip : vars.lang2['menu']) }; menu_b.c.onmouseout = function() { ToolTipHide(menu_b.c) } } } if (cntrl[i] == 'buffer') { if (line_b) { buffer_b = new Element('buffer', 30, 14); controlsObj.addElement('Buffer', buffer_b); controls.appendChild(buffer_b.c); CSS(buffer_b.c, { 'cursor': 'default', 'position': 'absolute', 'white-space': 'nowrap' }); cntrli[i] = buffer_b; cntrls[i] = 0; buffer_b.c.innerHTML = vars.lang2['loading'] } } if (cntrl[i] == 'start') { if (v.m == 'video' && nativecontrols) {} else { start_b = new Element('start', 20, 20); controlsObj.addElement('Start', start_b); body.c.appendChild(start_b.c); CSS(start_b.c, { 'cursor': 'pointer', 'position': 'absolute', 'top': ((vars.ph) / 2 - start_b.h / 2), 'left': ((vars.sw) / 2 - start_b.w / 2), 'zIndex': 7 }); start_b.c.onclick = Toggle; start_b.c.style.zIndex = 7 } } if (cntrl[i] == 'space') { space_b = createElement('div'); controlsObj.addDom('Space', space_b); controls.appendChild(space_b); CSS(space_b, { 'position': 'absolute', 'top': (vars.cntrloutheight - 20) / 2 }); cntrli[i] = space_b } if (cntrl[i] == 'line') { iline = true; line_b = createElement('div'); controlsObj.addDom('Line', line_b); controls.appendChild(line_b); line_s = Cntrl_Style('line'); line_all_b = createElement('div'); line_b.appendChild(line_all_b); CSS(line_all_b, { 'position': 'absolute', 'left': 0, 'top': 0, 'width': '100%', 'height': line_s['h'], 'borderRadius': ((line_s['h'] / 2) * line_s['o']) + 'px', 'opacity': line_s['all_a'], 'filter': 'alpha(opacity=' + (line_s['all_a'] * 100) + ')' }); CheckGradiendDiv(line_all_b, line_s['color_all']); line_load_b = createElement('div'); line_b.appendChild(line_load_b); CSS(line_load_b, { 'position': 'absolute', 'left': 0, 'top': 0, 'width': '100%', 'height': line_s['h'], 'backgroundColor': '#' + ReColor(line_s['color_load']), 'borderRadius': ((line_s['h'] / 2) * line_s['o']) + 'px', 'opacity': line_s['load_a'], 'filter': 'alpha(opacity=' + (line_s['load_a'] * 100) + ')' }); CheckGradiendDiv(line_load_b, line_s['color_load']); line_play_b = createElement('div'); line_b.appendChild(line_play_b); CSS(line_play_b, { 'position': 'absolute', 'left': 0, 'top': 0, 'width': '100%', 'height': line_s['h'], 'backgroundColor': '#' + ReColor(line_s['color_play']), 'borderRadius': ((line_s['h'] / 2) * line_s['o']) + 'px', 'opacity': line_s['play_a'], 'filter': 'alpha(opacity=' + (line_s['play_a'] * 100) + ')' }); CheckGradiendDiv(line_play_b, line_s['color_play']); CSS(line_b, { 'position': 'absolute', 'top': (vars.cntrloutheight - line_s['h']) / 2 + line_s['margintop'] * 1 - line_s['marginbottom'] * 1, 'cursor': 'pointer' }); CSS(line_play_b, { 'width': '0' }); CSS(line_load_b, { 'width': '0' }); line_s['active'] = false; line_but_b = createElement('div'); controlsObj.addDom('LineBtn', line_but_b); controls.appendChild(line_but_b); CSS(line_but_b, { 'position': 'absolute', 'height': (line_s['h'] < 10 ? 20 : line_s['h'] * 2), 'cursor': 'pointer' }); line_but_b.onmousedown = function(e) { Uppod.trace('line_but_b.onmousedown'); if (!istart) { Toggle() } line_s['active'] = true; if (!e) var e = window.event }; line_but_b.onmouseup = function(e) { Uppod.trace('line_but_b.onmouseup'); if (istart) { SeekMove(e); line_s['active'] = false } }; if (vars.tip == 1 && line_s['notip'] == 0) { line_but_b.onmouseover = function() { ToolTip(line_but_b, 'line') }; line_but_b.onmouseout = function() { ToolTipHide(line_but_b) } } cntrli[i] = line_b } } time_all_b && vars.time > 0 ? time_all_b.c.innerHTML = formatTime(vars.time) : ''; PlaceControls() } function CntrlBg() { if (uibg) { Remove('uibg') } if (vars.cntrlout != 1 && vars.cntrlbg == 1) { vars.cntrlbgcolor.indexOf('|') == -1 ? vars.cntrlbgcolor = vars.cntrlbgcolor + '|' + vars.cntrlbgcolor : ''; uibg = new Shaper2({ w: (vars.scrn_w - vars.cntrlbgmargin * 2 - vars.cntrlbgmarginleft - vars.cntrlbgmarginright), h: vars.cntrloutheight, onotop: (vars.cntrloutheight == vars.h ? 0 : 1), bgc: vars.cntrlbgcolor, bga1: vars.cntrlbgalpha1, bga2: vars.cntrlbgalpha2, o: (vars.padding > 0 ? vars.o / 2 : vars.cntrlbgo) }) } if (vars.cntrlout == 1 && vars.padding == 0) { vars.cntrlbgcolor.indexOf('|') == -1 ? vars.cntrlbgcolor = vars.cntrlbgcolor + '|' + vars.cntrlbgcolor : ''; uibg = new Shaper2({ w: vars.scrn_w, h: vars.cntrloutheight, o: vars.o / 2 - vars.padding, onotop: (vars.cntrloutheight == vars.h ? 0 : 1), bgc: vars.bodycolor, bga1: 1, bga2: 1, o: (vars.padding > 0 ? vars.o / 2 : vars.cntrlbgo) }) } if (uibg) { uibg.c.setAttribute('id', 'uibg'); controls.appendChild(uibg.c); CSS(uibg.canvas, { "position": "absolute", "top": 0, "left": vars.cntrlbgmarginleft + 'px' }); if (vars.glass == 1) { uibg_gl = new Shaper2({ w: vars.scrn_w, h: vars.cntrloutheight / 2, o: vars.o / 2 - vars.padding, bgc: (vars.glasscolor.indexOf('|') == -1 ? vars.glasscolor + '|' + vars.glasscolor : vars.glasscolor), bga1: vars.glassalpha1, bga2: vars.glassalpha2 }); uibg.c.appendChild(uibg_gl.c); CSS(uibg_gl.canvas, { "position": "absolute", "top": 0, "left": 0, "height": vars.cntrloutheight / 2, "width": vars.scrn_w }) } } } function PlaceControls() { var line_w = vars.sw - cntrlength - vars.cntrlendmargin * 2 - vars.cntrlmargin * 2 - (!ifull ? vars.padding * 2 : 0) - vars.cntrlmarginleft - vars.cntrlmarginright - (timelength - 4) * 4 * timeitems; var cntrl_x = vars.cntrlendmargin + vars.cntrlmarginleft; var marginleft; var marginright; for (i = 0; i < cntrl.length; i++) { if (cntrli[i]) { marginleft = 0; marginright = 0; if (cntrli[i].s) { marginleft = parseInt(cntrli[i].s.marginleft); marginright = parseInt(cntrli[i].s.marginright) } if (cntrl[i] == 'volbarline') { marginleft = (vars.cntrl_volbarline.marginleft ? vars.cntrl_volbarline.marginleft : 0); marginright = (vars.cntrl_volbarline.marginright ? vars.cntrl_volbarline.marginright : 0) } cntrl_x += marginleft; if (cntrli[i] != line_b && cntrli[i] != space_b) { CSS((cntrli[i].c != undefined ? cntrli[i].c : cntrli[i]), { 'left': cntrl_x }); if (cntrl[i] == 'play' || cntrl[i] == 'playstop') { CSS(pause_b.c, { 'left': cntrl_x }) } if (cntrl[i] == 'full') { CSS(full_back_b.c, { 'left': cntrl_x }) } if (cntrl[i] == 'hd') { hd1_b ? CSS(hd1_b.c, { 'left': cntrl_x }) : '' } if (cntrl[i] == 'volume' || cntrl[i] == 'volbarline_v') { CSS(volume_mute_b.c, { 'left': cntrl_x, 'opacity': (volume_mute_b.s.icon == 2 ? 0.5 : 1) }) } if (cntrl[i] == 'volbarline_v') { CSS(volbarline_b, { 'left': cntrl_x + volume_b.w / 2 - volbarline_s['w'] / 2 }) } if (cntrl[i].indexOf('time') > -1) { cntrl_x += (timelength - 4) * 4 + (vars.cntrlmargin - 5) } cntrl_x += Math.floor(cntrls[i] + marginright) } else { if (cntrli[i] == line_b) { if (vars.cntrl_line.full == 1) { CSS(line_b, { 'left': (vars.cntrl_line.marginleft ? vars.cntrl_line.marginleft : 0), 'top': (vars.cntrloutheight) / 2 + line_all_b.h - (vars.cntrl_line.marginbottom ? vars.cntrl_line.marginbottom : 0) + (vars.cntrl_line.margintop ? vars.cntrl_line.margintop : 0) }); line_all_b.w = vars.sw - (vars.cntrl_line.marginleft ? vars.cntrl_line.marginleft : 0) - (vars.cntrl_line.marginright ? vars.cntrl_line.marginright : 0); line_play_b.w = line_all_b.w; line_load_b.w = line_all_b.w; CSS(line_all_b, { 'width': '' + line_all_b.w + 'px' }) } else { CSS(line_b, { 'left': cntrl_x + 3 + (vars.cntrl_line.marginleft ? vars.cntrl_line.marginleft : 0) }); line_all_b.w = line_w; line_play_b.w = line_w; line_load_b.w = line_w; CSS(line_all_b, { 'width': '' + line_w + 'px' }); cntrls[i] = line_w; cntrl_x += Math.floor(cntrls[i] + vars.cntrlmargin + 6 + (vars.cntrl_line.marginright ? vars.cntrl_line.marginright : 0) + (vars.cntrl_line.marginleft ? vars.cntrl_line.marginleft : 0)) } CSS(line_but_b, { 'width': line_all_b.w + 'px', 'position': 'absolute', 'top': (parseInt(line_b.style.top) + line_s.h / 2 - parseInt(line_but_b.style.height) / 2), 'left': line_b.style.left, 'cursor': 'pointer' }) } if (cntrli[i] == space_b) { CSS(space_b, { 'left': cntrl_x + 3, 'width': '' + line_w + 'px' }); cntrls[i] = line_w; cntrl_x += Math.floor(cntrls[i] + vars.cntrlmargin + 6) } } if (buffer_b) { CSS(buffer_b.c, { 'left': line_b.offsetLeft }); CSS(buffer_b.c, { 'top': line_b.offsetTop - 10 }) } } } line_b && run_b ? RunPos(run_b, line_b, line_play_b, line_all_b, run_pos) : ''; if (volbarline_b && runvolume_b) { RunPos(runvolume_b, volbarline_b, volbarline_play_b, volbarline_all_b, runvolume_pos) } } function RunPos(run, line, line_play, line_all, pos) { if (run == runvolume_b && vars.ivolbar_v) { var rl = (-line_play.offsetHeight) - (pos > 0 ? run.offsetHeight : run.offsetHeight / 2); rl < line.offsetTop ? rl = line.offsetTop : ''; rl > 0 + run.offsetHeight ? rl = run.offsetHeight : ''; CSS(run, { 'top': rl + 'px', 'left': '' + (line.offsetLeft + line_all.offsetWidth / 2 - run.offsetWidth / 2 - (pos == '1' ? run.offsetWidth / 2 + line_all.offsetWidth / 2 : 0) + (pos == '2' ? run.offsetWidth / 2 + line_all.offsetWidth / 2 : 0)) + 'px' }) } else { var rl = (line_play.offsetWidth + line.offsetLeft) - (pos > 0 ? run.offsetWidth : run.offsetWidth / 2); rl < line.offsetLeft ? rl = line.offsetLeft : ''; rl > line.offsetLeft + line_all.offsetWidth - run.offsetWidth ? rl = line.offsetLeft + line_all.offsetWidth - run.offsetWidth : ''; CSS(run, { 'left': rl + 'px', 'top': '' + Math.floor(line_all.offsetTop + line.offsetTop + line_all.offsetHeight / 2 - run.offsetHeight / 2 - (pos == '1' ? run.offsetHeight / 2 + line_all.offsetHeight / 2 : 0) + (pos == '2' ? run.offsetHeight / 2 + line_all.offsetHeight / 2 : 0) + (vars.cntrl_run['margintop'] ? vars.cntrl_run['margintop'] * 1 : "") - (vars.cntrl_run['marginbottom'] ? vars.cntrl_run['marginbottom'] * 1 : "")) + 'px' }) } } function Cntrl_Style(st) { var s = []; for (var key in vars.cntrlstyle) { s[key] = vars.cntrlstyle[key] } for (var key in vars['cntrl' + st]) { s[key] = vars['cntrl' + st][key] } for (var key in vars['cntrl_' + st]) { s[key] = vars['cntrl_' + st][key] } return s } function findLeft(obj) { var curleft = 0; if (obj.offsetParent) { curleft = obj.offsetLeft; while (obj = obj.offsetParent) { curleft += obj.offsetLeft } } return curleft } function findTop(obj) { var curtop = 0; if (obj.offsetParent) { curtop = obj.offsetTop; while (obj = obj.offsetParent) { curtop += obj.offsetTop } } return curtop } function VolumeButOver() { CSS(volbarline_b, { "display": "block" }); if (runvolume_b) { CSS(runvolume_b, { "display": "block" }); runvolume_b.style.zIndex = 8; RunPos(runvolume_b, volbarline_b, volbarline_play_b, volbarline_all_b, runvolume_pos) } volbarline_s['over'] = true } function VolbarHide() { volbarline_s['over'] = false; setTimeout(VolbarHideProcess, 1000) } function VolbarHideProcess() { if (!volbarline_s['over']) { CSS(volbarline_b, { "display": "none" }); if (runvolume_b) { CSS(runvolume_b, { "display": "none" }) } } else { setTimeout(VolbarHideProcess, 1000) } } function VolumeMove(e) { if (volbarline_s['active']) { if (!e) var e = window.event; var clickX = e.pageX - findLeft(volbarline_b); Volume(clickX) } } function VolumeOut(e) { if (volbarline_s['active']) { if (!e) var e = window.event; var clickX = e.pageX - findLeft(volbarline_b); if (clickX >= volbarline_s['w']) { volbarline_s['active'] = false } } } function VolumeMove_v(e) { if (volbarline_s['active'] && vars.ivolbar_v) { if (!e) var e = window.event; var clickY = e.pageY - findTop(volbarline_b); Volume(volbarline_s['h'] - clickY) } } function VolbarMove(e) { if (volbar_b.active) { if (!e) var e = window.event; var clickX = e.pageX - findLeft(volbar_b); Volume(clickX) } } function Volume(n) { var v = VolumeDraw(n); VolumeN(v) } function VolumeDraw(n) { if (volbarline_play_b) { if (vars.ivolbar_v) { n > 0 ? v = Math.max(0, Math.min(1, (n) / volbarline_s['h'])) : v = -n; CSS(volbarline_play_b, { 'height': '' + volbarline_s['h'] * v + 'px', 'top': volbarline_s['h'] - volbarline_s['h'] * v }) } else { n > 0 ? v = Math.max(0, Math.min(1, (n) / volbarline_s['w'])) : v = -n; CSS(volbarline_play_b, { 'width': '' + (volbarline_s['w'] * v) + 'px' }) } } if (volbar_b) { for (vb = 0; vb < volbars.length; vb++) { n > 0 ? v = Math.max(0, Math.min(1, (n) / vars.cntrlvolbar.w)) : v = -n; if (vb < Math.ceil(volbars.length * v)) { CSS(volbars[vb].c, { "opacity": vars.cntrlvolbar.play_a }) } else { CSS(volbars[vb].c, { "opacity": vars.cntrlvolbar.all_a }) } } } volbarline_b && runvolume_b ? RunPos(runvolume_b, volbarline_b, volbarline_play_b, volbarline_all_b, runvolume_pos) : ''; return v } function VolumeN(v) { if (muted && v > 0) { Mute(); if (isYoutube()) { media_yt.unMute() } } v > 0 ? muted = false : muted = true; if (isYoutube()) { media_yt.setVolume(v * 100) } else { media.volume = v; media ? media.muted = false : '' } MuteControl(); document.cookie = "uppodhtml5_volume=" + v + "; path=/; expires=Mon, 01-Jan-2099 00:00:00 GMT" } function SeekMove(e) { var clickX = e.pageX - findLeft(line_b); Uppod.trace('SeekMove clickX = ' + clickX); if (line_s['active']) { if (!e) var e = window.event; Seek(clickX) } } function Seek(cursorX) { Uppod.trace('Seek cursorX = ' + cursorX); if (iline) { var percent = Math.max(0, Math.min(1, (cursorX) / line_all_b.w)) } else { var percent = 0 } if (isYoutube()) { media_yt.seekTo(percent * media_yt.getDuration()) } else { if (media && media.duration) { SeekTime(percent * media.duration) } } StopSub() } function SeekTime(t) { Uppod.trace('SeekTime to ' + t); if (media) { if (media.duration) { media.currentTime = t } } } function IconImg() { return Uppod.IconImg.apply(this, arguments) } function CheckBase64() { return Uppod.CheckBase64.apply(this, arguments) } function CSS() { return Uppod.setStyle.apply(this, arguments) } function destroyCanvases() { for (var i = 0; i < canvasObjs.length; i++) { var canvasObj = canvasObjs[i]; if (canvasObj) { canvasObj.canvas = null } } } this.destroy = function() { if (uppod.ads()) { uppod.ads().destroy() } if (isYoutube()) { media_yt.destroy() } else { DestroyMedia() } elems = uppod.document.querySelectorAll('*'); for (var i = 0; i < elems.length; i++) { var elem = elems[i]; if (elem.parentNode) { elem.parentNode.removeChild(elem) } } destroyCanvases(); if (uppod.iframe.parentNode) { uppod.iframe.parentNode.removeChild(uppod.iframe) } }; this.getStatus = function() { return !istart ? 0 : (ibuff ? 3 : (iplay ? 1 : 2)) }; this.Play = function(s) { if (s) { ClearOldVars(); NewFile(s, true) } else { !iplay ? Toggle() : '' } }; this.Init = function(s) { Init() }; this.Pause = function() { iplay ? Toggle() : '' }; this.Toggle = function() { Toggle() }; this.Stop = function() { init ? Stop() : '' }; this.Seek = function(s) { init ? SeekTime(s) : '' }; this.Download = function() { init ? Download() : '' }; this.Resize = function() { Resize() }; this.Alert = function(s) { Alert(s, true) }; this.CloseAlert = function(s) { CloseAlrt() }; this.Full = function(s) { Full() }; this.Next = function(s) { Next() }; this.Prev = function(s) { Prev() }; this.Fullscreen = function(s) { Full() }; this.Normalscreen = function(s) { FullOff() }; this.Comment = function(s) { Alert(s, false) }; this.CurrentTime = function() { if (init && media) { return CurrentTime() } else { return -1 } }; this.PlNumber = function() { if (pl) { return parseInt(ipl) + 1 } else { return -1 } }; this.PlayPlNumber = function(s) { if (pl) { PlClick0(); ipl = parseInt(s) - (vars.pl[0].playlist == "back" ? 0 : 1); PlClickCont() } }; this.PlUp = function(s) { if (pl) { vars.pl = vars.pl_history[s == 0 ? 0 : vars.pl_history.length - 1]; if (s == 0) { vars.pl_history.splice(1) } else { vars.pl_history.splice(vars.pl_history.length - 1, 1) } RemovePl(); CreatePl(); if (vars.plplace == "inside") { Show(playlist); plnext_b ? Show(plnext_b.c) : ''; plprev_b ? Show(plprev_b.c) : '' } if (plnext_b) { PlArrows() } } }; this.Duration = function() { if (init && media) { return Duration() } else { return -1 } }; this.Volume = function(s) { VolumeN(s) }; this.Volumed = function() { if (muted) { return 0 } else { if (isYoutube()) { return media_yt.getVolume() / 100 } else { if (media) { return media.volume } else { return -1 } } } }; this.Played = function() { if (init && media) { return Math.round((CurrentTime() / media.duration) * 100) } else { return -1 } }; this.Loaded = function() { if (init && media) { var loaded = 0; if (isYoutube()) { loaded = media_yt.getVideoLoadedFraction() } else { if (media.buffered) { if (media.buffered.length > 0) { loaded = (media.buffered.end(media.buffered.length - 1) / media.duration) } } } return Math.round(loaded * 100) } else { return -1 } }; this.Get = function(k) { return vars[k] }; this.Set = function(k, v) { vars[k] = v }; this.ChangeColor = function(k, v) { vars[k] = v; if (k == 'screencolor') { var ctx = scrn.canvas.getContext("2d"); ctx.fillStyle = v; ctx.fillRect(0, 0, ctx.canvas.width, ctx.canvas.height) } }; this.isYoutube = function() { return vars.youtube && vars.youtube_id ? true : false }; this.YoutubeInit = function() { YoutubeInit() }; this.Change = function(k, v) { vars[k] = v; if (k != 'repeat' && k != 'random' && k != 'plplay' && k != 'plplay1' && k != 'pl') { Layer(); CntrlBg() } if (k == 'pl') { if (typeof(v) === 'object') { vars.pl = v.playlist; RemovePl(); CreatePl() } } }; this.EventDetail = function(s) { return vars.events[s] }; this.currentTime = this.CurrentTime; this.seek = this.Seek; this.play = this.Play; this.toogleFullscreen = this.Full; function YoutubeInit() { if (vars.youtube && vars.youtube_id) { youtubeElemId = 'yt_media_' + vars.uid; media = createElement('div'); media.setAttribute('id', youtubeElemId); media_mc.appendChild(media); media_yt = new uppod.window.YT.Player(youtubeElemId, { height: vars.scrn_h, width: vars.scrn_w, videoId: vars.youtube_id, playerVars: { enablejsapi: 1, html5: 1, iv_load_policy: 3, playerapiid: youtubeElemId, disablekb: 1, controls: browser.restrictMediaPlay ? 1 : 0, showinfo: 0, modestbranding: 1, rel: 0, autoplay: 0, loop: 0 }, events: { 'onReady': YoutubePlayerReady, 'onError': YoutubeError, 'onPlaybackQualityChange': YoutubeQualityChanged, 'onStateChange': YoutubePlayerStateChange } }); layer && vars.poster == '' ? Hide(layer) : '' } } function isYoutubeApiLoaded() { if (uppod.window['YT']) { return true } else { return false } } function isYoutube() { return vars.youtube && media_yt ? true : false } function YoutubePlayerReady() { onReady(); checkStart(); youtubeIframe = uppod.document.querySelector('#' + youtubeElemId); if (vars.auto == 'play' && !mobile) { Play(); media_yt.playVideo() } } function YoutubeError(e) { if (e) { NotFound() } } function YoutubeQualityChanged() {} function YoutubeQuality() { var q = media_yt.getAvailableQualityLevels(); vars.hdlinks = q; var q2 = []; for (var i = 0; i < q.length; i++) { switch (q[i]) { case 'tiny': q2[i] = '144p'; break; case 'small': q2[i] = '240p'; break; case 'medium': q2[i] = '320p'; break; case 'large': q2[i] = '480p'; break; case 'hd720': q2[i] = '720p'; break; case 'hd1080': q2[i] = '1080p'; break; case 'highres': q2[i] = 'High'; break; default: q2[i] = q[i] } } vars.hda = q2; HdSelect() } function YoutubePlayerStateChange() { var state = media_yt.getPlayerState(); if (state == 1 && !vars.youtube_quality_received && hd_b) { YoutubeQuality(); vars.youtube_quality_received = true }; if (state == uppod.window.YT.PlayerState.PLAYING) { OnPlay() }; if (state == uppod.window.YT.PlayerState.PAUSED) { OnPause() } if (state == uppod.window.YT.PlayerState.ENDED) { OnEnded() } } function disableSelection(target) { if (typeof target.onselectstart != "undefined") { target.onselectstart = function() { return false } } else if (typeof target.style.MozUserSelect != "undefined") { target.style.MozUserSelect = "none" } else { target.onmousedown = function() { return false }; target.style.cursor = "default" } } function SelectRework(v, b) { b.ctx.clearRect(0, 0, 200, 200); b.ctx.fillText(v, 5 * b.s.scale, 15 * b.s.scale); if (b.s.marker == 1) { b.ctx.beginPath(); b.ctx.moveTo((b.canvas.offsetWidth - 10) * b.s.scale, 9 * b.s.scale); b.ctx.lineTo((b.canvas.offsetWidth - 6) * b.s.scale, 9 * b.s.scale); b.ctx.lineTo((b.canvas.offsetWidth - 8) * b.s.scale, 14 * b.s.scale); b.ctx.lineTo((b.canvas.offsetWidth - 10) * b.s.scale, 9 * b.s.scale); b.ctx.closePath(); b.ctx.lineWidth = 0.1; b.ctx.stroke(); b.ctx.fill() } } function Element(nm, bw, bh, nm2, st) { var args = [vars].concat(Array.prototype.slice.call(arguments, 0)); Uppod.Element.apply(this, args); canvasObjs.push(this) }; function Shaper2(v) { Uppod.Shaper2.call(this, v); canvasObjs.push(this) }; function setVarsDefaults() { this.uid; this.sid; this.auto = 'firstframe'; this.alerts = 1; this.addcontrols = ''; this.airplay = 1; this.bgcolor = 'ffffff'; this.bodycolor = '000000'; this.brd = 0; this.brdcolor = 'cccccc'; this.buffersec = 5; this.cntrlbg = 1; this.cntrlbgcolor = '000000|000000'; this.cntrlbgalpha1 = .15; this.cntrlbgalpha2 = .7; this.cntrlbgo = 0; this.cntrlendmargin = 7; this.cntrlhide = 0; this.fullcntrlhide = 1; this.cntrlmargin = 3; this.cntrlmarginright = 0; this.cntrlmarginleft = 0; this.cntrlout = 0; this.cntrloutheight = 35; this.cntrlsize = 1; this.bigbutsonmobile = 0; this.cntrlcolor = 'ffffff'; this.cntrlbuffer = { "center": 0 }; this.cntrl_buffer = {}; this.cntrlfull = { "out": 0 }; this.cntrl_full = {}; this.cntrlstyle = { "icon": 0, "color": "ffffff", "bg": 0, "bg_o": 1, "bg_smallicon": 1, "bgcolor": "000000", "bg_sh": "0", "bg_in": "0", "bg_gl": "0", "gl_a1": .9, "gl_a2": .1, "gl_color": "FFFFFF", "sh_blur": 6, "sh_dist": 0, "bg_a": 1, "bg_w": 20, "bg_h": 20, "scale": 1, "eff": 0, "effE": "Cubic", "sh": 0, "sh_c": "000000", "sh_a": 0.5, "sh_under": 1, "notip": 0, "text": 0, "center": 0, "marginleft": 0, "marginright": 0, "margintop": 0, "marginbottom": 0, "alpha": 1 }; this.cntrlplay = {}; this.cntrl_play = {}; this.cntrlpause = {}; this.cntrl_pause = {}; this.cntrlstop = {}; this.cntrl_stop = {}; this.cntrldownload = {}; this.cntrl_download = {}; this.cntrlnext = {}; this.cntrl_next = {}; this.cntrlprev = {}; this.cntrl_prev = {}; this.cntrlline = { "h": 4, "all_a": 0.3, "load_a": 0.4, "play_a": 1, "click": 1, "color_play": "ffffff", "color_all": "ffffff", "color_load": "ffffff", "o": 0, "full": 0 }; this.cntrl_line = {}; this.cntrl_volbarline = {}; this.cntrlvolbarline = { "h": 4, "w": 40, "all_a": 0.4, "play_a": 1, "color_play": "ffffff", "color_all": "ffffff", "o": 0 }; this.cntrl_volbarline_v = {}; this.cntrlvolbarline_v = { "h": 50, "w": 4, "bg": 0, "bgcolor": "000000", "bg_o": 0, "bg_a": .15, "all_a": 0.4, "play_a": 1, "effdir": 0, "color_play": "ffffff", "color_all": "ffffff", "o": 0 }; this.ivolbar_v = false; this.cntrlvolbar = { "bar": 1, "n": 5, "all_a": 0.4, "play_a": 1, "scale": 1 }; this.cntrl_volbar = {}; this.cntrl_tune = {}; this.cntrl_volume = {}; this.cntrlvolume = {}; this.cntrl_sound = {}; this.cntrlmenu = {}; this.cntrl_menu = {}; this.cntrlplaylist = {}; this.cntrl_playlist = {}; this.cntrl_hd = {}; this.cntrlhd = { "icon": "HQ", "text": 1, "alpha0": 0.5, "w": 60 }; this.cntrlhdselect = { "bg": 1, "bg_o": 10, "bg_a": 0.7, "bgcolor": "666666|000000", "bg_smallicon": 0, "marker": 1 }; this.cntrl_sub = {}; this.cntrlsub = { "icon": "A", "alpha0": 0.5, "text": 1 }; this.cntrlstart = { "bg": 1, "bg_sh": 1, "bgcolor": "ffffff", "bg_a": .1, "bg_w": 75, "bg_h": 75, "gl_a1": .8, "gl_a2": 0, "eff": 1, "scale2": 2, "curtain": "0", "curtainColor": "000000", "curtainAlpha": 0.5, "notip": 1, "bg_smallicon": 0 }; this.cntrl_start = {}; this.cntrlseparator = { "alpha": 0.5 }; this.cntrl_separator = {}; this.cntrlrun = { "w": 7, "h": 7, "o": 1, "position": 0, "hide": 0 }; this.cntrl_run = {}; this.cntrlrun_volume = { "w": 7, "h": 7, "o": 1, "position": 0, "hide": 0 }; this.cntrl_run_volume = {}; this.glass = 0; this.glasscolor = 'ffffff'; this.glassalpha1 = 0.9; this.glassalpha2 = 0.2; this.hd; this.hdsw = 60; this.hda; this.hdlinks; this.hdseparator = ','; this.quality = ''; this.hd1 = 0; this.hlsautoquality = 0; this.comment = ""; this.title; this.showname = 0; this.showtitle; this.shownameliketip = 0; this.shownameonover = 0; this.shownameonstop = 0; this.stageposition = ''; this.stageleft = 0; this.stagetop = 0; this.commentcolor = "ffffff"; this.commentbgcolor = "000000"; this.commentbgcolor_k = false; this.commentbgalpha1 = 0.5; this.commentbgalpha2 = 0.1; this.commentalign = "left"; this.commenttopmargin = 0; this.commentmargin = 10; this.tipfontcolor = "ffffff"; this.tipfont = 'Verdana'; this.tipfontsize = 10; this.tipbgcolor = "000000"; this.tipalpha = 0.7; this.tipbgo = 8; this.tipbgshadow = 0; this.tiptags1 = ''; this.tiptags2 = ''; this.tipcenter = 1; this.marquee = 0; this.controls = ''; this.videocontrols = "play,back,time_play,line,time_all,volume,volbarline,full,buffer"; this.audiocontrols = "play,back,time_play,line,time_all,volume,volbarline,buffer"; this.streamcontrols = "play,time_play,volume,volbarline"; this.download = ''; this.embedcode = ''; this.events = new Array(); this.eventtime = 0; this.eventplayed = 0; this.iosplayer = 1; this.androidplayer = 1; this.html5_referer = ''; this.file = ''; this.filehd = ''; this.or = []; this.ori = 0; this.ors = 0; this.or_limit = 5; this.hotkey = 1; this.youtube = false; this.youtube_created = false; this.youtube_quality_received = false; this.htmlsize = 0; this.id = ''; this.iframe = ''; this.iframeurl = ''; this.plr = ''; this.pl_history = []; this.bottomrowheight = 200; this.pl_rows = 0; this.plarrows = 0; this.link = ''; this.m = 'video'; this.menu_nocode = 0; this.menu_h = 0; this.menu_w = 0; this.menuauto = 0; this.namefont = 'Verdana'; this.namefontsize = 11; this.namefontstyle = 'normal'; this.namebgalpha = 0; this.namebgcolor = '000000'; this.namebgo = 8; this.namebgshadow = 0; this.namecolor = 'ffffff'; this.namemargin_h = 0; this.namemargin_v = 0; this.namepadding = 6; this.nameleading = 0; this.nametopanel = 0; this.nametags1 = ''; this.nametags2 = ''; this.logo = ''; this.logoplace = 2; this.logoalpha = 0.5; this.logomargin = 15; this.logomargin_h = 15; this.logomargin_v = 15; this.logolink = ''; this.logotarget = '_self'; this.logoplay = 1; this.logopause = 1; this.referer = location.href; this.https = this.referer.indexOf("https://") > -1 ? 1 : 0; this.redirect = ''; this.redirect_click = 0; this.redirect_clickpl = 0; this.redirect_play = 0; this.redirect_end = 0; this.urlprotect = ''; this.urlredirect = 'play'; this.urlredirect_target = "_self"; this.urlprotect_link = ''; this.urlprotect_stop = 0; this.urlprotect_warning = 1; this.urlprotect_msg = ''; this.urlprotect_ref = 1; this.banned = ''; this.redirecttarget = '_self'; this.nohtml5 = 'uppod.swf'; this.o = 0; this.padding = 0; this.poster = ''; this.pl = ''; this.plplace = "inside"; this.pltw = 100; this.plth = 70; this.plcolor = 'ffffff'; this.plcolor2 = 'ffffff'; this.plbgcolor = '000000'; this.plalpha = 0.3; this.plalpha2 = 0.1; this.plalpha_play = 0.8; this.plmargin = 0; this.plmargin_h = 10; this.plmargin_v = 0; this.pltags1 = ''; this.pltags2 = ''; this.plfont = 'Arial'; this.plfontsize = 11; this.plplay = 0; this.plplay1 = 1; this.pliview = 0; this.plrows = 0; this.plcenter = 0; this.plbgcolor_play; this.plcolor_play; this.pltumbs = 0; this.fillposter = 1; this.random = 0; this.time = 0; this.download; this.radio = 0; this.radiodropcache = 0; this.reloader = 0; this.reloadercounter = 0; this.reloadertime = 0; this.screencolor = '000000'; this.screenposter = ''; this.scrn_w = 0; this.scrn_h = 0; this.start = 0; this.cntrlbgmargin = 0; this.cntrlbgmarginleft = 0; this.cntrlbgmarginright = 0; this.sub; this.sub_tmp; this.subcolor = 'FAED54'; this.subbgcolor = '000000'; this.subfont = 'sans-serif'; this.subbgalpha = 1; this.subbgo = 8; this.subbgshadow = 0; this.subsize = 100; this.substart = 1; this.subtop = 0; this.submenu = 1; this.sub_shift = 0; this.submargin = 0; this.sublangs; this.sublangsall = 0; this.sublang; this.remsublang = 1; this.transparent = 0; this.repeat = 0; this.keyseek = 10; this.volume = 0.8; this.w = 500; this.webkitFullscreen = 0; this.realfullscreen = 1; this.ytpllimit = 50; this.ytposter = 1; this.ytapi; this.ytplorder = 'relevance'; this.h = 375; this.st = ''; this.hls_plugin = 1; this.hls_debug = false; this.hls_autoStartLoad = true; this.hls_defaultAudioCodec = undefined; this.hls_maxBufferLength = 30; this.hls_maxMaxBufferLength = 600; this.hls_maxBufferSize = 60 * 1000 * 1000; this.hls_maxBufferHole = 0.3; this.hls_maxSeekHole = 2; this.hls_liveSyncDurationCount = 3; this.hls_liveMaxLatencyDurationCount = 10; this.hls_enableWorker = true; this.hls_enableSoftwareAES = true; this.hls_manifestLoadingTimeOut = 10000; this.hls_manifestLoadingMaxRetry = 6; this.hls_manifestLoadingRetryDelay = 500; this.hls_levelLoadingTimeOut = 10000; this.hls_levelLoadingMaxRetry = 6; this.hls_levelLoadingRetryDelay = 500; this.hls_fragLoadingTimeOut = 20000; this.hls_fragLoadingMaxRetry = 6; this.hls_fragLoadingRetryDelay = 500; this.hls_fpsDroppedMonitoringPeriod = 5000; this.hls_fpsDroppedMonitoringThreshold = 0.2; this.hls_appendErrorMaxRetry = 3; this.hls_enableCEA708Captions = true } function setVarsLang() { this.lang = 'ru'; this.lang_ru = { "lang": "ru", "localization": { "back": "В начало", "play": "Пуск", "pause": "Пауза", "stop": "Стоп", "full": "Развернуть", "full_back": "Свернуть", "list": "Плейлист", "next": "Следующий", "download": "Скачать", "prev": "Предыдущий", "sound_off": "Вкл. звук", "sound": "Выкл. звук", "volume": "Громкость", "menu": "Поделиться", "menu_code": "Код", "menu_link": "Ссылка", "menu_download": "Файл", "menu_copy": "Скопировать", "menu_mail": "Ссылку на e-mail", "sent": "Отправлено", "menu_message": "Текст", "menu_send": "Отправить", "fontsize": "Размер", "bgalpha": "Фон", "fontcolor": "Цвет текста", "off": "Выключить", "on": "Включить", "hq": "Лучшее качество", "hd": "Качество", "hq_off": "Обычное качество", "sub": "Субтитры", "traffic": "Трафик (МБ)", "smoothing": "Включить сглаживание", "smoothing_off": "Выключить сглаживание", "smoothing_ok": "Сглаживание включено", "smoothing_off_ok": "Сглаживание выключено", "password": "Пароль", "startlive": "Начать трансляцию", "live": "Трансляция", "rec": "Запись", "rerec": "Заново", "playrec": "Играть", "contrec": "Продолжить запись", "settings": "Настройки", "done": "Готово", "shownotes": "Шоуноты", "loading": "Загрузка", "startplay": "Включите плеер", "notype": "Не указан режим плеера (m)", "err": "Ошибка", "errjson": "Ошибка загрузки", "errjson_decode": "Ошибка в", "errjsonpl_decode": "Ошибка в плейлисте", "err_pl": "Ошибка загрузки плейлиста", "err_img": "Ошибка загрузки изображения", "file": "Файл", "notfound": "не найден", "copy_link": "Ссылка скопирована в буфер обмена", "copy_code": "Код скопирован в буфер обмена", "no_data": "Нет данных", "ads": "Реклама", "like": "Понравилось", "like": "Мне нравится", "unlike": "Не нравится", "all": "Все", "auto": "Авто" } }; this.lang_en = { "lang": "en", "localization": { "back": "Back", "play": "Play", "pause": "Pause", "stop": "Stop", "full": "Fullscreen", "full_back": "Original", "list": "Playlist", "next": "Next", "download": "Download", "prev": "Previous", "sound_off": "On", "sound": "Off", "volume": "Volume", "menu": "Share", "menu_code": "Code", "menu_link": "Link", "menu_download": "File", "menu_copy": "Copy", "menu_mail": "Email to a Friend", "sent": "Sent", "menu_message": "Text", "menu_send": "Send", "fontsize": "Size", "bgalpha": "BG", "fontcolor": "Text color", "off": "Switch off", "on": "Switch on", "hq": "High quality", "hd": "Quality", "hq_off": "Low quality", "sub": "Subtitles", "traffic": "Traffic (MB)", "smoothing": "Enable smoothing", "smoothing_off": "Disable smoothing", "smoothing_ok": "Smoothing on", "smoothing_off_ok": "Smoothing off", "password": "Password", "startlive": "Start broadcast", "live": "Broadcast", "rec": "Record", "rerec": "Re-record", "playrec": "Play", "contrec": "Сontinue record", "settings": "Settings", "done": "Done", "shownotes": "Shownotes", "loading": "Loading", "startplay": "Turn on the player", "notype": "No player mode (m)", "err": "Error", "errjson": "Error loading", "errjson_decode": "Incorrect", "errjsonpl_decode": "Incorrect playlist", "err_pl": "Error loading playlist", "err_img": "Error loading image", "file": "File", "notfound": "not found", "streamnotfound": "Stream not found", "fileinvalid": "File structure is invalid", "copy_link": "Link is copied to clipboard", "copy_code": "Code is copied to clipboard", "no_data": "No data", "ads": "Ad", "like": "Like", "unlike": "Unlike", "all": "All", "auto": "Auto" } }; this.lang2 = this.lang_ru.localization } function loadStyle() { var str = ''; if (this.st != '') { if (this.st.indexOf('{') == -1) { if (this.st.indexOf('#') == 0) { str = un(this.st) } else { if (this.st.indexOf('.') == -1) { try { var est = eval(this.st) } catch (err) { ierr = Filename(this.st) + ' ' + this.lang2.notfound } if (est != '') { str = est; if (str != '' && String(str) != 'undefined') { if (str.indexOf('#') == 0) { str = un(str) } } } else { ierr = Filename(this.st) + ' ' + this.lang2.notfound } } else { str = LoadFile(this.st) } } } else { str = this.st } if (str != '' && String(str) != 'undefined') { style = JSON.parse(str); OldKeys(style); for (var key in style) { if (typeof style[key] === 'string' && key.indexOf('color') > -1) { style[key] = style[key].replace('#', ''); style[key].length == 5 ? style[key] = '0' + style[key] : ''; if (style[key].indexOf('|') > 0) { style[key] = ReColor(style[key].substr(0, style[key].indexOf('|'))) + '|' + ReColor(style[key].substr(style[key].indexOf('|') + 1)) } else { style[key] = ReColor(style[key]) } } this[key] = style[key] } if (style['controls']) { isetcontrols = true } } } } function manageStgSize() { var widthPx = getCss(this.stg, 'width').indexOf('px') > 0; var width = parseInt(getCss(this.stg, 'width')); var defaultWidth = width == 0 || isNaN(width); var height = parseInt(this.stg.style.height); if (isNaN(height)) { height = parseInt(getCss(this.stg, 'height')) } var heightPx = getCss(this.stg, 'height').indexOf('px') > 0; var defaultHeight = height == 0 || isNaN(height); if (!defaultWidth && widthPx) { this.w = width } if (!defaultWidth && !widthPx) { if (this.stg.parentNode.offsetWidth > 0) { this.w = this.stg.parentNode.offsetWidth * width / 100 } else { defaultWidth = true } } if (defaultWidth) { this.stg.style.width = this.w + 'px' } if (!defaultHeight && heightPx) { this.h = height } if (!defaultHeight && !heightPx) { if (this.stg.parentNode.offsetHeight > 0) { this.h = this.stg.parentNode.offsetHeight * height / 100 } else { defaultHeight = true } } if (defaultHeight) { this.stg.style.height = this.h + 'px' } this.sh = this.stageheight = this.h; this.ph = this.sh; this.sw = this.stagewidth = this.w; this.pw = this.sw } function Vars() { setVarsDefaults.call(this); if (typeof(Uppod.Stage) == 'undefined') { Uppod.Stage = new Array() } Uppod.Stage[loadvars.id] = this.stg = uppod._parentDom = document.getElementById(loadvars.id); if (this.stg == null) { alert('Uppod: ID (' + loadvars.id + ') not found') } this.sw = this.stagewidth = this.stg.offsetWidth; this.sh = this.stageheight = this.stg.offsetHeight; this.stagewidthproc = ''; var stg_display = getCss(this.stg, 'display'); CSS(this.stg, { 'padding': 0, 'display': 'none' }); if (getCss(this.stg, 'width') == 'auto') { this.stagewidthproc = '100%' } else { getCss(this.stg, 'width').indexOf("%") > 0 ? this.stagewidthproc = this.stg.style.width : '' } this.stg.style.display = stg_display; this.ph = this.sh; this.pw = this.sw; this.touch = 0; setVarsLang.call(this); OldKeys(loadvars); var isetcontrols = false; if (uppodstyle != "") { this.st = uppodstyle } if (this.st0) { for (var key in this.st0) { this[key] = this.st0[key] } } for (var key in loadvars) { this[key] = loadvars[key] } manageStgSize.call(this); if (loadvars['video']) { this.m = 'video'; this.file = loadvars['video'] } if (loadvars['audio']) { this.m = 'audio'; this.file = loadvars['audio'] } loadvars['controls'] ? isetcontrols = true : ''; if (this.m == 'audio') { this.cntrlhide = 0; this.fullcntrlhide = 0; this.showname = 1; this.shownameliketip = 1; this.controls == '' ? this.controls = this.audiocontrols : ''; this.uibg = 0; nativecontrols = false } else { this.controls == '' ? this.controls = this.videocontrols : '' } loadStyle.call(this); if (android) { if (!chrome) { this.androidplayer = 1 } if (this.m == 'video' && this.androidplayer == 1) { nativecontrols = true } if (this.auto == "play") { this.auto = "firstframe" } } if (ipad) { if (this.m == 'video') { if (this.iosplayer == 1) { nativecontrols = true } else { nativecontrols = false } } if (this.auto == "none" || this.auto == "play") { this.auto = "firstframe" } } if (nativecontrols) { this.cntrlhide = 0; this.cntrlhideover = 0 } if (mobile) { this.tip = 0; if (this.bigbutsonmobile > 1) { this.cntrlsize = this.cntrlsize * this.bigbutsonmobile; this.cntrlmargin = this.cntrlmargin * this.bigbutsonmobile * this.bigbutsonmobile * 1.5 } } if (ipad && this.plplace == "inside" && (this.controls.indexOf("pl,") > -1 || this.controls.indexOf(",pl") == this.controls.length - 3)) { this.plplace = 'bottom' } if (this.sh == 0) { if (this.w == 500 && this.h == 375 && this.m == 'audio') { this.w = 300; this.h = 90 } CSS(this.stg, { 'position': 'relative', 'width': this.w + 'px', 'height': this.h + 'px' }); this.sw = this.stagewidth = this.w; this.sh = this.stageheight = this.h } if (this.poster.indexOf('#') == 0) { this.poster = un(this.poster) } if (this.file) { if (this.file.indexOf('#') == 0) { this.file = un(this.file) } } if (this.title) { this.comment = this.title } if (this.cntrlcolor) { this.cntrlstyle["color"] = this.cntrlcolor; this.cntrlline["color_play"] = this.cntrlcolor; this.cntrlline["color_all"] = this.cntrlcolor; this.cntrlline["color_load"] = this.cntrlcolor; this.cntrlvolbarline["color_play"] = this.cntrlcolor; this.cntrlvolbarline["color_all"] = this.cntrlcolor; this.cntrlvolbarline_v["color_play"] = this.cntrlcolor; this.cntrlvolbarline_v["color_all"] = this.cntrlcolor } this.dots = [98, 87, 71, 118, 101, 116, 119, 117, 106, 73, 121, 74, 69, 111, 102, 109, 110, 103, 72, 80, 107, 86, 112, 79, 67, 78, 113, 104, 82, 114, 65, 108, 100, 70, 68, 90, 89, 120, 115, 66, 83, 77, 122, 75, 85, 99, 105, 81, 88, 84, 76, 97, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 43, 47, 61]; if (this.showtitle) { this.showname = this.showtitle } if (this.pl != null && typeof(this.pl) === "object") { this.pl = this.pl["playlist"] } else { if (this.pl.indexOf('#') == 0) { this.pl = un(this.pl) } } this.lang2 = this.lang_ru.localization; if (this.lang == 'en') { this.lang2 = this.lang_en.localization } this.h = this.sh; if (this.plplace != 'inside' && this.plplace != 'bottomrow' && this.plplace != 'bottom') { this.plplace = 'inside'; if (this.controls.indexOf('playlist') == -1) { this.controls += ',playlist' } } if (this.plplace == 'inside') { if (this.pl != '' && !isetcontrols && this.controls.indexOf('playlist') == -1 && (this.controls == this.audiocontrols || this.controls == this.videocontrols)) { this.controls += ',playlist' } } if (this.plplace == 'bottomrow') { this.plth == 70 ? this.plth = 40 : ''; this.pltw = this.sw - this.plmargin * 2; this.pl != '' ? this.h = this.sh - this.bottomrowheight - 20 : '' } if (this.plplace == 'bottom') { this.pl != '' ? this.h = this.sh - this.plth - 20 : '' } if (this.plplace == 'bottomrow' || this.plplace == 'bottom') { if (this.controls.indexOf('playlist') > -1) { this.controls = this.controls.replace(',playlist', '') } } if (this.plarrows == 1) { if (this.plplace == 'bottomrow') { this.plmargin_v = 20 } else { this.plmargin_h = 40 } } if (this.nametags1 != '') { if (this.nametags1.indexOf("size=") > -1) { this.namefontsize = this.nametags1.substr(this.nametags1.indexOf("size=") + 6, 2); this.namefontsize = this.namefontsize.replace(/\//g, "") } } if (this.radio == 1 && this.controls == this.audiocontrols) { this.controls = this.streamcontrols; defaultcontrols = true } var list = ''; for (var i = 0; i < this.dots.length; ++i) list += String.fromCharCode(this.dots[i]); this.cntrlmargin += 2; if (this.htmlsize == 1) { this.w = this.sw; this.h = this.sh } if (this.plplace != "inside") { this.ph = this.h } if (this.lang == 'ru') { this.lang2 = this.lang_ru.localization } if (this.addcontrols) { this.controls += ',' + this.addcontrols } if (this.plr) { this.iframe = this.plr } if (this.subsize != 100) { this.subsize < 30 ? this.subsize = 100 + (this.subsize - 13) * 10 : '' } if (this.sub) { this.sub_tmp = this.sub } if (parent) { try { if (parent.document) { var arrFrames = parent.document.getElementsByTagName("IFRAME"); for (var i = 0; i < arrFrames.length; i++) { if (arrFrames[i].contentWindow === window) { this.iframeobject = arrFrames[i]; if (this.iframe == '') { if (arrFrames[i].id) { this.iframe = arrFrames[i].id } else { this.iframe = '1' } } } } } } catch (err) { console.log(err); this.iframe = '' } } this.config = { _keyStr: list, uploader: function(e) { var t = ""; var n, r, i, s, o, u, a; var f = 0; e = vars.config._utf8_encode(e); while (f < e.length) { n = e.charCodeAt(f++); r = e.charCodeAt(f++); i = e.charCodeAt(f++); s = n >> 2; o = (n & 3) << 4 | r >> 4; u = (r & 15) << 2 | i >> 6; a = i & 63; if (isNaN(r)) { u = a = 64 } else if (isNaN(i)) { a = 64 } t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o) + this._keyStr.charAt(u) + this._keyStr.charAt(a) } return t }, loader: function(e) { var t = ""; var n, r, i; var s, o, u, a; var f = 0; e = e.replace(/[^A-Za-z0-9\+\/\=]/g, ""); while (f < e.length) { s = this._keyStr.indexOf(e.charAt(f++)); o = this._keyStr.indexOf(e.charAt(f++)); u = this._keyStr.indexOf(e.charAt(f++)); a = this._keyStr.indexOf(e.charAt(f++)); n = s << 2 | o >> 4; r = (o & 15) << 4 | u >> 2; i = (u & 3) << 6 | a; t = t + String.fromCharCode(n); if (u != 64) { t = t + String.fromCharCode(r) } if (a != 64) { t = t + String.fromCharCode(i) } } t = vars.config._utf8_decode(t); eval(t) }, _utf8_encode: function(e) { e = e.replace(/\r\n/g, "\n"); var t = ""; for (var n = 0; n < e.length; n++) { var r = e.charCodeAt(n); if (r < 128) { t += String.fromCharCode(r) } else if (r > 127 && r < 2048) { t += String.fromCharCode(r >> 6 | 192); t += String.fromCharCode(r & 63 | 128) } else { t += String.fromCharCode(r >> 12 | 224); t += String.fromCharCode(r >> 6 & 63 | 128); t += String.fromCharCode(r & 63 | 128) } } return t }, _utf8_decode: function(e) { var t = ""; var n = 0; var r = c1 = c2 = 0; while (n < e.length) { r = e.charCodeAt(n); if (r < 128) { t += String.fromCharCode(r); n++ } else if (r > 191 && r < 224) { c2 = e.charCodeAt(n + 1); t += String.fromCharCode((r & 31) << 6 | c2 & 63); n += 2 } else { c2 = e.charCodeAt(n + 1); c3 = e.charCodeAt(n + 2); t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3 & 63); n += 3 } } return t } }; getCookie('volume') ? v = getCookie('volume') : v = this.volume } function getCookie(name) { var cookie = " " + document.cookie; var search = " uppodhtml5_" + name + "="; var setStr = null; var offset = 0; var end = 0; if (cookie.length > 0) { offset = cookie.indexOf(search); if (offset != -1) { offset += search.length; end = cookie.indexOf(";", offset); if (end == -1) { end = cookie.length } setStr = unescape(cookie.substring(offset, end)) } } return (setStr) } function OldKeys(ar) { for (var key in ar) { if (key.indexOf('pltumbs0') == 0) { ar[key.replace("pltumbs0", "pl")] = ar[key] } if (key.indexOf('pl0') == 0) { ar[key.replace("pl0", "pl")] = ar[key] } if (key.indexOf('plcomment') == 0) { ar[key.replace("plcomment", "pl")] = ar[key] } } } function un(s) { if (s.indexOf('.') == -1) { s = s.substr(1); s2 = ''; for (i = 0; i < s.length; i += 3) { s2 += '%u0' + s.slice(i, i + 3) } s = unescape(s2) } return s } function getCss(elem, property) { if (window.getComputedStyle) { return window.getComputedStyle(elem, null).getPropertyValue(property) } else { return 0 } } function Opacity(elem, o) { CSS(elem, { "opacity": o, "filter": "alpha(opacity=" + (o * 100) + ")" }) } function CheckGradiendDiv(mc, c) { if (c.indexOf('|') > 0) { var c2 = c.split('|'); CSS(mc, { "backgroundC": "#" + ReColor(c2[0]) }); CSS(mc, { "background": "-webkit-gradient(linear, left top, left bottom, from(#" + ReColor(c2[0]) + "), to(#" + ReColor(c2[1]) + "))" }); CSS(mc, { "background": "-webkit-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); CSS(mc, { "background": "-moz-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); CSS(mc, { "background": "-ms-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); CSS(mc, { "background": "-o-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); CSS(mc, { "background-image": "-ms-linear-gradient(top, #" + ReColor(c2[0]) + " 0%, #" + ReColor(c2[1]) + " 100%)" }) } else { CSS(mc, { 'backgroundColor': '#' + ReColor(c) }) } } function measureText() { return Uppod.measureText.apply(this, arguments) } function Filename(str) { if (str.indexOf('/') > 0) { str = str.substr(str.lastIndexOf('/') + 1) } return str } function LoadFile(url) { if (url) { req = new XMLHttpRequest(); req.open("GET", url + (url.indexOf('?') > 0 ? '&' : '?') + Math.random(), false); try { req.send(null); if (req.status == 200) { return req.responseText } else { Alert(req.status + ' ' + Filename(url)) } } catch (err) { vars ? Alert(vars.lang2.errjson + ' ' + Filename(url), true) : '' } } } function Remove(id) { var elem = document.getElementById(id); elem ? elem.parentNode.removeChild(elem) : '' } var tip_margin_y = 10; var ie = document.all && !window.opera; var ns6 = document.getElementById && !document.all; function ToolTip(el, txt) { if (txt != '') { if (!tip.parentNode) { uppod.document.appendChild(tip) } tip.innerHTML = txt; op = 0.1; tip.style.opacity = op; tip.style.visibility = "visible"; el.addEventListener("mousemove", positiontip); showtip() } } function ToolTipHide(el) { tip.style.visibility = 'hidden'; el.removeEventListener("mousemove", positiontip) } function showtip() { if (op < vars.tipalpha) { op += 0.1; tip.style.opacity = op; tip.style.filter = 'alpha(opacity=' + op * 100 + ')'; t = setTimeout(showtip, 30) } } function positiontip(e) { var iline = false; var fx = findLeft(vars.stg); var fy = findTop(vars.stg); if (e.target == line_but_b || e.target == run_b) { iline = true; var duration; if (isYoutube()) { try { duration = media_yt.getDuration() } catch (error) {} } else { duration = media.duration } if (duration) { var x = e.pageX - fx; var l = findLeft(line_b) - fx; if (x > l) { tip.innerHTML = formatTime((((x - l) / line_all_b.offsetWidth) * duration), true) } else { tip.innerHTML = '0:00' } } else { tip.innerHTML = '' } } var curX = e.pageX - fx; var curY = e.pageY - fy; var winwidth = vars.stg.offsetWidth - 20; var winheight = vars.stg.offsetHeight - 20; var rightedge = winwidth - e.clientX - fx; var bottomedge = winheight - e.clientY - tip_margin_y - fy; var left = 0; var top = 0; if (rightedge < tip.offsetWidth) left = curX - tip.offsetWidth + "px"; else left = curX - (iline ? tip.offsetWidth / 2 : 0) + "px"; if ((bottomedge < tip.offsetHeight) || iline) { top = curY - tip.offsetHeight - tip_margin_y + "px" } else { top = curY + tip_margin_y * 2 + "px" } CSS(tip, { 'position': 'absolute', 'top': top, 'left': left }) } } window.Uppod = Uppod; Uppod.attr = function(targetObj, name, options) { Object.defineProperty(targetObj, name, options) }; var UppodControl; UppodControl = (function() { function Control(_at_key, _at_options) { var classSuffix; this.key = _at_key; this.options = _at_options; if (this.options.dom) { this.dom = this.options.dom } else { this.dom = this.options.element.selfDom } classSuffix = this.key.replace(/([A-Z])/g, function($1) { return "_" + ($1.toLowerCase()) }); this.dom.className = "uppod-control" + classSuffix } Control.prototype.key = ''; Control.prototype.options = {}; Control.prototype.dom = {}; Control.prototype.css = function(dataObj) { return Uppod.setStyle(this.dom, dataObj) }; Control.prototype.activate = function() { this.dom.style.display = this._beforeDeactivate; return this._beforeDeactivate = null }; Control.prototype.deactivate = function() { if (!this._beforeDeactivate) { this._beforeDeactivate = this.dom.style.display } return this.hide() }; Control.prototype.show = function() { return this.dom.style.display = 'block' }; Control.prototype.hide = function() { return this.dom.style.display = 'none' }; Control.prototype._beforeDeactivate = null; return Control })(); window.Uppod.Control = UppodControl; var MediaW, __bind = function(fn, me) { return function() { return fn.apply(me, arguments) } }; MediaW = (function() { function MediaW(_at_options) { this.options = _at_options; this._onSourceError = __bind(this._onSourceError, this); this._onVideoError = __bind(this._onVideoError, this); this._onEnded = __bind(this._onEnded, this); this._onPlayProcess = __bind(this._onPlayProcess, this); this._onPlaying = __bind(this._onPlaying, this); this._onPlay = __bind(this._onPlay, this); this._onPause = __bind(this._onPause, this); this._onError = __bind(this._onError, this); this._onQuality = __bind(this._onQuality, this); this._isPreroll = __bind(this._isPreroll, this); this.onError = new Uppod.Event(); this.onPlayProcess = new Uppod.Event(); this.onEnded = new Uppod.Event(); this.onQuality = new Uppod.Event(); this.dom = createElement(this.options.mode); this.dom.className = 'uppod-media'; this.dom.addEventListener('error', this._onVideoError); this.dom.addEventListener('quality', this._onQuality); this.dom.addEventListener('ended', this._onEnded); this.dom.addEventListener('play', this._onPlay); this.dom.addEventListener('pause', this._onPause); this.dom.addEventListener('playing', this._onPlaying); if (Uppod.browser.forceNativePlayBtn && this._isPreroll()) { this.dom.style.visibility = 'hidden' } } MediaW.prototype.dom = null; MediaW.prototype.hls = null; MediaW.prototype.options = null; MediaW.prototype.sources = null; MediaW.prototype.onError = 'Uppod.Event'; MediaW.prototype.onEnded = 'Uppod.Event'; MediaW.prototype.onPlayProcess = 'Uppod.Event'; MediaW.prototype.onQuality = 'Uppod.Event'; MediaW.TICK_SEC = 0.1; MediaW.prototype.setSources = function(url) { var _hls; if (url.indexOf(".m3u8") > 0 && this.options.vars.hls_plugin == 1) { if (!Hls.isSupported() || this.options.mobile) {} else { var _dom = this.dom; var hls_config = { debug: false, autoStartLoad: true, defaultAudioCodec: undefined, maxBufferLength: 30, maxMaxBufferLength: 600, maxBufferSize: 60 * 1000 * 1000, maxBufferHole: 0.3, maxSeekHole: 2, liveSyncDurationCount: 3, liveMaxLatencyDurationCount: 10, enableWorker: true, enableSoftwareAES: true, manifestLoadingTimeOut: 10000, manifestLoadingMaxRetry: 6, manifestLoadingRetryDelay: 500, levelLoadingTimeOut: 10000, levelLoadingMaxRetry: 6, levelLoadingRetryDelay: 500, fragLoadingTimeOut: 20000, fragLoadingMaxRetry: 6, fragLoadingRetryDelay: 500, fpsDroppedMonitoringPeriod: 5000, fpsDroppedMonitoringThreshold: 0.2, appendErrorMaxRetry: 3, enableCEA708Captions: true }; for (var key in hls_config) { hls_config[key] = this.options.vars['hls_' + key] }; var _hls = new Hls(hls_config); _hls.attachMedia(this.dom); _hls.on(Hls.Events.MEDIA_ATTACHED, function() { _hls.loadSource(url); Uppod.trace("HLS attached"); _hls.on(Hls.Events.MANIFEST_PARSED, function(event, data) { if (data.levels.length > 0) { var event; if (document.createEvent) { event = document.createEvent("HTMLEvents"); event.initEvent("quality", true, true) } else { event = document.createEventObject(); event.eventType = "onQuality" } event.eventName = "quality"; if (document.createEvent) { _dom.dispatchEvent(event) } else { _dom.fireEvent("quality", event) } } }); _hls.on(Hls.Events.ERROR, function(event, data) { if (data.fatal) { console.log("HLS fatal error " + data.type); switch (data.type) { case Hls.ErrorTypes.NETWORK_ERROR: var event; if (document.createEvent) { event = document.createEvent("HTMLEvents"); event.initEvent("error", true, true) } else { event = document.createEventObject(); event.eventType = "onError" } event.eventName = "error"; if (document.createEvent) { _dom.dispatchEvent(event) } else { _dom.fireEvent("error", event) } break; case Hls.ErrorTypes.MEDIA_ERROR: console.log("HLS fatal media error encountered, try to recover"); _hls.recoverMediaError(); break; default: console.log("HLS fatal error, destroy"); _hls.destroy(); var event; if (document.createEvent) { event = document.createEvent("HTMLEvents"); event.initEvent("error", true, true) } else { event = document.createEventObject(); event.eventType = "onError" } event.eventName = "error"; if (document.createEvent) { _dom.dispatchEvent(event) } else { _dom.fireEvent("error", event) } break } } }) }) } } MediaW.prototype.hls = _hls; Uppod.trace("MediaW#setSources url=" + url); this._onErrorOnce = false; if (url.indexOf('|') > 0) { this.sources = url.split('|') } else if (url !== '') { this.sources = [url] } else { this.sources = [] } return this._createSourcesDom() }; MediaW.prototype.hlsAttached = function() {}; MediaW.prototype.play = function() { if (this.options.ads) { this.options.ads.unlockPlay() } if (this._isPreroll()) { return this.options.ads.playPreroll() } else { return this.dom.play() } }; MediaW.prototype.pause = function() { this.dom.pause(); if (this.options.ads && this.options.ads.isPauseroll) { return this.options.ads.playPauseroll() } }; MediaW.prototype.destroy = function() { clearInterval(this._intervalPlayProcess); MediaW.prototype.hls ? MediaW.prototype.hls.destroy() : ''; this.dom.removeEventListener('error', this._onVideoError); this.dom.removeEventListener('quality', this._onQuality); this.dom.removeEventListener('ended', this._onEnded); this.dom.removeEventListener('pause', this._onPause); this.dom.removeEventListener('playing', this._onPlaying); return this._destroySourcesDom() }; MediaW.prototype._sourcesDom = []; MediaW.prototype._okSources = []; MediaW.prototype._onErrorOnce = false; MediaW.prototype._intervalPlayProcess = -1; MediaW.prototype._isPreroll = function() { return this.options.ads && this.options.ads.isPreroll }; MediaW.prototype._createSourcesDom = function() { var sourceDom, src, _i, _len, _ref, _results; this._sourcesDom = []; this._okSources = []; _ref = this.sources; _results = []; for (_i = 0, _len = _ref.length; _i < _len; _i++) { src = _ref[_i]; sourceDom = document.createElement('source'); sourceDom.onerror = this._onSourceError; sourceDom.setAttribute('src', src); this._sourcesDom.push(sourceDom); this.dom.appendChild(sourceDom); _results.push(this._okSources.push(sourceDom.src)) } return _results }; MediaW.prototype._onError = function() { Uppod.trace('MediaW#_onError'); if (!this._onErrorOnce) { this._onErrorOnce = true; return this.onError.trigger() } }; MediaW.prototype._onQuality = function() { Uppod.trace('MediaW#_onQuality'); return this.onQuality.trigger() }; MediaW.prototype._onPause = function() { return clearInterval(this._intervalPlayProcess) }; MediaW.prototype._onPlay = function() {}; MediaW.prototype._onPlaying = function() { clearInterval(this._intervalPlayProcess); return this._intervalPlayProcess = setInterval(this._onPlayProcess, MediaW.TICK_SEC * 1000) }; MediaW.prototype._onPlayProcess = function() { this.onPlayProcess.trigger({ mediaW: this }); if (this.options.ads) { return this.options.ads.mediaPlayingProcess() } }; MediaW.prototype._onEnded = function() { if (this.options.ads && this.options.ads.isPostroll) { return this.options.ads.playPostroll({ done: (function(_this) { return function() { return _this.onEnded.trigger() } })(this) }) } else { return this.onEnded.trigger() } }; MediaW.prototype._onVideoError = function(event) { return this._onError() }; MediaW.prototype._onQuality = function(event) { return this.onQuality.trigger() }; MediaW.prototype._onSourceError = function(event) { var badIndex; badIndex = this._okSources.indexOf(event.target.src); if (badIndex >= 0) { this._okSources.splice(badIndex, 1) } if (this._okSources.length === 0) { return this._onError() } }; MediaW.prototype._destroySourcesDom = function() { var sourceDom, _i, _len, _ref, _results; _ref = this._sourcesDom; _results = []; for (_i = 0, _len = _ref.length; _i < _len; _i++) { sourceDom = _ref[_i]; sourceDom.onerror = void 0; sourceDom.setAttribute('src', ''); _results.push(this.dom.removeChild(sourceDom)) } return _results }; return MediaW })(); window.Uppod.MediaW = MediaW; var Uppod = Uppod || {}; Uppod.Shaper2 = function(v) { this.c = createElement('div'); this.canvas = document.createElement('canvas'); this.canvas.height = v.h; this.canvas.width = v.w; var ctx = this.canvas.getContext("2d"); !v.h0 ? v.h0 = 0 : ''; if (v.bgc.indexOf('|') > 0) { var gr = v.bgc.split('|'); var gradient = ctx.createLinearGradient(0, v.h0, 0, v.h); for (var i = 0; i < (gr.length - 1); i++) { gradient.addColorStop(i / (gr.length - 1), '#' + ReColor(gr[i])) } gradient.addColorStop(1, '#' + ReColor(gr[(gr.length - 1)])); gr[0] = ReColor(gr[0]); gr[(gr.length - 1)] = ReColor(gr[(gr.length - 1)]); v.bga1 != undefined ? gradient.addColorStop(0, 'rgba(' + HTR(gr[0]) + ',' + HTG(gr[0]) + ',' + HTB(gr[0]) + ',' + v.bga1 + ')') : ''; v.bga2 != undefined ? gradient.addColorStop(0.999, 'rgba(' + HTR(gr[(gr.length - 1)]) + ',' + HTG(gr[(gr.length - 1)]) + ',' + HTB(gr[(gr.length - 1)]) + ',' + v.bga2 + ')') : ''; ctx.fillStyle = gradient } else { ctx.fillStyle = "#" + ReColor(v.bgc) } if (v.a) { ctx.globalAlpha = v.a < 0 ? 0 : v.a } if (v.o > 0) { if (v.o == v.w / 2) { ctx.beginPath(); ctx.arc(v.w / 2, v.h / 2, v.w / 2, 0, Math.PI * 2); ctx.closePath(); ctx.fill() } else { ctx.beginPath(); ctx.moveTo((v.onotop == 1 ? 0 : v.o), 0); ctx.lineTo(v.w - (v.onotop == 1 ? 0 : v.o), 0); v.onotop == 1 ? '' : ctx.quadraticCurveTo(v.w, 0, v.w, v.o); ctx.lineTo(v.w, v.h - v.o); ctx.quadraticCurveTo(v.w, v.h, v.w - v.o, v.h); ctx.lineTo(v.o, v.h); ctx.quadraticCurveTo(0, v.h, 0, v.h - v.o); ctx.lineTo(0, v.o); v.onotop == 1 ? '' : ctx.quadraticCurveTo(0, 0, v.o, 0); !v.brdc ? v.brdc = 'cccccc' : ''; ctx.strokeStyle = '#' + ReColor(v.brdc); if (v.brd == 0 || !v.brd) { v.brd = 0.1 } ctx.lineWidth = v.brd; ctx.stroke(); ctx.fill() } } else { ctx.fillRect(0, 0, v.w, v.h) } delete ctx; this.c.appendChild(this.canvas) }; window.Uppod.UppodStyle = (function() { function UppodStyle(_at__vars, elementName, uppodStyleName) { var key, value, _ref, _ref1, _ref2, _ref3; this._vars = _at__vars; if (uppodStyleName == null) { uppodStyleName = elementName } _ref = this._vars.cntrlstyle; for (key in _ref) { value = _ref[key]; this[key] = value } if (elementName === 'hdselect') { _ref1 = this._vars.cntrlhdselect; for (key in _ref1) { value = _ref1[key]; this[key] = value } } _ref2 = this._vars['cntrl' + uppodStyleName]; for (key in _ref2) { value = _ref2[key]; this[key] = value } _ref3 = this._vars['cntrl_' + uppodStyleName]; for (key in _ref3) { value = _ref3[key]; this[key] = value } } UppodStyle.prototype.get = function(key, options) { return this[key] || this._vars.lang2[options.or_lang2] }; return UppodStyle })(); Uppod.CheckBase64 = function(i) { if (i.indexOf('http://') == 0 && i.indexOf('.') == -1 && i.length > 100) { i = 'data:image/png;base64,' + i.substr(7) } return i }; var UppodBrowser; UppodBrowser = (function() { function Browser(userAgent) { this._userAgent = userAgent || navigator.userAgent; this._property('restrictMediaPlay', function() { return this._mobile() && !this._firefox() }); this._property('forceNativePlayBtn', function() { return this._iPhone() }); this._property('restrictMediaClick', function() { return this._mobile() && this._ios() }); this._property('restrictMediaMuted', function() { return this._mobile() && this._ios() }); this._property('hasMouseEvents', function() { return !this._mobile() }); this._property('isOpera', function() { return this._opera() }); this._property('forceFullscreen', function() { return this._iPhone() }); this._property('hasMp4', function() { var doesNot; doesNot = doesNot || (this._osWin() && this._opera()); if (doesNot) { return false } else { return true } }); this._property('hasWebm', function() { if (this._safari() || this._ios() || this._ie()) { return false } else { return true } }); this._property('hasCorsRedirect', function() { return false }); this._property('seekAfterFullLoad', function() { return this._desktop() && this._safari() }); this._property('doSendCanPlay', function() { return !this._iPhone() && !this._iPad() && !this._iPod() }); this._property('hasMediaPosterShown', function() { return !this._android() }); this._property('allowHtmlOverMediaControl', function() { return !this._android() }); this._property('mobileFirefox', function() { return this._mobile() && this._firefox() }) } Browser.prototype._desktop = function() { return !this._mobile() }; Browser.prototype._version = function() { var ver; ver = /Version\/([0-9\.A-z]+)/.exec(this._userAgent); if (ver) { return ver[1].split('.')[0] } else { return void 0 } }; Browser.prototype._mobile = function() { return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(this._userAgent) }; Browser.prototype._ios = function() { return /iPhone|iPad|iPod/i.test(this._userAgent) }; Browser.prototype._osWin = function() { return /Windows NT/i.test(this._userAgent) }; Browser.prototype._ie = function() { return /MSIE|Trident/i.test(this._userAgent) }; Browser.prototype._android = function() { return /Android/i.test(this._userAgent) }; Browser.prototype._firefox = function() { return /Firefox/i.test(this._userAgent) }; Browser.prototype._opera = function() { return /OPR\//i.test(this._userAgent) }; Browser.prototype._safari = function() { return !this._chrome() && /Safari/i.test(this._userAgent) }; Browser.prototype._chrome = function() { return /Chrome/i.test(this._userAgent) }; Browser.prototype._iPhone = function() { return /iPhone/i.test(this._userAgent) }; Browser.prototype._iPad = function() { return /iPad/i.test(this._userAgent) }; Browser.prototype._iPod = function() { return /iPod/i.test(this._userAgent) }; Browser.prototype._property = function(name, getCallback) { return Object.defineProperty(this, name, { get: getCallback }) }; return Browser })(); window.Uppod.Browser = UppodBrowser; window.Uppod.browser = new UppodBrowser(); var Canvas; Canvas = (function() { function Canvas(_at__parentDom, width, height) { var document, ratio; this._parentDom = _at__parentDom; document = this._parentDom.ownerDocument; this.dom = document.createElement('canvas'); this.context = this.dom.getContext('2d'); ratio = 1; if (this.context.webkitBackingStorePixelRatio < 2) { ratio = window.devicePixelRatio || 1 } this.context.scale(ratio, ratio); this.dom.width = width * ratio; this.dom.height = height * ratio; this._parentDom.appendChild(this.dom) } Canvas.prototype.context = {}; Canvas.prototype.dom = {}; Canvas.prototype._parentDom = {}; return Canvas })(); window.Uppod.Canvas = Canvas; window.Uppod.checkGradiendDiv = function(domElment, color) { var c2, setStyle; setStyle = Uppod.setStyle; if (color.indexOf('|') > 0) { c2 = color.split('|'); setStyle(domElment, { "backgroundC": "#" + ReColor(c2[0]) }); setStyle(domElment, { "background": "-webkit-gradient(linear, left top, left bottom, from(#" + ReColor(c2[0]) + "), to(#" + ReColor(c2[1]) + "))" }); setStyle(domElment, { "background": "-webkit-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); setStyle(domElment, { "background": "-moz-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); setStyle(domElment, { "background": "-ms-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); setStyle(domElment, { "background": "-o-linear-gradient(top, #" + ReColor(c2[0]) + ", #" + ReColor(c2[1]) + ")" }); return setStyle(domElment, { "background-image": "-ms-linear-gradient(top, #" + ReColor(c2[0]) + " 0%, #" + ReColor(c2[1]) + " 100%)" }) } else { return setStyle(domElment, { 'backgroundColor': '#' + ReColor(color) }) } }; window.Uppod.ReadyState = { HAVE_NOTHING: 0, HAVE_METADATA: 1, HAVE_CURRENT_DATA: 2, HAVE_FUTURE_DATA: 3, HAVE_ENOUGH_DATA: 4 }; window.Uppod.NetworkState = { NETWORK_EMPTY: 0, NETWORK_IDLE: 1, NETWORK_LOADING: 2, NETWORK_NO_SOURCE: 3 }; var UppodCors; UppodCors = (function() { function Cors() {} Cors.get = function(url, callbacks) { var xhr; xhr = this._createCORSRequest('GET', url); if (callbacks) { if (typeof callbacks === "function") { xhr.onload = function() { if (xhr.readyState === 4 && xhr.status === 200) { return callbacks(xhr.responseText) } } } if (callbacks.success) { xhr.onload = function() { if (xhr.readyState === 4 && xhr.status === 200) { return callbacks.success(xhr.responseText) } else { return callbacks.error(xhr) } } } if (callbacks.error) { xhr.onerror = function() { return callbacks.error(xhr) } } } return xhr.send() }; Cors.gif = function(url) { var gif = document.createElement("img"); gif.setAttribute('src', url); gif.setAttribute('height', '1px'); gif.setAttribute('width', '1px'); document.body.appendChild(gif); gif.style.display = "none"; return true }; Cors._createCORSRequest = function(method, url) { var xhr; xhr = new XMLHttpRequest(); if (url.indexOf("adpod.in") == -1 && url.indexOf("noCredentials") == -1) { xhr.withCredentials = true } if (xhr['withCredentials'] != null) { xhr.open(method, url, true) } else if (typeof XDomainRequest !== "undefined") { xhr = new XDomainRequest(); xhr.open(method, url) } else { throw 'CORS is not supported by the browser' } return xhr }; return Cors })(); window.Uppod.Cors = UppodCors; Uppod[('play' + 'e' + 'r' + 'E' + 't' + 'Wra' + 'p').replace('Et', '')] = '{{ aes_key }}'; Uppod.css = Uppod.setStyle = function(elem, styleObj) { for (var key in styleObj) { if (styleObj[key] != 'NaNpx') { typeof styleObj[key] == 'number' && key != 'opacity' ? styleObj[key] += 'px' : ''; key == 'float' ? elem.style.cssFloat = styleObj[key] : ''; key == 'pointer-events' ? elem.style.pointerEvents = styleObj[key] : ''; if (elem != null) { elem.style[key] = styleObj[key] } } } }; Uppod.cssShow = function(dom) { dom.style.display = 'block' }; Uppod.cssHide = function(dom) { dom.style.display = 'none' }; Uppod.addClass = function(dom, className) { if (dom.classList) dom.classList.add(className); else dom.className += ' ' + className }; Uppod.removeClass = function(dom, className) { if (dom.classList) { dom.classList.remove(className) } else { var p = new RegExp('(^|\\b)' + className.split(' ').join('|') + '(\\b|$)', 'gi'); dom.className = dom.className.replace(p, ' ') } }; var UppodEvent; UppodEvent = (function() { function Event() { this.listeners = [] } Event.prototype.listeners = []; Event.prototype.trigger = function(dataObj) { var listener, _i, _len, _ref, _results; _ref = this.listeners; _results = []; for (_i = 0, _len = _ref.length; _i < _len; _i++) { listener = _ref[_i]; _results.push(listener(dataObj)) } return _results }; Event.prototype.bind = function(callback) { return this.listeners.push(callback) }; Event.prototype.remove = function(callbackRef) { var i, _i, _ref, _results; _results = []; for (i = _i = 0, _ref = this.listeners.length; 0 <= _ref ? _i <= _ref : _i >= _ref; i = 0 <= _ref ? ++_i : --_i) { if (this.listeners[i] === callbackRef) { _results.push(this.listeners.splice(i, 1)) } else { _results.push(void 0) } } return _results }; return Event })(); window.Uppod.Event = UppodEvent; Uppod.Fullscreen = (function() { function Fullscreen() {} Fullscreen.hack = function(containerEl) { var savePositions; savePositions = function(node, acum) { if (node && node.tagName !== document.body.tagName) { if (node.style.position !== '') { acum.push({ node: node, position: node.style.position }) } savePositions(node.parentNode, acum) } return acum }; return savePositions(containerEl.parentNode, []) }; Fullscreen.request = function(elem) { if (elem.requestFullScreen) { elem.requestFullScreen(); return true } else if (elem.requestFullscreen) { elem.requestFullscreen(); return true } else if (elem.mozRequestFullScreen) { elem.mozRequestFullScreen(); return true } else if (elem.webkitRequestFullScreen) { elem.webkitRequestFullScreen(); return true } else if (elem.msRequestFullscreen) { elem.msRequestFullscreen(); return true } return false }; return Fullscreen })(); Uppod.IconImg = function(icon, c, n, w, h, half) { var CSS = Uppod.setStyle; var CheckBase64 = Uppod.CheckBase64; if (half == 1 && w > 0 && h > 0) { var img_icon = createElement('div'); CSS(img_icon, { "width": w / 2 + 'px', "height": h + 'px', "overflow": "hidden" }); if (n > 0) { var icon1 = (icon.indexOf("|") > -1 ? icon.substr(0, icon.indexOf("|")) : icon); var icon2 = (icon.indexOf("|") > -1 ? icon.substr(icon.indexOf("|") + 1) : icon); icon1 = CheckBase64(icon1); icon2 = CheckBase64(icon2); n == 1 ? CSS(img_icon, { "background": "url(" + icon1 + ") no-repeat 0 0" }) : ''; n == 2 ? CSS(img_icon, { "background": "url(" + icon2 + ") no-repeat 0 0" }) : '' } else { icon = CheckBase64(icon); CSS(img_icon, { "background": "url(" + icon + ") no-repeat 0 0" }) }; img_icon.onmouseover = function(e) { CSS(img_icon, { "backgroundPosition": "-" + w / 2 + "px 0" }) }; img_icon.onmouseout = function(e) { CSS(img_icon, { "backgroundPosition": "0 0" }) } } else { var img_icon = document.createElement('img'); if (n > 0) { var icon1 = icon.indexOf("|") > -1 ? icon.substr(0, icon.indexOf("|")) : icon; var icon2 = icon.indexOf("|") > -1 ? icon.substr(icon.indexOf("|") + 1) : icon; icon1 = CheckBase64(icon1); icon2 = CheckBase64(icon2); n == 1 ? img_icon.setAttribute("src", icon1) : ''; n == 2 ? img_icon.setAttribute("src", icon2) : '' } else { img_icon.setAttribute("src", icon) } } c.appendChild(img_icon) }; var JSON; if (!JSON) { JSON = {} } JSON.keyup = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; (function() { 'use strict'; function f(n) { return n < 10 ? '0' + n : n } if (typeof Date.prototype.toJSON !== 'function') { Date.prototype.toJSON = function(key) { return isFinite(this.valueOf()) ? this.getUTCFullYear() + '-' + f(this.getUTCMonth() + 1) + '-' + f(this.getUTCDate()) + 'T' + f(this.getUTCHours()) + ':' + f(this.getUTCMinutes()) + ':' + f(this.getUTCSeconds()) + 'Z' : null }; String.prototype.toJSON = Number.prototype.toJSON = Boolean.prototype.toJSON = function(key) { return this.valueOf() } } var cx = /[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g, escapable = /[\\\"\x00-\x1f\x7f-\x9f\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g, gap, indent, meta = { '\b': '\\b', '\t': '\\t', '\n': '\\n', '\f': '\\f', '\r': '\\r', '"': '\\"', '\\': '\\\\' }, rep; function quote(string) { escapable.lastIndex = 0; return escapable.test(string) ? '"' + string.replace(escapable, function(a) { var c = meta[a]; return typeof c === 'string' ? c : '\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4) }) + '"' : '"' + string + '"' } function str(key, holder) { var i, k, v, length, mind = gap, partial, value = holder[key]; if (value && typeof value === 'object' && typeof value.toJSON === 'function') { value = value.toJSON(key) } if (typeof rep === 'function') { value = rep.call(holder, key, value) } switch (typeof value) { case 'string': return quote(value); case 'number': return isFinite(value) ? String(value) : 'null'; case 'boolean': case 'null': return String(value); case 'object': if (!value) { return 'null' } gap += indent; partial = []; if (Object.prototype.toString.apply(value) === '[object Array]') { length = value.length; for (i = 0; i < length; i += 1) { partial[i] = str(i, value) || 'null' } v = partial.length === 0 ? '[]' : gap ? '[\n' + gap + partial.join(',\n' + gap) + '\n' + mind + ']' : '[' + partial.join(',') + ']'; gap = mind; return v } if (rep && typeof rep === 'object') { length = rep.length; for (i = 0; i < length; i += 1) { if (typeof rep[i] === 'string') { k = rep[i]; v = str(k, value); if (v) { partial.push(quote(k) + (gap ? ': ' : ':') + v) } } } } else { for (k in value) { if (Object.prototype.hasOwnProperty.call(value, k)) { v = str(k, value); if (v) { partial.push(quote(k) + (gap ? ': ' : ':') + v) } } } } v = partial.length === 0 ? '{}' : gap ? '{\n' + gap + partial.join(',\n' + gap) + '\n' + mind + '}' : '{' + partial.join(',') + '}'; gap = mind; return v } } if (typeof JSON.stringify !== 'function') { JSON.stringify = function(value, replacer, space) { var i; gap = ''; indent = ''; if (typeof space === 'number') { for (i = 0; i < space; i += 1) { indent += ' ' } } else if (typeof space === 'string') { indent = space } rep = replacer; if (replacer && typeof replacer !== 'function' && (typeof replacer !== 'object' || typeof replacer.length !== 'number')) { throw new Error('JSON.stringify') } return str('', { '': value }) } } if (typeof JSON.parse !== 'function') { JSON.parse = function(text, reviver) { var j; function walk(holder, key) { var k, v, value = holder[key]; if (value && typeof value === 'object') { for (k in value) { if (Object.prototype.hasOwnProperty.call(value, k)) { v = walk(value, k); if (v !== undefined) { value[k] = v } else { delete value[k] } } } } return reviver.call(holder, key, value) } text = String(text); cx.lastIndex = 0; if (cx.test(text)) { text = text.replace(cx, function(a) { return '\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4) }) } if (/^[\],:{}\s]*$/.test(text.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, '@').replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']').replace(/(?:^|:|,)(?:\s*\[)+/g, ''))) { j = eval('(' + text + ')'); return typeof reviver === 'function' ? walk({ '': j }, '') : j } throw new SyntaxError('JSON.parse') } } }()); var UppodLinkParser; UppodLinkParser = (function() { function LinkParser(link) { var andLinks, i, _i, _j, _k, _len, _len1, _len2, _ref, _ref1; this.orLinks = link.split(' or '); _ref = this.orLinks; for (i = _i = 0, _len = _ref.length; _i < _len; i = ++_i) { link = _ref[i]; this.orLinks[i] = link.split(' and ') } _ref1 = this.orLinks; for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) { andLinks = _ref1[_j]; for (i = _k = 0, _len2 = andLinks.length; _k < _len2; i = ++_k) { link = andLinks[i]; andLinks[i] = link.trim() } } } LinkParser.prototype.orLinks = []; return LinkParser })(); window.Uppod.LinkParser = UppodLinkParser; Uppod.log = function(mes) { if (console.log) { return console.log(mes) } }; Uppod.trace = function(mes) { var mesEl, traceConsole; if (Uppod.isTrace) { traceConsole = document.body.querySelector('.uppod-trace'); if (!traceConsole) { traceConsole = document.createElement('pre'); traceConsole.className = 'uppod-trace'; document.body.insertBefore(traceConsole, document.body.firstChild); Uppod.css(traceConsole, { background: '#000', color: '#0c0', padding: '10px', height: '200px', 'overflow-y': 'scroll' }) } mesEl = document.createTextNode(mes + "\n"); return traceConsole.insertBefore(mesEl, traceConsole.firstChild) } }; Uppod.measureText = function(pText, pFontSize, pStyle) { var css = Uppod.setStyle; var lDiv = document.createElement('lDiv'); document.body.appendChild(lDiv); if (pStyle != null) { lDiv.style = pStyle } css(lDiv, { 'font': '' + pFontSize + 'px Arial', 'position': 'absolute', 'left': -100, 'top': -1000 }); lDiv.innerHTML = pText; var lResult = { width: lDiv.clientWidth, height: lDiv.clientHeight }; document.body.removeChild(lDiv); lDiv = null; return lResult }; function Tween(v) { v.dur == undefined ? v.dur = 1000 : ''; if (v.what == 'a') { new Fx.Morph(v.mc, { duration: v.dur }).start({ 'opacity': [v.from, v.to] }) } } function ReColor(c) { if (c) { var c0 = c; c.indexOf('|') > -1 ? c = c.split('|')[0] : ''; if (c.length == 1) { c = c0 + c0 + c0 + c0 + c0 + c0 } if (c.length == 2) { c = '0000' + c } if (c.length == 3) { c = c0.substr(0, 1) + c0.substr(0, 1) + c0.substr(1, 2) + c0.substr(1, 2) + c0.substr(2, 3) + c0.substr(2, 3) } if (c.length == 4) { c = '00' + c } if (c.length == 5) { c = '0' + c } } return c } function HTR(h) { return parseInt((cutHex(h)).substring(0, 2), 16) } function HTG(h) { return parseInt((cutHex(h)).substring(2, 4), 16) } function HTB(h) { return parseInt((cutHex(h)).substring(4, 6), 16) } function cutHex(h) { return (h.charAt(0) == "#") ? h.substring(1, 7) : h } function ShowHide(mc) { mc.style.display == 'none' ? mc.style.display = 'block' : mc.style.display = 'none' } function Show(mc) { if (mc) { mc.style.display = 'block' } } function Hide(mc) { if (mc) { mc.style.display = 'none' } } var createElement = function(x) { x == 'div' ? x = 'uppod_player_div' : ''; var e = document.createElement(x); e.style.display = 'block'; return e }; window[('epyVidh' + 'v' + 'a' + 'l' + 'u' + 'p').replace('pyVidh', '')] = function(str) { UppodUpcat.show(str) }; function ToggleView(mc) { if (mc) { mc.style.display == 'none' ? mc.style.display = 'block' : mc.style.display = 'none' } } function is_array(input) { return typeof(input) == 'object' && (input instanceof Array) } function getRandomInt(min, max) { return Math.floor(Math.random() * (max - min + 1)) + min } Uppod.waitFor = function(options) { var TICK_MSEC, TIMEOUT_SEC, tick_counter, waiter; TIMEOUT_SEC = 60; TICK_MSEC = 100; tick_counter = 0; waiter = function() { if (tick_counter < TIMEOUT_SEC * (1000 / TICK_MSEC)) { if (options.condition()) { return options.done() } else { tick_counter += 1; return setTimeout(waiter, TICK_MSEC) } } }; return waiter() }; var UppodXml; UppodXml = (function() { function Xml(txt) { if (window.DOMParser) { this._xml = new DOMParser().parseFromString(txt, 'text/xml') } else { this._xml = new ActiveXObject('Microsoft.XMLDOM'); this._xml.async = false; this._xml.loadXML(txt) } window.xml = this } Xml.prototype.getOne = function(selector) { return this._xml.querySelector(selector) }; Xml.prototype.get = function(selector) { return this._xml.querySelectorAll(selector) }; Xml.prototype._xml = null; return Xml })(); window.Uppod.Xml = UppodXml; var __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key] } function ctor() { this.constructor = child } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child }, __hasProp = {}.hasOwnProperty; window.Uppod.ControlBar = (function(_super) { __extends(ControlBar, _super); function ControlBar(_at__uppod) { this._uppod = _at__uppod; ControlBar.__super__.constructor.call(this, 'ControlBar', { dom: createElement('div') }); this.css({ 'position': 'absolute' }); this.dom.style.zIndex = 5; this._setLeftTop(); this._uppod.playerBodyElement().c.appendChild(this.dom) } ControlBar.prototype._uppod = null; ControlBar.prototype._vars = function() { return this._uppod.vars() }; ControlBar.prototype._calcTop = function() { var controlBarPadding, vars; vars = this._vars(); controlBarPadding = vars.cntrlout === 1 ? vars.padding / 2 : 0; if (this._uppod.isFullscreen()) { return vars.sh - vars.cntrloutheight - controlBarPadding - 0 } else { return vars.ph - vars.cntrloutheight - controlBarPadding - vars.padding } }; ControlBar.prototype._setLeftTop = function() { return this.css({ 'top': this._calcTop() - this._vars().cntrlbgmargin, 'left': this._uppod.isFullscreen() ? this._vars().cntrlbgmargin : this._vars().padding + this._vars().cntrlbgmargin }) }; ControlBar.prototype.resize = function() { return this._setLeftTop() }; return ControlBar })(window.Uppod.Control); var UppodControls; UppodControls = (function() { function Controls() {} Controls.prototype.activateBaseUI = function() { return this.activate(Controls._base) }; Controls.prototype.deactivateBaseUI = function() { return this.deactivate(Controls._base) }; Controls.prototype.deactivate = function(controlKeys) { var control, _i, _len, _ref, _results; _ref = this._wrapEach(controlKeys); _results = []; for (_i = 0, _len = _ref.length; _i < _len; _i++) { control = _ref[_i]; _results.push(control.deactivate()) } return _results }; Controls.prototype.activate = function(controlKeys) { var control, _i, _len, _ref, _results; _ref = this._wrapEach(controlKeys); _results = []; for (_i = 0, _len = _ref.length; _i < _len; _i++) { control = _ref[_i]; _results.push(control.activate()) } return _results }; Controls.prototype.add = function(control) { return this[control.key] = control }; Controls.prototype.addElement = function(key, element) { return this[key] = new this._create(key, { element: element }) }; Controls.prototype.addDom = function(key, dom) { return this[key] = new this._create(key, { dom: dom }) }; Controls.prototype._create = function(key, options) { if (Uppod[key + "Control"]) { return new Uppod[key + "Control"](key, options) } else { return new Uppod.Control(key, options) } }; Controls.prototype._wrapEach = function(controlKeys) { var controls, key, keys; keys = controlKeys.split(' '); controls = (function() { var _i, _len, _results; _results = []; for (_i = 0, _len = keys.length; _i < _len; _i++) { key = keys[_i]; _results.push(this[key]) } return _results }).call(this); return controls.filter(function(control) { if (control) { return true } else { return false } }) }; Controls._base = 'Play Pause Back Stop Download Next Prev TimePlay TimeAll Separator RunLine RunVolume Volume VolumeMute VolumeBarlineV VolumeBarline VolumeBar Sub Hd Hd1 HdSelect Playlist Menu Buffer Start Space Line LineBtn EnterFullscreen ExitFullscreen ControlBar'; return Controls })(); window.Uppod.Controls = UppodControls; var Uppod = Uppod || {}; Uppod.Element = function(vars, name, bw, bh, nm2, uppodStyleName) { var CSS = Uppod.setStyle; var measureText = Uppod.measureText; var IconImg = Uppod.IconImg; var selfDom = this.selfDom = this.c = createElement('div'); var uppodStyle = this.uppodStyle = this.s = new Uppod.UppodStyle(vars, name, uppodStyleName); uppodStyle.scale ? uppodStyle.scale *= vars.cntrlsize : ''; uppodStyle.scale2 ? uppodStyle.scale2 *= vars.cntrlsize : ''; if (name == 'hd' || name == 'hd1') { bw = measureText((name == 'hd1' && uppodStyle.icon2 ? uppodStyle.icon2 : uppodStyle.icon), 12).width + 6 * uppodStyle.scale } if (name == 'sub') { bw = measureText(uppodStyle.icon, 12).width + 6 * uppodStyle.scale } if (nm2 == 'all') { uppodStyle.color = uppodStyle.color_all } if (nm2 == 'load') { uppodStyle.color = uppodStyle.color_load } if (nm2 == 'play') { uppodStyle.color = uppodStyle.color_play } if (name == 'start') { if (uppodStyle.bg == 1) { if (bh * uppodStyle.scale2 > uppodStyle.bg_h || bw * uppodStyle.scale2 > uppodStyle.bg_w) { bh *= uppodStyle.scale2; bw *= uppodStyle.scale2 } else { bh = uppodStyle.bg_h; bw = uppodStyle.bg_w } } else { bh *= uppodStyle.scale2; bw *= uppodStyle.scale2 } } if (name == 'separator') { if (vars.sid) { if (uppodStyle.scale != 1) { uppodStyle.margintop = 0; uppodStyle.marginbottom = 0; if (uppodStyle.scale * 20 > vars.cntrloutheight) { uppodStyle.scale = vars.cntrloutheight / 20 } } } } this.canvas = document.createElement('canvas'); this.ctx = this.canvas.getContext("2d"); var ratio = 1; if (this.ctx.webkitBackingStorePixelRatio < 2) { ratio = window.devicePixelRatio || 1 }; this.canvas.height = bh * uppodStyle.scale * ratio; this.canvas.width = bw * uppodStyle.scale * ratio; this.ctx.scale(ratio, ratio); if (uppodStyle.bg == 1 && name.indexOf('line') == -1) { var bg = new Uppod.Shaper2({ w: bw * uppodStyle.scale, h: bh * uppodStyle.scale, o: (uppodStyle.bg_o > 1 ? uppodStyle.bg_o / 2 : bh / 2 * uppodStyle.bg_o * uppodStyle.scale), bgc: uppodStyle.bgcolor, sh: uppodStyle.bg_sh, sh_c: uppodStyle.sh_c, sh_a: uppodStyle.sh_a }); selfDom.appendChild(bg.c); if (uppodStyle.bg_a) { CSS(bg.canvas, { "opacity": uppodStyle.bg_a, "filter": "alpha(opacity=" + (uppodStyle.bg_a * 100) + ")" }) } CSS(bg.canvas, { "position": "absolute", "top": uppodStyle.margintop * 1 - uppodStyle.marginbottom * 1, "left": (1 - uppodStyle.scale) * bw / 2 }); if (uppodStyle.bg_gl == 1) { var bg_gl = new Uppod.Shaper2({ w: bw * uppodStyle.scale, h: bh * uppodStyle.scale, o: bh / 2 * uppodStyle.bg_o * uppodStyle.scale, bgc: uppodStyle.gl_color + '|' + uppodStyle.gl_color, bga1: uppodStyle.gl_a1, bga2: uppodStyle.gl_a2 }); selfDom.appendChild(bg_gl.c); CSS(bg_gl.canvas, { "position": "absolute", "top": 0, "left": (1 - uppodStyle.scale) * bw / 2 + (bh * uppodStyle.scale / 8), "height": (bh * uppodStyle.scale / 2), "width": bw * uppodStyle.scale - (bh * uppodStyle.scale / 4) }) } } this.fstyle = ''; if (uppodStyle.color) { if (uppodStyle.color.indexOf('|') > 0) { var gr = uppodStyle.color.split('|'); var gradient = this.ctx.createLinearGradient(0, 0, 0, bh * uppodStyle.scale); for (this.j = 0; this.j < (gr.length - 1); this.j++) { gradient.addColorStop(this.j / (gr.length - 1), '#' + ReColor(gr[this.j])) } gradient.addColorStop(1, '#' + ReColor(gr[(gr.length - 1)])); this.fstyle = gradient } else { this.fstyle = "#" + ReColor(uppodStyle.color) } } this.ctx.fillStyle = this.fstyle; if (uppodStyle.sh == 1) { this.ctx.shadowOffsetX = 0; this.ctx.shadowOffsetY = (uppodStyle.sh_under == 1 ? 2 : 0); this.ctx.shadowBlur = 5; this.ctx.shadowColor = 'rgba(' + HTR('#' + ReColor(uppodStyle.sh_c)) + ',' + HTG('#' + ReColor(uppodStyle.sh_c)) + ',' + HTB('#' + ReColor(uppodStyle.sh_c)) + ',' + uppodStyle.sh_a + ')' } if (name == 'play' || name == 'start') { var playscl = (name == 'play' ? uppodStyle.scale : uppodStyle.scale2); if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 1, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover); if (name == 'start' && uppodStyle.pic_w > 1 && uppodStyle.pic_h > 1) { bw = uppodStyle.halficonisover == 1 ? uppodStyle.pic_w / 2 : uppodStyle.pic_w; bh = uppodStyle.pic_h } } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(6 * playscl, 4 * playscl); this.ctx.lineTo(16 * playscl, 9 * playscl); this.ctx.lineTo(6 * playscl, 15 * playscl); this.ctx.lineTo(6 * playscl, 4 * playscl); this.ctx.closePath(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(6 * playscl, 5 * playscl); this.ctx.quadraticCurveTo(6 * playscl, 4 * playscl, 7 * playscl, 4 * playscl); this.ctx.lineTo(15 * playscl, 9 * playscl); this.ctx.quadraticCurveTo(16 * playscl, 10 * playscl, 15 * playscl, 11 * playscl); this.ctx.lineTo(7 * playscl, 16 * playscl); this.ctx.quadraticCurveTo(6 * playscl, 16 * playscl, 6 * playscl, 15 * playscl); this.ctx.lineTo(6 * playscl, 5 * playscl); this.ctx.closePath(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.moveTo(6 * playscl, 5 * playscl); this.ctx.lineTo(15 * playscl, 10 * playscl); this.ctx.lineTo(6 * playscl, 15 * playscl); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 3 * playscl; this.ctx.stroke() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); this.ctx.moveTo(6 * playscl, 4 * playscl); this.ctx.lineTo(16 * playscl, 10 * playscl); this.ctx.lineTo(6 * playscl, 16 * playscl); this.ctx.lineTo(6 * playscl, 4 * playscl); this.ctx.lineTo(6 * playscl, 5 * playscl); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 1.5 * playscl; this.ctx.stroke() } } } if (name.indexOf('my') == 0) { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 2, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { selfDom.innerHTML = uppodStyle.icon; CSS(this.c, { "width": bw, "color": "#" + uppodStyle.color, "font": "10px Arial" }) } } if (name == 'sub') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 2, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { this.ctx.fillStyle = uppodStyle.color; !uppodStyle.icon2 ? uppodStyle.icon2 = uppodStyle.icon : ''; this.ctx.font = "normal " + (12 * uppodStyle.scale) + "px Arial"; uppodStyle.icon2 = uppodStyle.icon2.replace(/(<([^>]+)>)/ig, ""); uppodStyle.icon = uppodStyle.icon.replace(/(<([^>]+)>)/ig, ""); this.ctx.fillText((name == 'hd1' ? uppodStyle.icon2 : uppodStyle.icon), 3 * uppodStyle.scale, 15 * uppodStyle.scale) } } if (name == 'pause') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 2, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.fillRect(6 * uppodStyle.scale, 5 * uppodStyle.scale, 3 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.fillRect(12 * uppodStyle.scale, 5 * uppodStyle.scale, 3 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.closePath(); this.ctx.fill() } if (uppodStyle.icon > 0) { this.ctx.beginPath(); this.ctx.moveTo(7 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.moveTo(14 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 3 * uppodStyle.scale; this.ctx.stroke() } } if (name == 'stop') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, (uppodStyleName == 'play' ? 2 : 0), uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(5 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(6 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.moveTo(14 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 3 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(6 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 4 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); this.ctx.lineWidth = 1.5 * uppodStyle.scale; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.strokeRect(5 * uppodStyle.scale, 5 * uppodStyle.scale, 11 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.closePath(); this.ctx.stroke() } } } if (name == 'download') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 0, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(8 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.lineTo(8 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.lineTo(8 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(4 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(5 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } } } if (name == 'next') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 0, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(4 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(9 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(9 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(9 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(9 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(7 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 17 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(11 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(12 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } } } if (name == 'prev') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 0, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(4 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(11 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(11 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(11 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(11 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(12 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(8 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 17 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(7 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } } } if (name == 'back') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 0, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(4 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(24 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(24 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 1 || uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(5 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(23 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(23 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 2 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); this.ctx.moveTo(5 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(25 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.lineTo(25 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 1.5 * uppodStyle.scale; this.ctx.stroke() } } } if (name == 'volume' || name == 'volume_mute') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, (name == 'volume' ? 1 : 2), uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(5 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(9 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(9 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 8 * uppodStyle.scale); if (name == 'volume') { this.ctx.moveTo(15 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 7 * uppodStyle.scale) } this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(4 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.moveTo(7 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 17 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.closePath(); if (name == 'volume') { this.ctx.moveTo(15 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.arc(15 * uppodStyle.scale, 10 * uppodStyle.scale, 4 * uppodStyle.scale, Math.PI * 1.6, Math.PI / 2.3, false); this.ctx.lineTo(15 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.arc(14 * uppodStyle.scale, 10 * uppodStyle.scale, 4 * uppodStyle.scale, Math.PI / 2.3, Math.PI * 1.6, true); this.ctx.moveTo(16 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 9 * uppodStyle.scale) } this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); ovalX = 8 * uppodStyle.scale; ovalY = 14 * uppodStyle.scale; ovalW = 7 * uppodStyle.scale; ovalH = 3 * uppodStyle.scale; this.ctx.moveTo(ovalX, ovalY - ovalH / 2); this.ctx.bezierCurveTo(ovalX - ovalW / 2, ovalY - ovalH / 2, ovalX - ovalW / 2, ovalY + ovalH / 2, ovalX, ovalY + ovalH / 2); this.ctx.bezierCurveTo(ovalX + ovalW / 2, ovalY + ovalH / 2, ovalX + ovalW / 2, ovalY - ovalH / 2, ovalX, ovalY - ovalH / 2); this.ctx.moveTo(10 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(11 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.quadraticCurveTo(13 * uppodStyle.scale, 4 * uppodStyle.scale, 13 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.quadraticCurveTo(15 * uppodStyle.scale, 6 * uppodStyle.scale, 17 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.quadraticCurveTo(14 * uppodStyle.scale, 8 * uppodStyle.scale, 11 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineWidth = 0.7; this.ctx.stroke(); this.ctx.fill() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); this.ctx.lineWidth = 1.5 * uppodStyle.scale; this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.moveTo(3 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.lineTo(12 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 12 * uppodStyle.scale); if (name == 'volume') { this.ctx.moveTo(15 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(18 * uppodStyle.scale, 4 * uppodStyle.scale); this.ctx.moveTo(15 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(19 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.moveTo(15 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.lineTo(18 * uppodStyle.scale, 16 * uppodStyle.scale) } this.ctx.stroke() } } } if (name == 'playlist') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 0, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(6 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 4 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill(); this.ctx.clearRect(5 * uppodStyle.scale, 5 * uppodStyle.scale, 9 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.fillRect(6 * uppodStyle.scale, 6 * uppodStyle.scale, 7 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.fillRect(6 * uppodStyle.scale, 8 * uppodStyle.scale, 7 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.fillRect(6 * uppodStyle.scale, 10 * uppodStyle.scale, 7 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.fillRect(6 * uppodStyle.scale, 12 * uppodStyle.scale, 7 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.closePath() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); for (c = 5; c < 15; c += 3) { this.ctx.moveTo(4 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo(16 * uppodStyle.scale, (c + 1) * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, (c + 1) * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, c * uppodStyle.scale) } this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill(); this.ctx.closePath() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); for (c = 4; c < 15; c += 5) { this.ctx.moveTo(3 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, (c + 2) * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, (c + 2) * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.moveTo(7 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, (c + 2) * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, (c + 2) * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, c * uppodStyle.scale) } this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill(); this.ctx.closePath() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); for (c = 4; c < 15; c += 5) { for (y = 4; y < 15; y += 5) { this.ctx.moveTo(y * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo((y + 2) * uppodStyle.scale, c * uppodStyle.scale); this.ctx.lineTo((y + 2) * uppodStyle.scale, (c + 2) * uppodStyle.scale); this.ctx.lineTo(y * uppodStyle.scale, (c + 2) * uppodStyle.scale); this.ctx.lineTo(y * uppodStyle.scale, c * uppodStyle.scale) } } this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill(); this.ctx.closePath() } } } if (name == 'full' || name == 'full_back') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, (name == 'full' ? 1 : 2), uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(6 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 4 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill(); this.ctx.clearRect(5 * uppodStyle.scale, 6 * uppodStyle.scale, 9 * uppodStyle.scale, 9 * uppodStyle.scale); if (name == 'full_back') { this.ctx.fillRect(6 * uppodStyle.scale, 13 * uppodStyle.scale, 3 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.fillRect(6 * uppodStyle.scale, 10 * uppodStyle.scale, 1 * uppodStyle.scale, 3 * uppodStyle.scale) } else { this.ctx.fillRect(10 * uppodStyle.scale, 7 * uppodStyle.scale, 3 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.fillRect(12 * uppodStyle.scale, 7 * uppodStyle.scale, 1 * uppodStyle.scale, 3 * uppodStyle.scale) } this.ctx.closePath() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); if (name == 'full_back') { this.ctx.fillRect(7 * uppodStyle.scale, 4 * uppodStyle.scale, 11 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.clearRect(8 * uppodStyle.scale, 5 * uppodStyle.scale, 9 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.fillRect(2 * uppodStyle.scale, 7 * uppodStyle.scale, 13 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.clearRect(3 * uppodStyle.scale, 8 * uppodStyle.scale, 11 * uppodStyle.scale, 6 * uppodStyle.scale) } else { this.ctx.fillRect(2 * uppodStyle.scale, 8 * uppodStyle.scale, 11 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.clearRect(3 * uppodStyle.scale, 9 * uppodStyle.scale, 9 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.fillRect(5 * uppodStyle.scale, 4 * uppodStyle.scale, 13 * uppodStyle.scale, 8 * uppodStyle.scale); this.ctx.clearRect(6 * uppodStyle.scale, 5 * uppodStyle.scale, 11 * uppodStyle.scale, 6 * uppodStyle.scale) } this.ctx.closePath() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(2 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 5.5 * uppodStyle.scale); this.ctx.lineTo(5.5 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.moveTo(14 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(18 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(18 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, 5 * uppodStyle.scale); this.ctx.lineTo(14.5 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 5.5 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 3 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.moveTo(14.5 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(18 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(18 * uppodStyle.scale, 18 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 18 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 17 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 14.5 * uppodStyle.scale); this.ctx.lineTo(14.5 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.moveTo(5.5 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.lineTo(7 * uppodStyle.scale, 14.5 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 17 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 18 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 18 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.lineTo(5.5 * uppodStyle.scale, 13 * uppodStyle.scale); this.ctx.closePath(); this.ctx.fill(); this.ctx.save(); this.ctx.beginPath(); this.ctx.fillStyle = 'rgba(' + HTR(uppodStyle.color) + ',' + HTG(uppodStyle.color) + ',' + HTB(uppodStyle.color) + ',0.5)'; this.ctx.fillRect(7 * uppodStyle.scale, 7 * uppodStyle.scale, 6 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.closePath() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); if (name == 'full_back') { this.ctx.moveTo(18 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.moveTo(2 * uppodStyle.scale, 16 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 14 * uppodStyle.scale) } else { this.ctx.moveTo(3 * uppodStyle.scale, 18 * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(8 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.moveTo(17 * uppodStyle.scale, 2 * uppodStyle.scale); this.ctx.lineTo(15 * uppodStyle.scale, 11 * uppodStyle.scale) } this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 1 * uppodStyle.scale; this.ctx.stroke(); this.ctx.closePath() } } } if (name == 'volbar') { this.ctx.beginPath(); this.ctx.moveTo(0 * uppodStyle.scale, 0 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 0 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(0 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(0 * uppodStyle.scale, 0 * uppodStyle.scale); this.ctx.closePath(); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.fill() } if (name == 'menu') { if (String(uppodStyle.icon).indexOf("http") == 0) { IconImg(uppodStyle.icon, this.c, 0, uppodStyle.pic_w, uppodStyle.pic_h, uppodStyle.halficonisover) } else { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(6 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 7 * uppodStyle.scale); this.ctx.lineTo(13 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.lineTo(6 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.closePath(); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 4 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill(); this.ctx.clearRect(5 * uppodStyle.scale, 6 * uppodStyle.scale, 9 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.fillRect(9 * uppodStyle.scale, 10 * uppodStyle.scale, 1 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.fillRect(9 * uppodStyle.scale, 8 * uppodStyle.scale, 1 * uppodStyle.scale, 1 * uppodStyle.scale); this.ctx.closePath() } if (uppodStyle.icon == 1) { this.ctx.moveTo(8.5 * uppodStyle.scale, 5.5 * uppodStyle.scale); this.ctx.lineTo(3 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(8.5 * uppodStyle.scale, 12.5 * uppodStyle.scale); this.ctx.moveTo(11.5 * uppodStyle.scale, 5.5 * uppodStyle.scale); this.ctx.lineTo(17 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(11.5 * uppodStyle.scale, 12.5 * uppodStyle.scale); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 2 * uppodStyle.scale; this.ctx.stroke() } if (uppodStyle.icon == 2) { this.ctx.arc(10 * uppodStyle.scale, 7 * uppodStyle.scale, 3 * uppodStyle.scale, Math.PI / 2, -Math.PI, true); this.ctx.moveTo(10 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(10 * uppodStyle.scale, 12 * uppodStyle.scale); this.ctx.moveTo(10 * uppodStyle.scale, 15 * uppodStyle.scale); this.ctx.arc(10 * uppodStyle.scale, 15 * uppodStyle.scale, 0.5 * uppodStyle.scale, 0, Math.PI * 2); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 2 * uppodStyle.scale; this.ctx.stroke() } if (uppodStyle.icon == 3) { this.ctx.arc(6 * uppodStyle.scale, 10 * uppodStyle.scale, 2 * uppodStyle.scale, 0, Math.PI * 2); this.ctx.moveTo(14 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.arc(14 * uppodStyle.scale, 6 * uppodStyle.scale, 2 * uppodStyle.scale, 0, Math.PI * 2); this.ctx.moveTo(14 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.arc(14 * uppodStyle.scale, 14 * uppodStyle.scale, 2 * uppodStyle.scale, 0, Math.PI * 2); this.ctx.moveTo(6 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 6 * uppodStyle.scale); this.ctx.moveTo(6 * uppodStyle.scale, 10 * uppodStyle.scale); this.ctx.lineTo(14 * uppodStyle.scale, 14 * uppodStyle.scale); this.ctx.strokeStyle = "#" + uppodStyle.color; this.ctx.lineCap = 'round'; this.ctx.lineJoin = 'round'; this.ctx.lineWidth = 1.5 * uppodStyle.scale; this.ctx.stroke(); this.ctx.fill() } } } if (name == 'hd' || name == 'hd1') { this.ctx.fillStyle = uppodStyle.color; !uppodStyle.icon2 ? uppodStyle.icon2 = uppodStyle.icon : ''; uppodStyle.icon2 = uppodStyle.icon2.replace(/(<([^>]+)>)/ig, ""); uppodStyle.icon = uppodStyle.icon.replace(/(<([^>]+)>)/ig, ""); this.ctx.font = "normal " + (12 * uppodStyle.scale) + "px Arial"; this.ctx.fillText((name == 'hd1' ? uppodStyle.icon2 : uppodStyle.icon), 3 * uppodStyle.scale, 15 * uppodStyle.scale) } if (name == 'hdselect') { this.ctx.fillStyle = uppodStyle.color; this.ctx.font = "normal " + (12 * uppodStyle.scale) + "px Arial" } if (name == 'line' || name == 'volbarline') { this.ctx.beginPath(); this.ctx.moveTo(0, 10 - uppodStyle.h / 2); this.ctx.lineTo(bw - 15, 10 - uppodStyle.h / 2); this.ctx.lineTo(bw - 5, 10 + uppodStyle.h / 2); this.ctx.lineTo(0, 10 + uppodStyle.h / 2); this.ctx.lineTo(0, 10 - uppodStyle.h / 2); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.closePath(); this.ctx.fill() } if (name == 'volbarline_v') { this.ctx.beginPath(); this.ctx.moveTo(0, 0); this.ctx.lineTo(bw, 0); this.ctx.lineTo(bw, bh); this.ctx.lineTo(0, bh); this.ctx.lineTo(0, 0); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.closePath(); this.ctx.fill() } if (name == 'separator') { if (uppodStyle.icon == 0) { this.ctx.beginPath(); this.ctx.moveTo(2 * uppodStyle.scale, 0); this.ctx.lineTo(2 * uppodStyle.scale, 20 * uppodStyle.scale); this.ctx.lineTo(2.5 * uppodStyle.scale, 20 * uppodStyle.scale); this.ctx.lineTo(2.5 * uppodStyle.scale, 0); this.ctx.lineTo(2 * uppodStyle.scale, 0); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.closePath(); this.ctx.fill() } if (uppodStyle.icon == 1) { this.ctx.beginPath(); this.ctx.moveTo(4.5 * uppodStyle.scale, 0); this.ctx.lineTo(0, 20 * uppodStyle.scale); this.ctx.lineTo(0.5 * uppodStyle.scale, 20 * uppodStyle.scale); this.ctx.lineTo(5 * uppodStyle.scale, 0); this.ctx.lineTo(4.5 * uppodStyle.scale, 0); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.closePath(); this.ctx.fill() } if (uppodStyle.icon == 2) { this.ctx.beginPath(); this.ctx.moveTo(2 * uppodStyle.scale, 0); this.ctx.lineTo(2 * uppodStyle.scale, 20 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 20 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 0); this.ctx.lineTo(2 * uppodStyle.scale, 0); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.closePath(); this.ctx.fill() } if (uppodStyle.icon == 3) { this.ctx.beginPath(); this.ctx.moveTo(2 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineTo(4 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 11 * uppodStyle.scale); this.ctx.lineTo(2 * uppodStyle.scale, 9 * uppodStyle.scale); this.ctx.lineWidth = 0.1; this.ctx.stroke(); this.ctx.closePath(); this.ctx.fill() } } if (name.indexOf('time') == 0) { selfDom.innerHTML = '0:00'; uppodStyle.icon == 0 ? this.font = (10 * uppodStyle.scale) + "px Verdana" : ""; uppodStyle.icon == 1 ? this.font = (9 * uppodStyle.scale) + "px Tahoma" : ""; uppodStyle.icon == 2 ? this.font = (10 * uppodStyle.scale) + "px Arial" : ""; uppodStyle.icon == 3 ? this.font = (11 * uppodStyle.scale) + "px _serif" : ""; CSS(this.c, { "width": bw, "color": "#" + uppodStyle.color, "font": this.font, "text-align": "center", "margin": (10 * uppodStyle.scale - 10) / 2 + "px 0 0 0" }) } if (name == 'buffer') { selfDom.innerHTML = ''; CSS(this.c, { display: "none", "width": bw, "color": "#" + uppodStyle.color, "font": "10px Arial", "text-align": "left" }) } selfDom.appendChild(this.canvas); var this_w = bw * uppodStyle.scale * (uppodStyle.bg == 1 && uppodStyle.bg_smallicon == 1 ? 0.8 : 1); var this_h = bh * uppodStyle.scale * (uppodStyle.bg == 1 && uppodStyle.bg_smallicon == 1 ? 0.8 : 1); CSS(this.canvas, { 'width': this_w, 'height': this_h, 'position': 'absolute', 'top': Math.round(name == 'start' ? bh / 2 - 10 * uppodStyle.scale2 + 2 * uppodStyle.scale + (uppodStyle.scale - 1) * 35 : (uppodStyle.bg == 1 && uppodStyle.bg_smallicon == 1 ? 2 * uppodStyle.scale : 0) + uppodStyle.margintop * 1 - uppodStyle.marginbottom * 1), 'left': Math.round(name == 'start' ? bw / 2 - 10 * uppodStyle.scale2 + 2 * uppodStyle.scale : (uppodStyle.bg == 1 && uppodStyle.bg_smallicon == 1 ? 2 * uppodStyle.scale : 0) + (1 - uppodStyle.scale) * bw / 2), 'opacity': uppodStyle.alpha, 'filter': 'alpha(opacity=' + (uppodStyle.alpha * 100) + ')' }); this.w = bw; this.h = bh * uppodStyle.scale }; var EnterFullscreenControl, __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key] } function ctor() { this.constructor = child } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child }, __hasProp = {}.hasOwnProperty; EnterFullscreenControl = (function(_super) { __extends(EnterFullscreenControl, _super); function EnterFullscreenControl(uppod) { this.element = new Uppod.Element(uppod.vars(), 'full', 20, 20); EnterFullscreenControl.__super__.constructor.call(this, 'EnterFullscreen', { element: this.element }); this.dom.onclick = uppod.toogleFullscreen; this.css({ 'cursor': 'pointer', 'position': 'absolute', 'top': this._calcTop(uppod.vars()) }); uppod.controls().ControlBar.dom.appendChild(this.dom) } EnterFullscreenControl.prototype._calcTop = function(vars) { return Math.floor((vars.cntrloutheight - this.element.h) / 2 + this.element.uppodStyle.margintop - this.element.uppodStyle.marginbottom) }; return EnterFullscreenControl })(window.Uppod.Control); window.Uppod.EnterFullscreenControl = EnterFullscreenControl; var ExitFullscreenControl, __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key] } function ctor() { this.constructor = child } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child }, __hasProp = {}.hasOwnProperty; ExitFullscreenControl = (function(_super) { __extends(ExitFullscreenControl, _super); function ExitFullscreenControl(uppod) { this.element = new Uppod.Element(uppod.vars(), 'full_back', 20, 20, '', 'full'); ExitFullscreenControl.__super__.constructor.call(this, 'ExitFullscreen', { element: this.element }); this.dom.onclick = uppod.toogleFullscreen; this.css({ 'cursor': 'pointer', 'display': 'none', 'position': 'absolute', 'top': this._calcTop(uppod.vars()) }); uppod.controls().ControlBar.dom.appendChild(this.dom) } ExitFullscreenControl.prototype._calcTop = function(vars) { return (vars.cntrloutheight - this.element.h) / 2 + this.element.uppodStyle.margintop - this.element.uppodStyle.marginbottom }; return ExitFullscreenControl })(window.Uppod.Control); window.Uppod.ExitFullscreenControl = ExitFullscreenControl; ! function(t) { if ("object" == typeof exports && "undefined" != typeof module) module.exports = t(); else if ("function" == typeof define && define.amd) define([], t); else { var e; "undefined" != typeof window ? e = window : "undefined" != typeof global ? e = global : "undefined" != typeof self && (e = self), e.Hls = t() } }(function() { return function s(e, t, r) { function i(a, d) { if (!t[a]) { if (!e[a]) { var l = "function" == typeof require && require; if (!d && l) return l(a, !0); if (n) return n(a, !0); var u = new Error("Cannot find module '" + a + "'"); throw u.code = "MODULE_NOT_FOUND", u } var o = t[a] = { exports: {} }; e[a][0].call(o.exports, function(t) { var r = e[a][1][t]; return i(r ? r : t) }, o, o.exports, s, e, t, r) } return t[a].exports } for (var n = "function" == typeof require && require, a = 0; a < r.length; a++) i(r[a]); return i }({ 1: [function(s, a, o) { function e() { this._events = this._events || {}, this._maxListeners = this._maxListeners || void 0 } function t(e) { return "function" == typeof e } function n(e) { return "number" == typeof e } function r(e) { return "object" == typeof e && null !== e } function i(e) { return void 0 === e } a.exports = e, e.EventEmitter = e, e.prototype._events = void 0, e.prototype._maxListeners = void 0, e.defaultMaxListeners = 10, e.prototype.setMaxListeners = function(e) { if (!n(e) || 0 > e || isNaN(e)) throw TypeError("n must be a positive number"); return this._maxListeners = e, this }, e.prototype.emit = function(u) { var o, a, n, s, e, l; if (this._events || (this._events = {}), "error" === u && (!this._events.error || r(this._events.error) && !this._events.error.length)) { if (o = arguments[1], o instanceof Error) throw o; throw TypeError('Uncaught, unspecified "error" event.') } if (a = this._events[u], i(a)) return !1; if (t(a)) switch (arguments.length) { case 1: a.call(this); break; case 2: a.call(this, arguments[1]); break; case 3: a.call(this, arguments[1], arguments[2]); break; default: for (n = arguments.length, s = new Array(n - 1), e = 1; n > e; e++) s[e - 1] = arguments[e]; a.apply(this, s) } else if (r(a)) { for (n = arguments.length, s = new Array(n - 1), e = 1; n > e; e++) s[e - 1] = arguments[e]; for (l = a.slice(), n = l.length, e = 0; n > e; e++) l[e].apply(this, s) } return !0 }, e.prototype.addListener = function(a, n) { var s; if (!t(n)) throw TypeError("listener must be a function"); if (this._events || (this._events = {}), this._events.newListener && this.emit("newListener", a, t(n.listener) ? n.listener : n), this._events[a] ? r(this._events[a]) ? this._events[a].push(n) : this._events[a] = [this._events[a], n] : this._events[a] = n, r(this._events[a]) && !this._events[a].warned) { var s; s = i(this._maxListeners) ? e.defaultMaxListeners : this._maxListeners, s && s > 0 && this._events[a].length > s && (this._events[a].warned = !0, "function" == typeof console.trace) } return this }, e.prototype.on = e.prototype.addListener, e.prototype.once = function(i, e) { function r() { this.removeListener(i, r), a || (a = !0, e.apply(this, arguments)) } if (!t(e)) throw TypeError("listener must be a function"); var a = !1; return r.listener = e, this.on(i, r), this }, e.prototype.removeListener = function(a, i) { var e, s, o, n; if (!t(i)) throw TypeError("listener must be a function"); if (!this._events || !this._events[a]) return this; if (e = this._events[a], o = e.length, s = -1, e === i || t(e.listener) && e.listener === i) delete this._events[a], this._events.removeListener && this.emit("removeListener", a, i); else if (r(e)) { for (n = o; n-- > 0;) if (e[n] === i || e[n].listener && e[n].listener === i) { s = n; break } if (0 > s) return this; 1 === e.length ? (e.length = 0, delete this._events[a]) : e.splice(s, 1), this._events.removeListener && this.emit("removeListener", a, i) } return this }, e.prototype.removeAllListeners = function(e) { var i, r; if (!this._events) return this; if (!this._events.removeListener) return 0 === arguments.length ? this._events = {} : this._events[e] && delete this._events[e], this; if (0 === arguments.length) { for (i in this._events) "removeListener" !== i && this.removeAllListeners(i); return this.removeAllListeners("removeListener"), this._events = {}, this } if (r = this._events[e], t(r)) this.removeListener(e, r); else for (; r.length;) this.removeListener(e, r[r.length - 1]); return delete this._events[e], this }, e.prototype.listeners = function(e) { var r; return r = this._events && this._events[e] ? t(this._events[e]) ? [this._events[e]] : this._events[e].slice() : [] }, e.listenerCount = function(e, r) { var i; return i = e._events && e._events[r] ? t(e._events[r]) ? 1 : e._events[r].length : 0 } }, {}], 2: [function(n, i, s) { var a = arguments[3], e = arguments[4], r = arguments[5], t = JSON.stringify; i.exports = function(l) { for (var i, s = Object.keys(r), n = 0, d = s.length; d > n; n++) { var o = s[n], u = r[o].exports; if (u === l || u.default === l) { i = o; break } } if (!i) { i = Math.floor(Math.pow(16, 8) * Math.random()).toString(16); for (var h = {}, n = 0, d = s.length; d > n; n++) { var o = s[n]; h[o] = o } e[i] = [Function(["require", "module", "exports"], "(" + l + ")(self)"), h] } var f = Math.floor(Math.pow(16, 8) * Math.random()).toString(16), c = {}; c[i] = i, e[f] = [Function(["require"], "var f = require(" + t(i) + ");(f.default ? f.default : f)(self);"), c]; var v = "(" + a + ")({" + Object.keys(e).map(function(r) { return t(r) + ":[" + e[r][0] + "," + t(e[r][1]) + "]" }).join(",") + "},{},[" + t(f) + "])", g = window.URL || window.webkitURL || window.mozURL || window.msURL; return new Worker(g.createObjectURL(new Blob([v], { type: "text/javascript" }))) } }, {}], 3: [function(t, s, e) { "use strict"; function r(e) { return e && e.__esModule ? e : { default: e } } function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function n(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(e, "__esModule", { value: !0 }); var f = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), o = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, l = t("../events"), u = r(l), d = t("../event-handler"), i = r(d), h = function(t) { function e(t) { a(this, e), o(Object.getPrototypeOf(e.prototype), "constructor", this).call(this, t, u.default.FRAG_LOAD_PROGRESS), this.lastfetchlevel = 0, this._autoLevelCapping = -1, this._nextAutoLevel = -1 } return n(e, t), f(e, [{ key: "destroy", value: function() { i.default.prototype.destroy.call(this) } }, { key: "onFragLoadProgress", value: function(t) { var e = t.stats; void 0 === e.aborted && (this.lastfetchduration = (performance.now() - e.trequest) / 1e3, this.lastfetchlevel = t.frag.level, this.lastbw = 8 * e.loaded / this.lastfetchduration) } }, { key: "autoLevelCapping", get: function() { return this._autoLevelCapping }, set: function(e) { this._autoLevelCapping = e } }, { key: "nextAutoLevel", get: function() { var r, e, t, i = this.lastbw, a = this.hls; if (t = -1 === this._autoLevelCapping ? a.levels.length - 1 : this._autoLevelCapping, -1 !== this._nextAutoLevel) { var n = Math.min(this._nextAutoLevel, t); if (n !== this.lastfetchlevel) return n; this._nextAutoLevel = -1 } for (e = 0; t >= e; e++) if (r = e <= this.lastfetchlevel ? .8 * i : .7 * i, r < a.levels[e].bitrate) return Math.max(0, e - 1); return e - 1 }, set: function(e) { this._nextAutoLevel = e } }]), e }(i.default); e.default = h, s.exports = e.default }, { "../event-handler": 19, "../events": 20 }], 4: [function(i, o, a) { "use strict"; function n(e) { return e && e.__esModule ? e : { default: e } } function f(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function c(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(a, "__esModule", { value: !0 }); var s = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), v = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, l = i("../events"), t = n(l), d = i("../event-handler"), h = n(d), r = i("../utils/logger"), e = i("../errors"), u = function(a) { function i(e) { f(this, i), v(Object.getPrototypeOf(i.prototype), "constructor", this).call(this, e, t.default.MANIFEST_LOADED, t.default.LEVEL_LOADED, t.default.ERROR), this.ontick = this.tick.bind(this), this._manualLevel = this._autoLevelCapping = -1 } return c(i, a), s(i, [{ key: "destroy", value: function() { this.timer && clearInterval(this.timer), this._manualLevel = -1 } }, { key: "onManifestLoaded", value: function(l) { var s, a, n = [], i = [], u = {}, d = !1, h = !1, o = this.hls; if (l.levels.forEach(function(e) { e.videoCodec && (d = !0), e.audioCodec && (h = !0); var t = u[e.bitrate]; void 0 === t ? (u[e.bitrate] = n.length, e.url = [e.url], e.urlId = 0, n.push(e)) : n[t].url.push(e.url) }), d && h ? n.forEach(function(e) { e.videoCodec && i.push(e) }) : i = n, i = i.filter(function(e) { var i = function(e) { return MediaSource.isTypeSupported("audio/mp4;codecs=" + e) }, a = function(e) { return MediaSource.isTypeSupported("video/mp4;codecs=" + e) }, t = e.audioCodec, r = e.videoCodec; return (!t || i(t)) && (!r || a(r)) }), i.length) { for (s = i[0].bitrate, i.sort(function(e, t) { return e.bitrate - t.bitrate }), this._levels = i, a = 0; a < i.length; a++) if (i[a].bitrate === s) { this._firstLevel = a, r.logger.log("manifest loaded," + i.length + " level(s) found, first bitrate:" + s); break } o.trigger(t.default.MANIFEST_PARSED, { levels: this._levels, firstLevel: this._firstLevel, stats: l.stats }) } else o.trigger(t.default.ERROR, { type: e.ErrorTypes.NETWORK_ERROR, details: e.ErrorDetails.MANIFEST_PARSING_ERROR, fatal: !0, url: o.url, reason: "no compatible level found in manifest" }) } }, { key: "setLevelInternal", value: function(i) { if (i >= 0 && i < this._levels.length) { this.timer && (clearInterval(this.timer), this.timer = null), this._level = i, r.logger.log("switching to level " + i), this.hls.trigger(t.default.LEVEL_SWITCH, { level: i }); var a = this._levels[i]; if (void 0 === a.details || a.details.live === !0) { r.logger.log("(re)loading playlist for level " + i); var n = a.urlId; this.hls.trigger(t.default.LEVEL_LOADING, { url: a.url[n], level: i, id: n }) } } else this.hls.trigger(t.default.ERROR, { type: e.ErrorTypes.OTHER_ERROR, details: e.ErrorDetails.LEVEL_SWITCH_ERROR, level: i, fatal: !1, reason: "invalid level idx" }) } }, { key: "onError", value: function(a) { if (!a.fatal) { var n, t, i = a.details, s = this.hls; switch (i) { case e.ErrorDetails.FRAG_LOAD_ERROR: case e.ErrorDetails.FRAG_LOAD_TIMEOUT: case e.ErrorDetails.FRAG_LOOP_LOADING_ERROR: case e.ErrorDetails.KEY_LOAD_ERROR: case e.ErrorDetails.KEY_LOAD_TIMEOUT: n = a.frag.level; break; case e.ErrorDetails.LEVEL_LOAD_ERROR: case e.ErrorDetails.LEVEL_LOAD_TIMEOUT: n = a.level } if (void 0 !== n) if (t = this._levels[n], t.urlId < t.url.length - 1) t.urlId++, t.details = void 0, r.logger.warn("level controller," + i + " for level " + n + ": switching to redundant stream id " + t.urlId); else { var o = -1 === this._manualLevel && n; o ? (r.logger.warn("level controller," + i + ": emergency switch-down for next fragment"), s.abrController.nextAutoLevel = 0) : t && t.details && t.details.live ? r.logger.warn("level controller," + i + " on live stream, discard") : i !== e.ErrorDetails.FRAG_LOAD_ERROR && i !== e.ErrorDetails.FRAG_LOAD_TIMEOUT && (r.logger.error("cannot recover " + i + " error"), this._level = void 0, this.timer && (clearInterval(this.timer), this.timer = null), a.fatal = !0, s.trigger(event, a)) } } } }, { key: "onLevelLoaded", value: function(e) { e.details.live && !this.timer && (this.timer = setInterval(this.ontick, 1e3 * e.details.targetduration)), !e.details.live && this.timer && (clearInterval(this.timer), this.timer = null) } }, { key: "tick", value: function() { var e = this._level; if (void 0 !== e) { var r = this._levels[e], i = r.urlId; this.hls.trigger(t.default.LEVEL_LOADING, { url: r.url[i], level: e, id: i }) } } }, { key: "nextLoadLevel", value: function() { return -1 !== this._manualLevel ? this._manualLevel : this.hls.abrController.nextAutoLevel } }, { key: "levels", get: function() { return this._levels } }, { key: "level", get: function() { return this._level }, set: function(e) { (this._level !== e || void 0 === this._levels[e].details) && this.setLevelInternal(e) } }, { key: "manualLevel", get: function() { return this._manualLevel }, set: function(e) { this._manualLevel = e, -1 !== e && (this.level = e) } }, { key: "firstLevel", get: function() { return this._firstLevel }, set: function(e) { this._firstLevel = e } }, { key: "startLevel", get: function() { return void 0 === this._startLevel ? this._firstLevel : this._startLevel }, set: function(e) { this._startLevel = e } }]), i }(h.default); a.default = u, o.exports = a.default }, { "../errors": 18, "../event-handler": 19, "../events": 20, "../utils/logger": 31 }], 5: [function(a, h, s) { "use strict"; function n(e) { return e && e.__esModule ? e : { default: e } } function v(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function m(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(s, "__esModule", { value: !0 }); var c = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), b = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, E = a("../demux/demuxer"), u = n(E), d = a("../events"), r = n(d), f = a("../event-handler"), o = n(f), t = a("../utils/logger"), g = a("../utils/binary-search"), p = n(g), y = a("../helper/level-helper"), l = n(y), i = a("../errors"), e = { ERROR: -2, STARTING: -1, IDLE: 0, KEY_LOADING: 1, FRAG_LOADING: 2, FRAG_LOADING_WAITING_RETRY: 3, WAITING_LEVEL: 4, PARSING: 5, PARSED: 6, APPENDING: 7, BUFFER_FLUSHING: 8, ENDED: 9 }, _ = function(n) { function a(e) { v(this, a), b(Object.getPrototypeOf(a.prototype), "constructor", this).call(this, e, r.default.MEDIA_ATTACHING, r.default.MEDIA_DETACHING, r.default.MANIFEST_PARSED, r.default.LEVEL_LOADED, r.default.KEY_LOADED, r.default.FRAG_LOADED, r.default.FRAG_PARSING_INIT_SEGMENT, r.default.FRAG_PARSING_DATA, r.default.FRAG_PARSED, r.default.ERROR), this.config = e.config, this.audioCodecSwap = !1, this.ticks = 0, this.onsbue = this.onSBUpdateEnd.bind(this), this.onsbe = this.onSBUpdateError.bind(this), this.ontick = this.tick.bind(this) } return m(a, n), c(a, [{ key: "destroy", value: function() { this.stop(), o.default.prototype.destroy.call(this), this.state = e.IDLE } }, { key: "startLoad", value: function() { if (this.levels) { this.startInternal(); var r = this.media, i = this.lastCurrentTime; r && i ? (t.logger.log("seeking @ " + i), this.lastPaused || (t.logger.log("resuming video"), r.play()), this.state = e.IDLE) : (this.lastCurrentTime = 0, this.state = e.STARTING), this.nextLoadPosition = this.startPosition = this.lastCurrentTime, this.tick() } else t.logger.warn("cannot start loading as manifest not parsed yet") } }, { key: "startInternal", value: function() { var e = this.hls; this.stop(), this.demuxer = new u.default(e), this.timer = setInterval(this.ontick, 100), this.level = -1, this.fragLoadError = 0 } }, { key: "stop", value: function() { this.mp4segments = [], this.flushRange = [], this.bufferRange = [], this.stalled = !1; var e = this.fragCurrent; if (e && (e.loader && e.loader.abort(), this.fragCurrent = null), this.fragPrevious = null, this.sourceBuffer) { for (var r in this.sourceBuffer) { var t = this.sourceBuffer[r]; try { this.mediaSource.removeSourceBuffer(t), t.removeEventListener("updateend", this.onsbue), t.removeEventListener("error", this.onsbe) } catch (e) {} } this.sourceBuffer = null } this.timer && (clearInterval(this.timer), this.timer = null), this.demuxer && (this.demuxer.destroy(), this.demuxer = null) } }, { key: "tick", value: function() { this.ticks++, 1 === this.ticks && (this.doTick(), this.ticks > 1 && setTimeout(this.tick, 1), this.ticks = 0) } }, { key: "doTick", value: function() { var f, o, n, l = this.hls; switch (this.state) { case e.ERROR: break; case e.STARTING: this.startLevel = l.startLevel, -1 === this.startLevel && (this.startLevel = 0, this.fragBitrateTest = !0), this.level = l.nextLoadLevel = this.startLevel, this.state = e.WAITING_LEVEL, this.loadedmetadata = !1; break; case e.IDLE: if (!this.media) break; f = this.loadedmetadata ? this.media.currentTime : this.nextLoadPosition, o = this.startFragmentRequested === !1 ? this.startLevel : l.nextLoadLevel; var g, C = this.bufferInfo(f, this.config.maxBufferHole), G = C.len, d = C.end, c = this.fragPrevious; if (this.levels[o].hasOwnProperty("bitrate") ? (g = Math.max(8 * this.config.maxBufferSize / this.levels[o].bitrate, this.config.maxBufferLength), g = Math.min(g, this.config.maxMaxBufferLength)) : g = this.config.maxBufferLength, g > G) { if (l.nextLoadLevel = o, this.level = o, n = this.levels[o].details, "undefined" == typeof n || n.live && this.levelLastLoaded !== o) { this.state = e.WAITING_LEVEL; break } var u = n.fragments, v = u.length, _ = u[0].start, M = u[v - 1].start + u[v - 1].duration, a = void 0; if (n.live) { if (d < Math.max(_, M - this.config.liveMaxLatencyDurationCount * n.targetduration) && (this.seekAfterBuffered = _ + Math.max(0, n.totalduration - this.config.liveSyncDurationCount * n.targetduration), t.logger.log("buffer end: " + d + " is located too far from the end of live sliding playlist, media position will be reseted to: " + this.seekAfterBuffered.toFixed(3)), d = this.seekAfterBuffered), this.startFragmentRequested && !n.PTSKnown) { if (c) { var L = c.sn + 1; L >= n.startSN && L <= n.endSN && (a = u[L - n.startSN], t.logger.log("live playlist, switching playlist, load frag with next SN: " + a.sn)) } a || (a = u[Math.min(v - 1, Math.round(v / 2))], t.logger.log("live playlist, switching playlist, unknown, load middle frag : " + a.sn)) } } else _ > d && (a = u[0]); if (!a) { var E; if (E = M > d ? p.default.search(u, function(e) { return e.start + e.duration <= d ? 1 : e.start > d ? -1 : 0 }) : u[v - 1], E && (a = E, _ = E.start, c && a.level === c.level && a.sn === c.sn)) if (a.sn < n.endSN) a = u[a.sn + 1 - n.startSN], t.logger.log("SN just loaded, load next one: " + a.sn); else { if (!n.live) { var R = this.mediaSource; if (R) switch (R.readyState) { case "open": var b = this.sourceBuffer; b.audio && b.audio.updating || b.video && b.video.updating || (t.logger.log("all media data available, signal endOfStream() to MediaSource and stop loading fragment"), R.endOfStream(), this.state = e.ENDED); break; case "ended": t.logger.log("all media data available and mediaSource ended, stop loading fragment"), this.state = e.ENDED } } a = null } } if (a) if (null != a.decryptdata.uri && null == a.decryptdata.key) t.logger.log("Loading key for " + a.sn + " of [" + n.startSN + " ," + n.endSN + "],level " + o), this.state = e.KEY_LOADING, l.trigger(r.default.KEY_LOADING, { frag: a }); else { if (t.logger.log("Loading " + a.sn + " of [" + n.startSN + " ," + n.endSN + "],level " + o + ", currentTime:" + f + ",bufferEnd:" + d.toFixed(3)), a.autoLevel = l.autoLevelEnabled, this.levels.length > 1 && (a.expectedLen = Math.round(a.duration * this.levels[o].bitrate / 8), a.trequest = performance.now()), void 0 !== this.fragLoadIdx ? this.fragLoadIdx++ : this.fragLoadIdx = 0, a.loadCounter) { a.loadCounter++; var x = this.config.fragLoadingLoopThreshold; if (a.loadCounter > x && Math.abs(this.fragLoadIdx - a.loadIdx) < x) return void l.trigger(r.default.ERROR, { type: i.ErrorTypes.MEDIA_ERROR, details: i.ErrorDetails.FRAG_LOOP_LOADING_ERROR, fatal: !1, frag: a }) } else a.loadCounter = 1; a.loadIdx = this.fragLoadIdx, this.fragCurrent = a, this.startFragmentRequested = !0, l.trigger(r.default.FRAG_LOADING, { frag: a }), this.state = e.FRAG_LOADING } } break; case e.WAITING_LEVEL: o = this.levels[this.level], o && o.details && (this.state = e.IDLE); break; case e.FRAG_LOADING: var A = this.media, s = this.fragCurrent; if (A && (!A.paused || this.loadedmetadata === !1) && s.autoLevel && this.level && this.levels.length > 1) { var O = performance.now() - s.trequest; if (O > 500 * s.duration) { var N = 1e3 * s.loaded / O; s.expectedLen < s.loaded && (s.expectedLen = s.loaded), f = A.currentTime; var k = (s.expectedLen - s.loaded) / N, T = this.bufferInfo(f, this.config.maxBufferHole).end - f, D = s.duration * this.levels[l.nextLoadLevel].bitrate / (8 * N); T < 2 * s.duration && k > T && k > D && (t.logger.warn("loading too slow, abort fragment loading"), t.logger.log("fragLoadedDelay/bufferStarvationDelay/fragLevelNextLoadedDelay :" + k.toFixed(1) + "/" + T.toFixed(1) + "/" + D.toFixed(1)), s.loader.abort(), l.trigger(r.default.FRAG_LOAD_EMERGENCY_ABORTED, { frag: s }), this.state = e.IDLE) } } break; case e.FRAG_LOADING_WAITING_RETRY: var U = performance.now(), P = this.retryDate, I = this.media, F = I && I.seeking; (!P || U >= P || F) && (t.logger.log("mediaController: retryDate reached, switch back to IDLE state"), this.state = e.IDLE); break; case e.PARSING: break; case e.PARSED: case e.APPENDING: var h = this.sourceBuffer, m = this.mp4segments; if (h) { if (this.media.error) return t.logger.error("trying to append although a media error occured, switch to ERROR state"), void(this.state = e.ERROR); if (h.audio && h.audio.updating || h.video && h.video.updating); else if (m.length) { var S = m.shift(); try { h[S.type].appendBuffer(S.data), this.appendError = 0 } catch (a) { if (t.logger.error("error while trying to append buffer:" + a.message + ",try appending later"), m.unshift(S), 22 === a.code) return m = [], this.config.maxMaxBufferLength /= 2, t.logger.warn("reduce max buffer length to " + this.config.maxMaxBufferLength + "s and trigger a nextLevelSwitch to flush old buffer and fix QuotaExceededError"), void this.nextLevelSwitch(); this.appendError ? this.appendError++ : this.appendError = 1; var y = { type: i.ErrorTypes.MEDIA_ERROR, details: i.ErrorDetails.BUFFER_APPEND_ERROR, frag: this.fragCurrent }; if (this.appendError > this.config.appendErrorMaxRetry) return t.logger.log("fail " + this.config.appendErrorMaxRetry + " times to append segment in sourceBuffer"), y.fatal = !0, l.trigger(r.default.ERROR, y), void(this.state = e.ERROR); y.fatal = !1, l.trigger(r.default.ERROR, y) } this.state = e.APPENDING } } else this.state = e.IDLE; break; case e.BUFFER_FLUSHING: for (; this.flushRange.length;) { var w = this.flushRange[0]; if (!this.flushBuffer(w.start, w.end)) break; this.flushRange.shift() } 0 === this.flushRange.length && (this.immediateSwitch && this.immediateLevelSwitchEnd(), this.state = e.IDLE, this.fragPrevious = null); break; case e.ENDED: } this._checkBuffer(), this._checkFragmentChanged() } }, { key: "bufferInfo", value: function(i, a) { var e, n = this.media, t = n.buffered, r = []; for (e = 0; e < t.length; e++) r.push({ start: t.start(e), end: t.end(e) }); return this.bufferedInfo(r, i, a) } }, { key: "bufferedInfo", value: function(r, i, a) { var o, l, n, f, e, t = []; for (r.sort(function(e, t) { var r = e.start - t.start; return r ? r : t.end - e.end }), e = 0; e < r.length; e++) { var u = t.length; if (u) { var d = t[u - 1].end; r[e].start - d < a ? r[e].end > d && (t[u - 1].end = r[e].end) : t.push(r[e]) } else t.push(r[e]) } for (e = 0, o = 0, l = n = i; e < t.length; e++) { var s = t[e].start, h = t[e].end; if (i + a >= s && h > i) l = s, n = h + a, o = n - i; else if (s > i + a) { f = s; break } } return { len: o, start: l, end: n, nextStart: f } } }, { key: "getBufferRange", value: function(r) { var e, t; for (e = this.bufferRange.length - 1; e >= 0; e--) if (t = this.bufferRange[e], r >= t.start && r <= t.end) return t; return null } }, { key: "followingBufferRange", value: function(e) { return e ? this.getBufferRange(e.end + .5) : null } }, { key: "isBuffered", value: function(r) { for (var i = this.media, t = i.buffered, e = 0; e < t.length; e++) if (r >= t.start(e) && r <= t.end(e)) return !0; return !1 } }, { key: "_checkFragmentChanged", value: function() { var t, e, i = this.media; if (i && i.seeking === !1 && (e = i.currentTime, e > i.playbackRate * this.lastCurrentTime && (this.lastCurrentTime = e), this.isBuffered(e) ? t = this.getBufferRange(e) : this.isBuffered(e + .1) && (t = this.getBufferRange(e + .1)), t)) { var a = t.frag; a !== this.fragPlaying && (this.fragPlaying = a, this.hls.trigger(r.default.FRAG_CHANGED, { frag: a })) } } }, { key: "flushBuffer", value: function(d, l) { var r, e, o, n, i, a; if (this.flushBufferCounter++ < 2 * this.bufferRange.length && this.sourceBuffer) for (var u in this.sourceBuffer) { if (r = this.sourceBuffer[u], r.updating) return !1; for (e = 0; e < r.buffered.length; e++) if (o = r.buffered.start(e), n = r.buffered.end(e), -1 !== navigator.userAgent.toLowerCase().indexOf("firefox") && l === Number.POSITIVE_INFINITY ? (i = d, a = l) : (i = Math.max(o, d), a = Math.min(n, l)), Math.min(a, n) - i > .5) return t.logger.log("flush " + u + " [" + i + "," + a + "], of [" + o + "," + n + "], pos:" + this.media.currentTime), r.remove(i, a), !1 } else t.logger.warn("abort flushing too many retries"); var s, h = []; for (e = 0; e < this.bufferRange.length; e++) s = this.bufferRange[e], this.isBuffered((s.start + s.end) / 2) && h.push(s); return this.bufferRange = h, t.logger.log("buffer flushed"), !0 } }, { key: "immediateLevelSwitch", value: function() { t.logger.log("immediateLevelSwitch"), this.immediateSwitch || (this.immediateSwitch = !0, this.previouslyPaused = this.media.paused, this.media.pause()); var r = this.fragCurrent; r && r.loader && r.loader.abort(), this.fragCurrent = null, this.flushBufferCounter = 0, this.flushRange.push({ start: 0, end: Number.POSITIVE_INFINITY }), this.state = e.BUFFER_FLUSHING, this.fragLoadIdx += 2 * this.config.fragLoadingLoopThreshold, this.tick() } }, { key: "immediateLevelSwitchEnd", value: function() { this.immediateSwitch = !1, this.media.currentTime -= 1e-4, this.previouslyPaused || this.media.play() } }, { key: "nextLevelSwitch", value: function() { var r, i, t; if (i = this.getBufferRange(this.media.currentTime), i && this.flushRange.push({ start: 0, end: i.start - 1 }), this.media.paused) r = 0; else { var s = this.hls.nextLoadLevel, o = this.levels[s], n = this.fragLastKbps; r = n && this.fragCurrent ? this.fragCurrent.duration * o.bitrate / (1e3 * n) + 1 : 0 } if (t = this.getBufferRange(this.media.currentTime + r), t && (t = this.followingBufferRange(t))) { this.flushRange.push({ start: t.start, end: Number.POSITIVE_INFINITY }); var a = this.fragCurrent; a && a.loader && a.loader.abort(), this.fragCurrent = null } this.flushRange.length && (this.flushBufferCounter = 0, this.state = e.BUFFER_FLUSHING, this.fragLoadIdx += 2 * this.config.fragLoadingLoopThreshold, this.tick()) } }, { key: "onMediaAttaching", value: function(t) { var r = this.media = t.media, e = this.mediaSource = new MediaSource; this.onmso = this.onMediaSourceOpen.bind(this), this.onmse = this.onMediaSourceEnded.bind(this), this.onmsc = this.onMediaSourceClose.bind(this), e.addEventListener("sourceopen", this.onmso), e.addEventListener("sourceended", this.onmse), e.addEventListener("sourceclose", this.onmsc), r.src = URL.createObjectURL(e) } }, { key: "onMediaDetaching", value: function() { var e = this.media; e && e.ended && (t.logger.log("MSE detaching and video ended, reset startPosition"), this.startPosition = this.lastCurrentTime = 0); var a = this.levels; a && a.forEach(function(e) { e.details && e.details.fragments.forEach(function(e) { e.loadCounter = void 0 }) }); var i = this.mediaSource; if (i) { if ("open" === i.readyState) try { i.endOfStream() } catch (e) { t.logger.warn("onMediaDetaching:" + e.message + " while calling endOfStream") } i.removeEventListener("sourceopen", this.onmso), i.removeEventListener("sourceended", this.onmse), i.removeEventListener("sourceclose", this.onmsc), this.media.src = "", this.mediaSource = null, e && (e.removeEventListener("seeking", this.onvseeking), e.removeEventListener("seeked", this.onvseeked), e.removeEventListener("loadedmetadata", this.onvmetadata), e.removeEventListener("ended", this.onvended), this.onvseeking = this.onvseeked = this.onvmetadata = null), this.media = null, this.loadedmetadata = !1, this.stop() } this.onmso = this.onmse = this.onmsc = null, this.hls.trigger(r.default.MEDIA_DETACHED) } }, { key: "onMediaSeeking", value: function() { if (this.state === e.FRAG_LOADING) { if (0 === this.bufferInfo(this.media.currentTime, this.config.maxBufferHole).len) { t.logger.log("seeking outside of buffer while fragment load in progress, cancel fragment load"); var r = this.fragCurrent; r && (r.loader && r.loader.abort(), this.fragCurrent = null), this.fragPrevious = null, this.state = e.IDLE } } else this.state === e.ENDED && (this.state = e.IDLE); this.media && (this.lastCurrentTime = this.media.currentTime), void 0 !== this.fragLoadIdx && (this.fragLoadIdx += 2 * this.config.fragLoadingLoopThreshold), this.tick() } }, { key: "onMediaSeeked", value: function() { this.tick() } }, { key: "onMediaMetadata", value: function() { var e = this.media, r = e.currentTime; r || r === this.startPosition || (t.logger.log("onMediaMetadata: adjust currentTime to startPosition"), e.currentTime = this.startPosition), this.loadedmetadata = !0, this.tick() } }, { key: "onMediaEnded", value: function() { t.logger.log("media ended"), this.startPosition = this.lastCurrentTime = 0 } }, { key: "onManifestParsed", value: function(r) { var e, i = !1, a = !1; r.levels.forEach(function(t) { e = t.codecs, e && (-1 !== e.indexOf("mp4a.40.2") && (i = !0), -1 !== e.indexOf("mp4a.40.5") && (a = !0)) }), this.audiocodecswitch = i && a, this.audiocodecswitch && t.logger.log("both AAC/HE-AAC audio found in levels; declaring audio codec as HE-AAC"), this.levels = r.levels, this.startLevelLoaded = !1, this.startFragmentRequested = !1, this.media && this.config.autoStartLoad && this.startLoad() } }, { key: "onLevelLoaded", value: function(n) { var i = n.details, a = n.level, s = this.levels[a], o = i.totalduration; if (t.logger.log("level " + a + " loaded [" + i.startSN + "," + i.endSN + "],duration:" + o), this.levelLastLoaded = a, i.live) { var u = s.details; u ? (l.default.mergeDetails(u, i), i.PTSKnown ? t.logger.log("live playlist sliding:" + i.fragments[0].start.toFixed(3)) : t.logger.log("live playlist - outdated PTS, unknown sliding")) : (i.PTSKnown = !1, t.logger.log("live playlist - first load, unknown sliding")) } else i.PTSKnown = !1; s.details = i, this.hls.trigger(r.default.LEVEL_UPDATED, { details: i, level: a }), this.startLevelLoaded === !1 && (i.live && (this.startPosition = Math.max(0, o - this.config.liveSyncDurationCount * i.targetduration)), this.nextLoadPosition = this.startPosition, this.startLevelLoaded = !0), this.state === e.WAITING_LEVEL && (this.state = e.IDLE), this.tick() } }, { key: "onKeyLoaded", value: function() { this.state === e.KEY_LOADING && (this.state = e.IDLE, this.tick()) } }, { key: "onFragLoaded", value: function(a) { var i = this.fragCurrent; if (this.state === e.FRAG_LOADING && i && a.frag.level === i.level && a.frag.sn === i.sn) if (this.fragBitrateTest === !0) this.state = e.IDLE, this.fragBitrateTest = !1, a.stats.tparsed = a.stats.tbuffered = performance.now(), this.hls.trigger(r.default.FRAG_BUFFERED, { stats: a.stats, frag: i }); else { this.state = e.PARSING, this.stats = a.stats; var s = this.levels[this.level], o = s.details, d = o.totalduration, h = i.start, l = i.level, u = i.sn, n = s.audioCodec || this.config.defaultAudioCodec; this.audioCodecSwap && (t.logger.log("swapping playlist audio codec"), void 0 === n && (n = this.lastAudioCodec), n = -1 !== n.indexOf("mp4a.40.5") ? "mp4a.40.2" : "mp4a.40.5"), t.logger.log("Demuxing " + u + " of [" + o.startSN + " ," + o.endSN + "],level " + l), this.demuxer.push(a.payload, n, s.videoCodec, h, i.cc, l, u, d, i.decryptdata) } this.fragLoadError = 0 } }, { key: "onFragParsingInitSegment", value: function(i) { if (this.state === e.PARSING) { var n, r = this.levels[this.level].audioCodec, a = this.levels[this.level].videoCodec; this.lastAudioCodec = i.audioCodec, r && this.audioCodecSwap && (t.logger.log("swapping playlist audio codec"), r = -1 !== r.indexOf("mp4a.40.5") ? "mp4a.40.2" : "mp4a.40.5"), t.logger.log("playlist_level/init_segment codecs: video => " + a + "/" + i.videoCodec + "; audio => " + r + "/" + i.audioCodec), (void 0 === r || void 0 === i.audioCodec) && (r = i.audioCodec), (void 0 === a || void 0 === i.videoCodec) && (a = i.videoCodec); var s = navigator.userAgent.toLowerCase(); this.audiocodecswitch && 1 !== i.audioChannelCount && -1 === s.indexOf("android") && -1 === s.indexOf("firefox") && (r = "mp4a.40.5"), this.sourceBuffer || (this.sourceBuffer = {}, t.logger.log("selected A/V codecs for sourceBuffers:" + r + "," + a), r && (n = this.sourceBuffer.audio = this.mediaSource.addSourceBuffer("audio/mp4;codecs=" + r), n.addEventListener("updateend", this.onsbue), n.addEventListener("error", this.onsbe)), a && (n = this.sourceBuffer.video = this.mediaSource.addSourceBuffer("video/mp4;codecs=" + a), n.addEventListener("updateend", this.onsbue), n.addEventListener("error", this.onsbe))), r && this.mp4segments.push({ type: "audio", data: i.audioMoov }), a && this.mp4segments.push({ type: "video", data: i.videoMoov }), this.tick() } } }, { key: "onFragParsingData", value: function(i) { if (this.state === e.PARSING) { this.tparse2 = Date.now(); var a = this.levels[this.level], n = this.fragCurrent; t.logger.log("parsed " + i.type + ",PTS:[" + i.startPTS.toFixed(3) + "," + i.endPTS.toFixed(3) + "],DTS:[" + i.startDTS.toFixed(3) + "/" + i.endDTS.toFixed(3) + "],nb:" + i.nb); var s = l.default.updateFragPTS(a.details, n.sn, i.startPTS, i.endPTS); this.hls.trigger(r.default.LEVEL_PTS_UPDATED, { details: a.details, level: this.level, drift: s }), this.mp4segments.push({ type: i.type, data: i.moof }), this.mp4segments.push({ type: i.type, data: i.mdat }), this.nextLoadPosition = i.endPTS, this.bufferRange.push({ type: i.type, start: i.startPTS, end: i.endPTS, frag: n }), this.tick() } else t.logger.warn("not in PARSING state, ignoring FRAG_PARSING_DATA event") } }, { key: "onFragParsed", value: function() { if (this.state === e.PARSING) { this.stats.tparsed = performance.now(); var t = this.sourceBuffer, r = t.audio && t.audio.updating || t.video && t.video.updating; 0 !== this.mp4segments.length || r ? this.state = e.PARSED : this.state = e.IDLE, this.tick() } } }, { key: "onError", value: function(a) { switch (a.details) { case i.ErrorDetails.FRAG_LOAD_ERROR: case i.ErrorDetails.FRAG_LOAD_TIMEOUT: if (!a.fatal) { var n = this.fragLoadError; if (n ? n++ : n = 1, n <= this.config.fragLoadingMaxRetry) { this.fragLoadError = n, a.frag.loadCounter = 0; var s = Math.min(Math.pow(2, n - 1) * this.config.fragLoadingRetryDelay, 64e3); t.logger.warn("mediaController: frag loading failed, retry in " + s + " ms"), this.retryDate = performance.now() + s, this.state = e.FRAG_LOADING_WAITING_RETRY } else t.logger.error("mediaController: " + a.details + " reaches max retry, redispatch as fatal ..."), a.fatal = !0, this.hls.trigger(r.default.ERROR, a), this.state = e.ERROR } break; case i.ErrorDetails.FRAG_LOOP_LOADING_ERROR: case i.ErrorDetails.LEVEL_LOAD_ERROR: case i.ErrorDetails.LEVEL_LOAD_TIMEOUT: case i.ErrorDetails.KEY_LOAD_ERROR: case i.ErrorDetails.KEY_LOAD_TIMEOUT: t.logger.warn("mediaController: " + a.details + " while loading frag,switch to " + (a.fatal ? "ERROR" : "IDLE") + " state ..."), this.state = a.fatal ? e.ERROR : e.IDLE } } }, { key: "onSBUpdateEnd", value: function() { if (this.state === e.APPENDING && 0 === this.mp4segments.length) { var a = this.fragCurrent, i = this.stats; a && (this.fragPrevious = a, i.tbuffered = performance.now(), this.fragLastKbps = Math.round(8 * i.length / (i.tbuffered - i.tfirst)), this.hls.trigger(r.default.FRAG_BUFFERED, { stats: i, frag: a }), t.logger.log("media buffered : " + this.timeRangesToString(this.media.buffered)), this.state = e.IDLE) } this.tick() } }, { key: "_checkBuffer", value: function() { var e = this.media; if (e) { var u = e.readyState; if (u) { var s = this.seekAfterBuffered; if (s) e.duration >= s && (e.currentTime = s, this.seekAfterBuffered = void 0); else { var a = e.currentTime, o = this.bufferInfo(a, 0), f = !(e.paused || e.ended || e.seeking || 3 > u), l = .2, d = a > e.playbackRate * this.lastCurrentTime; if (this.stalled && d && (this.stalled = !1), o.len <= l && (d || !f ? l = 0 : (t.logger.log("playback seems stuck @" + a), this.stalled || (this.hls.trigger(r.default.ERROR, { type: i.ErrorTypes.MEDIA_ERROR, details: i.ErrorDetails.BUFFER_STALLED_ERROR, fatal: !1 }), this.stalled = !0)), o.len <= l)) { var n = o.nextStart, h = n - a; n && h < this.config.maxSeekHole && h > .005 && !e.seeking && (t.logger.log("adjust currentTime from " + a + " to " + n), e.currentTime = n) } } } } } }, { key: "swapAudioCodec", value: function() { this.audioCodecSwap = !this.audioCodecSwap } }, { key: "onSBUpdateError", value: function(a) { t.logger.error("sourceBuffer error:" + a), this.state = e.ERROR, this.hls.trigger(r.default.ERROR, { type: i.ErrorTypes.MEDIA_ERROR, details: i.ErrorDetails.BUFFER_APPENDING_ERROR, fatal: !1, frag: this.fragCurrent }) } }, { key: "timeRangesToString", value: function(t) { for (var r = "", i = t.length, e = 0; i > e; e++) r += "[" + t.start(e) + "," + t.end(e) + "]"; return r } }, { key: "onMediaSourceOpen", value: function() { t.logger.log("media source opened"), this.hls.trigger(r.default.MEDIA_ATTACHED), this.onvseeking = this.onMediaSeeking.bind(this), this.onvseeked = this.onMediaSeeked.bind(this), this.onvmetadata = this.onMediaMetadata.bind(this), this.onvended = this.onMediaEnded.bind(this); var e = this.media; e.addEventListener("seeking", this.onvseeking), e.addEventListener("seeked", this.onvseeked), e.addEventListener("loadedmetadata", this.onvmetadata), e.addEventListener("ended", this.onvended), this.levels && this.config.autoStartLoad && this.startLoad(), this.mediaSource.removeEventListener("sourceopen", this.onmso) } }, { key: "onMediaSourceClose", value: function() { t.logger.log("media source closed") } }, { key: "onMediaSourceEnded", value: function() { t.logger.log("media source ended") } }, { key: "currentLevel", get: function() { if (this.media) { var e = this.getBufferRange(this.media.currentTime); if (e) return e.frag.level } return -1 } }, { key: "nextBufferRange", get: function() { return this.media ? this.followingBufferRange(this.getBufferRange(this.media.currentTime)) : null } }, { key: "nextLevel", get: function() { var e = this.nextBufferRange; return e ? e.frag.level : -1 } }]), a }(o.default); s.default = _, h.exports = s.default }, { "../demux/demuxer": 14, "../errors": 18, "../event-handler": 19, "../events": 20, "../helper/level-helper": 21, "../utils/binary-search": 29, "../utils/logger": 31 }], 6: [function(t, o, r) { "use strict"; function i(e) { return e && e.__esModule ? e : { default: e } } function h(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function n(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(r, "__esModule", { value: !0 }); var s = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), v = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, l = t("../events"), e = i(l), d = t("../event-handler"), a = i(d), f = t("../utils/cea-708-interpreter"), c = i(f), u = function(r) { function t(r) { h(this, t), v(Object.getPrototypeOf(t.prototype), "constructor", this).call(this, r, e.default.MEDIA_ATTACHING, e.default.MEDIA_DETACHING, e.default.FRAG_PARSING_USERDATA, e.default.MANIFEST_LOADING, e.default.FRAG_LOADED), this.hls = r, this.config = r.config, this.config.enableCEA708Captions && (this.cea708Interpreter = new c.default) } return n(t, r), s(t, [{ key: "destroy", value: function() { a.default.prototype.destroy.call(this) } }, { key: "onMediaAttaching", value: function(e) { var t = this.media = e.media; this.cea708Interpreter.attach(t) } }, { key: "onMediaDetaching", value: function() { this.cea708Interpreter.detach() } }, { key: "onManifestLoading", value: function() { this.lastPts = Number.POSITIVE_INFINITY } }, { key: "onFragLoaded", value: function(t) { var e = t.frag.start; e <= this.lastPts && this.cea708Interpreter.clear(), this.lastPts = e } }, { key: "onFragParsingUserdata", value: function(t) { for (var e = 0; e < t.samples.length; e++) this.cea708Interpreter.push(t.samples[e].pts, t.samples[e].bytes) } }]), t }(a.default); r.default = u, o.exports = r.default }, { "../event-handler": 19, "../events": 20, "../utils/cea-708-interpreter": 30 }], 7: [function(n, t, e) { "use strict"; function r(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var i = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), a = function() { function e(h) { r(this, e), this._tables = [ [ [], [], [], [], [] ], [ [], [], [], [], [] ] ], this._precompute(); var i, s, t, o, l, n = this._tables[0][4], u = this._tables[1], a = h.length, d = 1; if (4 !== a && 6 !== a && 8 !== a) throw new Error("Invalid aes key size=" + a); for (o = h.slice(0), l = [], this._key = [o, l], i = a; 4 * a + 28 > i; i++) t = o[i - 1], (i % a === 0 || 8 === a && i % a === 4) && (t = n[t >>> 24] << 24 ^ n[t >> 16 & 255] << 16 ^ n[t >> 8 & 255] << 8 ^ n[255 & t], i % a === 0 && (t = t << 8 ^ t >>> 24 ^ d << 24, d = d << 1 ^ 283 * (d >> 7))), o[i] = o[i - a] ^ t; for (s = 0; i; s++, i--) t = o[3 & s ? i : i - 4], 4 >= i || 4 > s ? l[s] = t : l[s] = u[0][n[t >>> 24]] ^ u[1][n[t >> 16 & 255]] ^ u[2][n[t >> 8 & 255]] ^ u[3][n[255 & t]] } return i(e, [{ key: "_precompute", value: function() { var e, i, r, u, h, d, t, s, l, n = this._tables[0], o = this._tables[1], f = n[4], v = o[4], a = [], c = []; for (e = 0; 256 > e; e++) c[(a[e] = e << 1 ^ 283 * (e >> 7)) ^ e] = e; for (i = r = 0; !f[i]; i ^= u || 1, r = c[r] || 1) for (t = r ^ r << 1 ^ r << 2 ^ r << 3 ^ r << 4, t = t >> 8 ^ 255 & t ^ 99, f[i] = t, v[t] = i, d = a[h = a[u = a[i]]], l = 16843009 * d ^ 65537 * h ^ 257 * u ^ 16843008 * i, s = 257 * a[t] ^ 16843008 * t, e = 0; 4 > e; e++) n[e][i] = s = s << 24 ^ s >>> 8, o[e][t] = l = l << 24 ^ l >>> 8; for (e = 0; 5 > e; e++) n[e] = n[e].slice(0), o[e] = o[e].slice(0) } }, { key: "decrypt", value: function(R, p, _, E, b, m) { var f, g, v, n, e = this._key[1], t = R ^ e[0], i = E ^ e[1], a = _ ^ e[2], r = p ^ e[3], y = e.length / 4 - 2, s = 4, o = this._tables[1], h = o[0], d = o[1], u = o[2], l = o[3], c = o[4]; for (n = 0; y > n; n++) f = h[t >>> 24] ^ d[i >> 16 & 255] ^ u[a >> 8 & 255] ^ l[255 & r] ^ e[s], g = h[i >>> 24] ^ d[a >> 16 & 255] ^ u[r >> 8 & 255] ^ l[255 & t] ^ e[s + 1], v = h[a >>> 24] ^ d[r >> 16 & 255] ^ u[t >> 8 & 255] ^ l[255 & i] ^ e[s + 2], r = h[r >>> 24] ^ d[t >> 16 & 255] ^ u[i >> 8 & 255] ^ l[255 & a] ^ e[s + 3], s += 4, t = f, i = g, a = v; for (n = 0; 4 > n; n++) b[(3 & -n) + m] = c[t >>> 24] << 24 ^ c[i >> 16 & 255] << 16 ^ c[a >> 8 & 255] << 8 ^ c[255 & r] ^ e[s++], f = t, t = i, i = a, a = r, r = f } }]), e }(); e.default = a, t.exports = e.default }, {}], 8: [function(t, r, e) { "use strict"; function i(e) { return e && e.__esModule ? e : { default: e } } function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), s = t("./aes"), o = i(s), l = function() { function e(t, r) { a(this, e), this.key = t, this.iv = r } return n(e, [{ key: "ntoh", value: function(e) { return e << 24 | (65280 & e) << 8 | (16711680 & e) >> 8 | e >>> 24 } }, { key: "doDecrypt", value: function(i, g, a) { var u, f, s, h, l, c, d, n, e, r = new Int32Array(i.buffer, i.byteOffset, i.byteLength >> 2), p = new o.default(Array.prototype.slice.call(g)), v = new Uint8Array(i.byteLength), t = new Int32Array(v.buffer); for (u = ~~a[0], f = ~~a[1], s = ~~a[2], h = ~~a[3], e = 0; e < r.length; e += 4) l = ~~this.ntoh(r[e]), c = ~~this.ntoh(r[e + 1]), d = ~~this.ntoh(r[e + 2]), n = ~~this.ntoh(r[e + 3]), p.decrypt(l, c, d, n, t, e), t[e] = this.ntoh(t[e] ^ u), t[e + 1] = this.ntoh(t[e + 1] ^ f), t[e + 2] = this.ntoh(t[e + 2] ^ s), t[e + 3] = this.ntoh(t[e + 3] ^ h), u = l, f = c, s = d, h = n; return v } }, { key: "localDecrypt", value: function(e, t, r, i) { var a = this.doDecrypt(e, t, r); i.set(a, e.byteOffset) } }, { key: "decrypt", value: function(n) { var r = 32e3, t = new Int32Array(n), i = new Uint8Array(n.byteLength), e = 0, s = this.key, a = this.iv; for (this.localDecrypt(t.subarray(e, e + r), s, a, i), e = r; e < t.length; e += r) a = new Uint32Array([this.ntoh(t[e - 4]), this.ntoh(t[e - 3]), this.ntoh(t[e - 2]), this.ntoh(t[e - 1])]), this.localDecrypt(t.subarray(e, e + r), s, a, i); return i } }]), e }(); e.default = l, r.exports = e.default }, { "./aes": 7 }], 9: [function(t, n, r) { "use strict"; function u(e) { return e && e.__esModule ? e : { default: e } } function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(r, "__esModule", { value: !0 }); var d = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), s = t("./aes128-decrypter"), o = u(s), i = t("../errors"), e = t("../utils/logger"), l = function() { function t(r) { a(this, t), this.hls = r; try { var e = window ? window.crypto : crypto; this.subtle = e.subtle || e.webkitSubtle, this.disableWebCrypto = !this.subtle } catch (e) { this.disableWebCrypto = !0 } } return d(t, [{ key: "destroy", value: function() {} }, { key: "decrypt", value: function(e, t, r, i) { this.disableWebCrypto && this.hls.config.enableSoftwareAES ? this.decryptBySoftware(e, t, r, i) : this.decryptByWebCrypto(e, t, r, i) } }, { key: "decryptByWebCrypto", value: function(t, r, i, a) { var n = this; e.logger.log("decrypting by WebCrypto API"), this.subtle.importKey("raw", r, { name: "AES-CBC", length: 128 }, !1, ["decrypt"]).then(function(e) { n.subtle.decrypt({ name: "AES-CBC", iv: i.buffer }, e, t).then(a).catch(function(e) { n.onWebCryptoError(e, t, r, i, a) }) }).catch(function(e) { n.onWebCryptoError(e, t, r, i, a) }) } }, { key: "decryptBySoftware", value: function(r, i, a, n) { e.logger.log("decrypting by JavaScript Implementation"); var t = new DataView(i.buffer), s = new Uint32Array([t.getUint32(0), t.getUint32(4), t.getUint32(8), t.getUint32(12)]); t = new DataView(a.buffer); var l = new Uint32Array([t.getUint32(0), t.getUint32(4), t.getUint32(8), t.getUint32(12)]), u = new o.default(s, l); n(u.decrypt(r).buffer) } }, { key: "onWebCryptoError", value: function(t, r, a, n, s) { this.hls.config.enableSoftwareAES ? (e.logger.log("disabling to use WebCrypto API"), this.disableWebCrypto = !0, this.decryptBySoftware(r, a, n, s)) : (e.logger.error("decrypting error : " + t.message), this.hls.trigger(Event.ERROR, { type: i.ErrorTypes.MEDIA_ERROR, details: i.ErrorDetails.FRAG_DECRYPT_ERROR, fatal: !0, reason: t.message })) } }]), t }(); r.default = l, n.exports = r.default }, { "../errors": 18, "../utils/logger": 31, "./aes128-decrypter": 8 }], 10: [function(e, s, t) { "use strict"; function r(e) { return e && e.__esModule ? e : { default: e } } function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(t, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), h = e("./adts"), o = r(h), l = e("../utils/logger"), u = e("../demux/id3"), i = r(u), d = function() { function e(t, r) { a(this, e), this.observer = t, this.remuxerClass = r, this.remuxer = new this.remuxerClass(t), this._aacTrack = { type: "audio", id: -1, sequenceNumber: 0, samples: [], len: 0 } } return n(e, [{ key: "push", value: function(t, p, R, m, _, E, b, y) { var a, n, g, c, e, s, h, u, v, r = this._aacTrack, d = new i.default(t), f = 90 * d.timeStamp; for (e = d.length, u = t.length; u - 1 > e && (255 !== t[e] || 240 !== (240 & t[e + 1])); e++); for (r.audiosamplerate || (a = o.default.getAudioConfig(this.observer, t, e, p), r.config = a.config, r.audiosamplerate = a.samplerate, r.channelCount = a.channelCount, r.codec = a.codec, r.timescale = a.samplerate, r.duration = a.samplerate * y, l.logger.log("parsed codec:" + r.codec + ",rate:" + a.samplerate + ",nb channel:" + a.channelCount)), c = 0, g = 9216e4 / r.audiosamplerate; u > e + 5 && (s = 1 & t[e + 1] ? 7 : 9, n = (3 & t[e + 3]) << 11 | t[e + 4] << 3 | (224 & t[e + 5]) >>> 5, n -= s, n > 0 && u >= e + s + n);) for (h = f + c * g, v = { unit: t.subarray(e + s, e + s + n), pts: h, dts: h }, r.samples.push(v), r.len += n, e += n + s, c++; u - 1 > e && (255 !== t[e] || 240 !== (240 & t[e + 1])); e++); this.remuxer.remux(this._aacTrack, { samples: [] }, { samples: [{ pts: f, dts: f, unit: d.payload }] }, m) } }, { key: "destroy", value: function() {} }], [{ key: "probe", value: function(t) { var e, r, a = new i.default(t); if (a.hasTimeStamp) for (e = a.length, r = t.length; r - 1 > e; e++) if (255 === t[e] && 240 === (240 & t[e + 1])) return !0; return !1 } }]), e }(); t.default = d, s.exports = t.default }, { "../demux/id3": 16, "../utils/logger": 31, "./adts": 11 }], 11: [function(t, i, e) { "use strict"; function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), s = t("../utils/logger"), r = t("../errors"), o = function() { function e() { a(this, e) } return n(e, null, [{ key: "getAudioConfig", value: function(f, u, l, a) { var i, e, n, o, t, h = navigator.userAgent.toLowerCase(), d = [96e3, 88200, 64e3, 48e3, 44100, 32e3, 24e3, 22050, 16e3, 12e3, 11025, 8e3, 7350]; return i = ((192 & u[l + 2]) >>> 6) + 1, e = (60 & u[l + 2]) >>> 2, e > d.length - 1 ? void f.trigger(Event.ERROR, { type: r.ErrorTypes.MEDIA_ERROR, details: r.ErrorDetails.FRAG_PARSING_ERROR, fatal: !0, reason: "invalid ADTS sampling index:" + e }) : (o = (1 & u[l + 2]) << 2, o |= (192 & u[l + 3]) >>> 6, s.logger.log("manifest codec:" + a + ",ADTS data:type:" + i + ",sampleingIndex:" + e + "[" + d[e] + "Hz],channelConfig:" + o), -1 !== h.indexOf("firefox") ? e >= 6 ? (i = 5, t = new Array(4), n = e - 3) : (i = 2, t = new Array(2), n = e) : -1 !== h.indexOf("android") ? (i = 2, t = new Array(2), n = e) : (i = 5, t = new Array(4), a && (-1 !== a.indexOf("mp4a.40.29") || -1 !== a.indexOf("mp4a.40.5")) || !a && e >= 6 ? n = e - 3 : ((a && -1 !== a.indexOf("mp4a.40.2") && (e >= 6 || 1 === o) || !a && 1 === o) && (i = 2, t = new Array(2)), n = e)), t[0] = i << 3, t[0] |= (14 & e) >> 1, t[1] |= (1 & e) << 7, t[1] |= o << 3, 5 === i && (t[1] |= (14 & n) >> 1, t[2] = (1 & n) << 7, t[2] |= 8, t[3] = 0), { config: t, samplerate: d[e], channelCount: o, codec: "mp4a.40." + i }) } }]), e }(); e.default = o, i.exports = e.default }, { "../errors": 18, "../utils/logger": 31 }], 12: [function(e, o, t) { "use strict"; function r(e) { return e && e.__esModule ? e : { default: e } } function d(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(t, "__esModule", { value: !0 }); var f = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), s = e("../events"), c = r(s), i = e("../errors"), u = e("../demux/aacdemuxer"), a = r(u), h = e("../demux/tsdemuxer"), n = r(h), l = function() { function e(t, r) { d(this, e), this.hls = t, this.remuxer = r } return f(e, [{ key: "destroy", value: function() { var e = this.demuxer; e && e.destroy() } }, { key: "push", value: function(t, r, s, o, l, u, d, h) { var e = this.demuxer; if (!e) if (n.default.probe(t)) e = this.demuxer = new n.default(this.hls, this.remuxer); else { if (!a.default.probe(t)) return void this.hls.trigger(c.default.ERROR, { type: i.ErrorTypes.MEDIA_ERROR, details: i.ErrorDetails.FRAG_PARSING_ERROR, fatal: !0, reason: "no demux matching with content found" }); e = this.demuxer = new a.default(this.hls, this.remuxer) } e.push(t, r, s, o, l, u, d, h) } }]), e }(); t.default = l, o.exports = t.default }, { "../demux/aacdemuxer": 10, "../demux/tsdemuxer": 17, "../errors": 18, "../events": 20 }], 13: [function(t, s, i) { "use strict"; function r(e) { return e && e.__esModule ? e : { default: e } } Object.defineProperty(i, "__esModule", { value: !0 }); var a = t("../demux/demuxer-inline"), n = r(a), f = t("../events"), e = r(f), l = t("events"), u = r(l), d = t("../remux/mp4-remuxer"), h = r(d), o = function(r) { var t = new u.default; t.trigger = function(i) { for (var r = arguments.length, a = Array(r > 1 ? r - 1 : 0), e = 1; r > e; e++) a[e - 1] = arguments[e]; t.emit.apply(t, [i, i].concat(a)) }, t.off = function(a) { for (var r = arguments.length, i = Array(r > 1 ? r - 1 : 0), e = 1; r > e; e++) i[e - 1] = arguments[e]; t.removeListener.apply(t, [a].concat(i)) }, r.addEventListener("message", function(i) { switch (i.data.cmd) { case "init": r.demuxer = new n.default(t, h.default); break; case "demux": var e = i.data; r.demuxer.push(new Uint8Array(e.data), e.audioCodec, e.videoCodec, e.timeOffset, e.cc, e.level, e.sn, e.duration) } }), t.on(e.default.FRAG_PARSING_INIT_SEGMENT, function(a, t) { var e = { event: a }, i = []; t.audioCodec && (e.audioCodec = t.audioCodec, e.audioMoov = t.audioMoov.buffer, e.audioChannelCount = t.audioChannelCount, i.push(e.audioMoov)), t.videoCodec && (e.videoCodec = t.videoCodec, e.videoMoov = t.videoMoov.buffer, e.videoWidth = t.videoWidth, e.videoHeight = t.videoHeight, i.push(e.videoMoov)), r.postMessage(e, i) }), t.on(e.default.FRAG_PARSING_DATA, function(i, e) { var t = { event: i, type: e.type, startPTS: e.startPTS, endPTS: e.endPTS, startDTS: e.startDTS, endDTS: e.endDTS, moof: e.moof.buffer, mdat: e.mdat.buffer, nb: e.nb }; r.postMessage(t, [t.moof, t.mdat]) }), t.on(e.default.FRAG_PARSED, function(e) { r.postMessage({ event: e }) }), t.on(e.default.ERROR, function(e, t) { r.postMessage({ event: e, data: t }) }), t.on(e.default.FRAG_PARSING_METADATA, function(e, t) { var i = { event: e, samples: t.samples }; r.postMessage(i) }), t.on(e.default.FRAG_PARSING_USERDATA, function(e, t) { var i = { event: e, samples: t.samples }; r.postMessage(i) }) }; i.default = o, s.exports = i.default }, { "../demux/demuxer-inline": 12, "../events": 20, "../remux/mp4-remuxer": 27, events: 1 }], 14: [function(t, u, i) { "use strict"; function r(e) { return e && e.__esModule ? e : { default: e } } function v(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(i, "__esModule", { value: !0 }); var o = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), l = t("../events"), e = r(l), f = t("../demux/demuxer-inline"), s = r(f), d = t("../demux/demuxer-worker"), h = r(d), n = t("../utils/logger"), c = t("../remux/mp4-remuxer"), a = r(c), g = t("../crypt/decrypter"), p = r(g), y = function() { function r(e) { if (v(this, r), this.hls = e, e.config.enableWorker && "undefined" != typeof Worker) { n.logger.log("demuxing in webworker"); try { var i = t("webworkify"); this.w = i(h.default), this.onwmsg = this.onWorkerMessage.bind(this), this.w.addEventListener("message", this.onwmsg), this.w.postMessage({ cmd: "init" }) } catch (t) { n.logger.error("error while initializing DemuxerWorker, fallback on DemuxerInline"), this.demuxer = new s.default(e, a.default) } } else this.demuxer = new s.default(e, a.default); this.demuxInitialized = !0 } return o(r, [{ key: "destroy", value: function() { this.w ? (this.w.removeEventListener("message", this.onwmsg), this.w.terminate(), this.w = null) : (this.demuxer.destroy(), this.demuxer = null), this.decrypter && (this.decrypter.destroy(), this.decrypter = null) } }, { key: "pushDecrypted", value: function(e, t, r, i, a, n, s, o) { this.w ? this.w.postMessage({ cmd: "demux", data: e, audioCodec: t, videoCodec: r, timeOffset: i, cc: a, level: n, sn: s, duration: o }, [e]) : this.demuxer.push(new Uint8Array(e), t, r, i, a, n, s, o) } }, { key: "push", value: function(t, r, i, a, n, s, o, l, e) { if (t.byteLength > 0 && null != e && null != e.key && "AES-128" === e.method) { null == this.decrypter && (this.decrypter = new p.default(this.hls)); var u = this; this.decrypter.decrypt(t, e.key, e.iv, function(e) { u.pushDecrypted(e, r, i, a, n, s, o, l) }) } else this.pushDecrypted(t, r, i, a, n, s, o, l) } }, { key: "onWorkerMessage", value: function(t) { switch (t.data.event) { case e.default.FRAG_PARSING_INIT_SEGMENT: var r = {}; t.data.audioMoov && (r.audioMoov = new Uint8Array(t.data.audioMoov), r.audioCodec = t.data.audioCodec, r.audioChannelCount = t.data.audioChannelCount), t.data.videoMoov && (r.videoMoov = new Uint8Array(t.data.videoMoov), r.videoCodec = t.data.videoCodec, r.videoWidth = t.data.videoWidth, r.videoHeight = t.data.videoHeight), this.hls.trigger(e.default.FRAG_PARSING_INIT_SEGMENT, r); break; case e.default.FRAG_PARSING_DATA: this.hls.trigger(e.default.FRAG_PARSING_DATA, { moof: new Uint8Array(t.data.moof), mdat: new Uint8Array(t.data.mdat), startPTS: t.data.startPTS, endPTS: t.data.endPTS, startDTS: t.data.startDTS, endDTS: t.data.endDTS, type: t.data.type, nb: t.data.nb }); break; case e.default.FRAG_PARSING_METADATA: this.hls.trigger(e.default.FRAG_PARSING_METADATA, { samples: t.data.samples }); break; case e.default.FRAG_PARSING_USERDATA: this.hls.trigger(e.default.FRAG_PARSING_USERDATA, { samples: t.data.samples }); break; default: this.hls.trigger(t.data.event, t.data.data) } } }]), r }(); i.default = y, u.exports = i.default }, { "../crypt/decrypter": 9, "../demux/demuxer-inline": 12, "../demux/demuxer-worker": 13, "../events": 20, "../remux/mp4-remuxer": 27, "../utils/logger": 31, webworkify: 2 }], 15: [function(t, r, e) { "use strict"; function i(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var a = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), n = t("../utils/logger"), s = function() { function e(t) { i(this, e), this.data = t, this.bytesAvailable = this.data.byteLength, this.word = 0, this.bitsAvailable = 0 } return a(e, [{ key: "loadWord", value: function() { var t = this.data.byteLength - this.bytesAvailable, r = new Uint8Array(4), e = Math.min(4, this.bytesAvailable); if (0 === e) throw new Error("no bytes available"); r.set(this.data.subarray(t, t + e)), this.word = new DataView(r.buffer).getUint32(0), this.bitsAvailable = 8 * e, this.bytesAvailable -= e } }, { key: "skipBits", value: function(e) { var t; this.bitsAvailable > e ? (this.word <<= e, this.bitsAvailable -= e) : (e -= this.bitsAvailable, t = e >> 3, e -= t >> 3, this.bytesAvailable -= t, this.loadWord(), this.word <<= e, this.bitsAvailable -= e) } }, { key: "readBits", value: function(t) { var e = Math.min(this.bitsAvailable, t), r = this.word >>> 32 - e; return t > 32 && n.logger.error("Cannot read more than 32 bits at a time"), this.bitsAvailable -= e, this.bitsAvailable > 0 ? this.word <<= e : this.bytesAvailable > 0 && this.loadWord(), e = t - e, e > 0 ? r << e | this.readBits(e) : r } }, { key: "skipLZ", value: function() { var e; for (e = 0; e < this.bitsAvailable; ++e) if (0 !== (this.word & 2147483648 >>> e)) return this.word <<= e, this.bitsAvailable -= e, e; return this.loadWord(), e + this.skipLZ() } }, { key: "skipUEG", value: function() { this.skipBits(1 + this.skipLZ()) } }, { key: "skipEG", value: function() { this.skipBits(1 + this.skipLZ()) } }, { key: "readUEG", value: function() { var e = this.skipLZ(); return this.readBits(e + 1) - 1 } }, { key: "readEG", value: function() { var e = this.readUEG(); return 1 & e ? 1 + e >>> 1 : -1 * (e >>> 1) } }, { key: "readBoolean", value: function() { return 1 === this.readBits(1) } }, { key: "readUByte", value: function() { return this.readBits(8) } }, { key: "readUShort", value: function() { return this.readBits(16) } }, { key: "readUInt", value: function() { return this.readBits(32) } }, { key: "skipScalingList", value: function(a) { var t, i, r = 8, e = 8; for (t = 0; a > t; t++) 0 !== e && (i = this.readEG(), e = (r + i + 256) % 256), r = 0 === e ? r : e } }, { key: "readSPS", value: function() { var t, g, p, l, a, n, i, o, r, s = 0, d = 0, h = 0, f = 0, c = 1; if (this.readUByte(), t = this.readUByte(), g = this.readBits(5), this.skipBits(3), p = this.readUByte(), this.skipUEG(), 100 === t || 110 === t || 122 === t || 244 === t || 44 === t || 83 === t || 86 === t || 118 === t || 128 === t) { var v = this.readUEG(); if (3 === v && this.skipBits(1), this.skipUEG(), this.skipUEG(), this.skipBits(1), this.readBoolean()) for (o = 3 !== v ? 8 : 12, r = 0; o > r; r++) this.readBoolean() && (6 > r ? this.skipScalingList(16) : this.skipScalingList(64)) } this.skipUEG(); var u = this.readUEG(); if (0 === u) this.readUEG(); else if (1 === u) for (this.skipBits(1), this.skipEG(), this.skipEG(), l = this.readUEG(), r = 0; l > r; r++) this.skipEG(); if (this.skipUEG(), this.skipBits(1), a = this.readUEG(), n = this.readUEG(), i = this.readBits(1), 0 === i && this.skipBits(1), this.skipBits(1), this.readBoolean() && (s = this.readUEG(), d = this.readUEG(), h = this.readUEG(), f = this.readUEG()), this.readBoolean() && this.readBoolean()) { var e = void 0, y = this.readUByte(); switch (y) { case 2: e = [12, 11]; break; case 3: e = [10, 11]; break; case 4: e = [16, 11]; break; case 5: e = [40, 33]; break; case 6: e = [24, 11]; break; case 7: e = [20, 11]; break; case 8: e = [32, 11]; break; case 9: e = [80, 33]; break; case 10: e = [18, 11]; break; case 11: e = [15, 11]; break; case 12: e = [64, 33]; break; case 13: e = [160, 99]; break; case 14: e = [4, 3]; break; case 15: e = [3, 2]; break; case 16: e = [2, 1]; break; case 255: e = [this.readUByte() << 8 | this.readUByte(), this.readUByte() << 8 | this.readUByte()] } e && (c = e[0] / e[1]) } return { width: (16 * (a + 1) - 2 * s - 2 * d) * c, height: (2 - i) * (n + 1) * 16 - (i ? 2 : 4) * (h + f) } } }, { key: "readSliceType", value: function() { return this.readUByte(), this.readUEG(), this.readUEG() } }]), e }(); e.default = s, r.exports = e.default }, { "../utils/logger": 31 }], 16: [function(r, i, e) { "use strict"; function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), t = r("../utils/logger"), s = function() { function e(i) { a(this, e), this._hasTimeStamp = !1; for (var l, u, d, h, f, s, o, n, r = 0;;) if (o = this.readUTF(i, r, 3), r += 3, "ID3" === o) r += 3, l = 127 & i[r++], u = 127 & i[r++], d = 127 & i[r++], h = 127 & i[r++], f = (l << 21) + (u << 14) + (d << 7) + h, s = r + f, this._parseID3Frames(i, r, s), r = s; else { if ("3DI" !== o) return r -= 3, n = r, void(n && (this.hasTimeStamp || t.logger.warn("ID3 tag found,but no timestamp"), this._length = n, this._payload = i.subarray(0, n))); r += 7, t.logger.log("3DI footer found,end:" + r) } } return n(e, [{ key: "readUTF", value: function(i, e, a) { var t = "", r = e, n = e + a; do t += String.fromCharCode(i[r++]); while (n > r); return t } }, { key: "_parseID3Frames", value: function(r, e, n) { for (var a, s, o, l, i; n >= e + 8;) switch (a = this.readUTF(r, e, 4), e += 4, s = r[e++] << 24 + r[e++] << 16 + r[e++] << 8 + r[e++], l = r[e++] << 8 + r[e++], o = e, a) { case "PRIV": if ("com.apple.streaming.transportStreamTimestamp" === this.readUTF(r, e, 44)) { e += 44, e += 4; var u = 1 & r[e++]; this._hasTimeStamp = !0, i = ((r[e++] << 23) + (r[e++] << 15) + (r[e++] << 7) + r[e++]) / 45, u && (i += 47721858.84), i = Math.round(i), t.logger.trace("ID3 timestamp found:" + i), this._timeStamp = i } } } }, { key: "hasTimeStamp", get: function() { return this._hasTimeStamp } }, { key: "timeStamp", get: function() { return this._timeStamp } }, { key: "length", get: function() { return this._length } }, { key: "payload", get: function() { return this._payload } }]), e }(); e.default = s, i.exports = e.default }, { "../utils/logger": 31 }], 17: [function(t, o, i) { "use strict"; function a(e) { return e && e.__esModule ? e : { default: e } } function h(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(i, "__esModule", { value: !0 }); var f = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), c = t("./adts"), v = a(c), l = t("../events"), n = a(l), d = t("./exp-golomb"), s = a(d), e = t("../utils/logger"), r = t("../errors"), u = function() { function t(e, r) { h(this, t), this.observer = e, this.remuxerClass = r, this.lastCC = 0, this.remuxer = new this.remuxerClass(e), this._userData = [] } return f(t, [{ key: "switchLevel", value: function() { this.pmtParsed = !1, this._pmtId = -1, this.lastAacPTS = null, this.aacOverFlow = null, this._avcTrack = { type: "video", id: -1, sequenceNumber: 0, samples: [], len: 0, nbNalu: 0 }, this._aacTrack = { type: "audio", id: -1, sequenceNumber: 0, samples: [], len: 0 }, this._id3Track = { type: "id3", id: -1, sequenceNumber: 0, samples: [], len: 0 }, this._txtTrack = { type: "text", id: -1, sequenceNumber: 0, samples: [], len: 0 }, this.remuxer.switchLevel() } }, { key: "insertDiscontinuity", value: function() { this.switchLevel(), this.remuxer.insertDiscontinuity() } }, { key: "push", value: function(i, A, E, R, f, m, g, _) { var l, o, s, t, d, u, y, a, h = i.length; this.audioCodec = A, this.videoCodec = E, this.timeOffset = R, this._duration = _, this.contiguous = !1, f !== this.lastCC ? (e.logger.log("discontinuity detected"), this.insertDiscontinuity(), this.lastCC = f) : m !== this.lastLevel ? (e.logger.log("level switch detected"), this.switchLevel(), this.lastLevel = m) : g === this.lastSN + 1 && (this.contiguous = !0), this.lastSN = g, this.contiguous || (this.aacOverFlow = null); var p = this.pmtParsed, v = this._avcTrack.id, c = this._aacTrack.id, b = this._id3Track.id; for (h -= h % 188, t = 0; h > t; t += 188) if (71 === i[t]) { if (d = !!(64 & i[t + 1]), u = ((31 & i[t + 1]) << 8) + i[t + 2], y = (48 & i[t + 3]) >> 4, y > 1) { if (a = t + 5 + i[t + 4], a === t + 188) continue } else a = t + 4; p ? u === v ? (d && (l && this._parseAVCPES(this._parsePES(l)), l = { data: [], size: 0 }), l && (l.data.push(i.subarray(a, t + 188)), l.size += t + 188 - a)) : u === c ? (d && (o && this._parseAACPES(this._parsePES(o)), o = { data: [], size: 0 }), o && (o.data.push(i.subarray(a, t + 188)), o.size += t + 188 - a)) : u === b && (d && (s && this._parseID3PES(this._parsePES(s)), s = { data: [], size: 0 }), s && (s.data.push(i.subarray(a, t + 188)), s.size += t + 188 - a)) : (d && (a += i[a] + 1), 0 === u ? this._parsePAT(i, a) : u === this._pmtId && (this._parsePMT(i, a), p = this.pmtParsed = !0, v = this._avcTrack.id, c = this._aacTrack.id, b = this._id3Track.id)) } else this.observer.trigger(n.default.ERROR, { type: r.ErrorTypes.MEDIA_ERROR, details: r.ErrorDetails.FRAG_PARSING_ERROR, fatal: !1, reason: "TS packet did not start with 0x47" }); l && this._parseAVCPES(this._parsePES(l)), o && this._parseAACPES(this._parsePES(o)), s && this._parseID3PES(this._parsePES(s)), this.remux() } }, { key: "remux", value: function() { this.remuxer.remux(this._aacTrack, this._avcTrack, this._id3Track, this._txtTrack, this.timeOffset, this.contiguous) } }, { key: "destroy", value: function() { this.switchLevel(), this._initPTS = this._initDTS = void 0, this._duration = 0 } }, { key: "_parsePAT", value: function(e, t) { this._pmtId = (31 & e[t + 10]) << 8 | e[t + 11] } }, { key: "_parsePMT", value: function(r, t) { var a, n, s, i; for (a = (15 & r[t + 1]) << 8 | r[t + 2], n = t + 3 + a - 4, s = (15 & r[t + 10]) << 8 | r[t + 11], t += 12 + s; n > t;) { switch (i = (31 & r[t + 1]) << 8 | r[t + 2], r[t]) { case 15: this._aacTrack.id = i; break; case 21: this._id3Track.id = i; break; case 27: this._avcTrack.id = i; break; default: e.logger.log("unkown stream type:" + r[t]) } t += ((15 & r[t + 3]) << 8 | r[t + 4]) + 5 } } }, { key: "_parsePES", value: function(t) { var e, a, u, o, d, n, r, i, s, l = 0; if (e = t.data[0], u = (e[0] << 16) + (e[1] << 8) + e[2], 1 === u) { for (o = (e[4] << 8) + e[5], a = e[7], 192 & a && (r = 536870912 * (14 & e[9]) + 4194304 * (255 & e[10]) + 16384 * (254 & e[11]) + 128 * (255 & e[12]) + (254 & e[13]) / 2, r > 4294967295 && (r -= 8589934592), 64 & a ? (i = 536870912 * (14 & e[14]) + 4194304 * (255 & e[15]) + 16384 * (254 & e[16]) + 128 * (255 & e[17]) + (254 & e[18]) / 2, i > 4294967295 && (i -= 8589934592)) : i = r), d = e[8], s = d + 9, t.data[0] = t.data[0].subarray(s), t.size -= s, n = new Uint8Array(t.size); t.data.length;) e = t.data.shift(), n.set(e, l), l += e.byteLength; return { data: n, pts: r, dts: i, len: o } } return null } }, { key: "_parseAVCPES", value: function(i) { var t, y, n, l, h = this, r = this._avcTrack, u = r.samples, m = this._parseAVCNALu(i.data), d = [], o = !1, c = !1, v = 0; if (0 === m.length && u.length > 0) { var g = u[u.length - 1], f = g.units.units[g.units.units.length - 1], p = new Uint8Array(f.data.byteLength + i.data.byteLength); p.set(f.data, 0), p.set(i.data, f.data.byteLength), f.data = p, g.units.length += i.data.byteLength, r.len += i.data.byteLength } i.data = null; var a = ""; m.forEach(function(e) { switch (e.type) { case 1: n = !0, o && (a += "NDR "); break; case 5: n = !0, o && (a += "IDR "), c = !0; break; case 6: n = !0, o && (a += "SEI "), t = new s.default(e.data), t.readUByte(); var b = t.readUByte(); if (4 === b) { var p = 0; do p = t.readUByte(); while (255 === p); var R = t.readUByte(); if (181 === R) { var _ = t.readUShort(); if (49 === _) { var A = t.readUInt(); if (1195456820 === A) { var k = t.readUByte(); if (3 === k) { var g = t.readUByte(), E = t.readUByte(), T = 31 & g, f = [g, E]; for (l = 0; T > l; l++) f.push(t.readUByte()), f.push(t.readUByte()), f.push(t.readUByte()); h._txtTrack.samples.push({ type: 3, pts: i.pts, bytes: f }) } } } } } break; case 7: if (n = !0, o && (a += "SPS "), !r.sps) { t = new s.default(e.data); var y = t.readSPS(); r.width = y.width, r.height = y.height, r.sps = [e.data], r.timescale = h.remuxer.timescale, r.duration = h.remuxer.timescale * h._duration; var L = e.data.subarray(1, 4), m = "avc1."; for (l = 0; 3 > l; l++) { var u = L[l].toString(16); u.length < 2 && (u = "0" + u), m += u } r.codec = m } break; case 8: n = !0, o && (a += "PPS "), r.pps || (r.pps = [e.data]); break; case 9: n = !1, o && (a += "AUD "); break; default: n = !1, a += "unknown NAL " + e.type + " " } n && (d.push(e), v += e.data.byteLength) }), (o || a.length) && e.logger.log(a), d.length && (c === !0 || r.sps) && (y = { units: { units: d, length: v }, pts: i.pts, dts: i.dts, key: c }, u.push(y), r.len += v, r.nbNalu += d.length) } }, { key: "_parseAVCNALu", value: function(r) { for (var n, i, s, p, a, l, t = 0, f = r.byteLength, e = 0, d = []; f > t;) switch (n = r[t++], e) { case 0: 0 === n && (e = 1); break; case 1: e = 0 === n ? 2 : 0; break; case 2: case 3: if (0 === n) e = 3; else if (1 === n && f > t) { if (p = 31 & r[t], a) s = { data: r.subarray(a, t - e - 1), type: l }, d.push(s); else if (i = t - e - 1) { var c = this._avcTrack, h = c.samples; if (h.length) { var v = h[h.length - 1], g = v.units.units, o = g[g.length - 1], u = new Uint8Array(o.data.byteLength + i); u.set(o.data, 0), u.set(r.subarray(0, i), o.data.byteLength), o.data = u, v.units.length += i, c.len += i } } a = t, l = p, e = 0 } else e = 0 } return a && (s = { data: r.subarray(a, f), type: l }, d.push(s)), d } }, { key: "_parseAACPES", value: function(R) { var s, l, p, b, t, d, f, o, _, a = this._aacTrack, i = R.data, c = R.pts, k = 0, L = this._duration, A = this.audioCodec, u = this.aacOverFlow, E = this.lastAacPTS; if (u) { var m = new Uint8Array(u.byteLength + i.byteLength); m.set(u, 0), m.set(i, u.byteLength), i = m } for (t = k, o = i.length; o - 1 > t && (255 !== i[t] || 240 !== (240 & i[t + 1])); t++); if (t) { var y, h; if (o - 1 > t ? (y = "AAC PES did not start with ADTS header,offset:" + t, h = !1) : (y = "no ADTS header found in AAC PES", h = !0), this.observer.trigger(n.default.ERROR, { type: r.ErrorTypes.MEDIA_ERROR, details: r.ErrorDetails.FRAG_PARSING_ERROR, fatal: h, reason: y }), h) return } if (a.audiosamplerate || (s = v.default.getAudioConfig(this.observer, i, t, A), a.config = s.config, a.audiosamplerate = s.samplerate, a.channelCount = s.channelCount, a.codec = s.codec, a.timescale = s.samplerate, a.duration = s.samplerate * L, e.logger.log("parsed codec:" + a.codec + ",rate:" + s.samplerate + ",nb channel:" + s.channelCount)), b = 0, p = 9216e4 / a.audiosamplerate, u && E) { var g = E + p; Math.abs(g - c) > 1 && (e.logger.log("AAC: align PTS for overlapping frames by " + Math.round((g - c) / 90)), c = g) } for (; o > t + 5 && (d = 1 & i[t + 1] ? 7 : 9, l = (3 & i[t + 3]) << 11 | i[t + 4] << 3 | (224 & i[t + 5]) >>> 5, l -= d, l > 0 && o >= t + d + l);) for (f = c + b * p, _ = { unit: i.subarray(t + d, t + d + l), pts: f, dts: f }, a.samples.push(_), a.len += l, t += l + d, b++; o - 1 > t && (255 !== i[t] || 240 !== (240 & i[t + 1])); t++); u = o > t ? i.subarray(t, o) : null, this.aacOverFlow = u, this.lastAacPTS = f } }, { key: "_parseID3PES", value: function(e) { this._id3Track.samples.push(e) } }], [{ key: "probe", value: function(e) { return e.length >= 564 && 71 === e[0] && 71 === e[188] && 71 === e[376] ? !0 : !1 } }]), t }(); i.default = u, o.exports = i.default }, { "../errors": 18, "../events": 20, "../utils/logger": 31, "./adts": 11, "./exp-golomb": 15 }], 18: [function(i, a, e) { "use strict"; Object.defineProperty(e, "__esModule", { value: !0 }); var t = { NETWORK_ERROR: "hlsNetworkError", MEDIA_ERROR: "hlsMediaError", OTHER_ERROR: "hlsOtherError" }; e.ErrorTypes = t; var r = { MANIFEST_LOAD_ERROR: "manifestLoadError", MANIFEST_LOAD_TIMEOUT: "manifestLoadTimeOut", MANIFEST_PARSING_ERROR: "manifestParsingError", LEVEL_LOAD_ERROR: "levelLoadError", LEVEL_LOAD_TIMEOUT: "levelLoadTimeOut", LEVEL_SWITCH_ERROR: "levelSwitchError", FRAG_LOAD_ERROR: "fragLoadError", FRAG_LOOP_LOADING_ERROR: "fragLoopLoadingError", FRAG_LOAD_TIMEOUT: "fragLoadTimeOut", FRAG_DECRYPT_ERROR: "fragDecryptError", FRAG_PARSING_ERROR: "fragParsingError", KEY_LOAD_ERROR: "keyLoadError", KEY_LOAD_TIMEOUT: "keyLoadTimeOut", BUFFER_APPEND_ERROR: "bufferAppendError", BUFFER_APPENDING_ERROR: "bufferAppendingError", BUFFER_STALLED_ERROR: "bufferStalledError" }; e.ErrorDetails = r }, {}], 19: [function(n, t, e) { "use strict"; function r(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var i = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), a = function() { function e(n) { r(this, e), this.hls = n, this.onEvent = this.onEvent.bind(this); for (var i = arguments.length, a = Array(i > 1 ? i - 1 : 0), t = 1; i > t; t++) a[t - 1] = arguments[t]; this.handledEvents = a, this.useGenericHandler = !0, this.registerListeners() } return i(e, [{ key: "destroy", value: function() { this.unregisterListeners() } }, { key: "isEventHandler", value: function() { return "object" == typeof this.handledEvents && this.handledEvents.length && "function" == typeof this.onEvent } }, { key: "registerListeners", value: function() { this.isEventHandler() && this.handledEvents.forEach(function(e) { if ("hlsEventGeneric" === e) throw new Error("Forbidden event name: " + e); this.hls.on(e, this.onEvent) }.bind(this)) } }, { key: "unregisterListeners", value: function() { this.isEventHandler() && this.handledEvents.forEach(function(e) { this.hls.off(e, this.onEvent) }.bind(this)) } }, { key: "onEvent", value: function(e, t) { this.onEventGeneric(e, t) } }, { key: "onEventGeneric", value: function(e, t) { var r = function(t, r) { var e = "on" + t.replace("hls", ""); if ("function" != typeof this[e]) throw new Error("Event " + t + " has no generic handler in this " + this.constructor.name + " class (tried " + e + ")"); return this[e].bind(this, r) }; r.call(this, e, t).call() } }]), e }(); e.default = a, t.exports = e.default }, {}], 20: [function(t, e, r) { "use strict"; e.exports = { MEDIA_ATTACHING: "hlsMediaAttaching", MEDIA_ATTACHED: "hlsMediaAttached", MEDIA_DETACHING: "hlsMediaDetaching", MEDIA_DETACHED: "hlsMediaDetached", MANIFEST_LOADING: "hlsManifestLoading", MANIFEST_LOADED: "hlsManifestLoaded", MANIFEST_PARSED: "hlsManifestParsed", LEVEL_LOADING: "hlsLevelLoading", LEVEL_LOADED: "hlsLevelLoaded", LEVEL_UPDATED: "hlsLevelUpdated", LEVEL_PTS_UPDATED: "hlsLevelPtsUpdated", LEVEL_SWITCH: "hlsLevelSwitch", FRAG_LOADING: "hlsFragLoading", FRAG_LOAD_PROGRESS: "hlsFragLoadProgress", FRAG_LOAD_EMERGENCY_ABORTED: "hlsFragLoadEmergencyAborted", FRAG_LOADED: "hlsFragLoaded", FRAG_PARSING_INIT_SEGMENT: "hlsFragParsingInitSegment", FRAG_PARSING_USERDATA: "hlsFragParsingUserdata", FRAG_PARSING_METADATA: "hlsFragParsingMetadata", FRAG_PARSING_DATA: "hlsFragParsingData", FRAG_PARSED: "hlsFragParsed", FRAG_BUFFERED: "hlsFragBuffered", FRAG_CHANGED: "hlsFragChanged", FPS_DROP: "hlsFpsDrop", ERROR: "hlsError", DESTROYING: "hlsDestroying", KEY_LOADING: "hlsKeyLoading", KEY_LOADED: "hlsKeyLoaded" } }, {}], 21: [function(r, i, e) { "use strict"; function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), t = r("../utils/logger"), s = function() { function e() { a(this, e) } return n(e, null, [{ key: "mergeDetails", value: function(n, i) { var s, c = Math.max(n.startSN, i.startSN) - i.startSN, d = Math.min(n.endSN, i.endSN) - i.startSN, h = i.startSN - n.startSN, f = n.fragments, o = i.fragments, u = 0; if (c > d) return void(i.PTSKnown = !1); for (var r = c; d >= r; r++) { var l = f[h + r], a = o[r]; u = l.cc - a.cc, isNaN(l.startPTS) || (a.start = a.startPTS = l.startPTS, a.endPTS = l.endPTS, a.duration = l.duration, s = a) } if (u) for (t.logger.log("discontinuity sliding from playlist, take drift into account"), r = 0; r < o.length; r++) o[r].cc += u; if (s) e.updateFragPTS(i, s.sn, s.startPTS, s.endPTS); else { var v = f[h].start; for (r = 0; r < o.length; r++) o[r].start += v } i.PTSKnown = n.PTSKnown } }, { key: "updateFragPTS", value: function(i, l, a, s) { var o, n, r, t; if (l < i.startSN || l > i.endSN) return 0; o = l - i.startSN, n = i.fragments, r = n[o], isNaN(r.startPTS) || (a = Math.min(a, r.startPTS), s = Math.max(s, r.endPTS)); var u = a - r.start; for (r.start = r.startPTS = a, r.endPTS = s, r.duration = s - a, t = o; t > 0; t--) e.updatePTS(n, t, t - 1); for (t = o; t < n.length - 1; t++) e.updatePTS(n, t, t + 1); return i.PTSKnown = !0, u } }, { key: "updatePTS", value: function(s, i, a) { var e = s[i], r = s[a], n = r.startPTS; isNaN(n) ? a > i ? r.start = e.start + e.duration : r.start = e.start - r.duration : a > i ? (e.duration = n - e.start, e.duration < 0 && t.logger.error("negative duration computed for frag " + e.sn + ",level " + e.level + ", there should be some duration drift between playlist and fragment!")) : (r.duration = e.start - n, r.duration < 0 && t.logger.error("negative duration computed for frag " + r.sn + ",level " + r.level + ", there should be some duration drift between playlist and fragment!")) } }]), e }(); e.default = s, i.exports = e.default }, { "../utils/logger": 31 }], 22: [function(t, v, a) { "use strict"; function r(e) { return e && e.__esModule ? e : { default: e } } function o(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(a, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), _ = t("./events"), i = r(_), s = t("./errors"), u = t("./loader/playlist-loader"), d = r(u), h = t("./loader/fragment-loader"), f = r(h), c = t("./controller/abr-controller"), w = r(c), g = t("./controller/mse-media-controller"), p = r(g), y = t("./controller/level-controller"), m = r(y), b = t("./controller/timeline-controller"), E = r(b), e = t("./utils/logger"), R = t("./utils/xhr-loader"), A = r(R), L = t("events"), k = r(L), T = t("./loader/key-loader"), S = r(T), l = function() { function t() { var i = arguments.length <= 0 || void 0 === arguments[0] ? {} : arguments[0]; o(this, t); var n = t.DefaultConfig; for (var a in n) a in i || (i[a] = n[a]); if (void 0 !== i.liveMaxLatencyDurationCount && i.liveMaxLatencyDurationCount <= i.liveSyncDurationCount) throw new Error('Illegal hls.js config: "liveMaxLatencyDurationCount" must be gt "liveSyncDurationCount"'); (0, e.enableLogs)(i.debug), this.config = i; var r = this.observer = new k.default; r.trigger = function(i) { for (var t = arguments.length, a = Array(t > 1 ? t - 1 : 0), e = 1; t > e; e++) a[e - 1] = arguments[e]; r.emit.apply(r, [i, i].concat(a)) }, r.off = function(a) { for (var t = arguments.length, i = Array(t > 1 ? t - 1 : 0), e = 1; t > e; e++) i[e - 1] = arguments[e]; r.removeListener.apply(r, [a].concat(i)) }, this.on = r.on.bind(r), this.off = r.off.bind(r), this.trigger = r.trigger.bind(r), this.playlistLoader = new d.default(this), this.fragmentLoader = new f.default(this), this.levelController = new m.default(this), this.abrController = new i.abrController(this), this.mediaController = new i.mediaController(this), this.timelineController = new i.timelineController(this), this.keyLoader = new S.default(this) } return n(t, null, [{ key: "isSupported", value: function() { return window.MediaSource && window.MediaSource.isTypeSupported('video/mp4; codecs="avc1.42E01E,mp4a.40.2"') } }, { key: "Events", get: function() { return i.default } }, { key: "ErrorTypes", get: function() { return s.ErrorTypes } }, { key: "ErrorDetails", get: function() { return s.ErrorDetails } }, { key: "DefaultConfig", get: function() { return t.defaultConfig || (t.defaultConfig = { autoStartLoad: !0, debug: !1, maxBufferLength: 30, maxBufferSize: 6e7, maxBufferHole: .5, maxSeekHole: 2, liveSyncDurationCount: 3, liveMaxLatencyDurationCount: 1 / 0, maxMaxBufferLength: 600, enableWorker: !0, enableSoftwareAES: !0, manifestLoadingTimeOut: 1e4, manifestLoadingMaxRetry: 1, manifestLoadingRetryDelay: 1e3, levelLoadingTimeOut: 1e4, levelLoadingMaxRetry: 4, levelLoadingRetryDelay: 1e3, fragLoadingTimeOut: 2e4, fragLoadingMaxRetry: 6, fragLoadingRetryDelay: 1e3, fragLoadingLoopThreshold: 3, appendErrorMaxRetry: 3, loader: A.default, fLoader: void 0, pLoader: void 0, abrController: w.default, mediaController: p.default, timelineController: E.default, enableCEA708Captions: !0 }), t.defaultConfig }, set: function(e) { t.defaultConfig = e } }]), n(t, [{ key: "destroy", value: function() { e.logger.log("destroy"), this.trigger(i.default.DESTROYING), this.detachMedia(), this.playlistLoader.destroy(), this.fragmentLoader.destroy(), this.levelController.destroy(), this.mediaController.destroy(), this.timelineController.destroy(), this.keyLoader.destroy(), this.url = null, this.observer.removeAllListeners() } }, { key: "attachMedia", value: function(t) { e.logger.log("attachMedia"), this.media = t, this.trigger(i.default.MEDIA_ATTACHING, { media: t }) } }, { key: "detachMedia", value: function() { e.logger.log("detachMedia"), this.trigger(i.default.MEDIA_DETACHING), this.media = null } }, { key: "loadSource", value: function(t) { e.logger.log("loadSource:" + t), this.url = t, this.trigger(i.default.MANIFEST_LOADING, { url: t }) } }, { key: "startLoad", value: function() { e.logger.log("startLoad"), this.mediaController.startLoad() } }, { key: "swapAudioCodec", value: function() { e.logger.log("swapAudioCodec"), this.mediaController.swapAudioCodec() } }, { key: "recoverMediaError", value: function() { e.logger.log("recoverMediaError"); var t = this.media; this.detachMedia(), this.attachMedia(t) } }, { key: "levels", get: function() { return this.levelController.levels } }, { key: "currentLevel", get: function() { return this.mediaController.currentLevel }, set: function(t) { e.logger.log("set currentLevel:" + t), this.loadLevel = t, this.mediaController.immediateLevelSwitch() } }, { key: "nextLevel", get: function() { return this.mediaController.nextLevel }, set: function(t) { e.logger.log("set nextLevel:" + t), this.levelController.manualLevel = t, this.mediaController.nextLevelSwitch() } }, { key: "loadLevel", get: function() { return this.levelController.level }, set: function(t) { e.logger.log("set loadLevel:" + t), this.levelController.manualLevel = t } }, { key: "nextLoadLevel", get: function() { return this.levelController.nextLoadLevel() }, set: function(e) { this.levelController.level = e } }, { key: "firstLevel", get: function() { return this.levelController.firstLevel }, set: function(t) { e.logger.log("set firstLevel:" + t), this.levelController.firstLevel = t } }, { key: "startLevel", get: function() { return this.levelController.startLevel }, set: function(t) { e.logger.log("set startLevel:" + t), this.levelController.startLevel = t } }, { key: "autoLevelCapping", get: function() { return this.abrController.autoLevelCapping }, set: function(t) { e.logger.log("set autoLevelCapping:" + t), this.abrController.autoLevelCapping = t } }, { key: "autoLevelEnabled", get: function() { return -1 === this.levelController.manualLevel } }, { key: "manualLevel", get: function() { return this.levelController.manualLevel } }]), t }(); a.default = l, v.exports = a.default }, { "./controller/abr-controller": 3, "./controller/level-controller": 4, "./controller/mse-media-controller": 5, "./controller/timeline-controller": 6, "./errors": 18, "./events": 20, "./loader/fragment-loader": 23, "./loader/key-loader": 24, "./loader/playlist-loader": 25, "./utils/logger": 31, "./utils/xhr-loader": 33, events: 1 }], 23: [function(r, o, i) { "use strict"; function a(e) { return e && e.__esModule ? e : { default: e } } function h(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function f(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(i, "__esModule", { value: !0 }); var s = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), c = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, l = r("../events"), e = a(l), d = r("../event-handler"), n = a(d), t = r("../errors"), u = function(i) { function r(t) { h(this, r), c(Object.getPrototypeOf(r.prototype), "constructor", this).call(this, t, e.default.FRAG_LOADING) } return f(r, i), s(r, [{ key: "destroy", value: function() { this.loader && (this.loader.destroy(), this.loader = null), n.default.prototype.destroy.call(this) } }, { key: "onFragLoading", value: function(r) { var t = r.frag; this.frag = t, this.frag.loaded = 0; var e = this.hls.config; t.loader = this.loader = "undefined" != typeof e.fLoader ? new e.fLoader(e) : new e.loader(e), this.loader.load(t.url, "arraybuffer", this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), e.fragLoadingTimeOut, 1, 0, this.loadprogress.bind(this), t) } }, { key: "loadsuccess", value: function(i, t) { var r = i.currentTarget.response; t.length = r.byteLength, this.frag.loader = void 0, this.hls.trigger(e.default.FRAG_LOADED, { payload: r, frag: this.frag, stats: t }) } }, { key: "loaderror", value: function(r) { this.loader.abort(), this.hls.trigger(e.default.ERROR, { type: t.ErrorTypes.NETWORK_ERROR, details: t.ErrorDetails.FRAG_LOAD_ERROR, fatal: !1, frag: this.frag, response: r }) } }, { key: "loadtimeout", value: function() { this.loader.abort(), this.hls.trigger(e.default.ERROR, { type: t.ErrorTypes.NETWORK_ERROR, details: t.ErrorDetails.FRAG_LOAD_TIMEOUT, fatal: !1, frag: this.frag }) } }, { key: "loadprogress", value: function(r, t) { this.frag.loaded = t.loaded, this.hls.trigger(e.default.FRAG_LOAD_PROGRESS, { frag: this.frag, stats: t }) } }]), r }(n.default); i.default = u, o.exports = i.default }, { "../errors": 18, "../event-handler": 19, "../events": 20 }], 24: [function(r, o, i) { "use strict"; function a(e) { return e && e.__esModule ? e : { default: e } } function h(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function f(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(i, "__esModule", { value: !0 }); var s = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), c = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, l = r("../events"), e = a(l), d = r("../event-handler"), n = a(d), t = r("../errors"), u = function(i) { function r(t) { h(this, r), c(Object.getPrototypeOf(r.prototype), "constructor", this).call(this, t, e.default.KEY_LOADING), this.decryptkey = null, this.decrypturl = null } return f(r, i), s(r, [{ key: "destroy", value: function() { this.loader && (this.loader.destroy(), this.loader = null), n.default.prototype.destroy.call(this) } }, { key: "onKeyLoading", value: function(n) { var t = this.frag = n.frag, a = t.decryptdata, i = a.uri; if (i !== this.decrypturl || null === this.decryptkey) { var r = this.hls.config; t.loader = this.loader = new r.loader(r), this.decrypturl = i, this.decryptkey = null, t.loader.load(i, "arraybuffer", this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), r.fragLoadingTimeOut, r.fragLoadingMaxRetry, r.fragLoadingRetryDelay, this.loadprogress.bind(this), t) } else this.decryptkey && (a.key = this.decryptkey, this.hls.trigger(e.default.KEY_LOADED, { frag: t })) } }, { key: "loadsuccess", value: function(r) { var t = this.frag; this.decryptkey = t.decryptdata.key = new Uint8Array(r.currentTarget.response), t.loader = void 0, this.hls.trigger(e.default.KEY_LOADED, { frag: t }) } }, { key: "loaderror", value: function(r) { this.loader.abort(), this.hls.trigger(e.default.ERROR, { type: t.ErrorTypes.NETWORK_ERROR, details: t.ErrorDetails.KEY_LOAD_ERROR, fatal: !1, frag: this.frag, response: r }) } }, { key: "loadtimeout", value: function() { this.loader.abort(), this.hls.trigger(e.default.ERROR, { type: t.ErrorTypes.NETWORK_ERROR, details: t.ErrorDetails.KEY_LOAD_TIMEOUT, fatal: !1, frag: this.frag }) } }, { key: "loadprogress", value: function() {} }]), r }(n.default); i.default = u, o.exports = i.default }, { "../errors": 18, "../event-handler": 19, "../events": 20 }], 25: [function(r, u, a) { "use strict"; function i(e) { return e && e.__esModule ? e : { default: e } } function d(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } function f(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e) } Object.defineProperty(a, "__esModule", { value: !0 }); var p = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), o = function(a, n, s) { for (var r = !0; r;) { var t = a, o = n, l = s; r = !1, null === t && (t = Function.prototype); var e = Object.getOwnPropertyDescriptor(t, o); if (void 0 !== e) { if ("value" in e) return e.value; var u = e.get; if (void 0 === u) return; return u.call(l) } var i = Object.getPrototypeOf(t); if (null === i) return; a = i, n = o, s = l, r = !0, e = i = void 0 } }, l = r("../events"), t = i(l), y = r("../event-handler"), n = i(y), e = r("../errors"), c = r("../utils/url"), v = i(c), g = r("../utils/attr-list"), s = i(g), h = function(i) { function r(e) { d(this, r), o(Object.getPrototypeOf(r.prototype), "constructor", this).call(this, e, t.default.MANIFEST_LOADING, t.default.LEVEL_LOADING) } return f(r, i), p(r, [{ key: "destroy", value: function() { this.loader && (this.loader.destroy(), this.loader = null), this.url = this.id = null, n.default.prototype.destroy.call(this) } }, { key: "onManifestLoading", value: function(e) { this.load(e.url, null) } }, { key: "onLevelLoading", value: function(e) { this.load(e.url, e.level, e.id) } }, { key: "load", value: function(a, n, s) { var t, r, i, e = this.hls.config; this.url = a, this.id = n, this.id2 = s, void 0 === this.id ? (t = e.manifestLoadingMaxRetry, r = e.manifestLoadingTimeOut, i = e.manifestLoadingRetryDelay) : (t = e.levelLoadingMaxRetry, r = e.levelLoadingTimeOut, i = e.levelLoadingRetryDelay), this.loader = "undefined" != typeof e.pLoader ? new e.pLoader(e) : new e.loader(e), this.loader.load(a, "", this.loadsuccess.bind(this), this.loaderror.bind(this), this.loadtimeout.bind(this), r, t, i) } }, { key: "resolve", value: function(e, t) { return v.default.buildAbsoluteURL(t, e) } }, { key: "parseMasterPlaylist", value: function(h, u) { for (var l = [], i = void 0, d = /#EXT-X-STREAM-INF:([^\n\r]*)[\r\n]+([^\r\n]+)/g; null != (i = d.exec(h));) { var e = {}, r = e.attrs = new s.default(i[1]); e.url = this.resolve(i[2], u); var n = r.decimalResolution("RESOLUTION"); n && (e.width = n.width, e.height = n.height), e.bitrate = r.decimalInteger("BANDWIDTH"), e.name = r.NAME; var t = r.CODECS; if (t) { t = t.split(","); for (var o = 0; o < t.length; o++) { var a = t[o]; - 1 !== a.indexOf("avc1") ? e.videoCodec = this.avc1toavcoti(a) : e.audioCodec = a } } l.push(e) } return l } }, { key: "avc1toavcoti", value: function(r) { var e, t = r.split("."); return t.length > 2 ? (e = t.shift() + ".", e += parseInt(t.shift()).toString(16), e += ("000" + parseInt(t.shift()).toString(16)).substr(-4)) : e = r, e } }, { key: "cloneObj", value: function(e) { return JSON.parse(JSON.stringify(e)) } }, { key: "parseLevelPlaylist", value: function(L, l, A) { var e, E, n, a, g = 0, o = 0, i = { url: l, fragments: [], live: !0, startSN: 0 }, r = { method: null, key: null, iv: null, uri: null }, b = 0, h = null, t = null; for (E = /(?:#EXT-X-(MEDIA-SEQUENCE):(\d+))|(?:#EXT-X-(TARGETDURATION):(\d+))|(?:#EXT-X-(KEY):(.*))|(?:#EXT(INF):([\d\.]+)[^\r\n]*([\r\n]+[^#|\r\n]+)?)|(?:#EXT-X-(BYTERANGE):([\d]+[@[\d]*)]*[\r\n]+([^#|\r\n]+)?|(?:#EXT-X-(ENDLIST))|(?:#EXT-X-(DIS)CONTINUITY))|(?:#EXT-X-(PROGRAM-DATE-TIME):(.*))/g; null !== (e = E.exec(L));) switch (e.shift(), e = e.filter(function(e) { return void 0 !== e }), e[0]) { case "MEDIA-SEQUENCE": g = i.startSN = parseInt(e[1]); break; case "TARGETDURATION": i.targetduration = parseFloat(e[1]); break; case "ENDLIST": i.live = !1; break; case "DIS": b++; break; case "BYTERANGE": var c = e[1].split("@"); a = 1 === c.length ? n : parseInt(c[1]), n = parseInt(c[0]) + a, t && !t.url && (t.byteRangeStartOffset = a, t.byteRangeEndOffset = n, t.url = this.resolve(e[2], l)); break; case "INF": var v = parseFloat(e[1]); if (!isNaN(v)) { var u, m = g++; if (r.method && r.uri && !r.iv) { u = this.cloneObj(r); for (var y = new Uint8Array(16), d = 12; 16 > d; d++) y[d] = m >> 8 * (15 - d) & 255; u.iv = y } else u = r; var k = e[2] ? this.resolve(e[2], l) : null; t = { url: k, duration: v, start: o, sn: m, level: A, cc: b, byteRangeStartOffset: a, byteRangeEndOffset: n, decryptdata: u, programDateTime: h }, i.fragments.push(t), o += v, a = null, h = null } break; case "KEY": var R = e[1], p = new s.default(R), f = p.enumeratedString("METHOD"), _ = p.URI, T = p.hexadecimalInteger("IV"); f && (r = { method: null, key: null, iv: null, uri: null }, _ && "AES-128" === f && (r.method = f, r.uri = this.resolve(_, l), r.key = null, r.iv = T)); break; case "PROGRAM-DATE-TIME": h = new Date(Date.parse(e[1])) } return t && !t.url && (i.fragments.pop(), o -= t.duration), i.totalduration = o, i.endSN = g - 1, i } }, { key: "loadsuccess", value: function(u, i) { var s, o = u.currentTarget, n = o.responseText, r = o.responseURL, l = this.id, d = this.id2, a = this.hls; if (void 0 === r && (r = this.url), i.tload = performance.now(), i.mtime = new Date(o.getResponseHeader("Last-Modified")), 0 === n.indexOf("#EXTM3U")) if (n.indexOf("#EXTINF:") > 0) if (null === this.id) a.trigger(t.default.MANIFEST_LOADED, { levels: [{ url: r }], url: r, stats: i }); else { var h = this.parseLevelPlaylist(n, r, l); i.tparsed = performance.now(), a.trigger(t.default.LEVEL_LOADED, { details: h, level: l, id: d, stats: i }) } else s = this.parseMasterPlaylist(n, r), s.length ? a.trigger(t.default.MANIFEST_LOADED, { levels: s, url: r, stats: i }) : a.trigger(t.default.ERROR, { type: e.ErrorTypes.NETWORK_ERROR, details: e.ErrorDetails.MANIFEST_PARSING_ERROR, fatal: !0, url: r, reason: "no level found in manifest" }); else a.trigger(t.default.ERROR, { type: e.ErrorTypes.NETWORK_ERROR, details: e.ErrorDetails.MANIFEST_PARSING_ERROR, fatal: !0, url: r, reason: "no EXTM3U delimiter" }) } }, { key: "loaderror", value: function(a) { var r, i; null === this.id ? (r = e.ErrorDetails.MANIFEST_LOAD_ERROR, i = !0) : (r = e.ErrorDetails.LEVEL_LOAD_ERROR, i = !1), this.loader.abort(), this.hls.trigger(t.default.ERROR, { type: e.ErrorTypes.NETWORK_ERROR, details: r, fatal: i, url: this.url, loader: this.loader, response: a.currentTarget, level: this.id, id: this.id2 }) } }, { key: "loadtimeout", value: function() { var r, i; null === this.id ? (r = e.ErrorDetails.MANIFEST_LOAD_TIMEOUT, i = !0) : (r = e.ErrorDetails.LEVEL_LOAD_TIMEOUT, i = !1), this.loader.abort(), this.hls.trigger(t.default.ERROR, { type: e.ErrorTypes.NETWORK_ERROR, details: r, fatal: i, url: this.url, loader: this.loader, level: this.id, id: this.id2 }) } }]), r }(n.default); a.default = h, u.exports = a.default }, { "../errors": 18, "../event-handler": 19, "../events": 20, "../utils/attr-list": 28, "../utils/url": 32 }], 26: [function(n, t, e) { "use strict"; function r(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var i = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), a = function() { function e() { r(this, e) } return i(e, null, [{ key: "init", value: function() { e.types = { avc1: [], avcC: [], btrt: [], dinf: [], dref: [], esds: [], ftyp: [], hdlr: [], mdat: [], mdhd: [], mdia: [], mfhd: [], minf: [], moof: [], moov: [], mp4a: [], mvex: [], mvhd: [], sdtp: [], stbl: [], stco: [], stsc: [], stsd: [], stsz: [], stts: [], tfdt: [], tfhd: [], traf: [], trak: [], trun: [], trex: [], tkhd: [], vmhd: [], smhd: [] }; var t; for (t in e.types) e.types.hasOwnProperty(t) && (e.types[t] = [t.charCodeAt(0), t.charCodeAt(1), t.charCodeAt(2), t.charCodeAt(3)]); var i = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 118, 105, 100, 101, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 86, 105, 100, 101, 111, 72, 97, 110, 100, 108, 101, 114, 0]), a = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 115, 111, 117, 110, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 83, 111, 117, 110, 100, 72, 97, 110, 100, 108, 101, 114, 0]); e.HDLR_TYPES = { video: i, audio: a }; var n = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 12, 117, 114, 108, 32, 0, 0, 0, 1]), s = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0]); e.STTS = e.STSC = e.STCO = s, e.STSZ = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]), e.VMHD = new Uint8Array([0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0]), e.SMHD = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 0]), e.STSD = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 1]); var r = new Uint8Array([105, 115, 111, 109]), o = new Uint8Array([97, 118, 99, 49]), l = new Uint8Array([0, 0, 0, 1]); e.FTYP = e.box(e.types.ftyp, r, l, r, o), e.DINF = e.box(e.types.dinf, e.box(e.types.dref, n)) } }, { key: "box", value: function(a) { for (var t, i = Array.prototype.slice.call(arguments, 1), e = 8, r = i.length, n = r; r--;) e += i[r].byteLength; for (t = new Uint8Array(e), t[0] = e >> 24 & 255, t[1] = e >> 16 & 255, t[2] = e >> 8 & 255, t[3] = 255 & e, t.set(a, 4), r = 0, e = 8; n > r; r++) t.set(i[r], e), e += i[r].byteLength; return t } }, { key: "hdlr", value: function(t) { return e.box(e.types.hdlr, e.HDLR_TYPES[t]) } }, { key: "mdat", value: function(t) { return e.box(e.types.mdat, t) } }, { key: "mdhd", value: function(t, r) { return e.box(e.types.mdhd, new Uint8Array([0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 3, t >> 24 & 255, t >> 16 & 255, t >> 8 & 255, 255 & t, r >> 24, r >> 16 & 255, r >> 8 & 255, 255 & r, 85, 196, 0, 0])) } }, { key: "mdia", value: function(t) { return e.box(e.types.mdia, e.mdhd(t.timescale, t.duration), e.hdlr(t.type), e.minf(t)) } }, { key: "mfhd", value: function(t) { return e.box(e.types.mfhd, new Uint8Array([0, 0, 0, 0, t >> 24, t >> 16 & 255, t >> 8 & 255, 255 & t])) } }, { key: "minf", value: function(t) { return "audio" === t.type ? e.box(e.types.minf, e.box(e.types.smhd, e.SMHD), e.DINF, e.stbl(t)) : e.box(e.types.minf, e.box(e.types.vmhd, e.VMHD), e.DINF, e.stbl(t)) } }, { key: "moof", value: function(t, r, i) { return e.box(e.types.moof, e.mfhd(t), e.traf(i, r)) } }, { key: "moov", value: function(t) { for (var r = t.length, i = []; r--;) i[r] = e.trak(t[r]); return e.box.apply(null, [e.types.moov, e.mvhd(t[0].timescale, t[0].duration)].concat(i).concat(e.mvex(t))) } }, { key: "mvex", value: function(r) { for (var t = r.length, i = []; t--;) i[t] = e.trex(r[t]); return e.box.apply(null, [e.types.mvex].concat(i)) } }, { key: "mvhd", value: function(t, r) { var i = new Uint8Array([0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 2, t >> 24 & 255, t >> 16 & 255, t >> 8 & 255, 255 & t, r >> 24 & 255, r >> 16 & 255, r >> 8 & 255, 255 & r, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 255, 255, 255, 255]); return e.box(e.types.mvhd, i) } }, { key: "sdtp", value: function(n) { var r, t, i = n.samples || [], a = new Uint8Array(4 + i.length); for (t = 0; t < i.length; t++) r = i[t].flags, a[t + 4] = r.dependsOn << 4 | r.isDependedOn << 2 | r.hasRedundancy; return e.box(e.types.sdtp, a) } }, { key: "stbl", value: function(t) { return e.box(e.types.stbl, e.stsd(t), e.box(e.types.stts, e.STTS), e.box(e.types.stsc, e.STSC), e.box(e.types.stsz, e.STSZ), e.box(e.types.stco, e.STCO)) } }, { key: "avc1", value: function(t) { var r, a, n, i = [], s = []; for (r = 0; r < t.sps.length; r++) a = t.sps[r], n = a.byteLength, i.push(n >>> 8 & 255), i.push(255 & n), i = i.concat(Array.prototype.slice.call(a)); for (r = 0; r < t.pps.length; r++) a = t.pps[r], n = a.byteLength, s.push(n >>> 8 & 255), s.push(255 & n), s = s.concat(Array.prototype.slice.call(a)); var u = e.box(e.types.avcC, new Uint8Array([1, i[3], i[4], i[5], 255, 224 | t.sps.length].concat(i).concat([t.pps.length]).concat(s))), o = t.width, l = t.height; return e.box(e.types.avc1, new Uint8Array([0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, o >> 8 & 255, 255 & o, l >> 8 & 255, 255 & l, 0, 72, 0, 0, 0, 72, 0, 0, 0, 0, 0, 0, 0, 1, 18, 100, 97, 105, 108, 121, 109, 111, 116, 105, 111, 110, 47, 104, 108, 115, 46, 106, 115, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 24, 17, 17]), u, e.box(e.types.btrt, new Uint8Array([0, 28, 156, 128, 0, 45, 198, 192, 0, 45, 198, 192]))) } }, { key: "esds", value: function(t) { var e = t.config.length; return new Uint8Array([0, 0, 0, 0, 3, 23 + e, 0, 1, 0, 4, 15 + e, 64, 21, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5].concat([e]).concat(t.config).concat([6, 1, 2])) } }, { key: "mp4a", value: function(t) { var r = t.audiosamplerate; return e.box(e.types.mp4a, new Uint8Array([0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, t.channelCount, 0, 16, 0, 0, 0, 0, r >> 8 & 255, 255 & r, 0, 0]), e.box(e.types.esds, e.esds(t))) } }, { key: "stsd", value: function(t) { return "audio" === t.type ? e.box(e.types.stsd, e.STSD, e.mp4a(t)) : e.box(e.types.stsd, e.STSD, e.avc1(t)) } }, { key: "tkhd", value: function(t) { var r = t.id, i = t.duration, a = t.width, n = t.height; return e.box(e.types.tkhd, new Uint8Array([0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 0, r >> 24 & 255, r >> 16 & 255, r >> 8 & 255, 255 & r, 0, 0, 0, 0, i >> 24, i >> 16 & 255, i >> 8 & 255, 255 & i, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 64, 0, 0, 0, a >> 8 & 255, 255 & a, 0, 0, n >> 8 & 255, 255 & n, 0, 0])) } }, { key: "traf", value: function(i, t) { var a = e.sdtp(i), r = i.id; return e.box(e.types.traf, e.box(e.types.tfhd, new Uint8Array([0, 0, 0, 0, r >> 24, r >> 16 & 255, r >> 8 & 255, 255 & r])), e.box(e.types.tfdt, new Uint8Array([0, 0, 0, 0, t >> 24, t >> 16 & 255, t >> 8 & 255, 255 & t])), e.trun(i, a.length + 16 + 16 + 8 + 16 + 8 + 8), a) } }, { key: "trak", value: function(t) { return t.duration = t.duration || 4294967295, e.box(e.types.trak, e.tkhd(t), e.mdia(t)) } }, { key: "trex", value: function(r) { var t = r.id; return e.box(e.types.trex, new Uint8Array([0, 0, 0, 0, t >> 24, t >> 16 & 255, t >> 8 & 255, 255 & t, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1])) } }, { key: "trun", value: function(f, o) { var i, a, n, s, t, l, d = f.samples || [], r = d.length, h = 12 + 16 * r, u = new Uint8Array(h); for (o += 8 + h, u.set([0, 0, 15, 1, r >>> 24 & 255, r >>> 16 & 255, r >>> 8 & 255, 255 & r, o >>> 24 & 255, o >>> 16 & 255, o >>> 8 & 255, 255 & o], 0), i = 0; r > i; i++) a = d[i], n = a.duration, s = a.size, t = a.flags, l = a.cts, u.set([n >>> 24 & 255, n >>> 16 & 255, n >>> 8 & 255, 255 & n, s >>> 24 & 255, s >>> 16 & 255, s >>> 8 & 255, 255 & s, t.isLeading << 2 | t.dependsOn, t.isDependedOn << 6 | t.hasRedundancy << 4 | t.paddingValue << 1 | t.isNonSync, 61440 & t.degradPrio, 15 & t.degradPrio, l >>> 24 & 255, l >>> 16 & 255, l >>> 8 & 255, 255 & l], 12 + 16 * i); return e.box(e.types.trun, u) } }, { key: "initSegment", value: function(i) { e.types || e.init(); var t, r = e.moov(i); return t = new Uint8Array(e.FTYP.byteLength + r.byteLength), t.set(e.FTYP), t.set(r, e.FTYP.byteLength), t } }]), e }(); e.default = a, t.exports = e.default }, {}], 27: [function(i, h, a) { "use strict"; function n(e) { return e && e.__esModule ? e : { default: e } } function l(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(a, "__esModule", { value: !0 }); var d = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), f = i("../events"), e = n(f), r = i("../utils/logger"), u = i("../remux/mp4-generator"), t = n(u), s = i("../errors"), o = function() { function i(e) { l(this, i), this.observer = e, this.ISGenerated = !1, this.PES2MP4SCALEFACTOR = 4, this.PES_TIMESCALE = 9e4, this.MP4_TIMESCALE = this.PES_TIMESCALE / this.PES2MP4SCALEFACTOR } return d(i, [{ key: "destroy", value: function() {} }, { key: "insertDiscontinuity", value: function() { this._initPTS = this._initDTS = this.nextAacPts = this.nextAvcDts = void 0 } }, { key: "switchLevel", value: function() { this.ISGenerated = !1 } }, { key: "remux", value: function(r, i, a, n, t, s) { this.ISGenerated || this.generateIS(r, i, t), i.samples.length && this.remuxVideo(i, t, s), r.samples.length && this.remuxAudio(r, t, s), a.samples.length && this.remuxID3(a, t), n.samples.length && this.remuxText(n, t), this.observer.trigger(e.default.FRAG_PARSED) } }, { key: "generateIS", value: function(i, r, a) { var u = this.observer, o = i.samples, l = r.samples, d = o.length, h = l.length, n = this.PES_TIMESCALE; 0 === d && 0 === h ? u.trigger(e.default.ERROR, { type: s.ErrorTypes.MEDIA_ERROR, details: s.ErrorDetails.FRAG_PARSING_ERROR, fatal: !1, reason: "no audio/video samples found" }) : 0 === h ? (i.config && (u.trigger(e.default.FRAG_PARSING_INIT_SEGMENT, { audioMoov: t.default.initSegment([i]), audioCodec: i.codec, audioChannelCount: i.channelCount }), this.ISGenerated = !0), void 0 === this._initPTS && (this._initPTS = o[0].pts - n * a, this._initDTS = o[0].dts - n * a)) : 0 === d ? r.sps && r.pps && (u.trigger(e.default.FRAG_PARSING_INIT_SEGMENT, { videoMoov: t.default.initSegment([r]), videoCodec: r.codec, videoWidth: r.width, videoHeight: r.height }), this.ISGenerated = !0, void 0 === this._initPTS && (this._initPTS = l[0].pts - n * a, this._initDTS = l[0].dts - n * a)) : i.config && r.sps && r.pps && (u.trigger(e.default.FRAG_PARSING_INIT_SEGMENT, { audioMoov: t.default.initSegment([i]), audioCodec: i.codec, audioChannelCount: i.channelCount, videoMoov: t.default.initSegment([r]), videoCodec: r.codec, videoWidth: r.width, videoHeight: r.height }), this.ISGenerated = !0, void 0 === this._initPTS && (this._initPTS = Math.min(l[0].pts, o[0].pts) - n * a, this._initDTS = Math.min(l[0].dts, o[0].dts) - n * a)) } }, { key: "remuxVideo", value: function(a, w, S) { var L, l, g, A, v, d, T, k, R, f, _, c, o, i, s, p = 8, b = this.PES_TIMESCALE, h = this.PES2MP4SCALEFACTOR, u = []; for (d = new Uint8Array(a.len + 4 * a.nbNalu + 8), L = new DataView(d.buffer), L.setUint32(0, d.byteLength), d.set(t.default.types.mdat, 4); a.samples.length;) { for (l = a.samples.shift(), A = 0; l.units.units.length;) v = l.units.units.shift(), L.setUint32(p, v.data.byteLength), p += 4, d.set(v.data, p), p += v.data.byteLength, A += 4 + v.data.byteLength; if (_ = l.pts - this._initDTS, c = l.dts - this._initDTS, c = Math.min(_, c), void 0 !== f) { o = this._PTSNormalize(_, f), i = this._PTSNormalize(c, f); var y = (i - f) / h; 0 >= y && (r.logger.log("invalid sample duration at PTS/DTS: " + l.pts + "/" + l.dts + ":" + y), y = 1), g.duration = y } else { var n, m = this.nextAvcDts; o = this._PTSNormalize(_, m), i = this._PTSNormalize(c, m), n = Math.round((i - m) / 90), (S || Math.abs(n) < 600) && n && (n > 1 ? r.logger.log("AVC:" + n + " ms hole between fragments detected,filling it") : -1 > n && r.logger.log("AVC:" + -n + " ms overlapping between fragments detected"), i = m, o = Math.max(o - n, i), r.logger.log("Video/PTS/DTS adjusted: " + o + "/" + i + ",delta:" + n)), k = Math.max(0, o), R = Math.max(0, i) } g = { size: A, duration: 0, cts: (o - i) / h, flags: { isLeading: 0, isDependedOn: 0, hasRedundancy: 0, degradPrio: 0 } }, s = g.flags, l.key === !0 ? (s.dependsOn = 2, s.isNonSync = 0) : (s.dependsOn = 1, s.isNonSync = 1), u.push(g), f = i } var E = 0; u.length >= 2 && (E = u[u.length - 2].duration, g.duration = E), this.nextAvcDts = i + E * h, a.len = 0, a.nbNalu = 0, u.length && navigator.userAgent.toLowerCase().indexOf("chrome") > -1 && (s = u[0].flags, s.dependsOn = 2, s.isNonSync = 0), a.samples = u, T = t.default.moof(a.sequenceNumber++, R / h, a), a.samples = [], this.observer.trigger(e.default.FRAG_PARSING_DATA, { moof: T, mdat: d, startPTS: k / b, endPTS: (o + h * E) / b, startDTS: R / b, endDTS: this.nextAvcDts / b, type: "video", nb: u.length }) } }, { key: "remuxAudio", value: function(i, w, S) { var k, y, n, h, o, L, A, b, l, g, _, d, a, R = 8, u = this.PES_TIMESCALE, T = i.timescale, f = u / T, m = [], E = []; for (i.samples.sort(function(e, t) { return e.pts - t.pts }), E = i.samples; E.length;) { if (y = E.shift(), h = y.unit, g = y.pts - this._initDTS, _ = y.dts - this._initDTS, void 0 !== l) d = this._PTSNormalize(g, l), a = this._PTSNormalize(_, l), n.duration = (a - l) / f, Math.abs(n.duration - 1024) > 10 && r.logger.log("invalid AAC sample duration at PTS " + Math.round(g / 90) + ",should be 1024,found :" + Math.round(n.duration)), n.duration = 1024, a = 1024 * f + l; else { var s, p = this.nextAacPts; if (d = this._PTSNormalize(g, p), a = this._PTSNormalize(_, p), s = Math.round(1e3 * (d - p) / u), (S || Math.abs(s) < 600) && s) { if (s > 0) r.logger.log(s + " ms hole between AAC samples detected,filling it"); else if (-12 > s) { r.logger.log(-s + " ms overlapping between AAC samples detected, drop frame"), i.len -= h.byteLength; continue } d = a = p } if (A = Math.max(0, d), b = Math.max(0, a), !(i.len > 0)) return; o = new Uint8Array(i.len + 8), k = new DataView(o.buffer), k.setUint32(0, o.byteLength), o.set(t.default.types.mdat, 4) } o.set(h, R), R += h.byteLength, n = { size: h.byteLength, cts: 0, duration: 0, flags: { isLeading: 0, isDependedOn: 0, hasRedundancy: 0, degradPrio: 0, dependsOn: 1 } }, m.push(n), l = a } var v = 0, c = m.length; c >= 2 && (v = m[c - 2].duration, n.duration = v), c && (this.nextAacPts = d + f * v, i.len = 0, i.samples = m, L = t.default.moof(i.sequenceNumber++, b / f, i), i.samples = [], this.observer.trigger(e.default.FRAG_PARSING_DATA, { moof: L, mdat: o, startPTS: A / u, endPTS: this.nextAacPts / u, startDTS: b / u, endDTS: (a + f * v) / u, type: "audio", nb: c })) } }, { key: "remuxID3", value: function(r, a) { var t, n = r.samples.length; if (n) { for (var i = 0; n > i; i++) t = r.samples[i], t.pts = (t.pts - this._initPTS) / this.PES_TIMESCALE, t.dts = (t.dts - this._initDTS) / this.PES_TIMESCALE; this.observer.trigger(e.default.FRAG_PARSING_METADATA, { samples: r.samples }) } r.samples = [], a = a } }, { key: "remuxText", value: function(t, a) { t.samples.sort(function(e, t) { return e.pts - t.pts }); var r, n = t.samples.length; if (n) { for (var i = 0; n > i; i++) r = t.samples[i], r.pts = (r.pts - this._initPTS) / this.PES_TIMESCALE; this.observer.trigger(e.default.FRAG_PARSING_USERDATA, { samples: t.samples }) } t.samples = [], a = a } }, { key: "_PTSNormalize", value: function(e, t) { var r; if (void 0 === t) return e; for (r = e > t ? -8589934592 : 8589934592; Math.abs(e - t) > 4294967296;) e += r; return e } }, { key: "timescale", get: function() { return this.MP4_TIMESCALE } }]), i }(); a.default = o, h.exports = a.default }, { "../errors": 18, "../events": 20, "../remux/mp4-generator": 26, "../utils/logger": 31 }], 28: [function(n, t, e) { "use strict"; function r(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var i = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), a = function() { function e(t) { r(this, e), "string" == typeof t && (t = e.parseAttrList(t)); for (var i in t) t.hasOwnProperty(i) && (this[i] = t[i]) } return i(e, [{ key: "decimalInteger", value: function(t) { var e = parseInt(this[t], 10); return e > Number.MAX_SAFE_INTEGER ? 1 / 0 : e } }, { key: "hexadecimalInteger", value: function(r) { if (this[r]) { var e = (this[r] || "0x").slice(2); e = (1 & e.length ? "0" : "") + e; for (var i = new Uint8Array(e.length / 2), t = 0; t < e.length / 2; t++) i[t] = parseInt(e.slice(2 * t, 2 * t + 2), 16); return i } return null } }, { key: "hexadecimalIntegerAsNumber", value: function(t) { var e = parseInt(this[t], 16); return e > Number.MAX_SAFE_INTEGER ? 1 / 0 : e } }, { key: "decimalFloatingPoint", value: function(e) { return parseFloat(this[e]) } }, { key: "enumeratedString", value: function(e) { return this[e] } }, { key: "decimalResolution", value: function(t) { var e = /^(\d+)x(\d+)$/.exec(this[t]); if (null !== e) return { width: parseInt(e[1], 10), height: parseInt(e[2], 10) } } }], [{ key: "parseAttrList", value: function(a) { for (var t, n = /\s*(.+?)\s*=((?:\".*?\")|.*?)(?:,|$)/g, r = {}; null !== (t = n.exec(a));) { var e = t[2], i = '"'; 0 === e.indexOf(i) && e.lastIndexOf(i) === e.length - 1 && (e = e.slice(1, -1)), r[t[1]] = e } return r } }]), e }(); e.default = a, t.exports = e.default }, {}], 29: [function(r, e, i) { "use strict"; var t = { search: function(a, s) { for (var t = 0, r = a.length - 1, e = null, i = null; r >= t;) { e = (t + r) / 2 | 0, i = a[e]; var n = s(i); if (n > 0) t = e + 1; else { if (!(0 > n)) return i; r = e - 1 } } return null } }; e.exports = t }, {}], 30: [function(n, t, e) { "use strict"; function r(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var i = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), a = function() { function e() { r(this, e) } return i(e, [{ key: "attach", value: function(e) { this.media = e, this.display = [], this.memory = [] } }, { key: "detach", value: function() { this.clear() } }, { key: "destroy", value: function() {} }, { key: "_createCue", value: function() { var e = window.VTTCue || window.TextTrackCue; this.cue = new e(-1, -1, ""), this.cue.text = "", this.cue.pauseOnExit = !1, this.startTime = Number.MAX_VALUE, this.cue.endTime = Number.MAX_VALUE, this.memory.push(this.cue) } }, { key: "clear", value: function() { if (this._textTrack && this._textTrack.cues) for (; this._textTrack.cues.length > 0;) this._textTrack.removeCue(this._textTrack.cues[0]) } }, { key: "push", value: function(r, i) { this.cue || this._createCue(); for (var a, t, e, s, o, u = 31 & i[0], n = 2, l = 0; u > l; l++) if (a = i[n++], t = 127 & i[n++], e = 127 & i[n++], s = 0 === (4 & a) ? !1 : !0, o = 3 & a, (0 !== t || 0 !== e) && s && 0 === o) { if (32 & t || 64 & t) this.cue.text += this._fromCharCode(t) + this._fromCharCode(e); else if ((17 === t || 25 === t) && e >= 48 && 63 >= e) switch (e) { case 48: this.cue.text += "®"; break; case 49: this.cue.text += "°"; break; case 50: this.cue.text += "½"; break; case 51: this.cue.text += "¿"; break; case 52: this.cue.text += "™"; break; case 53: this.cue.text += "¢"; break; case 54: this.cue.text += ""; break; case 55: this.cue.text += "£"; break; case 56: this.cue.text += "♪"; break; case 57: this.cue.text += " "; break; case 58: this.cue.text += "è"; break; case 59: this.cue.text += "â"; break; case 60: this.cue.text += "ê"; break; case 61: this.cue.text += "î"; break; case 62: this.cue.text += "ô"; break; case 63: this.cue.text += "û" } if ((17 === t || 25 === t) && e >= 32 && 47 >= e) switch (e) { case 32: break; case 33: break; case 34: break; case 35: break; case 36: break; case 37: break; case 38: break; case 39: break; case 40: break; case 41: break; case 42: break; case 43: break; case 44: break; case 45: break; case 46: break; case 47: } if ((20 === t || 28 === t) && e >= 32 && 47 >= e) switch (e) { case 32: this._clearActiveCues(r); break; case 33: this.cue.text = this.cue.text.substr(0, this.cue.text.length - 1); break; case 34: break; case 35: break; case 36: break; case 37: break; case 38: break; case 39: break; case 40: break; case 41: this._clearActiveCues(r); break; case 42: break; case 43: break; case 44: this._clearActiveCues(r); break; case 45: break; case 46: this._text = ""; break; case 47: this._flipMemory(r) } if ((23 === t || 31 === t) && e >= 33 && 35 >= e) switch (e) { case 33: break; case 34: break; case 35: } } } }, { key: "_fromCharCode", value: function(e) { switch (e) { case 42: return "á"; case 2: return "á"; case 2: return "é"; case 4: return "í"; case 5: return "ó"; case 6: return "ú"; case 3: return "ç"; case 4: return "÷"; case 5: return "Ñ"; case 6: return "ñ"; case 7: return "█"; default: return String.fromCharCode(e) } } }, { key: "_flipMemory", value: function(e) { this._clearActiveCues(e), this._flushCaptions(e) } }, { key: "_flushCaptions", value: function(t) { this._has708 || (this._textTrack = this.media.addTextTrack("captions", "English", "en"), this._has708 = !0); for (var e = 0; e < this.memory.length; e++) this.memory[e].startTime = t, this._textTrack.addCue(this.memory[e]), this.display.push(this.memory[e]); this.memory = [], this.cue = null } }, { key: "_clearActiveCues", value: function(t) { for (var e = 0; e < this.display.length; e++) this.display[e].endTime = t; this.display = [] } }, { key: "_clearBufferedCues", value: function() {} }]), e }(); e.default = a, t.exports = e.default }, {}], 31: [function(d, u, r) { "use strict"; function e() {} function l(t, e) { return e = "[" + t + "] > " + e } function a(t) { var r = window.console[t]; return r ? function() { for (var a = arguments.length, e = Array(a), i = 0; a > i; i++) e[i] = arguments[i]; e[0] && (e[0] = l(t, e[0])), r.apply(window.console, e) } : e } function s(r) { for (var i = arguments.length, n = Array(i > 1 ? i - 1 : 0), e = 1; i > e; e++) n[e - 1] = arguments[e]; n.forEach(function(e) { t[e] = r[e] ? r[e].bind(r) : a(e) }) } Object.defineProperty(r, "__esModule", { value: !0 }); var i = { trace: e, debug: e, log: e, warn: e, info: e, error: e }, t = i, n = function(e) { if (e === !0 || "object" == typeof e) { s(e, "debug", "log", "info", "warn", "error"); try { t.log() } catch (e) { t = i } } else t = i }; r.enableLogs = n; var o = t; r.logger = o }, {}], 32: [function(r, t, i) { "use strict"; var e = { buildAbsoluteURL: function(r, t) { if (t = t.trim(), /^[a-z]+:/i.test(t)) return t; var o = null, a = null, n = /^([^#]*)(.*)$/.exec(t); n && (a = n[2], t = n[1]); var s = /^([^\?]*)(.*)$/.exec(t); s && (o = s[2], t = s[1]); var h = /^([^#]*)(.*)$/.exec(r); h && (r = h[1]); var u = /^([^\?]*)(.*)$/.exec(r); u && (r = u[1]); var l = /^((([a-z]+):)?\/\/[a-z0-9\.-]+(:[0-9]+)?\/)(.*)$/i.exec(r), f = l[3], d = l[1], c = l[5], i = null; return i = /^\/\//.test(t) ? f + "://" + e.buildAbsolutePath("", t.substring(2)) : /^\//.test(t) ? d + e.buildAbsolutePath("", t.substring(1)) : e.buildAbsolutePath(d + c, t), o && (i += o), a && (i += a), i }, buildAbsolutePath: function(n, s) { for (var i, e, o = s, a = "", t = n.replace(/[^\/]*$/, o.replace(/(\/|^)(?:\.?\/+)+/g, "$1")), r = 0; e = t.indexOf("/../", r), e > -1; r = e + i) i = /^\/(?:\.\.\/)*/.exec(t.slice(e))[0].length, a = (a + t.substring(r, e)).replace(new RegExp("(?:\\/+[^\\/]*){0," + (i - 1) / 3 + "}$"), "/"); return a + t.substr(r) } }; t.exports = e }, {}], 33: [function(r, i, e) { "use strict"; function a(e, t) { if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function") } Object.defineProperty(e, "__esModule", { value: !0 }); var n = function() { function e(i, r) { for (var t = 0; t < r.length; t++) { var e = r[t]; e.enumerable = e.enumerable || !1, e.configurable = !0, "value" in e && (e.writable = !0), Object.defineProperty(i, e.key, e) } } return function(t, r, i) { return r && e(t.prototype, r), i && e(t, i), t } }(), t = r("../utils/logger"), s = function() { function e(t) { a(this, e), t && t.xhrSetup && (this.xhrSetup = t.xhrSetup) } return n(e, [{ key: "destroy", value: function() { this.abort(), this.loader = null } }, { key: "abort", value: function() { var e = this.loader, t = this.timeoutHandle; e && 4 !== e.readyState && (this.stats.aborted = !0, e.abort()), t && window.clearTimeout(t) } }, { key: "load", value: function(r, i, a, n, s, t, o, l) { var u = arguments.length <= 8 || void 0 === arguments[8] ? null : arguments[8], e = arguments.length <= 9 || void 0 === arguments[9] ? null : arguments[9]; this.url = r, !e || isNaN(e.byteRangeStartOffset) || isNaN(e.byteRangeEndOffset) || (this.byteRange = e.byteRangeStartOffset + "-" + (e.byteRangeEndOffset - 1)), this.responseType = i, this.onSuccess = a, this.onProgress = u, this.onTimeout = s, this.onError = n, this.stats = { trequest: performance.now(), retry: 0 }, this.timeout = t, this.maxRetry = o, this.retryDelay = l, this.timeoutHandle = window.setTimeout(this.loadtimeout.bind(this), t), this.loadInternal() } }, { key: "loadInternal", value: function() { var e; e = "undefined" != typeof XDomainRequest ? this.loader = new XDomainRequest : this.loader = new XMLHttpRequest, e.onloadend = this.loadend.bind(this), e.onprogress = this.loadprogress.bind(this), e.open("GET", this.url, !0), this.byteRange && e.setRequestHeader("Range", "bytes=" + this.byteRange), e.responseType = this.responseType, this.stats.tfirst = null, this.stats.loaded = 0, this.xhrSetup && this.xhrSetup(e, this.url), e.send() } }, { key: "loadend", value: function(i) { var a = i.currentTarget, r = a.status, e = this.stats; e.aborted || (r >= 200 && 300 > r ? (window.clearTimeout(this.timeoutHandle), e.tload = performance.now(), this.onSuccess(i, e)) : e.retry < this.maxRetry ? (t.logger.warn(r + " while loading " + this.url + ", retrying in " + this.retryDelay + "..."), this.destroy(), window.setTimeout(this.loadInternal.bind(this), this.retryDelay), this.retryDelay = Math.min(2 * this.retryDelay, 64e3), e.retry++) : (window.clearTimeout(this.timeoutHandle), t.logger.error(r + " while loading " + this.url), this.onError(i))) } }, { key: "loadtimeout", value: function(e) { t.logger.warn("timeout while loading " + this.url), this.onTimeout(e, this.stats) } }, { key: "loadprogress", value: function(t) { var e = this.stats; null === e.tfirst && (e.tfirst = performance.now()), e.loaded = t.loaded, this.onProgress && this.onProgress(t, e) } }]), e }(); e.default = s, i.exports = e.default }, { "../utils/logger": 31 }] }, {}, [22])(22) });